汇编语言学习笔记(十)call和ret指令配合使用

时间:2021-08-12 00:42:56

1.ret和retf
ret:指令用栈中的数据,修改ip的内容,从而实现了近转移
cpu执行ret指令时,进行下面两步操作:
1)(ip)=((ss)*16+(sp))
2)(sp)=(sp)+2
相当于pop ip

retf:用栈中的数据,修改cs和ip的内容,从而实现远转移
1)(ip)=((ss)*16+(sp))
2)(sp)=(sp)+2
3)(cs)=((ss)*16+(sp))
4)(sp)=(sp)+2
相当于pop ip pop cs

call 标号:(相比jmp只是将当前的的位置保存到栈)
操作如下:
1)(sp)=(sp)-2
((ss)*16+(sp))=(ip)
2)(ip)=(ip)+16位位移

call far ptr 标号:远转移
1)(sp)=(sp)-2
((ss)*16+(sp))=(cs)
(sp)=(sp)-2
((ss)*16+(sp))=(ip)
2)(cs)=标号所在的段地址
(ip)=标号所在的偏移地址

call 16位寄存器
(sp)=(sp)-2
((ss)*16+(sp))=(ip)
(ip)=(16位寄存器)
相当于:
push ip
jmp 16位寄存器

转移地址在内存中的call指令有两种格式:
call word ptr 内存单元地址    近转移
call dword ptr 内存单元地址    远转移

mul指令:乘法指令
注意:相乘两数要么都是8位,要么都是16位
8位结果:ax中
16位结果:dx高位和ax地位中