实验任务1
问题① ① line27, 汇编指令 loop s1 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机 器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明 是如何计算得到跳转后标号s1其后指令的偏移地址的。 跳转的位移量:-14 loop指令为循环指令是短转移,在对应的机器码中包含转移的位移 cpu计算当前地址到标号地址的位移量,直接加在ip之后
loop
指令执行之后IP变成001B,需要跳转到000D,所以偏移量为-14
问题②
② line44,汇编指令 loop s2 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机
器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明
是如何计算得到跳转后标号s2其后指令的偏移地址的。
跳转的位移量:-16
loop指令执行之后,偏移地址为0039H,跳转的偏移地址是0029H,所以偏移量为-16
问题③
③ 附上上述分析时,在debug中进行调试观察的反汇编截图
实验任务2
根据call指令的跳转原理,先从理论上分析,程序执行到退出(line31)之前,
寄存器(ax) = 0021h 寄存器(bx) = 0026h 寄存器(cx) = 076ch
offset分别将s1,s2处地址传入偏移量为ds:[0]和ds:[2],第一次call指令执行,将下一条指令
即s1处地址入栈,并跳转至ds:[0]中地址即s1处,执行pop指令将栈中s1的地址传给ax,第二
次同理,不过入栈双字长度,即入栈下一条指令的段地址和偏移地址。ax中存放了s1处指令
在内存中的偏移地址,bx中存放了标号s2处指令在内存中的偏移地址,cx中存放了s2处指令
在内存中的段地址。
实验任务3
实验任务4
实验任务5