首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
考研
假设一个主频为1GHz、CPI为5的CPU需要从某个成块传送的I/O设备读取1000B的数据到主存缓冲区中,该I/O设备一旦启动即按50KB/s的数据传输率向主机传送1 000B数据,每个字节的读取、处理并存入内存缓冲区需要1 000个时钟周期,则以下4种
假设一个主频为1GHz、CPI为5的CPU需要从某个成块传送的I/O设备读取1000B的数据到主存缓冲区中,该I/O设备一旦启动即按50KB/s的数据传输率向主机传送1 000B数据,每个字节的读取、处理并存入内存缓冲区需要1 000个时钟周期,则以下4种
admin
2017-04-28
29
问题
假设一个主频为1GHz、CPI为5的CPU需要从某个成块传送的I/O设备读取1000B的数据到主存缓冲区中,该I/O设备一旦启动即按50KB/s的数据传输率向主机传送1 000B数据,每个字节的读取、处理并存入内存缓冲区需要1 000个时钟周期,则以下4种方式下,在1000B的读取过程中,CPU用在该设备的I/O操作上的时间分别为多少?占整个CPU时间的百分比分别是多少?
(1)采用定时查询方式,每次处理一个字节,一次状态查询至少需要60个时钟周期。
(2)采用独占查询方式,每次处理一个字节,一次状态查询至少需要60个时钟周期。
(3)采用中断I/O方式,外设每准备好一个字节发送一次中断请求。每次中断响应需要2个时钟周期,中断服务程序的执行需要1 200个时钟周期。
(4)采用周期挪用DMA方式,每挪用一次主存周期处理一个字节,一次DMA传送完成1 000B的传送,DMA初始化和后处理的时间为2 000个时钟周期,CPU和DMA之间没有访存冲突。
(5)如果设备的速度提高到5MB/s,则上述4种方式中,哪些是不可行的?为什么?对于可行的方式,计算出CPU在该设备I/O操作上所用的时间占整个CPU时间的百分比。
选项
答案
主频为1GHz,所以时钟周期为l/lGHz=lns。因为每个字节的读取、处理并存入内存缓冲区需要1 000个时钟周期,所以,对于像程序查询和中断等用软件实现输入/输出的方式,CPU为每个字节传送所用的时间至少为1 000×1ns=1000ns=1μs。在50kB/s的数据传输率下,设备每隔lB/50kB/s=20μs=20 000ns准备好一个字节,因而读取1 000B的时间为1 000×20μs=20ms。 (1)定时查询方式下的I/O过程如图7—12所示。用户可以设置每隔20 000ns查询一次,这样使得查询程序的开销达到最小,即第一次读取状态时就可能会发现就绪,然后用1 000个时钟周期进行相应处理,因此,对于每个字节的传送,CPU所用时钟周期数为60+1 000=1 060。因此,在1 000B的读取过程中,CPU用在该设备的I/O操作上的时间至少为1 000×1 060×1ns=1.060ms,占整个CPU时间的百分比至少为1.060/20=5.3%。 [*] (2)独占查询方式下的I/O过程如图7—13所示。启动设备后,CPU就开始查询,因为333 ×60+20=20 000,所以第一个字节传送在第334次读取状态查询时检测到就绪,随后用1 000个时钟周期进行相应的处理,然后继续第二个字节的状态查询,因为40+1 000+316×60=20 000,所以,第二个字节的传送在第316次读取状态查询时检测到就绪,第一个和第二个字节的传送过程如图7—13a所示。每次检测到就绪后,就进行相应的处理,然后周而复始地进行查询,因为(20 000—1 000)/60=316.7,所以,第3 17次状态查询时发现就绪。因为1 000+60×317—20 000=20,所以,每3B可多60个时钟周期,正好进行一次状态查询,因此,在剩下的998B的读取过程中,前996B的传送正好用了996×20 000个时钟周期,如图7—13b所示。最后两个字节的传送过程如图7—13c所示,因为2×(1 000+60×317—20 000)=40,此外,最后一个字节的处理还有1 000个时钟周期,所以最后两个字节总的时间为2×20 000+40+1 000=41 040个时钟周期。 综上所述,CPU用在该设备的I/O操作上的总时间为1 000×20 000ns+1 040×1ns=20.001 04ms~20ms,即在1000B的整个传输过程中,CPU —直为该设备服务,所用时间占整个CPU时间的100%。 [*] (3)中断方式下的I/O过程如图7—14所示。中断方式下,外设每准备好一个字节请求一次中断,每次中断CPU所用时钟周期数为2+1 200=1 202,因此CPU用在该设备的I/O操作上的时间为1 000×1 202×1ns—1.202ms,占整个CPU时间的百分比至少为1.202/20=6.01%。 [*] (4) DMA方式下,由于CPU和DMA没有访存冲突,所以不需考虑由于DMA而影响到CPU执行其他程序。因此,传送1 000B CPU所用的时钟周期数就是2 000,在1 000B的读取过程中,CPU用在该设备的I/O操作上的时间为2 000×lns=2μs,占整个CPU时间的百分比为2/(1 000×20)=0.01%。 (5)若设备数据传输率为5MB/s,则外设传输1 000B所用时间为1 000B/(5×10
6
B/s)=200μs。 对于定时查询和独占查询方式,传送1 000B CPU所用时间至少为1 000×(60+1 000)×lns=1 060μs;对于中断方式,传送1 000B CPU所用时间为1 000×(2+1 200)×lns=1 202μs。上述3种方式下,CPU所用的时间都比设备所用时间长得多,即设备的传输比CPU的处理快得多,因而发生数据丢失。因此,这3种方式都不能用于该设备的I/O操作。对于DMA方式,传送1 000B CPU所用时间为2 000×1ns=2μs,占整个CPU时间的百分比为2/200=1%。这说明可以使用DMA方式,不过由于外设传输速度加快,使得CPU频繁进行DMA预处理和后处理,因而CPU的开销从0.01%上升到了1%。 补充说明:在计算CPU占用时间百分比时也可用另一种方法计算得到。例如,对于(3)中断方式的计算,可以先求出Is内该外设请求的中断次数为l/(lB/50kB)=50k,然后得到1s内CPU用于数据I/O的时钟周期数为50k×(2+1 200)=6.01×10
7
,因此在该设备传输过程中,CPU用于该设备I/O操作的时间占整个CPU时间的百分比为6.01× l0
7
/1G=6.01%。
解析
转载请注明原文地址:https://jikaoti.com/ti/MBfjFFFM
本试题收录于:
计算机408题库学硕统考专业分类
0
计算机408
学硕统考专业
相关试题推荐
下列关于塞尔维乌斯改革的叙述错误的是()。
中国共产党与民主党派实行“长期共存,互相监督”的方针,其根本依据是()
汉章帝会群儒于白虎观,讨论经义,由()写成《白虎通德论》(又称《白虎通义》、《白虎通》)一书,这部书系统地吸收了阴阳五行和谶纬之学,形成今文经学派的主要观点。
1962年1、2月间,中共中央召开的统一思想、总结经验教训、明确工作方向的会议是()。
光绪元年七月,清政府迫于()强烈要求派一位使臣到其国,()成为中国第一个驻外公使
1898年,与康有为共同倡议发起组织保国会的是()。
阅读以下史料,并回答问题:心即理也,此心无私欲之蔽,即是天理,不须外面添一分。——《传习录》上朱子所谓格物云者,在即物而穷其理也。即物穷理,是就事事物物上求其所谓定理也。是以吾心而求理于事
19世纪中期,德意志资产阶级迫切要求实现国家的统一,其首要的目的是()。
20世纪五六十年代经济高速增长时期,西欧经济增长最快的国家是()。
(1)页面长度为1KB=210B,因此页内偏移地址占10位。主存大小为16KB=214B,所以物理地址占14位。0AC5H=0000101011000101B,除去后10位,得到页号为2,则查找页表可知物理块号为4,所以物理地址是0100101100
随机试题
给老年病人使用常规剂量的地高辛属于
梁板式筏基的底板厚度不应小于()mm。
以下关于现值和终值的说法,错误的是()。
下列错误中,并不会影响试算平衡表中借贷双方平衡关系的有()
某新建小区住宅楼的高度为三层到八层不等,如果住宅在三层以上,它就有电梯直达。如果上面陈述属实,则下面哪一项也是正确的?()
对地震学家们“最担心的事情”所包括的内容的理解,不正确的一项是()。下列对各国预测地震的研究成果的表述,正确的一项是()。
Hisessayis________withmorethan420full-colorphotographsthatdepictthenationalparkinallseasons.
______isannouncedinthepapers,ourcountryhaslaunchedalarge-scalemovementagainstsmugglingandfraudulentactivitiesi
A、Thetwooldfriendsmetonthestreetunexpectedly.B、Theircarsknockedintoeachother.C、Theyquarreledwitheachother.D、
Everyonehasamomentinhistory,whichbelongsparticularlytohim.Itisthemomentwhenhisemotionsachievetheirmostpower
最新回复
(
0
)