博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

2017-2018-1 20155217 《信息安全系统设计基础》第十一周学习总结

教材学习内容总结

第九章 虚拟存储器

  • 虚拟存储器3个重要的能力:
(1)将主存看作是一个存储在磁盘上的地址空间的高速缓存,在主存中只保护活动的区域,并根据需要在磁盘和主存之间来回传送数据
(2)为每个进程提供了一致的地址空间,从而简化了存储器管理
(3)保护了每个进程的地址空间不被其它进程破坏。

9.1 物理和虚拟寻址

  • 物理地址PA:计算机系统的主存被组织成一个由M个连续的字节大小的单元组成的数组,每字节都有一个唯一的物理地址PA。根据物理地址寻址的是物理寻址。

  • 地址翻译:使用虚拟寻址时,CPU通过生成一个虚拟地址VA来访问主存,这个虚拟地址在被送到存储器之前先转换成适当的物理地址,相关硬件为存储器管理单元MMU

9.2 地址空间

  • 线性地址空间:地址空间中的整数是连续的。

  • 虚拟地址空间:CPU从一个有N=2^n个地址的地址空间中生成虚拟地址,这个地址空间成为称为虚拟地址空间。

  • 地址空间的大小:由表示最大地址所需要的位数来描述。

  • 物理地址空间:与系统中的物理存储器的M个字节相对应。

  • 虚拟存储器的基本思想:主存中的每个字节都有一个选自虚拟地址空间的虚拟地址和一个选自物理地址空间的物理地址。

9.3 虚拟存储器作为缓存的工具

  • 任意时刻,虚拟页面的集合都被分为三个不相交的子集:
未分配的:VM系统还没分配/创建的页,不占用任何磁盘空间。 
缓存的:当前缓存在物理存储器中的已分配页
未缓存的:没有缓存在物理存储器中的已分配页
  • 虚拟存储器——虚拟页VP,每个虚拟页大小为P=2^平字节。物理存储器——物理页PP,也叫页帧,大小也为P字节
DRAM缓存的组织结构
  • 不命中处罚很大
  • 是全相联的——任何虚拟页都可以放在任何的物理页中。
  • 替换算法精密
  • 总是使用写回而不是直写。
9.3.4 缺页
  • DRA缓存不命中称为缺页。在不命中发生时,换入页面的策略称为按需页面调度。

9.4 虚拟存储器作为存储器管理工具

  • 按需页面调度和独立的虚拟地址空间的结合简化了链接和加载、代码和数据共享,以及应用程序的存储器分配。
简化链接:独立的地址空间允许每个进程的存储器映像使用相同的基本格式,而不管代码和数据实际存放在物理存储器的何处。 
简化加载:虚拟存储器使得容易想存储器中加载可执行文件和共享文件对象。 
简化共享:独立地址空间为操作系统提供了一个管理用户进程和操作系统自身之间共享的一致机制。 
简化存储器分配:虚拟存储器为向用户进程提供一个简单的分配额外存储器的机制。

9.5 虚拟存储器作为存储器保护的工具

  • PTE的三个许可位:
SUP:表示进程是否必须运行在内核模式下才能访问该页 
READ:读权限 
WRITE:写权限

9.6 地址翻译

  • 地址翻译:一个N元素的虚拟地址空间(VAS)中的元素和一个M元素的物理地址空间(PAS)之间的映射。
MAP:VAS→PAS∪空 MAP(A)='A':如果虚拟地址A处的数据在PAS的物理地址A处' 
空:如果虚拟地址A处的数据不在物理存储器中
  • CPU中的一个控制寄存器页表基址寄存器指向当前页表,n位的虚拟地址包含两个部分:
一个p位的虚拟页面偏移(VPO) 和一个(n-p)位的虚拟页号,页表条目中的物理页页号和虚拟地址中的VPO串联起来,就得到了相应的物理地址。

9.7 案例研究

9.7.1 core i7地址翻译

  • PTE的三个权限位:
R/W位:确定内容是读写还是只读 
U/S位:确定是否能在用户模式访问该页 
XD位:禁止执行位,64位系统中引入,可以用来禁止从某些存储器页取指令
  • 缺页处理程序涉及到的位:
A位,引用位,实现页替换算法 
D位,脏位,告诉是否必须写回牺牲页

9.7.2 LINUX 虚拟存储器系统

  • linux将虚拟存储器组织成一些区域(也叫做段)的集合。一个区域就是已经存在的(已分配的)虚拟存储器的连续片;

  • 允许虚拟地址空间有间隙;内核不用记录那些不存在的页,这样的页也不用占用存储器;

区域结构:

vm _start:指向这个区域的起始处;
vm _end:指向这个区域的结束处;
vm _prot:描述这个区域内所包含的所有页的读写许可权限; 
vm _fags:描述这个区域内的页面是与其他进程共享的,还是这个进程私有的,等等;
vm _next:指向链表的下一个结构. 

9.8 存储器映射

  • Linux通过将一个虚拟存储器区域与一个磁盘上的对象关联起来,以初始化这个虚拟存储器区域的内容的过程。

9.8.1 共享对象

  • 共享对象对于所有把它映射到自己的虚拟存储器进程来说都是可见的。
    即使映射到多个共享区域,物理存储器中也只需要存放共享对象的一个拷贝。

  • 私有对象

私有对象运用的技术:写时拷贝 
在物理存储器中只保存有私有对象的一份拷贝

