第2章 寄存器

第2章 寄存器

一个 CPU 由运算器,控制器,寄存器等器件构成,这些器件靠内部总线进行相连。简单的说 CPU 中:

  • 运算器进行信息处理
  • 寄存器进行信息存储
  • 控制器控制各种器件进行工作
  • 内部总线连接各个器件,在他们之间进行各种数据的传送

寄存器是 CPU 中程序员可以用指令读写的部件,程序员可以通过改变各种寄存器的内容实现对 CPU 的控制

8086CPU 由14个寄存器:AX,BX,CX,DX,SI,DI,SP,BP,IP,CS,SS,DS,ES,PSW

  • 外部总线:相对于 CPU 内部而言是外部总线,实现 CPU 和主板上其他器件的联系。
  • 内部总线:实现 CPU 内部各个器件之间的联系。

2.1 同用寄存器

8086CPU 的所有寄存器都是16位,可以存放两个字节。AX,BX,CX,DX 这4个通用寄存器,每一个寄存器可以分为两个可独立使用的8位寄存器来使用。

以 AX 为例:寄存器的逻辑结构如图 2.1 所示:

图2.1

  • AX 可以分为 AH 和 AL
  • BX 可以分为 BH 和 BL
  • CX 可以分为 CH 和 CL
  • DX 可以分为 DH 和 DL

以 AX 为例:8086CPU 的16位寄存器分为两个8位寄存器的情况如图 2.3 所示:

图 2.3

AX 的低8位(0位~7位)构成了 AL 寄存器,高8位(8位~15位)构成了 AH 寄存器。

图2.4 展示16位寄存器及其所分成的两个8位寄存器的数据存储情况:

图2.4

2.2 物理地址

CPU 访问内存单元,要给出内存单元的地址。每一个内存单元在这个空间中都有一个唯一的地址,我们将这个唯一的地址称之为物理地址

2.3 8086 CPU 给出物理地址的方法

image

  1. CPU 中的相关部件提供两个16位地址,一个称之为段地址,一个称之为偏移地址
  2. 段地址和偏移地址通过内部总线送入一个称之为地址加法器的部件
  3. 地址加法器将两个16位地址合成一个20位的物理地址
  4. 地址加法器通过内部总线将20位物理地址送入到输入和输出控制电路
  5. 输入和输出控制电路将20 位物理地址送上地址总线
  6. 20位物理地址被地址总线传送到存储器

地址加法器采用:物理地址 = 段地址*16+偏移地址 合成物理地址

例如:8086CPU 要访问地址为 123C8H 的内存单元,地址加法器的工作过程如图2.7所示:

图2.7

image

2.4 段的概念

在编程时可以根据需要,将若干地址连续的内存单元看作一个段。偏移地址位16位,16位地址的最大寻址能力位 64KB,所以要给段的长度最大位 64KB

2.5 段寄存器

段寄存器:CS、DS、SS、ES

CS:代码段寄存器

IP:指令指针寄存器

2.6 CS 和 IP

  • CS:代码段寄存器;
  • IP:指令指针寄存器。

假设 CS 中的内容为 M,IP 中内容为 N,8086CPU 将从内存 M✖16+N 单元开始,读取一条指令并执行

在 8086PC 机中,任意时刻,CPU 将 CS: IP 指向内存单元中的内容看作指令

2.7 总结

  • CS 存放指令的段地址,IP 存放指令的偏移地址,任意时刻,CPU 将 CS: IP 指向内容当作指令的执行
  • CPU 工作的流程:
  • 从 CS: IP 指向内存单元读取指令,读取的指令进入指令的缓冲器
  • IP = IP + 所读取指令的长度,从而指向下一条指令
  • 执行指令。

image

2.8 Debug

  • R 命令查看、改变 CPU 寄存器的内容

  • D 命令查看内存中的内容

  • E 命令改写内存中的内容

  • U 命令将内存中的机器指令翻译成汇编指令

  • T 命令执行一条机器指令
    g

  • R 命令查看、改变 CPU 寄存器的内容

  • D 命令查看内存中的内容

  • E 命令改写内存中的内容

  • U 命令将内存中的机器指令翻译成汇编指令

  • T 命令执行一条机器指令

  • A 命令已汇编指令的格式在内存中写入一条机器指令

  • 13
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

霜晨月c

谢谢老板地打赏~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值