三种内存地址:逻辑地址,线性地址,和物理地址
逻辑地址:
包含在机器语言指令中用来指定一个操作数或一条指令的地址。这种寻址方式在80X86著名的分段结构中表现得尤为具体,它促使MS-DOS或Windows程序员把程序分成若干段。每一个逻辑地址都是有一个段和偏移量组成,偏移量指明了从段开始的地方到时间地址之间的距离
线性地址:(虚拟地址)
是一个32位无符号整数,可以用来表示高达4GB的地址,也就是高达4294967296个内存单元。线性地址通常用十六进制数字表示
物理地址:
用于内存芯片级内存单元寻址。它们与从微处理器的地址引脚发送到内存总线上的电信号相对应。物理地址由32位或36位无符号整数表示
内存控制单元(MMU)通过一种称为分段单元的硬件电路把一个逻辑地址转换成线性地址
分段单元:
1,先检查段选择符的TI字段,已决定段描述符保存在哪一个描述符表中。TI字段指明描述符是在GDT中(在这种情况下,分段单元从gdtr寄存器中得到GDT的线性基地址)还是在激活的LDT中(在这种情况下,分段单元从ldtr寄存器中得到LDT的线性基地址)
2,从段选择符的index字段计算段描述符的地址,index字段的值乘以8,这个结果与gdtr或ldtr寄存器的内容相加
3,把逻辑地址的偏移量与段描述符base字段的值相加就得到了线性地址
第二个称为分页单元的硬件电路把线性地址转化成一个物理地址
分段单元 分页单元
逻辑地址=============》 线性地址 ============》 物理地址
实际上,分段和分页在某种程度上有点多余,因为它们都可以划分进程的物理地址空间:
分段可以给每一个进程分配不同的线性地址空间,而分页可以把同一线性地址空间映射到不同的物理空间,与分段相比,Linux更喜欢使用分页方式
因为:
当所有进程使用相同的段寄存器值时,内存管理变得更简单,也就是说它们能共享同样的一组线性地址
Linux设计目标之一是可以把它移植到绝大多数流行的处理器平台上。然而,RISC体系结构对分段的支持很有限
在多处理系统中,所有与CPU都共享同一内存;这意味着RAM芯片可以由独立的CPU并发访问。
因为在RAM芯片上的读或写操作必须串行的执行。因此一种所谓内存仲裁器的硬件电路插在总线和每个RAM芯片之间
作用是如果某个RAM芯片空闲,就准予一个CPU访问,如果该芯片忙于为另一个处理器提出的请求服务,就延迟这个CPU的访问。
即使在单处理器上也使用内存仲裁器,因为单处理器系统中包含有一个叫做DMA控制器的特殊处理器,而DMA控制器与CPU并发操作
在多处理器系统的情况下,因为仲裁器有多个输入端口,所以其结构更加复杂。
例如:双Pentium在每个芯片的入口维持一个两端口仲裁器,并在试图使用公用总线前请求两个CPU交换同步信息。
仲裁器由硬件电路管理,是隐藏的