1.修正上节课的转换图
上节课的页表的一级页表其实并不完全正确,一般虚拟页帧和物理页帧号不会都占用实际字段,这样毕竟很浪费内存。
2.再分析一下页表的开销情况:
一级页表:以4KB物理页为映射单位,每个进程4MB的虚拟地址空间,4GB/4KB=1MB个页表项entry,每个一级页表都需要4MB存储空间,每个进程需要4M的内存存储页表,100个进程需要400M。
二级页表:相当于把一级页表的4MB个entry拆分成,4096个二级entry(256个entry),但是如果全量映射的话,4096*256本质上也是1024 KB个entry。 所以这个角度分析没有任何内存优化。
- 一级页表PGD:一共占用12位,31-20位,也就是需要4K的页表项。(如果每个entry占用4字节,32位的话也就是16KB)
- 二级页表PTE:占据19-10一共10位,也就是1024个二级页表项,一般每个entry也是4字节,二级页表也就占据1KB。因为每个一级页表的entry都会执行一个二级页表,所有的二级页表加起来是4K * 1K = 4M。也就是每个进程如果全部映射的话也是需要4MB。(这里如果全部映