汇编语言页转换:线性地址转换位物理地址
若允许分页,则处理器必须将 32 位线性地址转换为 32 位物理地址。这个过程会用到 3 种结构:
- 页目录:一个数组,最多可包含 1024 个 32 位页目录项。
- 页表:一个数组,最多可包含 1024 个 32 位页表项。
- 页:4KB 或 4MB 的地址空间。
为了简化下面的叙述,假设页面大小为 4KB:
线性地址分为三个字段:页目录表项指针、页表项指针和页内偏移量。控制寄存器(CR3)保存了页目录的起始地址。如下图所示,处理器在进行线性地址到物理地址的转换时,采用如下步骤:
1) 线性地址引用线性地址空间中的一个位置。
2) 线性地址中 10 位的目录字段是页目录项的索引。页目录项包含了页表的基址。
3) 线性地址中 10 位的页表字段是页表的索引,该页表由页目录项指定。索引到的页表项包含了物理内存中页面的基址。
4) 线性地址中 12 位的偏移量字段与页面基址相加,生成的恰好是操作数的物理地址。
发表评论