Понимание нового пролога gcc
Мне было интересно, почему 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)
Заранее спасибо!