寄存器
寄存器是CPU中程序员可以用指令读写的部件,CPU的主要部件是寄存器,程序员通过改变各种寄存器的内容来实现对CPU的控制
CPU由运算器、控制器、寄存器等器件构成,器件通过总线连接,第一章描述的地址、控制、命令总线对于CPU内部来说是外部总线,内部总线实现内部各器件连接
运算器进行信息处理
寄存器进行信息存储
控制器控制各器件工作
内部总线连接各种器件,在他们之间传输数据
8086CPU由14个寄存器:AX、BX、CX、DX、SI、DI、SP、BP、IP、CS、SS、DS、ES、PSW
通用寄存器
8086CPU的寄存器都是16位的,可以放两个字节
AX、BX、CX、DX通常用来存放一般性的数据,成为通用寄存器
为了兼容之前的8位机,将AX、BX、CX、DX拆成了AH、AL这种类型
字在寄存器中的存储
略
几条汇编指令
mov ax,00
mov al,88H
add al,88H
此时 al的值 = 10,ah的值= 0
88H+88H = 110H 产生的进位,并不会存储到ah寄存器中,因为两者是独立的 在进行数据传送和运算时,注意指令操作的对象的位数要保持一致 汇编程序在编写时,汇编指令或寄存器不区分大小写
物理地址
内存单元的地址 = 物理地址
16位结构的CPU
运算器一次最多可以处理16位的数据
寄存器的最大宽度为16位
寄存器和运算器之间的通路为16位
对于16位CPU能一次性处理,传输,暂时存储16位的地址
8086CPU给出物理地址的方法
8086单片机一次只能处理16位的数据,地址总线数量却是20寻址能力达到1MB 采用两个16位地址合成的方法来形成20位的物理地址
提供两个16位的地址,段地址,偏移地址
段地址和偏移地址通过内部总线送入一个成为地址加法器的部件
地址加法器将个16位地址合成来形成20位的物理地址
地址加法器通过内部总线将20位物理地址送入输入输出控制电路
输入输出控制电路将20位物理地址送入地址总线
20位物理地址被地址总线传送到寄存器
地址加法器过程描述
寻址123C8的内存单元
将123C8分为 = 段地址 1230 位地址 00C8
送入地址加法器
段地址 x 16 = 12300
段地址 + 位地址 = 123C8
地址加法器输出123C8
段地址X16+偏移地址 = 物理地址
偏移地址寻址的本质:用一个基础地址(段地址X16)和相对基础地址的偏移地址相加,当初内存单元的物理地址
段地址:SA
位地址:EA
CPU的段长度不能超过2^N
段的概念
段寄存器
8086有4个段寄存器:CS、DS、SS、ES
CS和IP
CS和IP是8086CPU最关键的寄存器 CS是代码段寄存器,IP为指令指针寄存器 在8086PC机中,任意时刻,设CS = M,IP = N,8086CPU将从内存Mx16+N单元开始,读取指令并执行 CPU将CS:IP指向的内容当作指令执行 通过CS和IP寻址内存空间,将内存中的指令读取回来到指令缓冲器,再由执行控制器执行,IP中的值自动增加,增加的长度 = 指令的长度
从CS:IP指向的内存单元读取指令,读取的指令接入指令缓冲器
IP = IP + 所读取指令的长度,从而指向下一条指令
执行指令
8086CPU启动或者复位后CS = FFFFH,IP = 0000H
修改CS、IP的指令
CPU中,程序员能用指令读写的部件只有寄存器,程序员可以通过改变寄存器中的内容实现对CPU的控制,CPU从何处执行指令是由CS,IP决定的,可以通过改变CS,IP内容控制CPU执行目标指令 mov指令不能用于设置CS、IP的值,MOV指令被称为传送指令 能够改变CS、IP的内容的指令统称为转移指令 jump 2AE3:3,执行后:CS = 2AE3, IP= 0003H,CPU将从2AE33H读取指令 仅想修改IP寄存器的内容,可以通过 jump 寄存器 如jump ax,将ax的值赋值给ip寄存器
段代码
|