当前位置:   article > 正文

汇编语言指令_汇编 ptr ds

汇编 ptr ds

ptr

ptr的作用就是临时指定类型。8086CPU的指令,可以处理两种尺寸的数据,byte和word。所以在机器指令中要指明,指令进行的是字操作还是字节操作。对于这个问题,汇编语言中用以下方法处理。

1. 通过寄存器名指明要处理的数据的尺寸。
例如:
下面的指令中,寄存器指明了指令进行的是字操作是字操作:
mov ax,3
mov bx,ds:[4]
mov ds,ax
mov ds:[1],ax
inc ax
add ax,1000
下面的指令中,寄存器指明了指令进行的是字节操作:
mov al,1
mov al,bl
mov al,ds:[0]
mov ds:[0],al
inc al
add al,100
2.在没有寄存器名存在的情况下,用操作符 X ptr 指明内存单元的长度
X在汇编指令中可以是byte(字节)、word(字)、dword(双字)、qword(四字)、tbyte(十字节)、far(远类型)和near(近类型)
例:
mov byte ptr ds:[0],1
mov word ptr ds:[0],1
jmp near ptr 标号

3. 指令默认
有些指令默认了访问的是字单元还是字节单元,比如:push、pop指令就不用指明访问的是字单元还是字节单元,因为它们只进行字操作。

转移指令

可以修改IP,或同时修改CS和IP的指令统称为转移指令。

jmp

无条件转移指令,可以只修改ip也可同时修改cs与ip。
jmp指令要给出两种信息:
(1)转移的目的地址
(2)转移的距离(段间转移。段内短转移,段内近转移)
不同的给出目的地址的方法与不同的转移位置,对应有不同格式的jmp指令。
1,根据位移
这两条指令对应的机器码中并不包含转移的目的地址,而包含的是相对于当前IP的转移位移。

jmp short 标号 ip=ip+8位位移 段内短转移

其中,short指明此处的转移位移为8位,由编译程序在编译时计算得出。位移计算方法为标号处的地址 - jmp指令后的第一个字节的地址,8位位移的范围是-2^7 至2的7次方-1

jmp near ptr 标号 ip=ip+16位位移 段内近转移

其中near ptr指明转移位移为16位,其余同上。

2.转移的目的地址在指令中

jmp far ptr 标号 段间转移,又称远转移
far ptr指明了指令用标号的段地址和偏移地址修改cs和ip,cs=标号所在段的段地址,ip=标号在段中的偏移地址

3.转移地址在寄存器中

Jmp reg(16位)

ip=(16位reg)

4.转移地址在内存中

jmp word ptr 内存单元地址 (段内转移)
ip=(内存单元地址 )

jmp dword ptr 内存单元地址 (段间转移)
cs=(内存单元地址+2 )
ip=(内存单元地址 )

jcxz(jump if cx is zero)

短转移,对应的机器码中包含转移的位移,而不是目的地址。

jcxz 标号

if cx=0,ip=ip+8位位移,转移到标号处执行
if cx≠0,程序向下执行

相当于 if(cx==0)jmp short 标号

Loop

循环指令,所有的循环指令都是短转移,对应的机器码中包含转移的位移,而不是目的地址。

loop 标号

(cx)=(cx)-1
if(cx)≠0,IP=(IP)+8位位移
相当于:
(cx)- -;
if(cx≠0)jmp short 标号

CALL

(1)将当前的IP或CS和IP压入栈中;
(2)转移
无法实现短转移
1.根据位移转移的CALL指令
call 标号
(1)(SP)=(SP) - 2
((SS)*16+(SP))=(IP)
(2) (IP)=(IP)+16位位移

16位位移=标号处的地址 - CALL指令后的第一个字节地址
相当于:
PUSH IP
jmp near ptr 标号

2.转移目的地址在指令中
call far ptr 标号 段间转移
(1)(SP)=(SP) - 2
((SS)*16+(SP))=(CS)
(SP)=(SP) - 2
((SS)*16+(SP))=(IP)

(2)(CS)=标号所在段的段地址
	(IP)=标号所在段中的偏移地址
	相当于:
	PUSH CS
	PUSH IP
	JUMP FAR PTR 标号
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

3.转移地址在寄存器中

CALL 16位reg

(1)(SP)=(SP) - 2
((SS)*16+(SP))=(IP)
(2) (IP)=(16位reg)
相当于
PUSH IP
jmp 16位reg

4.转移地址在内存中

(1)call word ptr 内存单元地址
(2)call dword ptr 内存单元地址

ret / retf

ret
(1) (IP)=((SS)*16+(SP))
(2) (SP)=(SP) +2

相当于 pop ip
retf
(IP) = ((SS)*16+(SP))
(SP)=(SP) + 2
(cs) = ((SS)*16+(SP))
(SP)=(SP) + 2
相当于
pop ip
pop cs

mul指令

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/486960
推荐阅读
相关标签
  

闽ICP备14008679号