操作系统内存管理.ppt_第1页
操作系统内存管理.ppt_第2页
操作系统内存管理.ppt_第3页
操作系统内存管理.ppt_第4页
操作系统内存管理.ppt_第5页
已阅读5页,还剩90页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

内容提要,存储器的层次结构 程序执行的基础知识、程序的装入和链接 连续分配存储管理方式 分页存储管理方式 分段存储管理 段页式存储管理,存储器的层次结构,存储器是计算机系统的重要组成部分 容量、价格和速度之间的矛盾 内存、外存;易失性和永久性 内存,是稀缺资源 在现代计算机系统中,存储通常采用层次结构来组织 多级存储器结构 主存与寄存器 高速缓存和磁盘缓存,多级存储器结构,Storage systems in a computer system can be organized in a hierarchy Speed, access time Cost per bit Volatility,主存 vs. 寄存器,Same: Access directly for CPU Register name Memory address Different: access speed Register, one cycle of the CPU clock Memory, Many cycles (2 or more) Disadvantage: CPU needs to stall frequently & this is intolerable Remedy Cache,高级缓冲技术caching,Caching Copying information into faster storage system When accessing, first check in the cache, if In: use it directly Not in: get from upper storage system, and leave a copy in the cache Using of caching Registers provide a high-speed cache for main memory Instruction cache & data cache Main memory can be viewed as a fast cache for secondary storage ,Magnetic disks 磁盘,Transfer time 传输时间 TT data size * Transfer rate Transfer rate (n M/s)-1 ( n Byte/us )-1 1/n us/Byte Positioning time 定位时间 Seek time 寻道 Ts Rotational latency 旋转延迟 TR TP Ts +TR m ms TT VS. TP Please Store data closely,内容提要,存储器的层次结构 程序执行的基础知识、程序的装入和链接 连续分配存储管理方式 分页存储管理方式 分段存储管理 段页式存储管理,程序执行的基础知识,Von Neumann architecture 冯诺依曼体系结构 Program must be brought into memory Main memory is usually too small Process Program must be placed within a process for it to be executed 作业池 User programs Where to place the program several steps(图),地址的类型,Absolute address 绝对地址 Address seen by the memory unit Physical address 物理地址 Logical address 逻辑地址 Generated by the CPU Virtual address 虚拟地址 When can the absolute address can be decided?,Address binding 地址的绑定,Address binding 地址绑定, the binding of instructions and data to memory, 可以在三种时刻进行 Compile time If memory location known a priori, absolute code can be generated; must recompile code if starting location changes. Load time Must generate relocatable code if memory location is not known at compile time. Execution time Binding delayed until run time if the process can be moved during its execution from one memory segment to another. Need hardware support for address maps (e.g., base and limit registers),Memory-Management Unit (MMU),Hardware device, 逻辑地址 物理地址 Relocation register 重定位寄存器 Added to every address generated by a user process at the time it is sent to memory E.g. MS-DOS on 80x86 User program deals with logical addresses, it NEVER sees the real physical addresses.,是否需要将进程的所有代码和数据一次性装入?,Shall we put the entire program & data of a process in physical memory before the process can be executed? For better memory space utilization Dynamic loading Dynamic linking Overlays Swapping ,程序的装入,绝对装入方式 可重定位装入方式 动态运行时装入方式,绝对装入方式,编译时,产生absolute code,即使用绝对地址的代码 装入时,必须装入到指定的地址 无需对程序和数据的地址进行修改 适用于单道系统,可重定位装入方式,大多数情况下,不能预知装入地址,只能在装入时确定 编译时,产生可重定位代码,即使用相对地址的代码 装入时,必须重定位 通常把在装入时对目标程序中指令和数据的修改过程称为重定位。 由于地址变换是在装入时一次性完成的,以后不再改变,故称为静态重定位 可用于多道系统,动态运行时重定位,有时候,程序会在内存中移动位置 例如对换 需要能支持在运行过程中动态改变程序在内存中的位置 方法:推迟重定位时机 即从相对地址到绝对地址的转换推迟到程序真正执行时才进行 因此,装入内存中的代码和数据的地址仍然是相对地址 需要重定位寄存器的支持,动态运行时装入方式,根据程序运行的局部性,让程序及其数据在需要时才被装入 Better memory-space utilization; unused routine is never loaded. Useful when large amounts of code are needed to handle infrequently occurring cases Error routine No special support from OS is required implemented through program design Due to the users,程序的链接,多个源程序编译多个目标模块;库。 需要链接成可装入模块 根据链接时间的不同 静态链接方式:装入前很早就链接 装入时动态链接:边装入,边链接 运行时动态链接:运行时才链接,静态链接方式,静态链接方式: 在程序运行之前,先将各目标模块以及它们所需要的库函数,链接成一个完整的装配模块,以后不再拆开。 各目标模块内:相对地址 存在目标模块之间的调用关系 外部调用符号 要解决的问题: 修改相对地址: 多个相对地址空间一个统一的相对地址空间 变换外部调用符号,装入时动态链接,在装入时,根据外部模块调用事件,使用装入程序去寻找相应的外部目标模块,并装入,在装入时,修改相对地址 优点: 便于修改和更新 便于实现对目标模块的共享,运行时动态链接,程序的每次运行,可能要执行的目标模块集是不同的 全部装入?按需装入? 运行时动态链接将对某些模块的链接推迟到程序执行时才进行 需要操作系统配合 优点:程序运行前的装入速度加快;省空间,作业:,从一个源程序到一个在内存中可执行的程序,一般需要哪几个步骤? 有哪几种地址类型? 有哪几种程序装入方式和链接方式?,内容提要,存储器的层次结构 程序执行的基础知识、程序的装入和链接 连续分配存储管理方式 分页存储管理方式 分段存储管理 段页式存储管理,连续内存分配方式(contiguous memory allocation),连续分配存储管理方式 单一连续 固定分区 动态分区 对换,内存通常被划分为两个分区(partitions): 系统区:常驻操作系统,通常位于内存低端 用户区:提供给用户(进程)使用,常位于内存高端 连续内存分配是指: 从用户区中为每个进程分配一个单独的、连续的内存空间。 主要有以下两种方式 单一连续分配方式 多分区式分配方式 固定分区式 动态分区式(可变分区式),单一连续分配方式,最简单 只能用于单用户、单任务系统,存储保护机制 存储管理单元,MMU 或者不采用任何存储保护机制 出于信任,或采用再启动方式,,多分区式分配方式,支持多道程序, 用户区被进一步划分为若干个分区 每一个分区装载一个进程 多道程序度与分区的个数有关 根据分区大小是固定的还是可变的 固定分区方式 大小固定;等大小 or 不等大小 动态分区方式(可变分区方式) 动态&可变:内存的划分是动态的,分区的大小随进程的大小确定,分区的数目随系统的运行而不断变化,固定分区分配方式,支持多道程序,用于60年代IBM360的MFT中 分区的划分方法,两种 等大小 不等大小 但分区的大小一旦确定就不再发生变化 分配算法: 按大小顺序建立分区使用表,0,30K,45K,75K,125K,225K,固定分区使用表,分配算法,缺点 内存利用率低 定义:内部碎片和外部碎片 内部碎片:已经分配出去但得不到利用的存储区域 外部碎片:不能被利用的小分区 解决方案:动态分区,动态分区分配方式,能根据进程实际需要的内存大小,动态分配 能减少内部碎片 关键 数据结构:记录内存的使用情况,特别是空闲内存 分配算法 分配和回收操作,数据结构,空闲分区表,占用额外的空间 空闲分区链,利用空闲分区,分区分配算法,在将一个新作业装入内存时,要从空闲分区表或空闲分区链中,选出一个分区分配给该作业,有三种常见的分配算法 首次适应算法FF:First Fit 循环首次适应算法 最佳适应算法:Best Fit=smallest 最差适应算法:Worst Fist largest,思考,在一个系统中内存有如下的空闲区,10KB,4KB,20KB,18KB,7KB,9KB,12KB,以及15KB。在分别使用首次适应,最佳适应,最差适应以及循环首次适应算法,对下列3个连续空间分配,得到的空闲分区分别是什么? 12KB 10KB 9KB,分区分配操作,分配 设请求的分区大小为u.size; 利用某种分配算法,找到待分配的分区,大小为m.size 根据上述分区分配算法,有m.sizeu.size 判断m.size-u.size与min_size的大小 min_size为事先约定的最小分区大小 ,分割,分割出来的分配出去,余下的加入空闲数据结构 否则,直接分配 将分配到的分区的首地址返回 可以看出,动态分区分配方式中内部碎片最大不超过min_size,回收,要考虑合并 向前合并 只需修改前一个空闲分区表项中的大小 向后合并(图) 只需修改后一个空闲分区表项中的起始地址和大小 与前后同时合并 修改前一个空闲分区表项中的大小,并取消后一个分区表项 无相邻空闲分区,无需合并 建立一个新的表项,填写相关信息,插入 上述过程中,根据链表的维护规则,可能需要调整相应表项在空闲链表中的位置,动态分区分配分析,随着分配的进行,空闲分区可能分散在内存的各处 尽管有回收,但内存仍然被划分的越来越碎,形成大量的外部碎片,解决方案之一:紧凑Compaction,针对外部碎片:采用紧凑的方法 紧凑:通过移动进程在内存中的位置,把多个分散的小分区拼成大分区 需要动态重定位技术支持,动态重定位分区分配算法: 引入紧凑和动态重定位技术的动态分区分配算法 基本与动态分区分配算法相同,思考,紧凑的时间开销:若计算机读一个32位的时间是10ns,那么紧凑128MB的空间需要多长时间?,Swapping 对换,最早用于MIT的CTSS中 单用户时间片对换 对换是指 把内存中暂时不能运行的进程,或暂时不用的程序和数据,换出到外存上,以腾出足够的内存空间,把已具备运行条件的进程,或进程所需要的程序和数据,换入内存 能提高内存利用率 对换的单位: 进程:整体对换;进程对换 页、段:部分对换,对换技术需要实现三个方面的功能 对换空间的管理 进程的换出 进程的换入,Backing store,对换空间,Fast disk, large enough to accommodate copies of all memory images for all users; must provide direct access to these memory images. 为提高速度,考虑连续分配方式,忽略碎片问题 需提供数据结构对空闲盘块进行管理 方法类似动态分区分配方法,进程的换出,第一步:选择被换出的进程 Some approaches RR scheduling: swapped out when a quantum expires Priority-based scheduling: Roll out, roll in Lower-priority process is swapped out so higher-priority process can be loaded and executed. 第二步:换出 确定要换出的内容 非共享的程序和数据段的换出 共享的程序和数据段的换出:计数器 申请对换空间,换出,并修改相关数据结构,进程的换入,第一步:选择被换入的进程 考虑“静止就绪状态”的进程 其他原则 第二部:申请内存并换入 申请成功 申请失败:利用对换技术腾出内存,Schematic View of Swapping,Swapping (cont.),Context switch Swapped in & out cost too much Assume: process size 1MB, disk transfer rate 5MB/sec, average latency 8ms Transfer time =1MB / (5MB/sec) = 1/5 sec = 200 ms Swap time = 208 ms Swap out & in = 416 Major part of swap time is transfer time For RR scheduling, time quantum should 416ms Problems exist for pending I/O processes swapping,内容提要,存储器的层次结构 程序执行的基础知识、程序的装入和链接 连续分配存储管理方式 离散分配方式(Discrete Memory Allocation) 分页存储管理方式 碎片页 分段存储管理 从逻辑上进行分段 段页式存储管理,内容提要,存储器的层次结构 程序执行的基础知识、程序的装入和链接 连续分配存储管理方式 离散分配方式(Discrete Memory Allocation) 分页存储管理方式 碎片页 分段存储管理 从逻辑上进行分段 段页式存储管理,分页存储管理方式,1)将一个进程的地址空间分成若干个大小相等的片,称为页面或页(pages) 2)内存空间也分成与页大小相同的若干个存储块,称为物理页或页框(page frames) 序号: 0,1,n 大小:取2的幂, 5128192B,地址结构 页内偏移:相对于页(页框)的起始地址的相对地址 页(页框)号S 对于32位地址长度 若页(页框)的大小为4KB,则需要使用低端12位表示页内偏移 剩余的高端20位可以表示220个页(页框),1M个,页(页框)号p,页(页框)内偏移d,0,11,12,31,计算页(页框)号和页(页框)内偏移的方法: 地址:A 页(页框)大小:L 页(页框)号p A 整除 L 页(页框)内偏移d A mod L 考虑L是2的幂,不妨设为2N,则 p A 右移N位,即取A的高(32N)位 dA的低端N位,必须在进程的逻辑地址空间和内存的物理地址空间之间建立一个映射关系 使用页表 每个进程都拥有各自的页面映射表,即页表 按序号,进程地址空间中的每个页在页表中都有一个页表项表示 页表项中记录的对应的物理页框的序号 可以实现从页号到页框号的映射,页表示意图,页表的例子,Page size = 4B Physical memory = 32B 8 frames Logical memory = 16B 4 pages Logical address 9 = 2*4+1 p=2, d=1 Page 2 is stored in frame 1 Physical address = 1*4+1 = 5,思考,下列10进制虚拟地址,分别计算页面大小为4KB和8KB时的页号和页内偏移 20000 32768 60000,思考,根据左图,计算出以下虚拟地址对应的物理地址 20 4100 8300,地址变换机构,使用专门的(软)硬件 将用户地址空间中的逻辑地址转换为内存空间中的物理地址 基本的地址变换机构 具有快表的地址变换机构,基本的地址变换机构,Page table is kept in main memory, & Page-Table Base Register (PTBR) Points to the page table currently used Page-table length register (PRLR) Indicates size of the page table Context switch,3,b,Effective memory-access time, time needed for every data/instruction access 需要2次访存 Access the page table & Access the data/instruction Solution: A special fast-lookup hardware cache called associative registers or translation look-aside buffers (TLBs),联想存储器,快表,Associative registers Each register : a key & a value Parallel search (high speed) Expensive, typically 82048 entries Address translation (A, A) If A is in associative register, get frame # out. Otherwise get frame # from page table in memory,联想存储器,快表,TLB miss(TLB缺失) If the page number is not in the associative registers Get & store Hit ratio(命中率) The percentage of times that a page number is found in the associative registers Context switch TLB flushed TLB replacement algorithm,具有块表的地址变换机构,Effective Access Time 有效存取时间,设: Associative Lookup = time unit; memory cycle time = t time unit; Hit ratio = Effective Access Time (EAT) EAT = (t + ) + (2t + )(1 ) = 2t + t If (20 ns), t(100 ns), 1(80%), 2(98%): TLB hit: 20+100=120 ns TLB miss: 20+100+100=220 ns EAT1 = 120*0.8 + 220 * 0.2 = 140 ns EAT2 = 120*0.98 + 220 * 0.02 = 122 ns,思考,从页表中读取数据的时间开销是5ns,从块表中读取数据的开销则是1ns,为使平均开销降为1ns,则块表的命中率至少为多少?,Memory Protection 内存保护,If page size 2n, page & frame is aligned at 2n, so Memory protection implemented by associating protection bit with each frame Provide read only, read-write, execute-only protection or Valid-invalid “valid”: the associated page is in the process logical address space, and is thus a legal page. “invalid”: the page is not in the process logical address space.,Valid/invalid bit example,Address space 214 Page size 2KB Process size (010468) Page 5 has internal fragmentation PTLR=6 Page 6 & 7 are invalid,10486,10240,12287,两级和多级页表,考虑: 地址空间:32位;页大小4KB;有220即1M个页 需要页表项:1M个 假设,每个页表项使用32位表示,需要4MB的空间 解决方案: 进一步离散,两级页表,对页表分页,建立外层页表(页目录) 则上述4MB的页表,进一步分为1K个页 需要1K个页目录项 假设每个页目录项使用32位表示,需要4KB 因此,逻辑地址 where p1 is an index into the outer page table, and p2 is the displacement within the page of the outer page table.,两级页表举例,具有两级页表的地址变换机构,多级页表及其性能,Level number = L, effect memory accesses time = (L+1)t 考虑高速缓存技术: Cache hit rate of 98 percent yields: effective access time = 0.98 120 + 0.02 520 = 128 nanoseconds. which is only a 28 percent slowdown in memory access time.,内容提要,存储器的层次结构 程序执行的基础知识、程序的装入和链接 连续分配存储管理方式 离散分配方式(Discrete Memory Allocation) 分页存储管理方式 碎片页 分段存储管理 从逻辑上进行分段 段页式存储管理,分段存储管理方式,引入分段的目的,是为了满足用户在编程和使用上的需求(逻辑上) 在用户看来: A program is a collection of segments. A segment is a logical unit such as: main program, procedure, function, method, Object,local variables, global variables, common block, stack, symbol table,逻辑地址空间,A collection of segments each segment Two dimensional address space A logical address Compiler automatically constructs segments reflecting the input program. Pascal compiler FORTRAN compiler C compiler, such as gcc, ,Logical view of segmentation,分段的硬件支持,段表 2-D logical address 1-D physical addresses; 每个段表项包括 段在内存中的基地址 段的长度 Segment-table base register (STBR) Points to the segment tables location in memory. Segment-table length register (STLR) Indicates number of segments used by

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论