linux-0.11调试教程,task3(04),sa_restore函数

                               


返回用户态之后,先运行的是用户定义的信号处理程序,既sa_handler,然后sa_handler函数最后ret!!!ret之后运行sa_restore函数,sa_restore函数最后也是ret!!!再返回到int 0x80下面的语句,既old_eip位置处继续运行。


所以第一需要改变的是信号处理所在的用户程序的内核态堆栈中的eip,第二是用户态堆栈,用户态堆栈需要放置两个地址,最上面的是old_eip,最下面的是sa_restore函数的地址。


所以整个信号处理机制需要处理3个地址。3个地址其实都是用户态地址。这3个地址是0x18,0x11f,和0x170。

如在do_signal下断点面的第一行的最后一个字就是内核栈中的eip,也就是以后的old_eip。




此文原创,本文作者有内核注释的纸质书(42元的05年三月第一版,第三次印刷),电子版很少看,今天一看都到电子版都3.0了,里面有这里的一些内容,因为看纸质书的时候不解,又能调试,所以自己调试了一下于是有了这些文章。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值