我试图在Linux上运行此代码,看看会发生什么:
int fn(void) { return 0; }
int main(void) { __asm__("jmp fn;"); }
我没有看到SIGSEGV终止执行的任何理由,但这就是我得到的。我希望将流重定向到_start
,因为在main
和fn
内没有以任何方式修改堆栈,并且激活记录中的返回地址仍应为&# 34;可用"
你能解释一下这背后的原因吗?
答案 0 :(得分:4)
return 0
生成类似
mov $0x0, %eax
ret
其中ret
从堆栈中弹出返回地址并跳转到那里。一个简单的jmp
不会推送任何返回地址,因此ret
将弹出堆栈中的任何内容。