8086 CPU 给出物理地址的方法
8086 CPU 有20位地址总线,可以传送2位地址,达到1 MB的寻址能力。8086 CPU又是16位结构,在内部一次性处理,传送,暂时存储的地址是 16位。
从8086 CPU的内部结构来看,如果将地址从内部简单的发出,那么,它只能送出16位地址,表现出的寻址能力只有64 KB。
8086 CPU采用一种在内部用2个16位地址合成方法来姓曾一个20位的物理地址。
下图为8086 CPU县官部件的逻辑结构:
A > CPU 的相关部件提供2个16位的地址。一个称为段地址,一个称为偏移地址;
B> 段地址和偏移地址通过内部总线送入一个称为地址加法器的部件;
C> 地址加法器将2个16位地址合成一个20位的物理地址;
D> 地址加法器通过内部总线将20位物理地址送入输入输出控制电路;
E> 输入输出控制电路将20位物理地址送上地址总线;
地址加法器采用 物理地址 = 段地址 X 16 + 偏移地址 的方法用段地址 和 偏移地址合成物理地址。
物理地址 = 段地址 X 16 + 偏移地址 的本质含义是: CPU在访问内存时,用一个基础地址(段地址 X 16) 和一个相对于基础地址的偏移地址相加,给出内存但单元的物理地址。
更一般来说,8086 CPU的这种功能是 “基础地址+偏移地址 = 物理地址 ”寻址模式的一种具体实现方案。 8086 CPU中,段地址X 16 可以看作是基础地址。
什么是 段?
内存并没有分段,段的划分来自CPU,由于8086 CPU用“基础地址(段地址X 16) + 偏移地址 = 物理地址”的方式给出内存单元的物理地址,使得我们可以用分段的方式来管理内存。 在编程时可以根据需要,将若干地址连续的内存单元看成是一个段,用段地址X 16定位的起始地址(基础地址), 用偏移地址定位段的内存单元。
注意:
A> 段地址 X 16 必然是16 的倍数,所以 一个段的起始地址也一定是16的倍数;
B> 偏移地址为 16 位,16位地址的寻址能为 64 KB,所以, 一个段的长度最大为 64 KB。
~~~~~~~~~~~~~~~~~~ 续