ORIG_EAX

代码:
00050: EBX       = 0x00
00051: ECX       = 0x04
00052: EDX       = 0x08
00053: ESI       = 0x0C
00054: EDI       = 0x10
00055: EBP       = 0x14
00056: EAX       = 0x18
00057: DS       = 0x1C
00058: ES       = 0x20
00059: ORIG_EAX   = 0x24
00060: EIP       = 0x28
00061: CS       = 0x2C
00062: EFLAGS    = 0x30
00063: OLDESP    = 0x34
00064: OLDSS    = 0x38

当中断发生时,CPU将寄存器的EFLAGS的内容,以及代表返回地址的CS和EIP两个寄存器的内容压入堆栈。如果CPU的运行级别发生变化,则在此之前还要发生堆栈的切换,并且要把代表老堆栈指针的SS和ESP的内容压入堆栈。
以上这些都是CPU自动完成的动作,之后内核代码会将(中断号-256)压入系统堆栈,紧接着调用SAVE_ALL将中断发生时ES、DS、EAX、EBP、EDI、ESI、EDX、ECX和EBX寄存器中的值依次压入系统堆栈。完成这些操作之后的系统堆栈如下图所示:
附件:
SystemStack.JPG 
SystemStack.JPG [ 28.73 KiB | 被浏览 453 次 ]


从图中你不难发现实际上这些宏定义的值就是各个寄存器的内容在系统堆栈中相对栈顶指针的偏移量。
上面这个图是针对中断的,对于异常ORIG_EAX偏移处存放的是错误码(如果有的话),而对于系统调用则是存放着系统调用号。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值