《操作系统》第六章——虚拟存储器作业

一.单选题

  1. 某系统采用改进型Clock页面置换算法,页表项中字段A为访问位,M为修改位。A=0表示页最近没有被访问, A=1表示页最近被访问过。M=0 表示页没有被修改过,M=1表示页被修改过。按(A, M)形式可将页分为4类:(0,0)、(1,0)、(0,0)、(1,1),则该页面置换算法淘汰页的次序为( C ):
    A、(0,0)、(1,0)、(0,1)、(1,1)
    B、(0, 0)、(1,1)、(0,1)、(1,0)
    C、(0,0)、(0,1)、(1,0)、(1,1)
    D、(0, 0)、(0,1)、(1,1)、(1,0)
    在这里插入图片描述

  2. 在一个请求分页系统中,系统为某进程分配了4个物理块,考虑以下页面8、1、3、6、9、8、6、1、7、0,若使用OPT页面置换算法,则访问页面9时会淘汰页面( B )。
    A、1
    B、3
    C、8
    D、6
    在这里插入图片描述

  3. 在请求分页存储管理中,若所需页面不在内存中,则会引起( C )。
    A、越界中断
    B、I/O中断
    C、页故障
    D、缺段中断
    在这里插入图片描述

  4. 在请求分页系统中,页面分配策略与页面置换策略不能组合使用的是( C )。
    A、可变分配,全局置换
    B、可变分配,局部置换
    C、固定分配,全局置换
    D、固定分配,局部置换
    在这里插入图片描述

  5. 在缺页处理过程中,OS执行的操作可能是(A )。
       I.修改页表 II.磁盘I/O III.分配页框
    A、I、II、III
    B、仅III
    C、仅II
    D、仅 I、II
    在这里插入图片描述

  6. “抖动”是指在请求分页存储管理系统中,由于( A )设计不当或者进程分配的物理页面数量太少,刚被淘汰的页面很快又被调入内存,如此反复,使大量的CPU时间花费在了页面置换上的现象。
    A、页面置换算法(即页面淘汰算法)
    B、进程调度算法
    C、磁盘调度算法
    D、作业调度算法在这里插入图片描述

  7. 在分页存储管理系统中,虚拟地址变换成物理地址的工作是由( A )完成的。
    A、硬件
    B、地址转换程序
    C、装入程序
    D、用户程序
    在这里插入图片描述

  8. 在请求分页存储管理系统中,采用某些页面置换算法时会出现Belady异常现象,即进程的缺页次数会随着分配给该进程的页框个数的增加而增加。下列页面置换算法中,可能出现Belady异常现象的是( C )。
                I.LRU页面置换算法 II. FIFO页面置换算法 III. OPT页面置换算法
    A、仅 I、II
    B、仅II、III
    C、仅II
    D、仅 I、III
    在这里插入图片描述

  9. 系统为某进程分配了4个页框,该进程已访问的页号序列为2、0、2、9、3、4, 2、8、2、4、8、4、5、7 。若进程要访问的下一个页面的页号为7,依据LRU页面置换算法应淘汰的页面的页号是( C )。
    A、4
    B、3
    C、2
    D、8
    在这里插入图片描述

  10. 实现虚拟存储器的目的是( B )。
    A、都不对
    B、逻辑上扩充内存
    C、逻辑上扩充外存
    D、扩充物理内存
    在这里插入图片描述

  11. 虚拟分页存储管理中有页表若干项,当内存中某一页面被淘汰时,可能根据下列哪项来决定是否将该页面写回外存?( D )
    A、“访问”标志
    B、“是否在内存中”标志
    C、外存地址
    D、“修改”标志
    在这里插入图片描述

  12. 下列因素中,影响请求分页系统有效(平均)访存时间的是( A )。
               I.缺页率   II.磁盘读/写时间   III.内存访问时间   IV.执行缺页处理程序的CPU时间
    A、I、II、III、IV
    B、仅I、IV
    C、仅II、III
    D、仅I、II、III
    在这里插入图片描述

  13. 下列关于虚拟存储器的论述中,正确的是( )。
    A、作业在运行前,必须全部装入内存,但在运行过程中不必一直驻留内存
    B、作业在运行前,不必全部装入内存,且在运行过程中也不必一直驻留内存
    C、作业在运行前,不必全部装入内存,但在运行过程中必须一直驻留内存
    D、作业在运行前,必须全部装入内存,且在运行过程中必须一直驻留内存
    在这里插入图片描述

  14. 为使虚拟存储管理系统具有良好的性能,应用程序应具备的特征是(C )。
    A、程序模块化程度高,由许多小模块组成
    B、程序的I/O操作较少
    C、良好的局部性
    D、程序实际大小应小于实际物理内存容量
    在这里插入图片描述

  15. 某进程访问页面的页号序列如下图所示。
    在这里插入图片描述
    若工作集的窗口大小为6,则在t时刻的工作集为( A ) 。
    A、{6,0,3,2}
    B、{4,5,6,0,3,2}
    C、{2,3,0,4}
    D、{0,4,3,2,9}
    在这里插入图片描述

  16. 虚拟存储管理系统的基础是程序的( D )原理。
    A、虚拟性
    B、动态性
    C、共享性
    D、局部性
    在这里插入图片描述

  17. 若用户进程在访问内存时产生缺页,则下列选项中,OS可能执行的操作是( C )。
             I.处理越界错          II.置换页          III.分配内存
    A、I、II、III
    B、仅I、III
    C、仅II、III
    D、仅 I、II
    在这里插入图片描述

  18. 下列措施中,能加快虚/实地址转换的是( A )。
             I.增大快表         II.让页表常驻内存          III.增大交换区
    A、仅 I、II
    B、仅II
    C、仅II、III
    D、仅 I
    在这里插入图片描述

  19. 关于(进程)页表的页表项,基本分页存储管理方式和请求分页存储管理方式均须设立的字段为( A)。
    A、物理块号
    B、修改位
    C、状态位
    D、访问字段
    在这里插入图片描述

