Skip to content

Instantly share code, notes, and snippets.

@yinwang0
Created April 27, 2016 23:10
Show Gist options
  • Save yinwang0/7670bff673c9eda6051bfee78cde0fd1 to your computer and use it in GitHub Desktop.
Save yinwang0/7670bff673c9eda6051bfee78cde0fd1 to your computer and use it in GitHub Desktop.
assembly code generated by clang and gcc for recursive fib.c
.text
.file "fib.c"
.globl fib
.align 16, 0x90
.type fib,@function
fib: # @fib
.cfi_startproc
# BB#0:
pushq %r14
.Ltmp0:
.cfi_def_cfa_offset 16
pushq %rbx
.Ltmp1:
.cfi_def_cfa_offset 24
pushq %rax
.Ltmp2:
.cfi_def_cfa_offset 32
.Ltmp3:
.cfi_offset %rbx, -24
.Ltmp4:
.cfi_offset %r14, -16
movq %rdi, %rbx
cmpq $2, %rbx
jge .LBB0_1
# BB#2:
movq %rbx, %rax
jmp .LBB0_3
.LBB0_1:
leaq -1(%rbx), %rdi
callq fib
movq %rax, %r14
addq $-2, %rbx
movq %rbx, %rdi
callq fib
addq %r14, %rax
.LBB0_3:
addq $8, %rsp
popq %rbx
popq %r14
retq
.Ltmp5:
.size fib, .Ltmp5-fib
.cfi_endproc
.globl main
.align 16, 0x90
.type main,@function
main: # @main
.cfi_startproc
# BB#0:
pushq %rax
.Ltmp6:
.cfi_def_cfa_offset 16
movl $48, %edi
callq fib
movq %rax, %rcx
movl $.L.str, %edi
xorl %eax, %eax
movq %rcx, %rsi
callq printf
xorl %eax, %eax
popq %rdx
retq
.Ltmp7:
.size main, .Ltmp7-main
.cfi_endproc
.type .L.str,@object # @.str
.section .rodata.str1.1,"aMS",@progbits,1
.L.str:
.asciz "%ld\n"
.size .L.str, 5
.ident "Ubuntu clang version 3.6.2-1 (tags/RELEASE_362/final) (based on LLVM 3.6.2)"
.section ".note.GNU-stack","",@progbits
.file "fib.c"
.section .text.unlikely,"ax",@progbits
.LCOLDB0:
.text
.LHOTB0:
.p2align 4,,15
.globl fib
.type fib, @function
fib:
.LFB23:
.cfi_startproc
pushq %r15
.cfi_def_cfa_offset 16
.cfi_offset 15, -16
pushq %r14
.cfi_def_cfa_offset 24
.cfi_offset 14, -24
pushq %r13
.cfi_def_cfa_offset 32
.cfi_offset 13, -32
pushq %r12
.cfi_def_cfa_offset 40
.cfi_offset 12, -40
pushq %rbp
.cfi_def_cfa_offset 48
.cfi_offset 6, -48
pushq %rbx
.cfi_def_cfa_offset 56
.cfi_offset 3, -56
subq $312, %rsp
.cfi_def_cfa_offset 368
cmpq $1, %rdi
movq %rdi, 200(%rsp)
jle .L20
leaq -3(%rdi), %rcx
movq %rdi, %rax
movq $0, 104(%rsp)
movq %rcx, 168(%rsp)
.L19:
cmpq $2, %rax
je .L21
leaq -2(%rax), %rdx
subq $4, %rax
movq $0, 112(%rsp)
movq %rax, %rcx
movq %rax, 120(%rsp)
movq 168(%rsp), %rax
movq %rdx, 208(%rsp)
movq %rdx, 80(%rsp)
shrq %rax
movq %rax, 224(%rsp)
addq %rax, %rax
subq %rax, %rcx
movq %rdx, %rax
movq %rcx, 216(%rsp)
.L18:
cmpq $1, %rax
je .L22
leaq -1(%rax), %rsi
subq $3, %rax
movq $0, 128(%rsp)
movq %rax, 136(%rsp)
movq %rsi, 72(%rsp)
movq %rax, %rsi
movq 120(%rsp), %rax
shrq %rax
movq %rax, 240(%rsp)
addq %rax, %rax
subq %rax, %rsi
movq 72(%rsp), %rax
movq %rsi, 232(%rsp)
.L17:
cmpq $1, %rax
je .L23
leaq -1(%rax), %rdx
subq $3, %rax
movq $0, 144(%rsp)
movq %rax, %rcx
movq %rax, 152(%rsp)
movq 136(%rsp), %rax
movq %rdx, 64(%rsp)
shrq %rax
movq %rax, 256(%rsp)
addq %rax, %rax
subq %rax, %rcx
movq %rdx, %rax
movq %rcx, 248(%rsp)
.L16:
cmpq $1, %rax
je .L24
leaq -1(%rax), %rcx
subq $3, %rax
movq $0, 160(%rsp)
movq %rax, %rsi
movq %rax, 176(%rsp)
movq 152(%rsp), %rax
movq %rcx, 88(%rsp)
shrq %rax
movq %rax, 272(%rsp)
addq %rax, %rax
subq %rax, %rsi
movq %rcx, %rax
movq %rsi, 264(%rsp)
.L15:
cmpq $1, %rax
je .L25
leaq -1(%rax), %rsi
subq $3, %rax
movq $0, 184(%rsp)
movq %rax, %rcx
movq %rax, 192(%rsp)
movq 176(%rsp), %rax
movq %rsi, 96(%rsp)
shrq %rax
movq %rax, 288(%rsp)
addq %rax, %rax
subq %rax, %rcx
movq %rsi, %rax
movq %rcx, 280(%rsp)
.L14:
cmpq $1, %rax
je .L26
leaq -1(%rax), %rdx
subq $3, %rax
movq $0, 48(%rsp)
movq %rax, %rsi
movq %rax, 32(%rsp)
movq 192(%rsp), %rax
movq %rdx, 24(%rsp)
shrq %rax
movq %rax, 296(%rsp)
addq %rax, %rax
subq %rax, %rsi
movq %rdx, %rax
movq %rsi, 56(%rsp)
.L13:
cmpq $1, %rax
je .L27
leaq -3(%rax), %r14
leaq -1(%rax), %r12
movq 32(%rsp), %rax
movq $0, 8(%rsp)
movq %r14, %rcx
shrq %rax
movq %rax, 40(%rsp)
addq %rax, %rax
subq %rax, %rcx
movq %rcx, 16(%rsp)
.p2align 4,,10
.p2align 3
.L12:
cmpq $1, %r12
je .L28
movq %r14, %r13
leaq -3(%r12), %rbp
leaq -1(%r12), %r15
shrq %r13
xorl %ebx, %ebx
leaq (%r13,%r13), %rax
subq %rax, %rbp
.p2align 4,,10
.p2align 3
.L11:
movq %r15, %rdi
subq $2, %r15
call fib
addq %rax, %rbx
cmpq %r15, %rbp
jne .L11
negq %r13
leaq (%r14,%r13,2), %rax
.L10:
addq %rax, %rbx
subq $2, %r12
addq %rbx, 8(%rsp)
subq $2, %r14
cmpq 16(%rsp), %r12
jne .L12
movq 40(%rsp), %rax
movq 32(%rsp), %rdx
negq %rax
leaq (%rdx,%rax,2), %rax
.L9:
movq 8(%rsp), %r15
subq $2, 24(%rsp)
subq $2, 32(%rsp)
addq %rax, %r15
movq 24(%rsp), %rax
addq %r15, 48(%rsp)
cmpq %rax, 56(%rsp)
jne .L13
movq 296(%rsp), %rax
movq 192(%rsp), %rcx
negq %rax
leaq (%rcx,%rax,2), %rax
.L8:
addq 48(%rsp), %rax
subq $2, 96(%rsp)
addq %rax, 184(%rsp)
movq 96(%rsp), %rax
subq $2, 192(%rsp)
cmpq %rax, 280(%rsp)
jne .L14
movq 288(%rsp), %rax
movq 176(%rsp), %rcx
negq %rax
leaq (%rcx,%rax,2), %rax
.L7:
addq 184(%rsp), %rax
subq $2, 88(%rsp)
addq %rax, 160(%rsp)
movq 88(%rsp), %rax
subq $2, 176(%rsp)
cmpq %rax, 264(%rsp)
jne .L15
movq 272(%rsp), %rax
movq 152(%rsp), %rcx
negq %rax
leaq (%rcx,%rax,2), %rax
.L6:
addq 160(%rsp), %rax
subq $2, 64(%rsp)
addq %rax, 144(%rsp)
movq 64(%rsp), %rax
subq $2, 152(%rsp)
cmpq %rax, 248(%rsp)
jne .L16
movq 256(%rsp), %rax
movq 136(%rsp), %rcx
negq %rax
leaq (%rcx,%rax,2), %rax
.L5:
addq 144(%rsp), %rax
subq $2, 72(%rsp)
addq %rax, 128(%rsp)
movq 72(%rsp), %rax
subq $2, 136(%rsp)
cmpq %rax, 232(%rsp)
jne .L17
movq 240(%rsp), %rax
movq 120(%rsp), %rcx
negq %rax
leaq (%rcx,%rax,2), %rax
jmp .L4
.p2align 4,,10
.p2align 3
.L28:
xorl %ebx, %ebx
movl $1, %eax
jmp .L10
.L27:
movq $0, 8(%rsp)
movl $1, %eax
jmp .L9
.L26:
movq $0, 48(%rsp)
movl $1, %eax
jmp .L8
.L25:
movq $0, 184(%rsp)
movl $1, %eax
jmp .L7
.L24:
movq $0, 160(%rsp)
movl $1, %eax
jmp .L6
.L23:
movq $0, 144(%rsp)
movl $1, %eax
jmp .L5
.L21:
movq $0, 112(%rsp)
movl $1, %edx
movq $0, 208(%rsp)
.L3:
movq 208(%rsp), %rax
addq 112(%rsp), %rdx
addq %rdx, 104(%rsp)
subq $2, 168(%rsp)
cmpq $1, %rax
jg .L19
andq $1, 200(%rsp)
jmp .L2
.L20:
movq $0, 104(%rsp)
.L2:
movq 104(%rsp), %rax
addq 200(%rsp), %rax
addq $312, %rsp
.cfi_remember_state
.cfi_def_cfa_offset 56
popq %rbx
.cfi_def_cfa_offset 48
popq %rbp
.cfi_def_cfa_offset 40
popq %r12
.cfi_def_cfa_offset 32
popq %r13
.cfi_def_cfa_offset 24
popq %r14
.cfi_def_cfa_offset 16
popq %r15
.cfi_def_cfa_offset 8
ret
.L22:
.cfi_restore_state
movq $0, 128(%rsp)
movl $1, %eax
.L4:
addq 128(%rsp), %rax
subq $2, 80(%rsp)
addq %rax, 112(%rsp)
movq 80(%rsp), %rax
subq $2, 120(%rsp)
cmpq %rax, 216(%rsp)
jne .L18
movq 224(%rsp), %rax
movq 168(%rsp), %rcx
negq %rax
leaq (%rcx,%rax,2), %rdx
jmp .L3
.cfi_endproc
.LFE23:
.size fib, .-fib
.section .text.unlikely
.LCOLDE0:
.text
.LHOTE0:
.section .rodata.str1.1,"aMS",@progbits,1
.LC1:
.string "%ld\n"
.section .text.unlikely
.LCOLDB2:
.section .text.startup,"ax",@progbits
.LHOTB2:
.p2align 4,,15
.globl main
.type main, @function
main:
.LFB24:
.cfi_startproc
pushq %r12
.cfi_def_cfa_offset 16
.cfi_offset 12, -16
pushq %rbp
.cfi_def_cfa_offset 24
.cfi_offset 6, -24
movl $45, %r11d
pushq %rbx
.cfi_def_cfa_offset 32
.cfi_offset 3, -32
movl $47, %ebp
xorl %r12d, %r12d
.p2align 4,,10
.p2align 3
.L43:
cmpq $1, %rbp
je .L44
movq %r11, %rbx
leaq -1(%r11), %r10
leaq 1(%r11), %r8
shrq %rbx
xorl %r9d, %r9d
leaq (%rbx,%rbx), %rax
subq %rax, %r10
.p2align 4,,10
.p2align 3
.L42:
movq %r8, %rdi
call fib
subq $2, %r8
addq %rax, %r9
cmpq %r10, %r8
jne .L42
negq %rbx
leaq (%r11,%rbx,2), %rax
.L41:
addq %rax, %r9
subq $2, %r11
subq $2, %rbp
addq %r9, %r12
cmpq $-3, %r11
jne .L43
movq %r12, %rdx
movl $.LC1, %esi
movl $1, %edi
xorl %eax, %eax
call __printf_chk
popq %rbx
.cfi_remember_state
.cfi_def_cfa_offset 24
xorl %eax, %eax
popq %rbp
.cfi_def_cfa_offset 16
popq %r12
.cfi_def_cfa_offset 8
ret
.L44:
.cfi_restore_state
xorl %r9d, %r9d
movl $1, %eax
jmp .L41
.cfi_endproc
.LFE24:
.size main, .-main
.section .text.unlikely
.LCOLDE2:
.section .text.startup
.LHOTE2:
.ident "GCC: (Ubuntu 5.2.1-22ubuntu2) 5.2.1 20151010"
.section .note.GNU-stack,"",@progbits
#include <stdio.h>
long fib(long n) {
if (n < 2) {
return n;
} else {
return fib(n-1) + fib(n-2);
}
}
int main() {
printf("%ld\n", fib(48));
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment