在IA32如何将程序计数器的值放入到整数寄存器中?

  1.     call next
  2. next:
  3.     pop1 %eax

 

这是一个汇编代码的习惯用法. 刚开始它看起来很奇怪 call指令并没有与之匹配的ret.

然后我们就意识到它根本就不是一个真正的过程调用.

 

寄存器%eax被设置成了什么值?

答: %eax被设置成了popl指令的地址.

 

请解释为什么这个调用没有匹配的ret指令?

答: 这不是一个真正的子过程调用, 因为控制时按照与指令相同的顺序进行的, 而返回值是从栈中弹出的.

 

这段代码完成了什么功能?

答: 这是IA32中将程序计数器EIP中的值放到整数寄存器中的唯一方法.

 

什么是IA32?

答: Intel称其指令集为IA32. IA32是Intel Architecture 32-bit的缩写, 意义为Intel32位体系结构. 这个处理器系列也俗称x86.

 

<深入理解计算机系统>

posted on 2009-11-17 21:16  中道学友  阅读(911)  评论(0编辑  收藏  举报

导航

技术追求准确,态度积极向上