20.下列关于缺页处理的叙述中,错误的是( B )。
A、缺页是在地址转换时由CPU检测到的一种异常
B、缺页处理完成后程序会返回发生缺页的指令的下一条指令继续执行
C、缺页处理是由OS提供的缺页处理程序完成的
D、缺页处理程序根据页故障地址从外存读入所缺失的页面
在这里插入图片描述
21.下列关于虚拟存储的叙述中,正确的是 ( B )。
A、虚拟存储只能基于连续分配技术
B、虚拟存储只能基于离散分配技术
C、虚拟存储容量只受外存容量的限制
D、虚拟存储容量只受内存容量的限制
在这里插入图片描述

  1. 在虚拟内存管理中,地址转换机构可将逻辑地址转换为物理地址。形成该逻辑地址的阶段称为( A )。
    A、编译
    B、编辑
    C、装载
    D、链接
    在这里插入图片描述

  2. 在请求分页存储管理中,缺页率与进程所分得的内存页面数、( C )、进程页面流的走向等因素有关。
    A、进程调度算法
    B、页表的位置
    C、页面置换算法
    D、外存管理算法
    在这里插入图片描述

  3. 当系统发生“抖动”时,可以采取的有效措施是( B )。
             I.撤销部分进程          II.增加磁盘交换区的容量          III.提高用户进程的优先级
    A、仅III
    B、仅 I
    C、仅 I、II
    D、仅II
    在这里插入图片描述

二.填空题

  1. 页面置换算法主要有( )和( )。
    答:OPT;FIFO; LRU;LFU;CLOCLK;改进的CLOCK;页面缓冲;工作集
    在这里插入图片描述

  2. 为了实现请求分页存储管理,应在基本分页的基础上增加( )、( )、( )和( )等数据项。
    答:状态位;访问字段;修改位;外存地址
    在这里插入图片描述

  3. 在请求分页存储管理系统中,逻辑地址长度为16位, 每页的大小为2KB,部分页表如表
    在这里插入图片描述
    则逻辑地址0EC5H所对应的物理地址为( )H。
    答:56C5
    在这里插入图片描述

  4. 在请求分页系统中,地址转换过程可能会因为( )、( )和( )等原因而产生中断。
    答:逻辑地址越界;缺页;访问权限错误
    在这里插入图片描述

  5. 某系统的页面大小是1KB,某程序的大小是4.9KB,依次装入如下逻辑地址访问存储器:756、897、1 044、1 950、235、4 000、1 504、 2 597、2 896、4 501、4 890、3 768。请根据所给信息,解决以下问题。
    (1)写出程序的页面访问序列(页号之间以“、”分隔)。
    (2)假设系统只有2KB内存可供程序使用,程序加载采用预装入策略,若采用FIFO页面置换算法,则会发生多少次缺页中断?
    (3)若将(2)中的页面置换算法改为LRU页面置换算法,则会发生多少次缺页中断?
    答:
    (1): 0、0、1、1、0、3、1、2、2、4、4、3
    (2): 6
    (3): 7

    在这里插入图片描述

