为什么没有" mov rsp,rbp"在功能序幕?

时间:2017-03-29 03:45:44

标签: c++ c assembly

在汇编中,许多函数都以​​下面的序言开头:

00000001004010e0: main(int, char**)+0    push    %rbp
00000001004010e1: main(int, char**)+1    mov     %rsp,%rbp

某些功能(如下所示)不会:

                              int MainEntry(){
                                       MainEntry():
0000000100401104: MainEntry()+0          push    %rbp
0000000100401105: MainEntry()+1          push    %rbx
0000000100401106: MainEntry()+2          sub     $0x48,%rsp
000000010040110a: MainEntry()+6          lea     0x80(%rsp),%rbp
                                        vector<int> v;
0000000100401112: MainEntry()+14         lea     -0x60(%rbp),%rax
0000000100401116: MainEntry()+18         mov     %rax,%rcx
0000000100401119: MainEntry()+21         callq   0x100401b00 <std::vector<int, std::allocator<int> >::vector()>
                                        return 0;
000000010040111e: MainEntry()+26         mov     $0x0,%ebx
0000000100401123: MainEntry()+31         lea     -0x60(%rbp),%rax
0000000100401127: MainEntry()+35         mov     %rax,%rcx
000000010040112a: MainEntry()+38         callq   0x100401b20 <std::vector<int, std::allocator<int> >::~vector()>
000000010040112f: MainEntry()+43         mov     %ebx,%eax
                                     }

这是编译成这个的C ++代码:

int main(int c, char** args){
    MainEntry();
    return 0;
}

int MainEntry(){
    vector<int> v;
    return 0;
}

所以这是我的两个问题:

  1. MainEntry函数中,有push rbp,然后是push rbx。为什么rbx被推入堆栈?
  2. 如果我理解正确,sub $0x48,%rsp会在堆栈上分配0x48 bytes,并lea 0x80(%rsp),%rbp向下移动0x80 bytes并将其指定为基础。 rbp哪里最终会在本地堆栈框架中结束?它是如何实现的?

1 个答案:

答案 0 :(得分:2)

1)rbx被推入堆栈,因为调用约定表明它是在调用之间保留的。

2)此函数在没有帧指针的情况下编译。在没有帧指针的情况下进行编译时,rbp只是另一个通用寄存器。

标题中的问题)该指令不存在。 push始终采用一个参数。也许你的意思是问为什么rbp没有推动。答案是什么都没用,所以不需要任何指示来保存它。