内核加载器
创建PDE(页目录项):
页目录表和页表在物理内存中的位置:
页目录表的物理地址存放在cr3中,把页目录表放在物理内存0x100000,这是出了低端1MB空间的第1个字节。
页表的物理地址都以PDE(Page Directory Entry)的形式存储在页目录表中
(内核放在低端1MB)。
1、先把页目录占用的4KB空间逐字节清0。
2、将第0个页表的地址(0x101000存的地址)存入页目录项的第0项和第768项
为什么要在两处都指向第0个页表?
在加载内核前,一直是loader在运行,它的代码在1MB内,必须保证之前段机制下的线性地址和分页后的虚拟地址对应的物理地址一致。第0个页目录项代表的页表,表示的空间是0 ~ 0x3fffff(4MB)。
为什么要放到页目录表的第768项呢?
操作系统的虚拟地址是0xc0000000(3GB,二进制11后面30个0),该虚拟地址对应的页目录项是第768个(0xc0000000的高10位是0x300=768),这样虚拟地址0xc0000000 ~ 0xc03fffff(范围4MB)之间的内存指向的是低端4MB之内的物理地址,这自然包括操作系统所占的低端1MB物理内存,从而实现了操作系统高3GB以上的虚拟地址对应到了低端1MB
为了实现共享内核,所以各用户进程的虚拟空间的高1GB都必须指向内核所在的物理空间,即每个进程页目录表中第768 ~ 1022个页目录项都是与其他进程相同的(各进程页目录表中第1023个目录项指向页目录表自身)。