30.考虑一个请求分页存储管理系统,它釆用全局置换策略和平均分配内存块的算法(即若有m个内存块和n个进程,则每个进程可分得m/n个内存块)。如果在该系统中测得如下CPU利用率和对换盘利用率,则请问能否通过增加多道程序的道数来提高CP利用率?为什么?

(1) CPU利用率为13%,对换盘利用率为97%。

(2) CPU利用率为87%,对换盘利用率为3%。

(3) CPU利用率为13%,对换盘利用率为3%。
答:
(1)这种情况表示系统在频繁地进行页面置换,CPU的大部分时间被花在了页面置换上。此时,增加多道程序会进一步增加缺页率,使系统性能进一步恶化。因此,不能通过增加多道程序的道数来提高CPU利用率,反而应减少内存中的作业道数。

(2)在这种情况下,CPU利用率比较高,但对换盘利用率比较低,这表示运行进程的缺页率很低,可以通过适当增加多道程序的道数来提高CPU利用率。

(3)在这种情况下CPU利用率比较低,对换盘利用率非常低,这表示内存中可运行的程序数不足,此时,应该增加多道程序的道数以提高CPU利用率。
在这里插入图片描述

  1. 虚拟内存的容量可以比物理内存大得多,但是访问速度和物理内存相近,为什么?
    答:虚拟内存,具有请求调入功能和置换功能,目的是从逻辑上对内存容量加以扩充,其逻辑容量由计算机的地址字长所决定,比物理内存大得多。基于一定的页面置换算法,加上局部性原理等有效措施,使得即将要访问的内容以比较高的可能性被提前调入内存,而无须等到要访问该内容时才去外存调取,从而减少了时间开销,其运行速度接近于内存速度。
    在这里插入图片描述

  2. 系统为某进程分配了4个页框,该进程已访问的页号序列为:
        2、0、2、9、3、4, 2、8、2、4、8、4、5、7 。
    1、依据LRU页面置换算法,写出页面置换过程(页面序列的页号之间用逗号分隔)
    2、依据LRU页面置换算法被淘汰页面的页号分别是(页号之间用逗号分隔)。
    答:
    第一空: 页面序列: 2,0,2,9,3,4,2,8,2,4,8,4,5,7
                   页框号1 : 2,2,2,2,2,2,2,2,2,2,2,2,2,7
                   页框号2 : -,0,0,0,0,4,4,4,4,4,4,4,4,4
                   页框号3 : -,-,-,9,9,9,9,8,8,8,8,8,8,8
                   页框号4 : -,-,-,-,3,3,3,3,3,3,3,3,5,5
                    缺页置换: y,y,-,y,y,y,-,y,-,-,-,-,y,y
    第二空:0,9,3,2
    在这里插入图片描述

  3. )某虚拟存储器的用户空间中共有32个页面,每页的长度是1KB,内存大小是16KB。假定某时刻系统为作业的0、1、2、3页分别分配的物理块号为5、10、 4、7,试将CPU给出的虚拟地址0A5CH和093CH分别转换为物理地址。
    注意:答题给出的结果以16进制数表示。
    答:125CH、113CH
    在这里插入图片描述

  4. 某计算机的逻辑地址空间和物理地址空间均为64KB,按字节编址。若某进程最多需要6页数据存储空间,页的大小为1KB,OS采用固定分配局部置换策略为此进程分配4个页框。在装入时刻260之前,该进程的访问情况如表2-6-2所示 (访问位即使用位)。

