目录
引言
本文基于X86系统,简单了讲述了从Linux中在系统开启分页之后将虚拟地址转为物理地址的过程以及具体代码,不包含分页概念。内核版本基于4.19,内核开始支持5级分页,相对于4级分页,多了P4D目录项,但目前系统中并未使用,如有错误,欢迎指正。
虚拟地址
cpu从实模式进入保护模式后,系统开始支持分页,Intel的cpu还支持分段,但Linux通过将所有段基址都置为0,巧妙了跳过了分段机制,使得线性地址等于逻辑地址。
在开启分页之后,每个进程运行的地址不再是实模式中的绝对地址,而是虚拟地址。程序编译时都从地址0开始编译,在载入时系统在寻找未分配的内存页面进行进行分配。使得程序员可以不考虑程序在内存的实际位置,但我们若想获取变量在内存中实际地址怎么做?那就需要我们简单了解下Linux对于页面是进行如何划分的。
页面划分
图1 页面划分
如图1,是Linux对于64位cpu地址的页面划分的情况,64位cpu中的地址总线位数只有48位,高位实际上未使用;
对于给出的虚拟地址,其对应位数含义如下。记