CPU执行call指令时,进行两步操作:
1、将当前的IP或CS和IP压入栈中
2、转移
call指令不能实现短转移,除此之外,call指令实现转移的方法和jmp指令的原来相同
依据位移进行转移的call指令
call 标号(将当前的IP压栈后,转到标号处执行指令)
CPU执行此中格式的call指令时,进行如下的操作:
1、(SP)=(SP)-2
((SS)*16+(SP))=(IP) 注意:这里的IP地址是下一个命令的地址
2、(IP)=(IP)+16位位移
16位位移=标号处的地址-call指令后的第一个字节的地址
16位位移的范围为-32768~32767,用那个补码表示
16位位移由编译程序在编译时算出
从上面的描述中,可以看出,如果我们用汇编语法来解释此种格式的call指令,则:
CPU执行“call 标号”时,相当于进行:
push IP
jmp near ptr 标号
转移的目的地址在指令中的call指令
前面讲的call指令,其对应的机器指令中并没有转移的目的地址,而是相对于当前IP的转移地址
“call far prt 标号”实际的是段间转移
CPU执行此重格式的call指令时,进行如下的操作。
1、(sp)=(sp)-2
((ss)*16+(sp))=(cs)
(sp)=(sp)-2
((ss)*16+(sp))=(ip)
2、(cs)=标号所在段的段地址
(ip)=标号在段中的偏移地址
从上面的描述中可以看出,如果我们用汇编语法来解释此种格式的call指令,则:
CPU执行“call far prt 标号”时,相当于进行:
push cs
push ip
jmp far ptr 标号