上图反映了如下信息:
1、 进程的4G 线性空间被划分成三个部分:进程空间(0-3G)、内核直接映射空间(3G – high_memory)、内核动态映射空间(VMALLOC_START - VMALLOC_END)
2、 三个空间使用同一张页目录表,通过 CR3 可找到此页目录表。但不同的空间在页目录表中页对应不同的项,因此互相不冲突
3、 内核初始化以后,根据实际物理内存的大小,计算出 high_memory、VMALLOC_START、VMALLOC_END 的值。并为“内核直接映射”空间建立好映射关系,所有的物理内存都可以通过此空间进行访问。
4、 “进程空间”和“内核动态映射空间”的映射关系是动态建立的(通过缺页异常)
假设在有三个线性地址 addr1, addr2, addr3 ,分别属于三个线性空间,但是最终都映射到物理页面1:
1、 三个地址对应不同的页表和页表项
2、 但是页表项的高 20bit 肯定是1,表示物理页面的索引号是1
3、 同时,根据高 20 bit,可以从 mem_map[] 中找到对应的 struct page 结构,struct page 用于管理实际的物理页面(红线)
4、 从线性地址,根据页目录表,页表,可以找到物理地址
5、 Struct page 和物理地址之间很容易互相转换
6、 从物理地址,可以很容易的反推出在内核直接映射空间的线性地址(蓝线)。要想得到在进程空间或者内核动态映射空间的对应的线性地址,则需要遍历相应的“虚存区间”链表。
关于页目录表:
1、 每个进程有一个属于自己的页目录表,可通过 CR3 寄存器找到
2、&nbs
Linux内存管理:页目录与页表结构解析

这篇博客详细介绍了Linux内存管理中的页目录和页表结构。每个进程拥有独立的页目录表,可通过CR3寄存器访问,而内核则有其自身的页目录。进程空间、内核直接映射空间和内核动态映射空间通过同一页目录表实现不同映射。页表项的高20bit指示物理页面索引,用于管理struct page结构。线性地址通过页目录和页表转换为物理地址,反之亦然,对于进程空间和内核动态映射空间的转换则需要遍历虚存区间链表。
最低0.47元/天 解锁文章
394

被折叠的 条评论
为什么被折叠?



