一次寻址:
虚拟、逻辑地址:CS(段选择子)+ eip(段内偏移)=> 线性地址 : 32位或64位 =通过页表=> 物理地址
x86:
页面大小4k pte4个字节 10-10-12 (不管是x86 x86PAE x64下页内偏移都是12位)
(每个页表项占4个字节 4K/ 4 就是 10 位 才能表示这么多项)
线性地址 : 页目录表项10(PDI) 页表项10(PTI) 页内偏移地址12(OFFSET)
CR3寄存器指向页目录表(PDE)的基地址 => 通过PDI找到PTE的基地址 => 通过PTI找到物理内存的起始地址,物理地址的base + 线性地址的OFFSET就是对应的物理地址
PAE物理地址扩展: 要支持更大的内存 每个物理地址就是4字节->8字节 4K/8 => 9位
页面大小4K pte 8个字节=> 2-9-9-12
CR3->PDPTR的基地址 通过2位的值找到页目录表base => 页目录表通过9位找到页表基地址 => 页表基地址通过页表项找到物理地址base => 再+12位的OFFSET得到物理地址
x64中是使用了低48位,每级页表占9位,共4级,缩写分别为:PML4,PDP,PD,PT
因为页内偏移也是4K 地址8字节 => 9 位 9-9-9-9-12
CR3寄存器指向最顶级页表的基地址通过PML4中索引号=> 下一级页表起始地址+PDP索引号=>再下一级页表起始地址=> ...找到最下级页表,最后通过OFFSET找到物理地址
r cr3 可以查看顶级页表的值(CR3的值)
!pte vaddr 可以查看地址的翻译过程
!vtop. 能直接将虚拟地址转换为物理地址
双层地址翻译: 虚拟机地址 => (gpt页表)虚拟机物理地址=> (PET页表)真实机器物理地址
EPT(扩展页表技术)
CR3: 指向虚拟机页表(gpt:虚拟机虚拟地址到虚拟机物理地址映射)
EPTP:指向EPT页表(用于将虚拟机物理地址到真实地址映射)
虚拟机线性地址 -> 虚拟机物理地址 -> 真实物理地址
虚拟机线性地址 CR3指向gPT 然后一次寻址 计算出 虚拟机物理地址
虚拟机物理地址通过EPTP指向EPT表 再一次寻址计算出 真实物理地址
可以把EPTP当做另一个CR3 虚拟机物理地址可以当做一个新的虚拟地址 同一个逻辑,两次寻址得出物理地址