在这里插入图片描述
当该进程执行到装入时刻260时,要访问逻辑地址为17CAH的数据。回答下列问题。

(1)该逻辑地址对应的页号是多少?

(2)若采用FIFO页面置换算法,则该逻辑地址对应的物理地址是多少?要求给岀计算过程。
(第2、3空,分别给出物理地址和计算过程)

(3)若采用Clock页面置换算法,则该逻辑地址对应的物理地址是多少?要求给出计算过程。
(第4、5空,分别给出物理地址和计算过程)

设搜索下一页的指针沿顺时针方向移动,且具当前指向2号页框,如图2-6-3 所示。
在这里插入图片描述

答:
第一空: 5

第二空: lFCAH

第三空: 采用FIFO页面置换算法,与最早调入的页面(即0号页面)进行置换,其所在的页框号为7,于是对应的物理地址为0001 1111 1100 1010 = lFCAH。

第四空: 0BCAH

第五空: 采用Clock页面置换算法,首先从当前位置(2号页框)开始顺时针寻找访问位为0的页面,当指针指向的页面的访问位为1时,就把该访问位清“0”;指针遍历一周后,回到2号页框,此时2号页框的访问位为0;置换该页框的页面,于是得对应的物理地址为0000 1011 1100 1010=0BCAH。
在这里插入图片描述

  1. 虚拟内存空间的大小由什么因素决定?
    答:虚拟内存空间的大小受限于两个要求。

(1)虚拟内存空间的大小≤内存容量和外存容量之和,这是硬件的硬性条件所规定的,若虚拟内存空间的大小超过了这个容量,则没有相应的空间来供虚拟内存使用。

(2)虚拟内存空间的大小≤计算机的地址位数所能容纳的最大容量。假设地址是32位,按字节编址,一个地址代表1B存储空间,则虚拟内存空间的大小≤4GB(232B)。若虚拟内存空间的大小超过4GB,则32位的地址将无法访问全部虚拟内存,即4GB以外的空间会被浪费。

实际虚拟内存的容量是取要求(1)和要求(2)的交集,即两个要求都要满足。
在这里插入图片描述

  1. 某请求分页存储管理系统的页面置换策略如下: 系统从0时刻开始扫描,每隔5个时间单位扫描一轮驻留集(扫描时间忽略不计),且本轮没有被访问过的页框将被系统回收,并放入空闲页框链尾,其中的内容在下一次分配之前不会被清空。当发生缺页时,如果该页曾被使用过且还在空闲页框链表中,则将其重新放回进程的驻留集中;否则,从空闲页框链表头部取出1个页框。忽略其它进程的影响和系统开销。初始时进程驻留集为空。
    目前系统空闲页的页框号依次为32、15、21、41进程P依次访问的<虚拟页号,访问时刻>
    为<1, 1>、<3, 2>、<0, 4>、 <0, 6>、<1, 11>、<0, 13>、<2, 14>。
    请回容下列问题。
    (1)当进程P访问<0, 4>时,对应的页框号是多少?说明理由。
    (2)当进程P访问<1, 11>时,对应的页框号是多少?说明理由。
    (3)当进程P访问<2, 14>时,对应的页框号是多少?说明理由。
    (4)这种方法是否适用于时间局部性好的程序?说明理由。
    答:
    (1)21; 理由:因为起始驻留集为空,时刻1访问第1页,页框号为32;时刻2访问第3页,页框号为15;时刻4访问第0页,页框号为21。

    (2)32;理由:因11>10故发生第3轮扫描,页号为1的页框在第2轮已处于空闲页框链表中,此刻该页又被重新访问,因此应被重新放回到驻留集中。其页框号为32。

    (3)41;理由:因为第2页从来没有被访问过,它不在驻留集中,所以从空闲页框链表中取岀链表头的页框41,页框号为41。

    (4)适合;理由:因为时间局部性越好,从空闲页框链表中重新取回页面的机会就越大,该策略的优势就越明显。
    在这里插入图片描述

  2. 在请求分页存储管理系统中,调页的策略有( )和( )这两种。
    答:预调页策略、请求调页策略
    在这里插入图片描述

  3. 说明请求分段存储管理系统中段表各字段的作用。
    答:
    存取方式:用于标志本段的存取属性(包括只读、执行、允许读/写等)
    访问字段A:用于记录本段被访问的频繁程度。
    修改位M:用于记录本段在内存中是否被修改过,供页面置换参考。
    存在位P:用于表示本段是否已调入内存,供程序访问参考。
    增补位:用于表示本段在运行过程中是否会动态增长。
    外存地址:用于表示本段在外存中的起始地址,即起始盘块号。

    在这里插入图片描述

  4. 在虚拟分页存储管理系统中,为什么要引入缺页中断?缺页中断的实现由哪几部分组成?试简述其实现方法。

