zoukankan      html  css  js  c++  java
  • 21、深入理解计算机系统笔记,虚拟存储器,地址翻译

    1、地址翻译,是一个N元素的虚拟地址空间(VAS)中的元素和一个M元素的物理地址空间(PAS)中元素之间的映射。

    2、CPU中的一个控制寄存器,叫做页表基址寄存器(page table base register,PTBR)指向当前页表。N位的虚拟地址包含两个部分:一个p位的VPOvirtual page offset,虚拟页面偏移)和一个n-p位的VPNvirtual page number)。MMU利用VPN来选择适当的PTE。如VPN0选择PTE0。因为物理和虚拟页面都是p字节的,所以PPOphysical page offset物理页面偏移)和VPO是相同的,所以,将页表条目中PPNphysical page number,物理页号)和虚拟地址中的VPO串联起来,就是相应的物理地址。

    wps_clip_image-30079

    3、页面命中完全由硬件处理的,而处理缺页要求硬件和OS内核协作完成。

    wps_clip_image-25690

    wps_clip_image-87

    PTEA:页表条目地址,PTE:页表条目,PA:物理地址。

    4、结合高速缓存和虚拟存储器

        大多数系统是选择物理寻址的方式来访问高速缓存。使用物理寻址,多个进程同时在高速缓存中有存储块和共享来自相同虚拟页面的块成为简单的事情。而且,高速缓存无需处理保护的问题,因为访问权限的检查是地址翻译过程中一部分。

    5、利用TLB加速地址翻译

    MMU中包括一个关于PTE的小的缓存,称为TLBTLB是一个小的,虚拟寻址的缓存,其中每一行都保存着一个由单个PTE组成的块。

    wps_clip_image-26983

    Components of a virtual address that are used to access the TLB.

    wps_clip_image-21268

    wps_clip_image-21413

    6、用来压缩页表的常用方法是使用层次结构的页表。

    wps_clip_image-21657

    7、关于虚拟/物理寻址的一个示例

    wps_clip_image-22390

    wps_clip_image-21666

  • 相关阅读:
    面向对象-类与实例化对象
    面向对象-面向对象与面向过程优缺点
    pyCharn文件模板变量
    安装pycrypto以及报错处理
    文件-读、写、追加已经文件操作
    文件-读取与编码检测
    运算-三元运算
    三方工具-sqlacodegen
    函数-生成器之斐波拉契数列
    python内存-fromkeys
  • 原文地址:https://www.cnblogs.com/mydomain/p/2089357.html
Copyright © 2011-2022 走看看