我想知道为什么gcc给函数引入了一个新的序言(以及结尾)--特别是main(),因为我只是对它进行了分析。例如,以前是:
push ebp
mov ebp, esp
sub esp, 0x... ; Allocate memory space into the stack
; ... Some code
; Epilogue
leave
ret现在,这有点复杂(至少要理解):
lea ecx,[esp+0x4]
and esp,0xfffffff0
push DWORD PTR [ecx-0x4]
push ebp
mov ebp,esp
push ecx
sub esp,0x64
; Some code
; Epilogue
add esp,0x64
pop ecx
pop ebp
lea esp,[ecx-0x4]
ret我具体理解它是做什么的,但我不知道它的意图。它是为了使利用(堆栈溢出)尝试变得更加棘手吗?又一次电话会议?只是为了让堆栈更安全?(因为我在一场战争游戏中遇到了这些东西)
最后,我的gcc版本是: gcc版本4.3.2 (Debian 4.3.2-1.1)
提前感谢!
发布于 2012-08-09 15:12:18
其目的是在16字节边界上对齐堆栈.
https://stackoverflow.com/questions/11886429
复制相似问题