小小的ret汇编指令大有文章,找到ret的一段ret宏,可管中窥豹:)
macro ret AddEspNum
{
if ~ AddEspNum eq 0 ; return value
if (AddEspNum mod 4)<>0 ; 32-bit cpu
.err
end if
lea esp, [esp+(AddEspNum+4)]
jmp dword [esp-(AddEspNum+4)] ; skip AddEspNum bits stack value, and jump to next instruction
else
sub esp, -4
jmp dword [esp-4] ; no return value, jump to next instruction
end if
}
本文深入探讨了ret宏指令的工作原理及实现细节。通过对ret宏的分析,解释了如何根据不同条件调整ESP寄存器的值,并跳转到下一条指令执行。此过程对于理解32位CPU上函数调用后的返回机制至关重要。
1732

被折叠的 条评论
为什么被折叠?



