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要读写内存时:
- CPU中的相关部件提供两个16位的地址,一个成为段地址,另一个称为偏移地址;
- 段地址和偏移地址通过内部总线送入一个成位地址加法器的部件;
- 地址加法器将两个16位地址合成为一个20位的物理地址;
- 地址加法器通过内部总线将20位物理地址送入输入输出控制电路;
- 输入输出控制电路将20位物理地址送上地址总线;
- 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指令。