2019备考[嵌入式系统设计师]之“存储管理篇”

通过分析历年考题发现,在存储管理方面的题目蛮多的,应该是一个重要考点。无论是概念、理论、分析和计算都相当容易出题。这里就先拿这个点说说吧,其他的以后有时间再写了。

1、存储器系统的层次架构

  • 计算机系统的存储器被组织成一个金字塔的层次结构。自上而下为:CPU内部寄存器、芯片内部高速缓存(cache)、芯片外部高速缓存(SRAM、SDRAM、DRAM)、主存储器(NAND FLASH、NOR FLASH、EEPROM)、外部存储器(磁盘、光盘、CF卡、SD卡)和远程二级存储器(分布式文件系统、WEB服务器),6个层次的结构。上述设备从上而下,依次速度更慢、容量更大、访问频率更小,造价更便宜。

2、高速缓存(cache)

  • 工作原理:主要利用了程序的局部性特点。地址映象是指把主存地址空间映象到cache的地址空间。地址变换是指当程序或数据已经装入到cache后,在实际运行过程中,把主存地址如何编程cache空间的地址。

  • 常用的地址映象和地址变换的方式有:
    直接映象和变换:速度快,造价低,但有局限性,不能充分利用cache的好处。
    组相联地址映象和变换:速度稍慢但是命中率高。
    全相联地址映象和变换:可以任意映射。

  • 常用的cache替换算法:轮转法和随机替换算法。

  • 高速缓存的分类:
    A.统一cache和独立的数据/指令cache
    B.写通cache和写回cache
    C.读操作分配cache和写操作分配cache

3、存储管理单元(MMU)

  • MMU在CPU和物理内存之间进行地址转换,将地址从逻辑空间映射到物理空间,这个过程称为内存映射。MMU主要完成下面的工作:
    A.虚拟存储空间到物理空间的映射。
    B.存储器访问权限的控制。
    C.设置虚拟存储空间的缓冲特性。

  • 嵌入式系统中常常采用页式存储管理。为了管理这些页引入了页表的概念。页表是位于内存中的表,它的每一行对应虚拟存储空间的一个页,该行包含了该虚拟内存页对应的物理内存页的地址、该页的访问权限和该页的缓冲特性等。从虚拟地址到物理地址的变换过程就是查询页表的过程。

  • 由于页表存储在内存中的,整个查询过程需要付出很大的代价。根据程序局部性的特点,增加了一个小容量、高速度的存储部件来存放当前访问需要的地址变换条目,这个存储部件称为:地址转换后备缓冲器(TLB)

  • 当CPU访问内存时,首先在TLB中查找需要的地址变换条目,如果该条目不存在,CPU再从内存中的页表中查询,并把相应的结果添加到TLB中,更新它的内容。

  • 嵌入式系统中虚拟存储空间到物理空间的映射以内存块为单位进行。即虚拟存储空间中一块连续的存储空间被映射到物理存储空间中同样大小的一块连续存储空间。

  • 在页表和TLB中,每一个地址变换条目实际上记录了一个虚拟存储空间的内存块的基地址与物理存储空间相对应的一个内存块的基地址之间的对应关系。

  • 在MMU中实现虚拟地址到物理地址的映射是通过两级页表来实现的。禁止MMU时,所有物理地址和虚拟地址相等,即使用平板存储模式。

4、内存保护

  • 操作系统通常利用MMU来实现操作系统内核与应用程序之间的隔离,以及应用程序与应用程序之间的隔离。
    内存保护包含两个方面的内容:
    A.防止地址越界,每个应用程序都有自己独立的地址空间。
    B.防止越权操作,每个应用程序都有自己的访问权限。

