i386中为的地址映射
逻辑地址经过段映射为线性地址, 再经页映射到物理地址.
这个结构可以用下图表示:
目录项中含有指向一个页面表的指针, 页页面表中含有指向一个页面起始地址的指针. 每个目录项和页表项都是以4字节(32位机器)的长度存储的数据. 由于页面表和页面的起始地址都总是在4K字节的边界上, 这些指针的低12位都永远是0. 这样, 在目录项和页面表中都只要有20位的指针就够了, 余下的12位则可以用于控制或其他的目的.
为了方便理解这里copy了浅谈地址映射原理与举例分析中的例子. 若线性地址为,
0000 1000 0000 0100 1000 0101 0110 1000
高10位是0000 1000 00, 也就是32, 所以i386CPU就以32位下标去页面目录中找目录项. 这个目录项中的高20位指向一个页面表. 找到页面表后, CPU再来看线性地址的中间10位, 为 0001001000, 即十进制的72, 于是CPU就以此为下标在已经找到的页表中找到相应的表项. 这时这个线性地址的最低12位为0X568, 所以如果目标页面的起始地址为0X740000的话 (具体取决于内核中的动态分配), 那么物理地址就是0X740568.
其实段映射完全没必要存在, 只是i386为了兼容之前的16位段寄存器的, 不得不在采取段式地址映射来实现其"保护模式", 虽然只用页式管理就能实现更加有效和高效的"保护模式"下的内存地址映射, 事实上ARM等处理器就只有页式管理.
待续: 内存管理中的地址映射演变, 从实模式到保护模式