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
|
# rdi - adres zwracanej struktury (niejawnie)
# rsi - *a
# rdx - n
.global puzzle8
.text
puzzle8:
movq %rdx, %r11 # r11 := n
xorl %r10d, %r10d # r10 := 0
xorl %eax, %eax # rax := 0
movq $LONG_MIN, %r8 # r8 := 0x800...
movq $LONG_MAX, %r9 # r9 := 0x7ff...
.L2: cmpq %r11, %r10 # if n <= r10
jge .L5 # then jump to L5, else
movq (%rsi,%r10,8), %rcx # rcx := a[r10]
cmpq %rcx, %r9 # if a[r10] < r9
cmovg %rcx, %r9 # then r9 = a[r10]
cmpq %rcx, %r8 # if a[r10] > r8
cmovl %rcx, %r8 # then r8 = a[r10]
addq %rcx, %rax # rax += a[r10]
incq %r10 # r10++
jmp .L2
.L5: cqto # jeśli rax < 0 to niech rdx zaplonie
movq %r9, (%rdi) # rdi->0 := r9
idivq %r11 # podziel rax przez r11, efektywnie rax /= r11
movq %r8, 8(%rdi) # rdi->8 := r8
movq %rax, 16(%rdi) # rdi->16 := rax
movq %rdi, %rax # rax := rdi
ret
|