收藏 分享(赏)

UNIX内核-内存管理机制.doc

上传人:dzzj200808 文档编号:2460538 上传时间:2018-09-17 格式:DOC 页数:3 大小:24KB
下载 相关 举报
UNIX内核-内存管理机制.doc_第1页
第1页 / 共3页
UNIX内核-内存管理机制.doc_第2页
第2页 / 共3页
UNIX内核-内存管理机制.doc_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

1、UNIX 内核内存管理机制内存管理UNIX 内存管理是内核最复杂的任务之一。重要因为它用到许多 CPU 提供的功能,而且和这些功能关系密切。因此,在我们讨论内存管理时,先要讨论 CPU 及其在内存管理中的作用。1.受保护的编址方式CPU 执行的许多指令需要访问内存,看起来很简单,在机器代码指令中指定要提取或修改的内存单元的地址就行了。其实没有这么简单。当需要在内存中同时运行许多进程时,使每个进程都好像在它们自己的机器上运行一样就方便了。做到这一点的办法是在 CPU 内部完成不同形式的地址转换,将指令指定的地址(称为逻辑地址或有效地址)转换为硬件对实际内存的访问。进程按指令、数据和堆栈分成若干段

2、每一段都有段描述符(segment descriptor)。每一段描述符包含 8 个字节。内容包括段开始的基地址、段的容量和段的访问权限。段的描述符集中放在段描述表中。一个 CPU 内部寄存器保存访问段描述符表的基地址。除此之外,CPU 还包含一组段寄存器。每个寄存器指向描述表中的一个段描述符项。如果发生了任何类型的内存访问,将选择一个 CPU 段寄存器(或者由访问内存的类型的隐含说明,或者由访问内存的指令的明确说明)用来进行地址计算。计算的结果得到线性地址。这里说得是每一次的内存访问,CPU 都用一个内部寄存器的内容找到描述表的基地址。基地址和一个段寄存器的内容(它的最低 3 位的值为 0)

3、相加。相加的结果是指向描述符表的一个 8 字节的项的指针。注意:段的描述府项包含段在内存中的基地址,段的容量和对本段的访问权限。访问内存的指令本身也提供一个地址,这个地址是已取得段描述符的内存段内部的逻辑地址(或有效地址)。指令的逻辑地址和段的基地址相加得到线性地址。必须对线性地址进行检查,保证它落在段的范围内(不超过段的容量),并检查是否允许在段内进行请求的访问类型(读、写或执行)。如果这些检查被通过,CPU 现在有了用来访问内存的地址。我们已经看到的段描述符主表称为全程段描述表或者 GDT,而指向 GDT 起点的 CPU 寄存器称为 GDTR.在多任务环境中,可能愿意每个进程访问它自己的内

4、存段。为满足这一要求,CPU 也为每个进程提供另外一个描述符表,称为局部描述符表或者 LDT,它通过 GDT 的项和处理机内部寄存器 LDTR进行访问。如果每次内存访问都要查找描述符表(它本身又在内存中)的值,这将消耗大量的 CPU 时间。为了大大加速这一过程,CPU 内部有一些隐藏的,不能由程序直接访问的寄存器。这些寄存器用作快速缓存,保存当前每个段寄存器所指的段描述符的值。只有有关的段寄存器的值改变时,或者描述符表的 GDTR 或 LDTR 的基地址改变时,才用相应的段描述符值加载隐藏的寄存器。2.分页技术在前面讨论的组织内存访问的功能的基础上,可以建立起一个完全切实可行的多任务系统。只要

5、在开始运行时每个进程知道它实际需要的内存容量,一开始就可以为这一进程在合适的位置分配它所需的内存块。在进程存在期间也不用再改变内存的分配。然而,有些 UNIX 版本要比上面的简单模型更为灵活。例如,它允许进程不必考虑周围实际上还有其他的 进程存在的现实而增加它的内存要求。有的 UNIX 系统还允许同时运行比实际内存所能容纳的更多的进程。之所以能这样做,因为利用了处理机提供的分页(paging)功能。在 CPU 中是否进行调页由处理机控制寄存器中的 1 位来进行控制。如果调页位设置,32 位的线性地址将一分为二。高 20 位用作页号,而低 12 位用作页内的位移地址。这表示 32 位的线性地址可

6、以用来访问 100 万 4KB 页。分页所做的主要工作之一是将线性地址中提供的20 位页号转换位对应于机器实际 4KB 内存页的另一个 20 位页号。结果是,任何实际 4KB 内存页可以出现在处理机线性地址空间的 100 万 4KB 页边界内的任何位置。地址变换用内存中的对照表完成,其中线性地址的高 20位用作大的 32 位元素的数组的索引。从数组取得的 32 位值提供所需的20 位转换值,其余 12 位则用来指定类似下面的一些事项: 本页允许读、写还是只允许读访问? 本页是用户进程访问页,还是管理进程访问页? 是否对任何页内地址进行了读或写访问? 是否对任何页内地址进行了写操作? 本页在内存

7、中还是在磁盘上? 用两级页表取代单个大的页表可以不必用很大的连续线性地址空间来保存页表,两级页表将线性地址空间的高 20 位划分为两个独立的 10 位值。CPU 的 3 号控制寄存器包含内存中用作第一级页目录表的 4KB 的地址。每一 4KB 页分成 1024 项,每项占 32 位。线性地址中页号的前 10 位正好用来选择页表中的项。这样选出的 32 位包含 20 位实际页号,以及前面讨论过的 12 位。段的增长当你希望从包围在中间的内存段(segment)中提高内存容量时,分页技术显得特别重要。交换分页的另一个主要用途称为交换(swapping)。交换概念的实质在于允许在系统中同时运行比内存

8、实际能容纳的更多的进程。这包括另外设置交换区(通常在磁盘上)作为内存的溢出区。当需要启动一个新的进程而内存中由没有足够的空间允许这样做时,将调用交换程序,它将选择内存中的一个或者几个新进程将它们写到交换区中,留出内存空间供新的进程装入和运行。当进程运行一段时间后,一些进程因等待输入/输出而挂起。另一些进程将结束,这就给交换出去的进程调回内存的机会(也可能将其他进程交换出去作为代价,使它们能继续执行下去。利用分页技术实现了交换功能,表示不需要将整个进程交换到磁盘上,只要留出足够的页面供新的进程运行就行了。事实上,还有一种称为按需调页技术(demand paging)。为了实现按需调页技术,页表中

9、的描述符项需要提供说明本页的内容是否实际装入内存的信息。由了这一信息,当 CPU试图访问的页不在内存时,将产生异常信息(或称页面故障)。这一异常信息将导致执行异常处理程序,它将所需的页面装入实际内存。导致页面故障的指令将再次被执行,这一次它的内存访问将是成功的。利用分页技术将新的进程装入内存是好的设想。出现的情况是当运行的进程试图在没有装入内存的地址上执行指令时,将出现页面故障,对它进行处理后,进程又可以继续执行下去。对执行中的程序进行的研究发现:对一个适度大小的程序来讲,在任何特定的允许时刻,大部分代码并未得到执行。使用按需调页技术,它的含义在于当进程所需的页面调入之后,它将以少量的页面故障稳定允许一段时间,虽然它的大多数页面完全没有装入内存。即使特定的程序在运行时访问所有的程序页,但在任何时刻,在一段时间内进程只用其中少量的页面,所以,从资源利用的角度看,分页技术能取得很大的效益。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 高等教育 > 大学课件

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报