-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path009.asm
53 lines (46 loc) · 1.83 KB
/
009.asm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
section .data
msg db "%d", 10, 0 ;return string for printf (just the result)
section .text
extern printf
global main
main:
xor ebx, ebx ;r in Dickson's method
next:
add ebx, 2 ;the next even r (odd values not allowed)
mov eax, ebx ;put number in eax for multiplication
mul ebx ;square
shr eax, 1 ;half
mov ecx, eax ;put r^2 / 2 in ecx
xor edi, edi ;for divisors of r^2 / 2
triplets:
inc edi ;next divisor candidate
mov eax, edi ;candidate in eax
mul edi ;square
cmp eax, ecx ;check if square is less than r^2 / 2
jg next ;if not, go to next higher r
xor edx, edx ;prepare remainder
mov eax, ecx ;r^2 / 2 in eax for division
div edi ;divide by current divisor
test edx, edx ;check if remainder is zero
jnz triplets ;if not, continue with next divisor
lea r8d, [ebx + edi] ;a = r + s
lea r9d, [ebx + eax] ;b = r + t
lea r10d, [r9d + edi] ;c = r + s + t
mov eax, r8d ;put a in eax for product
add r8d, r9d
add r8d, r10d ;perimeter
cmp r8d, 1000 ;check if perimeter = 1000
jne triplets ;if not, continue with next candidate
mul r9d ;else calculate product
mul r10d
print: ;printing routine, differs slightly from OS to OS
push rbp
mov edi, msg
mov esi, eax
call printf
pop rbp
exit: ;exit routine, dito
mov eax, 1
xor edi, edi
syscall
section .note.GNU-stack ;just for gcc