9.8.2 fork函数

  • 当fork函数被当前进程调用时,内核为新进程创建各种数据结构,并分配给它一个唯一的PID。为了给这个新进程创建虚拟存储器,它创建了当前进程的mm_struct、区域结构和页表的原样拷贝。它将两个进程中的每个页面都为标记只读,并将两个进程中的每个区域结构都标记为私有的写时拷贝。

  • 当fork在新进程中返回时,新进程现在的虚拟存储器刚好和调用fork时存在的虚拟存储器相同。当这两个进程中的任一个后来进行写操作时,写时拷贝机制就会创建新页面,因此,也就为每个进程保持了私有地址空间的抽象概念。

9.8.3 execve函数

  • 使用execve函数将a.out程序加载到存储器的过程
    Execve("a.out",NULL,NULL);
  • 加载并运行所需要的步骤如下:
(1)删除已存在的用户区域。 
(2)映射私有区域。 
(3)映射共享区域。 
(4)设置程序计数器。

9.8.4使用map函数的用户级存储器映射

  • Unix进程可以使用mmap函数来创建新的虚拟存储器区域,并将对象映射到这些区域当中void *mmap(void *start,size_t length,int prot,int flags,int fd,off_t offest);若成功则为指向映射区域的指针,若出错则为MAP_FAILDE(-1)
  • munmap函数删除虚拟存储器的区域。int munmap(void *start,size_t length);若成功则返回0,若失败则返回-1.

9.9 动态存储器分配

  • 当运行时需要额外虚拟存储器时,使用动态存储器分配器维护一个进程的虚拟存储器区域。

  • 分配器有两种风格。

显示分配器:要求应用显式地释放任何已经分配的块。 
隐式分配器:要求分配器检测一个已分配块何时不再被程序所使用,就释放这个块。也叫做垃圾收集器。

9.9.1 malloc和free函数

  • 系统调用malloc函数,从堆中分配块:
#include <stdlib.h>
void *malloc(size_t size);
  • 成功返回指针,指向大小至少为size字节的存储器块,失败返回NULL
  • 系统调用free函数来释放已分配的堆块:
#include <stdlib.h>
void free(void *ptr);
  • 无返回值,ptr参数必须指向一个从malloc、calloc或者reallov获得的已分配块的起始位置。
  • 使用动态存储器分配原因:经常直到程序实际运行时,才知道某些数据结构的大小。

9.9.6 隐式空闲链表

  • 堆块的格式:由一个字的头部,有效荷载,和可能的额外填充组成。
  • 将堆组织成一个连续的已分配块和空闲块的序列:
空闲块通过头部中的大小字段隐含地连接着,分配器可以通过遍历堆中所有的块,从而间接地遍历整个空闲块的集合。
  • 需要:特殊标记的结束块。
  • 系统对齐要求和分配器对块格式的选择会对分配器上的最小块大小有强制的要求。

9.9.7 放置已分配的块

  • 分配方式有:
(1)首次适配:从头开始搜索空闲链表,选择第一个合适的空闲块 
(2)下一次适配:从上一次搜索的结束位置开始搜索 
(3)最佳适配:检索每个空闲块,选择适合所需请求大小的最小空闲块

教材学习中的问题和解决过程

  • 问题1:

    程序员需要理解虚拟存储器的原因是什么?

  • 问题1解决方案:

(1)虚拟存储器是中心的:它是硬件异常、硬件地址翻译、主存、磁盘文件和内核软件的交互中心
(2)虚拟存储器是强大的:它可以创建和销毁存储器片、可以映射存储器片映射到磁盘某个部分等 
(3)虚拟存储器若操作不当则十分危险
  • 问题2:

    DRAM缓存的组织结构总是使用写回而不是直写的原因?

  • 问题2解决方案:

    直写式缓存方式是当CPU要将数据写入内存时,除了更新缓冲内存上的数据外也将数据写在 DRAM 中,以维持主存与缓冲内存的一致性 当要写入内存的数据一多,速度自然就慢了下来。回写式的缓存方式是每当 CPU 要将数据写入内存时,只会先更新缓冲内存上的数据,随后再让缓冲内存在总线不塞车的时候才把数据写回 DRAM,所以速度自然快得多。

  • ...

  • 问题3:

    两层页表层次结构的好处是什么?

  • 问题3解决方案:

    1. 如果一级页表中的一个PTE是空的,那么相应的二级页表就根本不会存在
    2. 只有一级页表才需要总是在主存中,虚拟存储器系统可以在需要时创建、页面调入或调出二级页表,只有最经常使用的二级页表才缓存在主存中。

结对及互评

点评模板:

  • 博客中值得学习的或问题:
    • xxx
    • xxx
    • ...
  • 代码中值得学习的或问题:
    • xxx
    • xxx
    • ...
  • 其他

本周结对学习情况

- [20155236](http://www.cnblogs.com/fcgfcgfcg/p/7966694.html)
- 结对照片
- 结对学习内容
    1、页表:是一个数据结构,存放在物理存储器中,将虚拟页映射到物理页,就是一个页表条目的数组。
    页表就是一个页表条目PTE的数组。

    PTE:由一个有效位和一个n位地址字段组成的,表明了该虚拟页是否被缓存在DRAM中。 页表的组成:有效位+n位地址字段

    2、如果设置了有效位:
  
    地址字段表示DRAM中相应的物理页的起始位置,这个物理页中缓存了该虚拟页。

    如果没有设置有效位:

    空地址:表示该虚拟页未被分配 
    不是空地址:这个地址指向该虚拟页在磁盘上的起始位置。

其他(感悟、思考等,可选)

本章对虚拟存储器的讲解让我们把之前学习过的内容,比如进程、堆栈等知识都串联起来了,会有一种“原来如此”的感觉,觉得豁然开朗。