zoukankan      html  css  js  c++  java
  • 线性地址转物理地址

    为了节约页表占用的内存空间,x86将线性地址通过页目录表页表两级查找转换成物理地址

    32位的线性地址被分成3个部分:最高10位 Directory 页目录表偏移量,中间10位 Table是页表偏移量,最低12位Offset是物理页内的字节偏移量

    页目录表的大小为4KB(刚好是一个页的大小),包含1024项,每个项4字节(32位),表项里存储的内容就是页表的物理地址(因为物理页地址4k字节对齐,物理地址低12位总是0,所以表项里的最低12字节记录了一些其他信息,这里做简化分析)。如果页目录表中的页表尚未分配,则物理地址填0。

    页表的大小也是4k,同样包含1024项,每个项4字节,内容为最终物理页的物理内存起始地址。

    实例:mov    0x80495b0, %eax  中的地址为例分析一下线性地址转物理地址的过程。
    明确一点,Linux中逻辑地址等于线性地址,那么我们要转换的线性地址就是0x80495b0。转换的过程是由CPU自动完成的,Linux所要做的就是准备好转换所需的页目录表和页表(假设已经准备好)

    1)内核先将当前任务的页目录表的物理地址填入cr3寄存器
    2)线性地址 0x80495b0 转换成二进制后是 0000 1000 0000 0100 1001 0101 1011 0000

        最高10位0000 1000 00的十进制是32,CPU查看页目录表第32项,里面存放的是页表的物理地址。

        线性地址中间10位00 0100 1001 的十进制是73,页表的第73项存储的是最终物理页的物理起始地址。

        物理页基地址加上线性地址中最低12位的偏移量,CPU就找到了线性地址最终对应的物理内存单元。

  • 相关阅读:
    c++ bitset 操作
    c++ vector 使用方法
    功夫熊猫
    [转]PSP机能强大!已能模拟运行WINDOWS系统?
    刚刚发现的Picasa Web已经支持多种格式了。
    刚发现个BUG管理的小软件 BugTracker.NET
    [转]基于WEB的操作系统
    26岁生日了
    中华香烟真假辨别
    [转]软件史上最伟大的十大程序员
  • 原文地址:https://www.cnblogs.com/X-W-LIU/p/3455745.html
Copyright © 2011-2022 走看看