Linux操作系统存储器管理系统
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实用标准文案
Linux是一种自由和开放源码的类Unix操作系统。目前存在着许多不同的Linux,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,从手机、平板电脑、路由器和视频游戏控制台,到台式计算机、大型机和超级计算机。Linux 操作系统的诞生1981 年IBM 公司推出享誉全球的微型计算机IBM PC。
Linux实现了基于虚拟页式存储管理的虚拟存储,在i386结构的机器上,每个用户任务的虚拟地址空间都可达到4GB。
Linux的存储管理使用了三层页表来处理逻辑地址到物理地址的转换,分别是PGD(页表目录)、PMD(中间页表目录)和PT(页表)。
Linux将存储管理分为物理内存管理、内核内存管理、虚拟内存管理、内核虚拟内存管理和用户级内存管理。
一存储器管理的目的
(1).为多道程序设计提供支持
(2).提高内存利用率
(3).简化内存的使用,为用户开发应用程序提供支持
多道次序设计的主要目的是提高微处理器的利用律。而为了实现多道程序的并行运行,存储器管理系统必须能够将内存分为多个部分,每部分都装入一道程序,以便多道程序的并行运行。
影响内存利用率的一个重要因素是内存的管理开销。为了便于管理,内存分配有
一个最小单位。小于该单位的内存请求,将按此最小单位分配内存,其多余的未使用空间被称为“碎片”。减少碎片的方法,是缩小该基本单位。从内存精彩文档.
实用标准文案
的分区管理到分段管理再到分页管理和分段分页结合的段页式管理都体现了这一思路。
为了方便用户使用,存储器管理应该提供相应的功能,以支持用户的应用程序开发。比如分段机制可以帮助用户按功能组织代码,共享存储器机制可以方便用户高速通信。
二存储管理
1物理内存管理: 物理内存管理以页为单位,记录、分配和回收物理内存,物理内存管理使用Buddy(伙伴)算法。
(1)空闲物理内存单元的管理
Linux物理内存管理使用Buddy算法实现。其物理页面的信息由
mem_map_t结构描述,系统中的所有物理页面由一个mem_map_t类型的数组mem_map来表示。该数组的每一项都代表物理内存的一个页面,该叔祖的大小由实际的物理内存大小决定。mem_map_t结构的定义参考
linux\linux-2.4.x\include\linux\mm.h.
Linux内核定义了free_area数组记录系统中的当前空闲物理内存单元。每一项都是一个free_area_struct结构,描述了一组由相同大小的空闲物理页块构成的双向链表。
另外,Linux使用全局变量nr_free_pages来跟踪系统中的空闲物理内存
页面的总数,该变量的值等于free_area数组中空闲页的总数。使用该变量,Linux 可以知道系统物理内存的使用状况,当空闲的物理内存页面树立低于某个指标时,Linux将唤醒内核交换守护进程kswapd,让其尽可能回收一些物理内存。
精彩文档.
实用标准文案
(2)物理页的分配
所有物理内存的分配和释放必须针对连续的物理内存。因此,Buddy酸法将内存划分成2的i次方页大小的连续的页块,每一组有相同的i值。并且将同一组的空闲页块链接成一个双向链表然后将所有链表的头节点组成一个数组。
分配空间时,首先要在页块大小相应的空闲页块链中找到一块空间来返回给调用者,如果在这个链里没有找到合适的空间分配,则到free_area数组中的下一个元素的空闲链中去查找,直至找到能够分配的空间。
(3)物理页的释放
内存管理系统,在分配空间时将大页块都划分成了小页块,这使得系统中的页块都越变越小,这对于分配大块内存是不利的。为了避免产生大量的内存碎片,内存管理系统在物理页释放时,应该斤可能地将小页块合并成大页块。
(4)物理内存管理评价
为了内存对齐,Buddy算法往往会分配一些多余的内存空间给用户,这对提供内存利用率是不利的;但是Buddy算法避免了内存碎片的产生,避免了内存紧
抽的开销,效率很高。
2内核内存管理: 内核内存管理主要负责为各种内核数据结构分配空间,其大小一般较小。如果使用以页为单位的物理内存管理则浪费较大,为此Linux
专门提供了使用Slab算法的内核内存管理。
精彩文档.
实用标准文案
3虚拟内存管理: 在物理内存管理的基础上,使用请求调页机制和交换机制,为系统中的每个进程都提供高达4GB(i386平台)的虚拟内存空间。
(1)页表的管理
一个页表入口标识一个物理页,它包含了物理页的大量信息,如该页是否有效、该页的读写权限等。最重要的是页表入口给出了物理页的页框号,根据这个物理页框号就可以找到这个物理页的实际起始物理地址。
为了操作系统的可移植性,Linux使用三级页表来存储虚拟地址转换为物理地址映射关系。一级页表只占用一个页,其中存放了二级页表的入口指针,记为PGD;二级页表中存放了三级页表的入口的指针,记为pmd;在三级页表中每个项都是一个页表入口。在Linux的X86版本中,只使用了两极页表,即第一级和第三级,在Intel系列CPU中,一个物理页面大小是4KB,而每个页表项大小是4字节。因此,每个物理页面可以包含1024个页表项,则在X86平台上,每个进程的地址空间为1024*1024*4KB=4GB大小。
(2)虚拟存储空间的管理
在Linux系统中,主要使用了3个层次的数据结构page、mm_struct和
vm_area_struct来表示进程的虚拟地址空间。最底层的page结构描述了一个物理页桢及其页内消息的相关属性和链接指针,包括标志位、引用技术等。vm_area_struct结构是中间层次,它描述了一个虚拟内存区域(即一段连续的虚拟地址空间)的属性。其中,包括虚拟内存区域的开始、结束地址、访问权限、页目录、映射文件和链接指针。其定义参考
linux\linux-2.4.x\include\linux\mm.h.
精彩文档.
实用标准文案
mm_struct是描述进程虚拟地址空间的最高层的数据结构,一个mm_struct 就代表一个独立进程的虚拟内存空间。该结构中记录了实现任务管理的进程模型所需要的内存管理相关的全部信息,如:
进程的也目录的位置?进程的代码、数据、堆栈、堆、环境变量、入口参数等在虚拟地址空间中?的存储位置
进程占用的物理页桢树木、进程的LDT(局部描述符表)、引用计数?进程的虚拟地址空间的虚拟内存区域链表的链接信息和一些统计信息?(3)虚拟地址空间的创建
进程虚拟地址空间的创建实际上可以分为两个步骤。首先,复制父进程的地址空间;然后,根据可执行映像的要求,创建新的内存地址空间。
虚拟地址空间的复制: 完全复制父进程的地址空间,需要将父进程的内存管理结构、mm_struct、vm_area_struct、页目录表、页表以及对应物理页桢的内容都复制到子进程中。显然,开销太大。