目录
一、引言
视图
指令
指令=操作码 操作数1 操作数2
cpu一条接着一条地执行指令
段寄存器
ES:附加段寄存器
CS:代码段寄存器
SS:堆栈寄存器
DS:数据段寄存器
区分有效地址和实际中内存中的地址:
实际中内存的地址=有效地址+段地址
EIP如何发生改变
方式一:自动增量
方式二:跳转指令:更改程序计数器(PC)
方式三:分支指令:根据程序状态字PSW寄存器(也被称作标志寄存器FR)有条件地更改程序计数器
二、操作数寻址方式(Operand-addressing Mode)
是什么决定了在指令执行的每个步骤中将获取哪个数据项呢?
在c语言中:使用变量
在机器编码中:使用操作数寻址
操作数寻址方式分类:
- 寄存器寻址
- 立即寻址
- 存储器寻址
1.寄存器寻址(Register Addressing)
所有的操作数都存储在通用寄存器中
- 16位:AX,BX,CX,DX,SI,DL,SP或BP
- 8位: AH,AL,BH,BL,CH,CL,DH或DL
MOV AX,BX;//将数据从BX复制到AX
如下所示:
使用寄存器寻址,cpu无需访问内存就可以获取操作数,速度快很多
2.立即寻址(Immediate addressing)
在指令中使用的操作数是常数
MOV AX,1234H;//这里的1234H表示的是16进制数,将1234H复制到寄存器AX
如下所示:
解释一下:AX寄存器由AH和AL构成。
3.存储器寻址(Mermory addressing)
除了寄存器寻址(寄存器就在cpu中)和立即寻址(操作数就在指令中),其他的几种寻址方式的操作数都在内存单元中。
因此,对于存储器寻址,最重要的就是搞清楚cpu如何确定内存操作数的地址,然后cpu再对该内存单元的操作数进行处理。
3.1 直接寻址(direct addressing)
直接寻址就是指令中直接给出了内存操作数的地址。
指令中使用变量时,就是直接寻址
在翻译成机器指令后,变量是用它的地址而不是名字来表示的。
地址外面加上一对方括号,表示取这个地址的内容。
MOV AL,DS:[2000H];
3.2 寄存器间接寻址(register indirect addressing)
寄存器间接寻址就是指:内存操作数的地址放在了寄存器中
MOV AX,[BX];
3.3 寄存器相对寻址(register relative addressing)
寄存器相对寻址方式的操作数,其地址是寄存器和一个立即数相加后得到的结果
MOV AL,[BX+5];
解释一下:
EA:有效地址寄存器,表示操作数所在单元到段首的距离即逻辑地址的偏移地址
3.4 基址加变址寻址(base-plus-index addressing)
基址加变址寻址方式的操作数,其地址是两个寄存器相加得到的结果。这里的两个寄存器分别称之为基址寄存器和变址寄存器
在8086/8088/80286等16位的cpu中:
基址寄存器:BX和BP
变址寄存器:SI和DI
在80386及以后的32位cpu中:
基址寄存器:EAX,EBX,ECX,EDX,ESI,EDI,EBP和ESP
变址寄存器:EAX,EBX,ECX,EDX,ESI,EDI和EBP
MOV AL,[BX+SI];
3.5 相对基址变址寻址(base relative-plus-index addressing)
基址变址相对寻址方式的操作数,其地址是两个寄存器以及一个立即数相加后得到的结果。
MOV AL,[BX+SI+4];
3.6 比例变址寻址(scaled-index addressing)
地址=基址寄存器+变址寄存器*[1|2|4|8]+相对量
MOV EDI,[ESI+EBX*2+4];