操作符offset
- 操作符offset在汇编语言中是由编译器处理的符号,它的功能是取得标号的偏移地址。
jmp指令
- jmp为无条件转移指令,可以只修改IP,也可以同时修改CS和IP。
jmp指令要给出两种信息:
1、转移的目的地址
2、转移的距离(段间转移、段内短转移、段内近转移)
- jmp short 标号(转到标号处执行指令)–段内短转移方式
jmp far ptr 标号–实现的是段间转移:
1、(CS)=标号所在段的段地址;(IP)=标号所在段中的偏移地址
2、far ptr 指明了指令用标号的段地址和偏移地址修改CS和IP
jmp 16位 reg
- (IP) = (16位reg)
jmp word ptr 内存单元地址(段内转移)
- 从内存单元地址处开始存放着一个字,是转移的目的偏移地址
imp dword ptr 内存单元地址(段间转移)
- 从内存单元地址处开始存放这两个字,高地址处的字是转移的目的段地址,低地址处是转移的目的偏移地址。
jcxz指令
jcxz 标号(如果(CX)=0,转移到标号处执行):
1、当(CX)=0时,(IP)=(IP)+8位位移;
2、8位位移=标号处的地址-jcxz指令后的第一个字节的地址;
3、8位位移的范围位-128~127,用补码表示;
4、8位位移由编译器程序在编译时算出。
5、当(CX)!=0时,什么也不作(程序向下执行)
loop指令
- loop指令为循环指令,所有的循环指令都是短转移 ,在对应的机器码中包含转移的位移,而不是目的地址。
loop 标号((CX)=(CX)-1,如果(CX)!=0,转移到标号处执行):
1、(CX)=(CX)-1
2、如果(CX)!=0,(IP)=(IP)+8位位移
ret和retf
- ret指令用栈中的数据,修改IP的内容,从而实现近转移;
- retf指令用栈中的数据,修改CS和IP的内容,从而实现远转移。
执行ret指令时,进行下面操作:
1、(IP)=((SS)*16+(SP))
2、(SP)=(SP)+2
执行retf指令时,进行下面4步操作:
1、(IP)=((SS)*16+(SP))
2、(SP)=(SP)+2
3、(IP)=((SS)*16+(SP))
4、(SP)=(SP)+2
call指令
- 1、将当前的IP或CS和IP压入栈中;
- 2、转移。
call 标号(将当前的IP压栈后,转到标号处执行指令)
CPU执行此种格式的call指令时,进行如下的操作:
1、(SP)=(SP)-2
2、((SS)*16+(SP))=(IP)
3、(IP)=(IP)+16位位移
- 16位位移=标号处的地址-call指令后的第一个字节的地址;
call far ptr 标号(实现的是段间转移)
CPU执行此种格式的call指令时,进行如下的操作:
1、(SP)=(SP)-2
2、((SS)*16+(SP))=(CS)
3、(SP)=(SP)-2
4、((SS)*16+(SP))=(IP)
5、(CS)=标号所在段的段地址
6、(IP)=标号所在段中的偏移地址
call word ptr 内存单元地址
相当于进行下面指令:
1、push IP
2、jmp word ptr 内存单元地址
mul指令
- mul是乘法指令:
- 1、两个相乘的数,要么都是8位ie,要么都是16位。如果是8位,一个默认放在AL中,另一个放在8位reg或内存单元字节中;如果是16位,一个默认放在AX中,另一个放在16位reg或内存单元中。
- 2、结果:如果是8位乘法,结果默认放在AX中;如果是16位乘法,结果高位默认在DX中存放,地位在AX中放。
- 3、格式:mul reg 或 mul 内存单元
- 4、例如:mul byte ptr ds:[0]-- (ax)=(al)*((ds)*16+0)