【xv6学习之番外篇】jos内存布局详解

xv6的内存格式我们可以通过打开 inc/memlayout.h 查看。具体如下:

【xv6学习之番外篇】jos内存布局详解_第1张图片


这个页面布局代表的是启用地址转换以后,无论是操作系统还是用户程序,看到的虚拟内存布局(这也就是说,操作系统和用户程序 使用的是同一套页目录和页表,这个在绍老师的讲义里有提到)。关于每部分的详解,我们可以参见:


【xv6学习之番外篇】jos内存布局详解_第2张图片


这里列出几个需要注意的地方:

1、[UPAGES, UVPT]: 在虚拟地址中的这段内存就是对应的在实际物理地址里 pages 数组的存储位置。可以看到这段地址在ULIM之下,也就是说操作系统开放pages数组便于让用户程序可以访问。为什么呢?比如说假如有的程序想要知道一个物理页面被引用了多少次,那么根据相应的pages[i].pp_ref就可以知道了。我们看到这个区域在布局中分配了 PTSIZE 的大小,那么这个大小够么?因为我们知道在物理页面中pages所占用的大小为npage × sizeof (struct PageInfo) =npage ×8B(使用sizeof()查看,一个指针占4字节,uint16_t是2个字节,可是struct PageInfo占8字节,有些迷惑,可借鉴uint16_t类型在 Bochs 模拟出来的 x86 平台上是4字节理解)。我们看看PTSIZE的空间可以装struct Page的个数为1024 ×4KB / 8B = 4MB / 8B = 1/2M。一个Page结构对应一个实际大小为4KB的物理页面,所以这个PTSIZE大小的虚拟地址空间能够管理 1/2 M × 4KB =2GB的物理内存,这个对于我们的QEMU模拟器来讲应该还是足够了。

2、[UVPT, ULIM]: 这部分是一个系统页目录——kern_pgdir。开放给用户只读,可以使用户得到当前内存中某个虚拟地址对应的物物理页面地址是多少。关于这部分,我们需要看一下:

kern/pmap.c

【xv6学习之番外篇】jos内存布局详解_第3张图片

kern_pgdir这部分实际紧接在kernel 的 end 后面,也即在实际的物理地址里,上图最下面一句话使以物理地址 PADDR(kern_pgdir) 开始的一页成为了虚拟地址的 PDX = PDX(UVPT) 的页表。这部分实际占物理空间 PGSIZE, 但是在虚拟地址上却分配了 PTSIZE 大小。

注意 UVPD 的虚拟地址为 PDX(UVPT)<<22 | PDX(UVPT)<<12 | 0000000000   。


详细的 UVPT 介绍见:Lecture 5


3、[KERNBASE, 4G] : 此部分映射实际物理内存中从0开始的中断向量表IDT、BIOS程序、IO端口以及操作系统内核等,该部分虚拟地址 - KERNBASE 就是物理地址。


从这个布局结构我们就可以看出来,实际上虚拟内存中分配给用户的只有[0, ULIM)大概3.7GB而非4GB的空间(ULIM = 0xef800000),其余的空间需要分配给操作系统。

你可能感兴趣的:(【xv6学习之番外篇】jos内存布局详解)