理解新的 gcc 序言

2023-12-09

我想知道为什么 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

我明白它的具体作用,但我无法弄清楚purpose它的。是为了让利用(堆栈溢出)尝试变得更加棘手吗?另一个调用约定?只是为了让堆栈更安全? (因为我在战争游戏中遇到了这个东西)

最后,我的 gcc 版本是: gcc 版本 4.3.2 (Debian 4.3.2-1.1)

提前致谢!


目的是在 16 字节边界上对齐堆栈。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

理解新的 gcc 序言 的相关文章

随机推荐