在不支持PAE的x86机器上,两层页表已足够。中间页目录(PMD)被定义成大小为1,它在系统初始化时直接映射为全局页目录(PGD),并在编译时间以外的时段进行优化。
描述页目录
每个进程都有一个指向其自己PGD的指针(mm_struct->pgd
),它其实就是一个物理页面帧。该帧包括了一个pgd_t
类型的数组。在x86结构中,进程页表的载入是通过把mm_struct->pgd
复制到cr3
寄存器完成,这种方式对TLB的刷新有副作用。事实上,这种方式体现了在不同结构中__flush_tlb()
的实现情况。
描述页表项
三层页表中的每一个项PTE
、PMD
、PGD
分别由pte_t
、pmd_t
、pgd_t
描述。他们实际上都是无符号的整型数据,之所以定义成结构,一方面是为了起到数据类型保护的作用,以使他们不会被滥用;另一方面是为了满足某些特性,如在支持PAE的x86中,将有额外的4位用于大于4GB内存的寻址。
未启用PAE的x86结构下,定义如下
typedef s