《指令系统》12、地址指令0019HOPMOD001AHDISP第一条转移指令:0019HJMP001AH0006H(PC)=001AH,执行该JMP指令后(PC)=001AH+0006H=0020H第二条转移指令:0019HJMP001AH0025H(PC)=001AH,执行该JMP指令后(PC)=001AH+0025H=003FH13、寄存器-存储器型指令是指一个操作数来自寄存器,另一个操作数来自存储器。(1)指令字长32位:OP(6)MOD(3)REG(4)ADDR(19)直接寻址时EA=ADDR,因此主存最大存储空间为219字。(假设存储器按字编址)间接寻址时EA=(ADDR),因此操作数地址存放在主存地址为0~219-1的单元内,假设存储器按字编址,则EA应该是32位的地址,则主存最大存储空间为232字。(2)其实用32位通用寄存器做基址寄存器,类似于80X86机器上存储器分段管理。EA=32位基地址+偏移地址,所以EA是32位,则主存最大存储空间为232字。16、设某机寄存器字长16位,用16进制表示,已知:变址寄存器内容为0004H,PC的内容为0003H,内存中部分单元内容如下:地址:内容地址:内容0002H:000AH0007H:000AH0003H:0002H0008H:0002H0004H:0007H0009H:0003H0005H:0004H000AH:0009H0006H:0005H000BH:0008H指令为双字长指令,格式如下:操作码,寻址方式码,寄存器号(16位)0002H直接地址/间接地址/立即数/相对位移量/形式地址(16位)0007H若当前指令分别为下列寻址方式时,试求出操作数填入下表。寻址方式EA=操作数直接0007H000AH间接000AH0009H立即/0007H变址0004H+0007H0008H某机器字长16位,采用单字长指令,每个地址码6位。试采用操作码扩展技术,设计14条二地址指令,80条一地址指令,60条零地址指令。请给出指令编码示意图。双操作数指令格式:OP(4位)A1(6位)A2(6位)14条双操作数指令OP=0000…OP=1101A1(6位)A2(6位)单操作数指令格式:OP(10位)A1(6位)80条双操作数指令OP=1110000000…OP=1110111111OP=1111000000…OP=1110001111A1(6位)无操作数指令格式:OP(16位)60条双操作数指令OP=1110010000000000…OP=1110010000111011设某8位计算机,除HALT指令外,指令均为双字长,格式如下:OP(4位)M(2位)Rd(2位)A(8位)其中,假设:PC的内容为22H;变址寄存器R3的内容为30H;主存部分单元的内容如下:问:CPU启动执行指令到停机,期间执行了哪几条指令?写出每条指令的功能、寻址方式、操作数及执行结果。解:由于(PC)=22H,即程序的第一条指令地址为22H,从22H开始,执行到2DH(HALT指令)为止,共五条指令。经分析,所有指令的目的操作数的寻址方式均为寄存器寻址方式,为R1。下面列出每条指令的功能、源操作数的寻址方式、源操作数及执行结果。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=0EH·29H0FH2AH48HJMP相对(PC)+01H=2CH+01H=2DH——(PC)=2DH2BH01H2CH55H——————————2DHF0HHALT——————停机Rd为目的操作数的寄存器号,编码分配如下:00——R001——R110——R211——R3M为源操作数的寻址方式,编码分配如下:00—立即数寻址01—直接寻址10—相对寻址11—变址寻址(变址寄存器为R3)A为源操作数的立即数、直接地址、间接地址或偏移地址。OP为操作码,编码分配如下:0000——ADD0001——SUB0010——AND0011——MOV0100——JMP0101——INC(自增1)……1111——HALT(动态停机)主存地址:内容主存地址:内容主存地址:内容20H:22H27H:02H2EH:00H21H:33H28H:21H2FH:01H22H:35H29H:0FH30H:02H23H:20H2AH:48H31H:03H24H:01H2BH:01H32H:04H25H:20H2CH:55H33H:05H26H:1DH2DH:F0H34H:06H《控制器》6、设某机平均执行一条指令需要两次访问内存,平均需要三个机器周期,每个机器周期包含4个节拍周期。若机器主频为25MHz,试回答:1)若访问主存不需要插入等待周期,则平均执行一条指令的时间为多少?2)若每次访问内存需要插入2个等待节拍周期,则平均执行一条指令的时间是又多少?解:(1)MHz2511主频时钟周期s48.043时钟周期平均指令周期(2)s64.02243时钟周期时钟周期平均指令周期7、设某机主频为8MHz,每个机器周期包含4个节拍周期,该机平均指令执行速度为1MIPS。试回答:1)该机的平均指令周期是多少时间?2)平均每条指令周期包含几个机器周期?解:(1)s11机器速度平均指令周期(2)284机器周期平均每条指令机器周期MHz8、参见图7-41的数据通路,指令“INCR1”将R1寄存器的内容加1,画出其指令周期微程序流程图,并根据表7-11和表7-12写出每一条微指令码。解:INCR1;(R1)+1R1PCAR、PC+1RAMIRJ1#R1DA1DA1+1R1BTOOTBFUNCFSS3-S0MCi空M6-M011011100010000000000001001100001000000000000001100000000110000000001000000101100000000000000010010000100000000000000019、根据图7-41所示的模型机结构和数据通路,写出以下指令从取址到执行的全部微操作序列,说明各条指令需要哪几个机器周期,需要几次访问内存及完成什么操作。1)SUBA,R,该指令完成(A)-R→(A),源操作数一个为寄存器寻址,目标操作数为指令提供的内存有效地址A。2)JMP偏移量,该指令完成PC+偏移量→PC。解:(1)SUBA,R;(A)-R→(A)指令为双字节格式:OP(SUB)**RdAddrPCAR、PC+1RAMIRJ1#RsDA2DA1-DA2RAMPCAR、PC+1RAMDA1RAMAR所以,共需要8个机器周期,共访存4次。(2)JMPDISP;(PC)+DISP→PCPCAR、PC+1RAMIRJ1#PCDA2DA1+DA2PCPCAR、PC+1RAMDA1所以,共需要7个机器周期,共访存2次10、假设某机器主要部件有:程序计数器PC、指令寄存器IR、通用寄存器R0~R3、暂存器DD1和DD2、ALU、移位器、存储器地址寄存器MAR及存储器M。1)要求采用单总线结构,画出包含上述部件的逻辑框图,并注明数据流动方向。2)画出ADD(R1),(R2)指令在取指和执行阶段的操作步骤流程图。R1寄存器存放目标操作数地址,R2寄存器存放源操作数地址。3)写出各操作步骤所需的全部微操作命令。解:(1)指令译码MICRO-CONTROLLERUNITDMEMAM-WM-RMEMUNITPCPC+1PC-BB-PCB-MARMARIRB-IRINSUNITALU(74LS181)+-*/DD2B-DD2DD1B-DD1ALU-BALUUNITR3-BR0-BR0(74LS273)B-R0R1R2R1-BB-R1B-R2REGUNITR2R2-BB-R3MAP移位器SHIFTB-SHIFT循环左移循环右移...算术右移...(2)PCMAR、PC+1RAMIRMAP#RAMDD2DD1+DD2RAMR1MARR2MARRAMDD1(3)取ADD指令的微指令①PC-B#、B-MAR、PC+1②M-R#、B-IR③指令译码信号MAP#有效执行ADD指令的微指令①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,则X≥10(1)所以,该机微指令长度=31+10=41位(2)控制存储器的容量应该≥761×41位,取1024×41位。12、某机采用微程序控制方式,其存储器容量为512×48(位),微程序在整个控制存储器中实现转移,可控制微程序的条件共4个,判别测试字段采用编译法。微指令采用水平型格式,后继微指令地址采用判定方式,如图所示:←操作控制→←——————顺序控制————————→(1)微指令中的三个字段分别应多少位?(2)画出对应这种微指令格式的微程序控制器逻辑框图。微命令字段判别测试字段下地址字段解:(1)22=4,512=29控制字段(48-9-2=37位)判别测试字段(2位)下址字段(9位)(2)微地址散转及修改电路μAR控制存储器控制字段测试下址图7-20判定方式产生后继微地址的原理图开机置微地址初值+状态标志操作码地址码IR14、图7-46为某模型机的微程序流程图,图中每一个框表示一条微指令。在点(1)处为指令译码后转入指令的微程序入口的多路分支点,由指令寄存器IR的I5I4两位来决定转入哪一个入口。在点(2)处根据状态条件F实现条件转移,微指令中判断测试位为直接控制法。控存容量能容纳图7-46所列出的微指令即可。1)微指令的判断测试位需要几位二进制?微指令的下址字段需要几位?2)在图中标出每条微指令的微地址。3)写出每条微指令的下址字段内容及判断测试字段码。4)画出微地址转移逻辑电路图。解:所列出的微指令共25条,控存容量能容纳这25条微指令即可,则下址字段长5位;(1)因为微指令中判断测试位为直接控制法,只有2种转移测试和顺序执行,所以判断测试位需要3位二进制。(2)假如微指令B的下址字段为10000B,设微程序入口地址根据I5I4两位修改微指令B的下址字段的末两位,则微程序入口地址=100I5I4B。假如微指令G的下址字段为11000B,设条件转移地址根据ABEFIJONSWTDCHMRGLKQPUXVY(1)(2)I5I4=00I5I4=01I5I4=10I5I4=11F=0F=100H01H10H11H12H13H02H18H19H03H04H05H06H07H08H09H0AH0BH0CH0DH0EH0FH14H15H16HF位修改微指令G的下址字段的第1位,则条件转移地址=1100FB。则每条微指令的微地址如图所示。(3)设3位判断测试字段码:判断测试字段码=1H:顺序执行(后继微地址=下址字段)判断测试字段码=2H:微程序入口散转(后继微地址=下址字段末两位ANDI5I4)判断测试字段码=4H:条件转移(后继微地址=下址字段第1位ANDF)微指令判断测试字段码下址字段内容微指令判断测试字段码下址字段内容A1H01HN1H0CHB2H10HO1H15HC1H02HP1H16HD1H06HQ1H05HE1H0AHR1H09HF1H0FHS1H0DHG4H18HT1H0EHH1H07HU1H16HI1H08HV1