5、实模式与保护模式

  • 在嵌入式系统中,常见的存储管理方案可以分为两大类:实模式保护模式

  • 实模式:内存的平面使用模式。
    特点:
    A.不划分“系统空间”与“用户空间”,无须进行地址映射。
    B.操作系统与应用程序之间不再有物理的边界。
    C.系统中的“任务”或“进程”,实际上全是内核线程。
    内存布局:
    A.代码段:包含操作系统和应用程序的所有代码。
    B.数据段:所有带有初始值的全局变量。
    C.BSS段:所有未带初始值的全局变量。
    D.堆空间:动态分配的内存空间。
    E.栈空间:保存上下文以及函数调用时的局部变量和形参。
    在实模式存储管理方案下,主要的工作在于堆空间的管理,即如何来管理空闲的堆空间、如何来分配内存、如何来回收内存等等。

  • 保护模式:处理器中必须有MMU硬件并启用。
    特点:
    A.系统内核和用户程序都有各自独立的地址空间。
    B.每个应用程序只能访问自己的地址空间,不能去破坏操作系统和其他应用程序的代码和数据。

6、分区存储管理

为了实现多道程序系统而采用的内存管理。

  • 基本思路:把整个内存划分为两大区域,即系统区和用户区,然后再把用户区划分为若干个分区,每个任务占有其中的一个分区。这样,在内存当中就同时保留多个任务,让他们共享整个用户区,从而实现多个任务的并发运行。
  • 分区存储管理又可以分为两类:固定分区和可变分区。
    固定分区:各个用户分区的个数、位置和大小一旦确定后,就固定不变,不能再修改。
    优点:易于实现,系统开销较小。
    缺点:内存利用率不高,分区总数固定。
    可变分区:动态创建,在装入一个程序时,系统将根据它的需求和内存空间的使用情况来决定是否分配。
    优点:动态变化,非常灵活。
    缺点:可能存在外碎片。
  • 在实现可变存储管理技术的时候,需要考虑三个方面的问题:
    A.内存管理的数据结构
    B.内存的分配算法
    C.内存的回收算法

7、地址映射

  • 地址映射:地址映射也叫地址重定位。逻辑地址和物理地址是完全不同的,不能用逻辑地址来直接访问内存单元。为了保证CPU在执行指令的时候,可以正确地访问内存单元,需要将用户程序中的逻辑地址转换为运行时由机器直接寻址的物理地址。
  • 地址映射由存储管理单元MMU来完成。
  • 地址映射主要有两种方式:静态地址映射和动态地址映射。
    静态地址映射:当用户程序被装入内存时,直接对指令代码进行修改,一次性地实现逻辑地址到物理地址的转换。
    动态地址映射:当用户程序被装入内存时,不对指令代码做任何修改,而是在程序的运行过程中,当它需要访问内存单元的时候,再来进行地址转换。
  • 在具体实现时,这项转换工作一般是由硬件的地址映射机制来完成的。通常设置一个基地址寄存器,或者叫重定位寄存器。当一个任务被调度运行时,就把它所在分区的起始地址装入到整个寄存器中。然后,在程序运行的过程中,当需要访问某个内存单元时,硬件就会自动地将其中的逻辑地址加上基地址寄存器中的内容,从而得到实际的物理地址,并且按照这个物理地址区执行。这个基地址寄存器位于MMU的内部,整个地址映射过程是自动运行的。从理论上说,每访问一次内存都要进行一次地址映射。

