首页 > 解决方案 > 我需要帮助理解某些说明的含义

问题描述

我正在学习 x86 汇编,但在理解某些指令时遇到了一些问题。什么sub $0x10,%rsp意思,为什么 GCC 复制了这mov $0x0,%eax行两次?

0x0000000000001135 <+0>:    push   %rbp   
0x0000000000001136 <+1>:    mov    %rsp,%rbp
0x0000000000001139 <+4>:    sub    $0x10,%rsp
0x000000000000113d <+8>:    movl   $0xa,-0x4(%rbp)  
0x0000000000001144 <+15>:   mov    -0x4(%rbp),%eax
0x0000000000001147 <+18>:   mov    %eax,%esi
0x0000000000001149 <+20>:   lea    0xeb4(%rip),%rdi        # 0x2004
0x0000000000001150 <+27>:   mov    $0x0,%eax
0x0000000000001155 <+32>:   callq  0x1030 <printf@plt>
0x000000000000115a <+37>:   mov    $0x0,%eax
0x000000000000115f <+42>:   leaveq 
0x0000000000001160 <+43>:   retq

标签: assemblyx86-64att

解决方案


sub $0x10,%rsp在堆栈上分配空间,这与执行pushq 0两次相同,只是分配的堆栈空间中的值不一定为零,但这没关系,因为mov稍后使用的指令将垃圾替换为真实数据。

正如迈克尔正确指出的那样,这mov $0x0,%eax是因为printf(以及任何其他可变参数函数)采用rax.


推荐阅读