mirror of
https://github.com/pkivolowitz/asm_book.git
synced 2026-06-21 03:36:49 +08:00
first effort on recursion - not anywhere done
This commit is contained in:
parent
9c8ca24a6c
commit
51611ddf3d
4 changed files with 178 additions and 0 deletions
20
section_1/recursion/a.out.dSYM/Contents/Info.plist
Normal file
20
section_1/recursion/a.out.dSYM/Contents/Info.plist
Normal file
|
|
@ -0,0 +1,20 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||
<plist version="1.0">
|
||||
<dict>
|
||||
<key>CFBundleDevelopmentRegion</key>
|
||||
<string>English</string>
|
||||
<key>CFBundleIdentifier</key>
|
||||
<string>com.apple.xcode.dsym.a.out</string>
|
||||
<key>CFBundleInfoDictionaryVersion</key>
|
||||
<string>6.0</string>
|
||||
<key>CFBundlePackageType</key>
|
||||
<string>dSYM</string>
|
||||
<key>CFBundleSignature</key>
|
||||
<string>????</string>
|
||||
<key>CFBundleShortVersionString</key>
|
||||
<string>1.0</string>
|
||||
<key>CFBundleVersion</key>
|
||||
<string>1</string>
|
||||
</dict>
|
||||
</plist>
|
||||
22
section_1/recursion/fib.c
Normal file
22
section_1/recursion/fib.c
Normal file
|
|
@ -0,0 +1,22 @@
|
|||
#include <stdio.h>
|
||||
|
||||
extern unsigned int Fib(unsigned int nthNumber);
|
||||
|
||||
unsigned int FibonacciInC(unsigned int nthNumber) {
|
||||
if (nthNumber <= 1) {
|
||||
return nthNumber;
|
||||
}
|
||||
return FibonacciInC(nthNumber - 1) + FibonacciInC(nthNumber - 2);
|
||||
}
|
||||
|
||||
int main() {
|
||||
printf("In C:\n");
|
||||
for (unsigned int n = 0; n < 10; n++) {
|
||||
printf("Fibonacci number %2d is: %d\n", n, FibonacciInC(n));
|
||||
}
|
||||
printf("In assembly language:\n");
|
||||
for (unsigned int n = 0; n < 10; n++) {
|
||||
printf("Fibonacci number %2d is: %d\n", n, Fib(n));
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
115
section_1/recursion/fib.s
Normal file
115
section_1/recursion/fib.s
Normal file
|
|
@ -0,0 +1,115 @@
|
|||
.arch armv8-a
|
||||
.file "fib.c"
|
||||
.text
|
||||
.align 2
|
||||
.global FibonacciInC
|
||||
.type FibonacciInC, %function
|
||||
FibonacciInC:
|
||||
.LFB0:
|
||||
.cfi_startproc
|
||||
stp x29, x30, [sp, -48]!
|
||||
.cfi_def_cfa_offset 48
|
||||
.cfi_offset 29, -48
|
||||
.cfi_offset 30, -40
|
||||
mov x29, sp
|
||||
str x19, [sp, 16]
|
||||
.cfi_offset 19, -32
|
||||
str w0, [sp, 44]
|
||||
ldr w0, [sp, 44]
|
||||
cmp w0, 1
|
||||
bhi .L2
|
||||
ldr w0, [sp, 44]
|
||||
b .L3
|
||||
.L2:
|
||||
ldr w0, [sp, 44]
|
||||
sub w0, w0, #1
|
||||
bl FibonacciInC
|
||||
mov w19, w0
|
||||
ldr w0, [sp, 44]
|
||||
sub w0, w0, #2
|
||||
bl FibonacciInC
|
||||
add w0, w19, w0
|
||||
.L3:
|
||||
ldr x19, [sp, 16]
|
||||
ldp x29, x30, [sp], 48
|
||||
.cfi_restore 30
|
||||
.cfi_restore 29
|
||||
.cfi_restore 19
|
||||
.cfi_def_cfa_offset 0
|
||||
ret
|
||||
.cfi_endproc
|
||||
.LFE0:
|
||||
.size FibonacciInC, .-FibonacciInC
|
||||
.section .rodata
|
||||
.align 3
|
||||
.LC0:
|
||||
.string "In C:"
|
||||
.align 3
|
||||
.LC1:
|
||||
.string "Fibonacci number %2d is: %d\n"
|
||||
.align 3
|
||||
.LC2:
|
||||
.string "In assembly language:"
|
||||
.text
|
||||
.align 2
|
||||
.global main
|
||||
.type main, %function
|
||||
main:
|
||||
.LFB1:
|
||||
.cfi_startproc
|
||||
stp x29, x30, [sp, -32]!
|
||||
.cfi_def_cfa_offset 32
|
||||
.cfi_offset 29, -32
|
||||
.cfi_offset 30, -24
|
||||
mov x29, sp
|
||||
adrp x0, .LC0
|
||||
add x0, x0, :lo12:.LC0
|
||||
bl puts
|
||||
str wzr, [sp, 24]
|
||||
b .L5
|
||||
.L6:
|
||||
ldr w0, [sp, 24]
|
||||
bl FibonacciInC
|
||||
mov w2, w0
|
||||
ldr w1, [sp, 24]
|
||||
adrp x0, .LC1
|
||||
add x0, x0, :lo12:.LC1
|
||||
bl printf
|
||||
ldr w0, [sp, 24]
|
||||
add w0, w0, 1
|
||||
str w0, [sp, 24]
|
||||
.L5:
|
||||
ldr w0, [sp, 24]
|
||||
cmp w0, 9
|
||||
bls .L6
|
||||
adrp x0, .LC2
|
||||
add x0, x0, :lo12:.LC2
|
||||
bl puts
|
||||
str wzr, [sp, 28]
|
||||
b .L7
|
||||
.L8:
|
||||
ldr w0, [sp, 28]
|
||||
bl Fib
|
||||
mov w2, w0
|
||||
ldr w1, [sp, 28]
|
||||
adrp x0, .LC1
|
||||
add x0, x0, :lo12:.LC1
|
||||
bl printf
|
||||
ldr w0, [sp, 28]
|
||||
add w0, w0, 1
|
||||
str w0, [sp, 28]
|
||||
.L7:
|
||||
ldr w0, [sp, 28]
|
||||
cmp w0, 9
|
||||
bls .L8
|
||||
mov w0, 0
|
||||
ldp x29, x30, [sp], 32
|
||||
.cfi_restore 30
|
||||
.cfi_restore 29
|
||||
.cfi_def_cfa_offset 0
|
||||
ret
|
||||
.cfi_endproc
|
||||
.LFE1:
|
||||
.size main, .-main
|
||||
.ident "GCC: (Ubuntu 9.4.0-1ubuntu1~20.04.1) 9.4.0"
|
||||
.section .note.GNU-stack,"",@progbits
|
||||
21
section_1/recursion/fibo.s
Normal file
21
section_1/recursion/fibo.s
Normal file
|
|
@ -0,0 +1,21 @@
|
|||
.global Fib
|
||||
.text
|
||||
.align 4
|
||||
|
||||
Fib: str x30, [sp, -16]!
|
||||
cmp w0, 1
|
||||
// If w0 is 0 or 1, take the branch to return w0.
|
||||
bls 99f
|
||||
|
||||
// If we get here, we need to do the recursion.
|
||||
// Save the parameter on the stack so we can
|
||||
// get it back between recursions.
|
||||
|
||||
str w0, [sp, -16]!
|
||||
sub w0, w0, 1
|
||||
bl Fib
|
||||
ldr w0, [sp], 16 // temporary
|
||||
|
||||
99: ldr x30, [sp], 16
|
||||
ret
|
||||
|
||||
Loading…
Reference in a new issue