我在 x86_64 上的下面非常复杂的程序上做了 gcc -S:
int main() {
int x = 3;
x = 5;
return 0;
}
我得到的是:
.file "main.c"
.text
.globl main
.type main, @function
main:
.LFB0:
.cfi_startproc
pushq %rbp
.cfi_def_cfa_offset 16
.cfi_offset 6, -16
movq %rsp, %rbp
.cfi_def_cfa_register 6
movl $3, -4(%rbp)
movl $5, -4(%rbp)
movl $0, %eax
leave
.cfi_def_cfa 7, 8
ret
.cfi_endproc
.LFE0:
.size main, .-main
.ident "GCC: (GNU) 4.4.7 20120313 (Red Hat 4.4.7-3)"
.section .note.GNU-stack,"",@progbits
我想知道是否有人可以帮助我理解输出或向我推荐一些链接解释。具体来说,是什么cfi ,LFB0,LFE0 , leave
意思?关于这些,我能找到的只是这篇文章,但无法完全理解它的用途。另外,ret
在这种情况下怎么办?我猜它会返回到__libc_start_main()
哪个反过来会调用do_exit()
,对吗?