答:请求分页存储管理系统中,当所要访问的页不在内存中时,产生一个缺页中断,以请求OS将所缺的页调入内存。此时缺页进程阻塞,如果内存中有空闲块,则将调入的页装入一个空闲块中,并修改页表中相应的页表项;否则,就要发生置换。因此,这在一定程度上增加了内存的逻辑块数。

缺页中断作为中断,同样要经历保护CPU现场环境、分析中断原因、转入缺页中断程序、恢复CPU现场环境等步骤。实现方法:进行地址转换时,先检索快表,若找到要访问页的页表项,则修改页表项中的访问位,然后利用页表项中给出的物理块号和页内地址形成物理地址;若未找到,则査找页表,再根据页表项中的状态位P来判断该页是否已调入内存,若未调入,则产生缺页中断,请求OS从外存把该页调入内存。
在这里插入图片描述

  1. 某OS采用请求分页存储管理方式,现有一个进程需要访问的地址序列(字节)是:115、228、120、88、446、102、321、432、260、167。假设该进程的第0页已被装入内存,并分配给该进程300B,页的大小为100B,试回答以下问题。
    (1)采用LRU页面置换算法将发生多少次页面置换?
          依次淘汰的页面的页号依次是哪些(页号之间以“、”分隔)? 页面置换率是多少?

    (2)LRU页面置换算法的基本思想是什么?

    注意:请按以上问题的次序分别给出答案。
    答:
    (1):42、0、1、340%
    (2): LRU页面置换算法的基本思想是:用“最近的过去”的页面使用情况来预测“最近的将来”的页面使用情况,假设一个页面刚被访问过,且在不久的将来该页面还可能被访问,则选择最近最久未使用的页面进行淘汰。
    在这里插入图片描述
  • 20
    点赞
  • 139
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
第一章 计算机系统概述 复习题: 1.1、 列出并简要地定义计算机的四个主要组成部分。 答:主存储器,存储数据和程序;算术逻辑单元,能处理二进制数据;控制单元,解读存储器中的指令并且使他们得到执行;输入/输出设备,由控制单元管理。 1.2、 定义处理器寄存器的两种主要类别。 答:用户可见寄存器:优先使用这些寄存器,可以使机器语言或者汇编语言的程序员减少对主存储器的访问次数。对高级语言而言,由优化编译器负责决定把哪些变量应该分配给主存储器。一些高级语言,如C语言,允许程序言建议编译器把哪些变量保存在寄存器中。 控制和状态寄存器:用以控制处理器的操作,且主要被具有特权的操作系统例程使用,以控制程序的执行。 1.3、 一般而言,一条机器指令能指定的四种不同操作是什么? 答:这些动作分为四类:处理器-寄存器:数据可以从处理器传送到存储器,或者从存储器传送到处理器。处理器-I/O:通过处理器和I/O模块间的数据传送,数据可以输出到外部设备,或者从外部设备输入数据。数据处理,处理器可以执行很多关于数据的算术操作或逻辑操作。控制:某些指令可以改变执行顺序。 1.4、 什么是中断? 答:中断:其他模块(I/O,存储器)中断处理器正常处理过程的机制。 1.5、 多中断的处理方式是什么? 答:处理多中断有两种方法。第一种方法是当正在处理一个中断时,禁止再发生中断。第二种方法是定义中断优先级,允许高优先级的中断打断低优先级的中断处理器的运行。 1.6、 内存层次的各个元素间的特征是什么? 答:存储器的三个重要特性是:价格,容量和访问时间。 1.7、 什么是高速缓冲存储器? 答:高速缓冲存储器是比主存小而快的存储器,用以协调主存跟处理器,作为最近储存地址的缓冲区。 1.8、 列出并简要地定义I/O操作的三种技术。 答:可编程I/O:当处理器正在执行程序并遇到与I/O相关的指令时,它给相应的I/O模块发布命令(用以执行这个指令);在进一步的动作之前,处理器处于繁忙的等待中,直到该操作已经完成。中断驱动I/O:当处理器正在执行程序并遇到与I/O相关的指令时,它给相应的I/O模块发布命令,并继续执行后续指令,直到后者完成,它将被I/O模块中断。如果它对于进程等待I/O的完成来说是不必要的,可能是由于后续指令处于相同的进程中。否则,此进程在中断之前将被挂起,其他工作将被执行。直接存储访问:DMA模块控制主存与I/O模块间的数据交换。处理器向DMA模块发送一个传送数据块的请求,(处理器)只有当整个数据块传送完毕后才会被中断。 1.9、 空间局部性和临时局部性间的区别是什么? 答:空间局部性是指最近被访问的元素的周围的元素在不久的将来可能会被访问。临时局部性(即时间局部性)是指最近被访问的元素在不久的将来可能会被再次访问。 1.10、 开发空间局部性和时间局部性的策略是什么? 答:空间局部性的开发是利用更大的缓冲块并且在存储器控制逻辑中加入预处理机制。时间局部性的开发是利用在高速缓冲存储器中保留最近使用的指令及数据,并且定义缓冲存储的优先级。 习题: 1.1、图1.3中的理想机器还有两条I/O指令: 0011 = 从I/O中载入AC 0111 = 把AC保存到I/O中 在这种情况下,12位地址标识一个特殊的外部设备。请给出以下程序的执行过程(按照图1.4的格式): 1. 从设备5中载入AC。 2. 加上存储器单元940的内容。 3. 把AC保存到设备6中。 假设从设备5中取到的下一个值为3940单元中的值为2。 答案:存储器(16进制内容):300:3005;301:5940;302:7006 步骤1:3005->IR;步骤2:3->AC 步骤3:5940->IR;步骤4:3+2=5->AC 步骤5:7006->IR:步骤6:AC->设备 6 1.2、本章中用6步来描述图1.4中的程序执行情况,请使用MAR和MBR扩充这个描述。 答案:1. a. PC中包含第一条指令的地址300,该指令的内容被送入MAR中。 b. 地址为300的指令的内容(值为十六进制数1940)被送入MBR,并且PC增1。这两个步骤是并行完成的。 c. MBR中的值被送入指令寄存器IR中。 2. a. 指令寄存器IR中的地址部分(940)被送入MAR中。 b. 地址940中的值被送入MBR中。 c. MBR中的值被送入AC中。 3. a. PC中的值(301)被送入MAR中。 b. 地址为301的指令的内容(值为十六进制数5941)被送入MBR,并且PC增1。 c. MBR中的值被送入指令寄存器IR中。 4. a. 指令寄存器IR中的地址部分(941)被送入MAR中。 b. 地址941中的值被送入MBR中。 c. AC中以前的内容和地址为941的存储单元中的内容相加,结果保存到AC中。 5. a. PC中的值(302)被送入MAR中。 b. 地址为302的指令的内容(值为十六进制数2941)被送入MBR,并且PC增1。 c. MBR中的值被送入指令寄存器IR中。 6. a. 指令寄存器IR中的地址部分(941)被送入MAR中。 b. AC中的值被送入MBR中。 c. MBR中的值被存储到地址为941的存储单元之中。 1.4、假设有一个微处理器产生一个16位的地址(例如,假设程序计数器和地址寄存器都是16位)并且具有一个16位的数据总线。 a.如果连接到一个16位存储器上,处理器能够直接访问的最大存储器地址空间为多少? b.如果连接到一个8位存储器上,处理器能够直接访问的最大存储器地址空间为多少? c.处理访问一个独立的I/O空间需要哪些结构特征? d.如果输入指令和输出指令可以表示8位I/O端口号,这个微处理器可以支持多少8位I/O端口? 答案:对于(a)和(b)两种情况,微处理器可以直接访问的最大存储器地址空间为216 = 64K bytes;唯一的区别是8位存储器每次访问传输1个字节,而16位存储器每次访问可以传输一个字节或者一个16位的字。对于(c)情况,特殊的输入和输出指令是必要的,这些指令的执行体会产生特殊的“I/O信号”(有别于“存储器信号”,这些信号由存储器类型指令的执行体产生);在最小状态下,一个附加的输出针脚将用来传输新的信号。对于(d)情况,它支持28 = 256个输入和28 = 256个输出字节端口和相同数目的16位I/O端口;在任一情况, 一个输入和一个输出端口之间的区别是通过被执行的输入输出指令所产生的不同信号来定义的。 1.5、考虑一个32位微处理器,它有一个16位外部数据总线,并由一个8MHz的输入时钟驱动。假设这个微处理器有一个总线周期,其最大持续时间等于4个输入时钟周期。请问该微处理器可以支持的最大数据传送速度为多少?外部数据总线增加到21位,或者外部时钟频率加倍,哪种措施可以更好地提高处理器性能?请叙述你的设想并解释原因。 答案:时钟周期=1/(8MHZ)=125ns 总线周期=4×125ns=500ns 每500ns传输2比特;因此传输速度=4MB/s 加倍频率可能意味着采用了新的芯片制造技术(假设每个指令都有相同的时钟周期数);加倍外部数据总线,在芯片数据总线驱动/锁存、总线控制逻辑的修改等方面手段广泛(或许更新)。在第一种方案中,内存芯片的速度要提高一倍(大约),而不能降低微处理器的速度;第二种方案中,内存的字长必须加倍,以便能发送/接受32位数量。 1.6、考虑一个计算机系统,它包含一个I/O模块,用以控制一台简单的键盘/打印机电传打字设备。CPU中包含下列寄存器,这些寄存器直接连接到系统总线上: INPR:输入寄存器,8位 OUTR:输出寄存器,8位 FGI:输入标记,1位 FGO:输出标记,1位 IEN:中断允许,1位 I/O模块控制从打字机中输入击键,并输出到打印机中去。打字机可以把一个字母数字符号编码成一个8位字,也可以把一个8位字解码成一个字母数字符号。当8位字从打字机进入输入寄存器时,输入标记被置位;当打印一个字时,输出标记被置位。 a. 描述CPU如何使用这4个寄存器实现与打字机间的输入/输出。 b. 描述通过使用IEN,如何提高执行效率? 答案:a.来源于打字机的输入储存在INPR中。只有当FGI=0时,INPR才会接收来自打字机的数据。当数据接收后,被储存在INPR里面,同时FGI置为1。CPU定期检查FGI。如果FGI=1,CPU将把INPR里面的内容传送至AC,并把FGI置为0。 当CPU需要传送数据到打字机时,它会检查FGO。如果FGO=0,CPU处于等待。如果FGO=1,CPU将把AC的内容传送至OUTER并把FGO置为0。当数字符号打印后,打字机将把FGI置为1。 b.(A)描述的过程非常浪费。速度远高于打字机的CPU必须反复不断的检查FGI和FGO。如果中断被使用,当打字机准备接收或者发送数据时,可以向CPU发出一个中断请求。IEN计数器可以由CPU设置(在程序员的控制下)。 1.7、实际上在所有包括DMA模块的系统中,DMA访问主存储器的优先级总是高于处理器访问主存储器的优先级。这是为什么? 答案:如果一个处理器在尝试着读或者写存储器时被挂起, 通常除了一点轻微的时间损耗之外没有任何危害。但是,DMA可能从或者向设备(例如磁盘或磁带)以数据流的方式接收或者传输数据并且这是不能被打断的。否则,如果DMA设备被挂起(拒绝继续访问主存),数据可能会丢失。 1.9、一台计算机包括一个CPU和一台I/O设备D,通过一条共享总线连接到主存储器M,数据总线的宽度为1个字。CPU每秒最多可执行106条指令,平均每条指令需要5个机器周期,其中3个周期需要使用存储器总线。存储器读/写操作使用1个机器周期。假设CPU正在连续不断地执行后台程序,并且需要保证95%的指令执行速度,但没有任何I/O指令。假设1个处理器周期等于1个总线周期,现在要在M和D之间传送大块数据。 a.若使用程序控制I/O,I/O每传送1个字需要CPU执行两条指令。请估计通过D的I/O数据传送的最大可能速度。 b.如果使用DMA传送,请估计传送速度。 答案:a.处理器只能分配5%的时间给I/O.所以最大的I/O指令传送速度是10e6×0.05=50000条指令/秒。因此I/O的传送速率是25000字/秒。 b.使用DMA控制时,可用的机器周期下的数量是 10e6(0.05×5+0.95×2)=2.15×10e6 如果我们假设DMA模块可以使用所有这些周期,并且忽略任何设置和状态检查时间,那么这个值就是最大的I/O传输速率。 1.10、考虑以下代码: for ( i = 0;i < 20;i++) for (j = 0;j < 10;j++) a[i] = a[i]*j a. 请举例说明代码中的空间局部性。 b. 请举例说明代码中的时间局部性。 答案:a.读取第二条指令是紧跟着读取第一条指令的。 b.在很短的间歇时间内, a[i]在循环内部被访问了十次。 1.11、请将附录1A中的式(1.1)和式(1.2)推广到n级存储器层次中。 答案:定义: Ci = 存储器层次i上每一位的存储单元平均花销 Si = 存储器层次i的规模大小 Ti = 存储器层次i上访问一个字所需时间 Hi = 一个字在不高于层次i的存储器上的概率 Bi = 把一个数据块从层次i+1的存储器上传输到层次i的存储器上所需时间 高速缓冲存储器作为是存储器层次1;主存为存储器层次2;针对所有的N层存储器层以此类推。有: Ts的引用更复杂,我们从概率论入手:所期望的值 ,由此我们可以写出: 我们需要清楚如果一个字在M1(缓存)中,那么对它的读取非常快。如果这个字在M2而不在M1中,那么数据块需要从M2传输到M1中,然后才能读取。因此,T2 = B1+T1 进一步,T3 = B2+T2 = B1+B2+T1 以此类推: 所以, 但是, 最后, 1.12、考虑一个存储器系统,它具有以下参数: Tc = 100 ns Cc = 0.01 分/位 Tm = 1200 ns Cm = 0.001 分/位 a.1MB的主存储器价格为多少? b.使用高速缓冲存储器技术,1MB的主存储器价格为多少? c.如果有效存取时间比高速缓冲存储器存取时间多10% ,命中率H为多少? 答案:a.价格 = Cm×8×106 = 8×103 ¢ = $80 b.价格 = Cc×8×106 = 8×104 ¢ = $800 c.由等式1.1知:1.1×T1 = T1+(1-H)T2 (0.1)(100) = (1-H)(1200) H=1190/1200 1.13、一台计算机包括包括高速缓冲存储器、主存储器和一个用做虚拟存储器的磁盘。如果要存取的字在高速缓冲存储器中,存取它需要20ns;如果该字在主存储器中而不在高速缓冲存储器中,把它载入高速缓冲存储器需要60ns(包括最初检查高速缓冲存储器的时间),然后再重新开始存取;如果该字不在主存储器中,从磁盘中取到内存需要12ms,接着复制到高速缓冲存储器中还需要60ns,再重新开始存取。高速缓冲存储器的命中率为0.9,主存储器的命中率为0.6,则该系统中存取一个字的平均存取时间是多少(单位为ns)? 答案:有三种情况需要考虑: 字所在的位置 概率 访问所需时间(ns) 在缓存中 0.9 20 不在缓存,在主存中 (0.1)(0.6)= 0.06 60+20 = 80 不在缓存也不在主存中 (0.1)(0.4)= 0.04 12ms+60+20 = 12,000,080 所以平均访问时间是: Avg = (0.9)(20) + (0.06)(80) + (0.04)(12000080) = 480026 ns 1.14、假设处理器使用一个栈来管理过程调用和返回。请问可以取消程序计数器而用栈指针代替吗? 答案:如果栈只用于保存返回地址。或者如果栈也用于传递参数,这种方案只有当栈作为传递参数的控制单元而非机器指令时才成立。这两种情况下可以取消程序计数器而用栈指针代替。在后者情况中,处理器同时需要一个参数和指向栈顶部的程序计数器。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值