汇编语言笔记整理
寄存器
在CPU中:
- 运算器进行信息处理
- 寄存器进行信息存储
- 控制器控制各种器件进行工作
- 内部总线连接各种器件,在它们之间进行数据的传送
在8086COU中有14个寄存器,每个寄存器有一个名称。分别是:AX、BX、CX、DX、SI、DI、SP、BP、IP、CS、SS、DS、ES、PSW
通用寄存器
8086CPU的所有寄存器都是16位的,可以存放两个字节。AX、BX、CX、DX这4个寄存器通常用来存放一般性的数据,被称为通用寄存器。
以AX为例,寄存器逻辑结构:
由于8086CPU的上一代CPU中寄存器都是8位的,为了保障兼容,8086CPU的AX、BX、CX、DX这4个寄存器都可分为两个独立的8位寄存器使用。
- AX可分为AH和AL
- BX可分为BH和BL
- CX可分为CH和CL
- DX可分为DH和DL
AX的低8位(0-7位)构成了AL寄存器,高8位(8-15位)构成了AH寄存器。AH和AL寄存器都可以独立使用
几条常见的汇编指令:
汇编指令 | 控制CPU完成的操作 | 高级语言语法描述 |
---|---|---|
mov ax,18 | 将18送入寄存器AX | AX=18 |
mov ah,78 | 将78送入寄存器AH | AH=78 |
add ax,8 | 将寄存器AX中的数字加上8 | AX=AX+8 |
mov ax,bx | 将寄存器BX中的数据送入AX | AX=BX |
add ax,bx | 将AX和BX中的数值相加,结果存入AX | AX=AX+BX |
注:在进行数据传送或运算时,要注意指令的两个操作对象的位数应当一致。
mov ax,bl (在8位寄存器和16位存储器之间传送数据)
mov bh,ax (在16位和8位寄存器之间传送数据)
mov al,20000 (8位寄存器最大存放值为255,0~2^8-1)
add a1,100H (将一个高于8位的数据加到一个8位寄存器中)
都是错误的指令。
物理地址
CPU访问内存单元时,要给出内存单元的地址。所有的内存单元构成的存储空间是一个一维的线性空间,每一个内存单元在这个空间中都有一个唯一的地址,叫做物理地址。
CPU通过地址总线送入存储器的,必须是一个内存单元的物理地址。但在发出物理地址前,必须先在内部形成这个物理地址。在8086CPU中如何形成物理地址:
-
8086CPU是16位机,即字长为16位。但8086CPU有20位地址总线,故在内部用两个16位地址合成一个20位的物理地址
8086CPU相关部件的逻辑结构:
-
CPU要读写内存时:
1)CPU中相关部件提供两个16位地址,一个是段地址,一个是偏移地址
2)段地址和偏移地址通过内部总线送入地址加法器
3)地址加法器将两个16位地址合成为一个20位物理地址
4)地址加法器通过内部总线将20位物理地址送入输入输出控制电路
5)输入输出控制电路将20位物理地址送上地址总线
6)20位物理地址被地址总线传到存储器
地址加法器采用物理地址=段地址x16+偏移地址的方法合成物理地址
段
由于8086CPU用“基础地址(段地址x16)+偏移地址=物理地址”的方式给出内存单元物理地址,使得我们可以用分段方式管理内存。
我们可以认为:
地址10000H~100FFH的内存单元组成一个段,起始地址10000H,段地址为1000H,大小为100H
地址10000H1007FH、10080H100FFH的内存单元组成两个段,它们的起始地址为:10000H和10080H,段地址为1000H和1008H,大小都为80H
段寄存器
8086CPU在访问内存时由相关部件提供内存单元的段地址和偏移地址,送入地址加法器合成物理地址。段地址在段寄存器中存放。段寄存器有:CS、DS、SS、ES
CS和IP
CS:代码段寄存器
IP:指令指针寄存器
在8086机中,任意时刻,设CS中内容为M,IP中内容为N,8086CPU将从Mx16+N单元开始,读取一条指令并执行。
CPU将CS:IP指向的内存单元中的内容看作指令。
修改CS、IP的指令
修改CS、IP的值,用jmp指令:
jmp段地址:偏移地址。jmp 2AE3:3,执行:CS=2AE3H,IP=0003H,cpu将从2AE33H处读取指令。
仅修改IP的内容: jmp 某一合法寄存器。jmp ax:执行前:ax=1000H,CS=2000H,IP=0003H;执行后:ax=1000H,CS=2000H,IP=1000H
代码段
在编程时,根据需要,我们可以将一组内存单元定义为一个段。认为这段内存用来存放代码。比如:
mov ax,0000 (B8 00 00)
add ax,0123H (05 23 01)
mov bx,ax (8B D8)
jmp bx (FF E3)
这段长度为10字节的指令,存放在 123B0H123B9H的一组内存单元中,我们就可以认为,123B0H123B9H 这段内存用来存放代码的,是一个代码段。段地址为123BH,长度为10字节
(8B D8)
jmp bx (FF E3)
这段长度为10字节的指令,存放在 123B0H~123B9H的一组内存单元中,我们就可以认为,123B0H~123B9H 这段内存用来存放代码的,是一个代码段。段地址为123BH,长度为10字节