+ -
当前位置:首页 → 问答吧 → 关于linux内核源码trap.c中die函数的疑问

关于linux内核源码trap.c中die函数的疑问

时间:2011-06-05

来源:互联网

关于linux内核源码trap.c中die函数的疑问,还望哪位大侠能指点一下!
printk("EIP:\t%04x:%p\nEFLAGS:\t%p\nESP:\t%04x:%p\n",
esp[1],esp[0],esp[2],esp[4],esp[3]);
这里的esp是数组吗?如果是数组,那么每个元素的大小是多少?4字节吗?
在这段代码中是为了打印一些值,这里面的EIP和EFLAGS还有ESP是怎么与esp数组中的元素对应起来的?EIP为什么是对应esp[1],esp[0]。还有其他两个又是怎么对应起来的?
还有这里printk中的格式%04和%p是什么意思?
还望大侠指点

作者: tobeghost   发布时间: 2011-06-05

当前堆栈应该是ss,原esp,原eflag,es,eip,esp指的位置应该是eip这个地方,因此esp[0]就是表示距离esp偏移为0的单元,这个单元存的就是eip的值,取其他的单元的值也是类似的。注意,堆栈是从高到低的,堆栈元素都是4字节对齐的。

作者: biyeqingfeng   发布时间: 2011-12-13