8、页式存储管理(重点)

  • 基本思路:把物理内存划分为许多固定大小的内存块,称为物理页面;把逻辑地址空间也划分为大小相同的块,称为逻辑页面。当一个用户程序被装入内存时,不是以整个程序为单位,把它存放在一整块连续的区域,而是以页面为单位来进行分配的。对于一个大小为N的页面程序,需要有N个空闲的物理页面来把它装载。这些物理页面不一定是要连续的。
  • 在页式存储管理中需要解决三个问题:数据结构、内存分配与回收、地址映射。
  • 数据结构有两个:页表和物理页面表。
    A.页表:给出了任务逻辑页面号和内存中物理页面号之间的对应关系。
    B.物理页面表:描述内存空间中,各个物理页面的使用情况。
  • 内存的分配过程:
    A.对于一个新来的任务,计算它所需要的页面数N,然后查看位示图,看是否还有N个空闲的物理页面。
    B.如果有足够的空闲物理页面,就去申请一个页表,其长度为N,并把页表的起始地址填入到该任务的控制块中。
    C.分配N个空闲的物理页面,把他们的变换填到页表中,建立逻辑页面与物理页面直接的对应关系。
    D.修改位示图,对刚刚被占用的那些物理页面进行标记。
  • 地址映射的基本思路:
    A.逻辑地址分析:对逻辑地址,找到它所在的逻辑页面,以及它在页面内的偏移地址。
    B.页表查找:根据逻辑页面号,从页表中找出它对应的物理页面号。
    C.物理地址合成:根据物理页面号和页内偏移地址,最终确定物理地址。
  • 逻辑地址分析:
    页面的大小都是2的整数次幂。对于给定的一个逻辑地址,可以直接把它的高位部分作为逻辑页面号,把它的低位部分作为页内偏移地址。例如,假设页面的大小是4KB,即2的12次幂,逻辑地址为32为,那么在一个逻辑地址当中,最低12位为页内偏移地址,而剩下的20位就是逻辑页面号。
  • 计算方法:
    逻辑页面号=逻辑地址/页面大小
    页内偏移量=逻辑地址%页面大小
    页表查找:页表作为操作系统的一个数据结构,通常保存在内核的地址空间中。页表基地址寄存器用来指向页表的起始地址;页表长度寄存器用来指示页表的大小,即对于当前任务,它总共包含有多少个页面。
    物理地址合成:假设物理页面号为f,页内偏移地址为offset,每个页面大小为2n,那么相应的物理地址为:f×2n+offset。

9、虚拟存储管理

  • 程序局部性原理:时间局限性和空间局限性。
  • 虚拟页式存储管理:在页式管理的基础上,增加了请求调页和页面置换的功能。
  • 基本思路:当一个用户程序需要调入内存去运行时,不是将这个程序的所有页面都装入内存,而是只装载部分的页面,就可以启动这个程序运行。在运行过程中,如果发现要执行的指令或者访问的数据不在内存当中,就向系统发出缺页中断请求,然后系统在处理这个中断请求时,就会将保存在外存中的相应页面调入内存,从而使该程序能继续运行。
  • 在虚拟页式存储管理中,页表包含:逻辑页面号、物理页面号、驻留位、保护位、修改位和访问位。
    -常用的页面置换算法:
    A.最优页面置换算法:理想化算法。
    B.最近最久未使用算法:链表法和栈方法。寻找长时间没有被访问的页面。
    C.最不常用算法:每个页面设置一个访问计数器。
    D.先进先出算法:性能比较差。
    E.时钟页面置换算法:把页面组成环形链表,类似时钟面。
  • 一般来说,当一个任务刚刚启动的时候,它会不断去访问一些新的页面,然后逐步建立一个比较稳定的工作集。工作集是指当前任务正在使用的逻辑页面的集合。如果分配给一个任务的物理页面数太少,不能包含整个的工作集,任务将会造成很多缺页中断,需要频繁地进行页面置换,这种现象称为“抖动”。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容

  • 1. 基础知识 1.1、 基本概念、 功能 冯诺伊曼体系结构1、计算机处理的数据和指令一律用二进制数表示2、顺序执...
    yunpiao阅读 5,279评论 1 22
  • 操作系统对内存的管理 没有内存抽象的年代 在早些的操作系统中,并没有引入内存抽象的概念。程序直接访问和操作的都是物...
    Mr槑阅读 16,681评论 3 24
  • 年轻的我们,总是抱有满腔的自以为是,总以为每一个目标都能圆满完成,每一件事情的发展都能如自己所愿,不论结果,因为...
    妖精系的皮卡丘阅读 327评论 1 3
  • 面试第二天 第一天面试结束后,Z先生安慰自己说,什么事情都有第一次,坏事情结束了好事情就会来的,人生不会总是摔倒在...
    七海言阅读 851评论 1 51
  • 外面的雪还没有化。 收拾好行礼,躺在床上。点了一柱香,打开手机中的佛音《大悲咒》和《心经》。 点开简书的APP。突...
    曾经闪耀的星阅读 181评论 0 0