CPU寻址


title:CPU寻址
date:
tags:
categories: IT

description:

CPU寻址


本文摘自《汇编原理(第二版)》,作者王爽

CPU组成

一个典型的CPU由运算器、控制器、寄存器等器件构成,这些器件靠内部总线相连。简单的讲,在CPU中:

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

8086CPU的所有寄存器都是16位的。AX、BX、CX、DX这4个寄存器通常用来存放一般性的数据,被称为通用寄存器。
8086CPU的上一代CPU中的寄存器都是8位的,为了保证兼容,使原来基于上代CPU编写的程序稍加修改就可以运行在8086之上,8086CPU的AX、BX、CX、DX这4个寄存器都可分为两个独立使用的8位寄存器来用:例如AX可分为AH和AL。
出于对兼容性的考虑,8086CPU可以一次性处理以下两种尺寸的数据:字节和字。

将AX分为AH和AI使用时,CPU在执行指令的时候认为AH和AL是两个不相关的寄存器。不要错误的认为i,诸如add al,93H的指令产生的进位会存储在ah中,add al,93H进行的8位运算。

CPU如何在内部形成内存单元的物理地址

8086是16位结构的CPU,什么是16位结构的CPU呢?

1. 运算器一次最多可以处理16位的数据; 
2. 存储器的最大宽度为16位;
3. 寄存器和运算器之间的通路为16位。

这也就是说,在8086内部,能够一次性处理、传输、暂时存储的信息最大长度是16位的(是不是32位系统与64位系统也是这样,除了在内存上有差别还在性能上有差别?)。内存单元的地址在送上地址总线之前,必须在CPU中处理、传输、暂时存放,对于16位的CPU,能一次性处理、传输、暂存16位的地址。但是,8086有20位地址总线,怎么办?
8086CPU采用一种在内部用两个16位地址合成(通过地址加法器)的方法来形成一个20位物理地址。
当8086CPU要读写内存时:

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

地址加法器采用物理地址=段地址×16+偏移地址的方式合成物理地址。
例如两个16位,1230和00C8,1230*16=12300(左移4位)。12300+00C8=123C8。

段的概念

段地址包含着段的概念,其实不是内存分段,段的划分来自CPU,由于8086CPU用“基础地址(段地址*16)+偏移地址=物理地址”的方式给出的内存单元的物理地址,使得我们可以用分段的方式来管理内存。
对于同一地址比如10000H~100FFH的内存单元,可以有很多种表示方式
1. 基础地址为10000H,段地址为1000H,大小为100H;
2. 可以认为10000H~1007FH、10080H~100FFH内存单元组成两个段,它们的基础地址为:10000H和10080H,段地址为:1000H和1008H,大小都为80H。

有两点需要注意:

  • 段地址*16必然是16的倍数,所以一个段的起始地址也一定是16的倍数;
  • 偏移地址为16位,16位地址的寻址能力为64KB,所以一个段的长度最大为64KB

段寄存器

段地址在8086CPU的段寄存器中存放。8086CPU有4个段寄存器:CS、DS、SS、ES。其中CS用来存放指令的段地址。

CS和IP

CS和IP是8086CPU中最关键的寄存器,它们指示了CPU当前要读指令的地址。CS为代码段寄存器,IP为指令指针寄存器,即CS*16+IP。
8086CPU的工作过程:
1. 从CS:IP指向的内存单元读取指令,读取指令进入指令缓冲器;
2. IP指向下一条指令;
3. 执行指令。(转到步骤1,重复这个过程)

8086机中,任意时刻,CPU将CS:IP指向的内容当作指令执行。
在内存中,指令和数据没有任何区别,都是二进制信息,CPU在工作的时候把有的信息看作指令,有的信息看作数据。现在,如果提出一个问题:CPU根据什么将内存中的信息看作指令?如何回答?我们可以说,CPU将CS:IP指向的内存单元中的内容看作指令。

注意move指令不能改变CS、IP寄存器中的内容。能够改变CS、IP的内容的指令被统称为转移指令。如jump指令。

这本书中的第二章实验1可以多看几遍

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值