汇编学习之路之 8086CPU

        8086 CPU 给出物理地址的方法

        8086 CPU 有20位地址总线,可以传送2位地址,达到1 MB的寻址能力。8086 CPU又是16位结构,在内部一次性处理,传送,暂时存储的地址是 16位。

        从8086 CPU的内部结构来看,如果将地址从内部简单的发出,那么,它只能送出16位地址,表现出的寻址能力只有64 KB。

8086 CPU采用一种在内部用2个16位地址合成方法来姓曾一个20位的物理地址。

下图为8086 CPU县官部件的逻辑结构:

汇编学习之路之 8086CPU_第1张图片

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。 

        

~~~~~~~~~~~~~~~~~~   续

你可能感兴趣的:(汇编学习之路之 8086CPU)