《杭电-计算机组成原理-包建-课后作业答案(共35页).doc》由会员分享,可在线阅读,更多相关《杭电-计算机组成原理-包建-课后作业答案(共35页).doc(35页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、精选优质文档-倾情为你奉上运算器P61 3.3写出下列各数的原码、反码和补码,机器数长度为8位:真值二进制真值原码反码补码(1)00,0,0,1,1,(2)-1271,1,1,(3)-0.50.1.1.1.(4)-19/1280.1.1.1.(5)1000,0,0,(6)23/640.0.0.0.P61 3.4写出下列各机器数的二进制真值X:(1)X补=0,1001X=1001(2)X补=1,1001X=111(3)X原=0,1101X=1101(4)X原=1,1101X=1101(5)X反=0,1011X=1011(6)X反=1,1011X=100(7)X移=0,1001X=111(8)X移
2、=1,1001X=1001(9)X补=1,X=B,X128(10)X反=1,XB,X127(11)X原=1,X0(12)X移=1,X0P107 4.1X0.1101Y0.0110(设机器数长度为8位)X补=0.X补=1.2X补=溢出2X补=溢出X/2补=0.-X/2补=1.Y补=1.Y补=0.2Y补=1.2Y补=0.Y/2补=1.-Y/2补=0.-Y/4 补=0.P61:5、阶码(6位移码)尾数(6位原码)(1) X=-25/64=-0.B,Y=2.875=10.111BX浮=0,11111 1.11001=7F9H Y浮=1,00010 0.10111=897H(2) Z浮=9F4H=1,0
3、0111 1.10100=-80P61:6、机器数字长16位(1) 无符号整数:(2) 原码表示的定点整数:1,111110,11111即(3) 补码表示的定点整数:1,000000,11111即(4) 补码表示的定点小数:1.000000.11111即(5) 非规格化浮点数:阶码(8位移码)尾数(8位补码)最大数=阶码=1,尾数=0.最小数=阶码=1,尾数=1.最大负数=阶码=0,尾数=1.最小正数=阶码=0,尾数=0.(6) 规格化浮点数:最大数=阶码=1,尾数=0.最小数=阶码=1,尾数=1.最大负数=阶码=0,尾数=1.最小正数=阶码=0,尾数=0.P107:2、(1)(2)P108:
4、4142P108:551补码BOOTH算法52补码BOOTH算法P108:6、61原码恢复余数算法61原码加减交替算法62原码恢复余数算法62原码加减交替算法P108 71补码加减交替算法72补码加减交替算法P108:81阶码(5位补码)尾数(6位补码)(1)X=-1.625=-1.101B Y=5.25=101.01B X+YXY:1、对阶同上2、尾数相减: 11. + 11.01011 EX-Y补 = 11. 3、结果不需规格化 4、舍入处理:EX-Y补 1.00101 X-Y = 0,0011 1,00101 P108:82 X=0.2344 = 0.00111 Y= -0.1133=-
5、0.00011 XY:1、对阶同上2、尾数相减: 00.11100 + 00.01100 EX-Y补 = 01.01000 发生正溢 尾数右移,阶码加1 EX-Y补 = 0.10100 Mx-y = 1.1111 3、结果不需规格化 4、舍入处理:EX-Y补 0.10100 X-Y = 1,1111 0,10100P108:9-1阶码(5位移码)尾数(6位补码)(1)X=5.25=101.01B Y=-1.625=-1.101B X*Y9-1 X/Y: 9-2 X*Y 9-2 X/Y存储体系P225:2、(1)(2)(3)P225:3、(1) 最大主存容量=(2) 共需芯片;若采用异步刷新,则
6、刷新信号的周期为(3) 每块8字节,则Cache容量为,即c=9,Cache采用2路组相联映射,则r=1。主存容量为,即m=16。每块包含4个字,每字包含2个字节。主存字地址=462EH=00 0100 01,10 0010 11,10;因此该字映射到Cache的第139组。(4) 分析地址:128K的RAM区由SRAM芯片构成;分为8组,组与组之间进行字扩展;每个组内有2片进行位扩展。P225:5、平均访问时间其中:ta 平均访问时间;tc Cache的存储周期;tm 主存的存储周期;tp 磁盘的存储周期;hc Cache的命中率;hm 主存的命中率。所以,P168:6、命中率平均访问时间
7、e = tc/ta=40/45=8/9P168:7、4路组相联映射,所以r=2每块4字,所以b=2;每字32位,所以每字包含4字节。Cache容量为,故c=9主存容量为,故m=20(1) Cache共分为:2c-r = 29-2 = 128组。(2)P226:8、4路组相联映射,所以r=2每块64字,所以b=6;Cache容量为,故c=7主存容量为,故m=12主存字地址08447,位于主存的哪几块内呢?,即主存的第08447字位于连续的132块内。,因此这132块连续分布在第04大组内,其中在第4大组中只有4块。CPU第1次依次访问主存的08447字时不命中132次。Cache的变化如图所示C
8、PU从第2次开始直到第21次访问主存的08447字时,每轮不命中20次(从第04大组的前4块都不命中,其余都命中),Cache的变化如图所示因为,命中率设使用Cache比不使用Cache在速度上提高x倍,则指令系统12、地址指令0019HOPMOD001AHDISP第一条转移指令:0019HJMP001AH0006H(PC)=001AH,执行该JMP指令后(PC)=001AH+0006H=0020H第二条转移指令:0019HJMP001AH0025H(PC)=001AH,执行该JMP指令后(PC)=001AH+0025H=003FH13、寄存器-存储器型指令是指一个操作数来自寄存器,另一个操作
9、数来自存储器。(1)指令字长32位:OP(6)MOD(3)REG(4)ADDR(19)直接寻址时EA=ADDR,因此主存最大存储空间为219字。(假设存储器按字编址)间接寻址时EA=(ADDR),因此操作数地址存放在主存地址为0219-1的单元内,假设存储器按字编址,则EA应该是32位的地址,则主存最大存储空间为232字。(2)其实用32位通用寄存器做基址寄存器,类似于80X86机器上存储器分段管理。EA=32位基地址+偏移地址,所以EA是32位,则主存最大存储空间为232字。16、设某机寄存器字长16位,用16进制表示,已知:变址寄存器内容为0004H,PC的内容为0003H,内存中部分单元
10、内容如下: 地址:内容 地址:内容 0002H:000AH 0007H:000AH 0003H:0002H 0008H:0002H 0004H:0007H 0009H:0003H 0005H:0004H 000AH:0009H 0006H:0005H 000BH:0008H指令为双字长指令,格式如下:操作码,寻址方式码,寄存器号(16位)0002H直接地址/间接地址/立即数/相对位移量/形式地址(16位)0007H若当前指令分别为下列寻址方式时,试求出操作数填入下表。寻址方式EA=操作数直接0007H000AH间接000AH0009H立即/0007H变址0004H+0007H000bH某机器字
11、长16位,采用单字长指令,每个地址码6位。试采用操作码扩展技术,设计14条二地址指令,80条一地址指令,60条零地址指令。请给出指令编码示意图。双操作数指令格式:OP(4位)A1(6位)A2(6位)14条双操作数指令OP=0000OP=1101A1(6位)A2(6位)单操作数指令格式:OP(10位)A1(6位)80条双操作数指令OP=OP=OP=OP=A1(6位)无操作数指令格式:OP(16位)60条双操作数指令OP=00000OP=11011设某8位计算机,除HALT指令外,指令均为双字长,格式如下: OP(4位) M(2位)Rd(2位) A(8位)Rd为目的操作数的寄存器号,编码分配如下:
12、 00R0 01R1 10R2 11R3 M为源操作数的寻址方式,编码分配如下: 00立即数寻址 01直接寻址 10相对寻址 11变址寻址(变址寄存器为R3) A为源操作数的立即数、直接地址、间接地址或偏移地址。OP为操作码,编码分配如下: 0000ADD 0001SUB 0010AND 0011MOV 0100JMP0101INC(自增1) 1111HALT(动态停机)其中,假设:PC的内容为22H;变址寄存器R3的内容为30H;主存部分单元的内容如下: 主存地址:内容 主存地址:内容 主存地址:内容 20H: 22H 27H: 02H 2EH: 00H 21H: 33H 28H: 21H
13、2FH: 01H 22H: 35H 29H: 0FH 30H: 02H 23H: 20H 2AH: 48H 31H: 03H 24H: 01H 2BH: 01H 32H: 04H 25H: 20H 2CH: 55H 33H: 05H 26H: 1DH 2DH: F0H 34H: 06H 问:CPU启动执行指令到停机,期间执行了哪几条指令?写出每条指令的功能、寻址方式、操作数及执行结果。解:由于(PC)=22H,即程序的第一条指令地址为22H,从22H开始,执行到2DH(HALT指令)为止,共五条指令。经分析,所有指令的目的操作数的寻址方式均为寄存器寻址方式,为R1。下面列出每条指令的功能、源操
14、作数的寻址方式、源操作数及执行结果。PC指令助记符寻址方式EA源操作数执行结果22H35HMOV直接寻址20H(20H)=22H(R1)=22H23H20H24H01HADD立即数20H(R1)=(R1)+20H=42H25H20H26H1DHSUB变址寻址(R3)+02H=32H(32H)=04H(R1)=(R1)-04H=3EH27H02H28H21HAND立即数0FH(R1)=(R1)0FH=0EH29H0FH2AH48HJMP相对(PC)+01H=2CH+01H =2DH(PC)=2DH2BH01H2CH55H2DHF0HHALT停机控制器6、设某机平均执行一条指令需要两次访问内存,平
15、均需要三个机器周期,每个机器周期包含4个节拍周期。若机器主频为25MHz,试回答:1)若访问主存不需要插入等待周期,则平均执行一条指令的时间为多少?2)若每次访问内存需要插入2个等待节拍周期,则平均执行一条指令的时间是又多少?解:(1)(2)7、设某机主频为8MHz,每个机器周期包含4个节拍周期,该机平均指令执行速度为1MIPS。试回答:1)该机的平均指令周期是多少时间?2)平均每条指令周期包含几个机器周期?解:(1)(2)8、参见图741的数据通路,指令“INC R1”将R1寄存器的内容加1,画出其指令周期微程序流程图,并根据表711和表712写出每一条微指令码。解: INC R1;(R1)
16、+1R1BTOOTBFUNCFSS3-S0MCi空M6-M0110111000100110000100000000000110001011000001000010009、根据图741所示的模型机结构和数据通路,写出以下指令从取址到执行的全部微操作序列,说明各条指令需要哪几个机器周期,需要几次访问内存及完成什么操作。1)SUB A,R ,该指令完成(A)R(A),源操作数一个为寄存器寻址,目标操作数为指令提供的内存有效地址A。2)JMP 偏移量,该指令完成PC偏移量PC。解:(1)SUB A,R ;(A)R(A)指令为双字节格式:OP(SUB)*RdAddr所以,共需要8个机器周期,共访存4次。
17、(2)JMP DISP; (PC)DISPPC所以,共需要7个机器周期,共访存2次10、假设某机器主要部件有:程序计数器PC、指令寄存器IR、通用寄存器R0R3、暂存器DD1和DD2、ALU、移位器、存储器地址寄存器MAR及存储器M。1)要求采用单总线结构,画出包含上述部件的逻辑框图,并注明数据流动方向。2)画出ADD (R1),(R2)指令在取指和执行阶段的操作步骤流程图。R1寄存器存放目标操作数地址,R2寄存器存放源操作数地址。3)写出各操作步骤所需的全部微操作命令。解:(1)(2)(3)取ADD指令的微指令PC-B、B-MAR、PC+1 M-R#、B-IR指令译码信号MAP有效执行ADD
18、指令的微指令 R2-B#、B-MAR M-R#, B-DD1 R1-B#、B-MAR M-R#, B-DD2 “+”,ALU-B#,M-W#11、假设某机共有76条指令,平均每一条指令由11条微指令组成,其中有一条取指令的微指令是所有指令公共的,该机共有微命令31个,微指令的微操作码采用直接控制法。试问: 1)该机微指令长度为多少?2)控制存储器的容量应为多少?解:设微指令共有N条,N=76*11-75=761条;下址字段长为X位,2X 761,则X10(1)所以,该机微指令长度=31+10=41位(2)控制存储器的容量应该76141位,取102441位。12、某机采用微程序控制方式,其存储器
19、容量为51248(位),微程序在整个控制存储器中实现转移,可控制微程序的条件共4个,判别测试字段采用编译法。微指令采用水平型格式,后继微指令地址采用判定方式,如图所示: 微命令字段 判别测试字段 下地址字段 操作控制 顺序控制 (1) 微指令中的三个字段分别应多少位?(2) 画出对应这种微指令格式的微程序控制器逻辑框图。解:(1)22=4,512=29控制字段(48-9-2=37位)判别测试字段(2位)下址字段(9位)(2)14、图746为某模型机的微程序流程图,图中每一个框表示一条微指令。在点(1)处为指令译码后转入指令的微程序入口的多路分支点,由指令寄存器IR的I5I4两位来决定转入哪一个
20、入口。在点(2)处根据状态条件F实现条件转移,微指令中判断测试位为直接控制法。控存容量能容纳图746所列出的微指令即可。1)微指令的判断测试位需要几位二进制?微指令的下址字段需要几位?2)在图中标出每条微指令的微地址。3)写出每条微指令的下址字段内容及判断测试字段码。4)画出微地址转移逻辑电路图。解:所列出的微指令共25条,控存容量能容纳这25条微指令即可,则下址字段长5位;(1)因为微指令中判断测试位为直接控制法,只有2种转移测试和顺序执行,所以判断测试位需要3位二进制。(2)假如微指令B的下址字段为10000B,设微程序入口地址根据I5I4两位修改微指令B的下址字段的末两位,则微程序入口地
21、址=100 I5I4 B。假如微指令G的下址字段为11000B,设条件转移地址根据F位修改微指令G的下址字段的第1位,则条件转移地址=1100F B。则每条微指令的微地址如图所示。(3) 设3位判断测试字段码:判断测试字段码=1H:顺序执行(后继微地址 = 下址字段)判断测试字段码=2H:微程序入口散转(后继微地址 = 下址字段末两位 AND I5I4 )判断测试字段码=4H:条件转移(后继微地址 = 下址字段第1位 AND F)微指令判断测试字段码下址字段内容微指令判断测试字段码下址字段内容A1H01HN1H0CHB2H10HO1H15HC1H02HP1H16HD1H06HQ1H05HE1H0AHR1H09HF1H0FHS1H0DHG4H18HT1H0EHH1H07HU1H16HI1H08HV1H16HJ1H14HW1H0EHK1H03HX1H16HL1H04HY1H00HM1H08H(4)专心-专注-专业