硬件中的分页 :
分页单元把线性地址转换为物理地址。 注:分页异常的产生(访问无效——>访问类型与访问权限)
页的概念:线性地址被分为固定长度为单位的组。
页框是一个存储区域,页是一个数据块。两者的长度一致(一个),每个页框包含一个页。4KB
线性地址的3个域:
1:Directory 最高10位
2:Table 中间10位
3:Offset 最低12位
两级页表 :
两级表的第一级表称为页目录,存储在一个4K字节的页中,页目录表共有1K个表项,每个表项为4个字节,线性地址最高的10位(22-31)用来产生第一级表索引,由该索引得到的表项中的内容定位了二级表中的一个表的地址,即下级页表所在的内存块号。 第二级表称为页表,存储在一个4K字节页中,它包含了1K字节的表项,每个表项包含了一个页的物理地址。二级页表由线性地址的中间10位(12-21)位进行索引,定位页表表项,获得页的物理地址。页物理地址的高20位与线性地址的低12位形成最后的物理地址。
用户空间 :
在Linux中,每个用户进程都可以访问4GB的线性虚拟内存空间。其中从0到3GB的虚存地址是用户空间,用户进程可以直接访问。
内核空间:
从3GB到4GB的虚存地址为内核态空间,存放供内核访问的代码和数据,用户态进程不能访问。所有进程从3GB到4GB的虚拟空间都是一样的,linux以此方式让内核态进程共享代码段和数据段。