美文网首页
503 - 3种指令及控制信号

503 - 3种指令及控制信号

作者: 航航大魔王 | 来源:发表于2017-08-01 09:36 被阅读319次

运算指令的控制信号

加法指令的操作步骤

addu rd, rs, rt
MEM[PC] - 从指令存储器中取回指令
R[rd] = R[rs] + R[rt] - 指令指定的操作
PC = PC + 4 - 计算下一条指令的地址

①Instruction = MEM[PC]

  • 从指令存储器中取回指令
  • 所有指令均有此步骤
image.png

假设在系统中的某一个时刻 T0 所示的这个时钟上升沿之后很短的一段时间,此时 PC 寄存器的输入已经稳定,它的输出就是当前要取回的这条指令的地址。这个信号会连接到指令存储器的地址输入端。 经过一小段访问时间之后, 指令存储器就会将这个地址所指定的存储单元的内容放在其输出端。也就是我们要取回的指令的二进制编码。

我们用红色标出了这个步骤所关注的有效的信号。 同时我们注意左边的这个时钟信号。 我们用以标识当前时刻的这条虚线也向后移动了一小段。

②R[rd] = R[rs] + R[rt]<——记清楚这几个寄存器的位置

image.png

加法运算的步骤
①从IFU中取操作数,分别由rs和rt寄存器传输至busA和busB
②置IFU的控制信号为PC+4,等待读取下一条指令(与当前加法运算无关)
③置busB的输出端ALUSrc的控制信号为0(加法操作要用rt,不需要立即数),此时立即数扩展部件Extender失效,故置ExtO为x(0、1任意值);
④置ALUCtr的控制信号为ADD,开始执行加法运算;
⑤置数据存储器DM的写使能信号为0(加法指令不需要读写数据存储器。 因此需要把数据存储器的写使能信号作为无效。 否则在下一个时钟上升沿, 数据存储器会采样它的数据输入,从而改变其中的内容。 );
⑥由⑤可得,DM无效,因此置MemtoReg信号为0;
⑦置RegWr信号为“1”;置RegDst信号为1(经ALU运算后产生的结果需要通过rd寄存器写入寄存器堆)

image.png image.png image.png

ori指令的操作步骤

ori rt, rs, imm16
MEM[PC] 从指令存储器中取回指令
R[rt] = R[rs] | ZeroExt[imm16] 指令指定的操作
PC = PC + 4 计算下一条指令的地址

image.png

主要看第二步R[rt] = R[rs] | ZeroExt[imm16] 指令指定的操作

与加法运算相比,只是添加了立即数,即:
①IFU的<0,15>位域连接imm16立即数;
②使用Extender立即数扩展部件(置ExtOp = “zero”零扩展,ALUSrc = 1);
③置RegDst = 0(回写入rt寄存器)

image.png

访存指令的控制信号

Load指令的操作步骤

lw rt, imm16(rs)
MEM[PC] 从指令存储器中取回指令
R[rt] = DataMemory{R[rs] + SignExt[imm16]} 指令指定的操作
PC = PC + 4 计算下一条指令的地址

还是来看R[rt] = DataMemory{R[rs] + SignExt[imm16]} 指令指定的操作
同样是一条I型指令,与逻辑或指令的不同之处在于:
①扩展部件要使用符号扩展,即置ExtOp = “sign”;
②访问但不写入数据存储器DM,即置MemWr = 0; MemtoReg = 1;

image.png

Store指令的操作步骤

sw rt, imm16(rs)
MEM[PC] 从指令存储器中取回指令
DataMemory{R[rs] + SignExt[imm16]} = R[rt] 指令指定的操作
PC = PC + 4 计算下一条指令的地址

DataMemory{R[rs] + SignExt[imm16]} = R[rt] 指令指定的操作:

对于store指令,也需要将rs寄存器中的内容和立即数 的符号扩展进行加法运算,并以此作为地址访问数据存储器, 不过不是读出,而是写入,

因为对store指令,我们不需要改写寄存器堆的内容, 所以无论选择哪个通路,都是没有意义的。 在这里,我们就设置这个控制信号,可以是0,也可以是1,就用x来进行标记。这样,这个多选器总会选出一组信号, 最终送到寄存器堆的数据输入端。

我们只需要设置寄存器堆的写使能信号为无效, 在时钟上升沿到来的时候,寄存器堆的内容就不会发生改变。也正因为如此, 这个要写入的寄存器编号,无论设成rb还是rt,也都是可以的, 这就是对于store指令的控制信号的设置方法。

image.png

分支指令的控制信号

相关文章

  • 503 - 3种指令及控制信号

    运算指令的控制信号 加法指令的操作步骤 addu rd, rs, rt① MEM[PC] - 从指令存储器中取回指...

  • 控制器、微程序控制

    1.控制器的功能 (1)取指令(指令地址,控制信号) (2)分析指令(解释指令,指令译码) (3)执行指令 (4)...

  • 电器理论基础(2)典型电器的结构原理

    典型电器控制角度: 1.感测器官 接收信号,做出判断,发出指令 2.执行器官 输出指令型号,实现控制目的 3.连动...

  • 2019年上午综合知识真题知识点汇总

    知识点汇总:1.计算机执行指令的过程中,需要由CPU的控制器产生每条指令的操作信号并将信号送往相应的部件进行处理,...

  • VAL语言6种监控指令,不知道怎么做工程师

    工业机器人VAL语言的监控指令有六类,分别为位置及姿态定义指令、程序编辑指令、列表指令、存储指令、控制程序执行指令...

  • Sass总结(二)

    控制指令 Sass中可使用条件控制指令和循环控制指令。 @if指令 @for指令 @for指令有两种形式,一种是@...

  • linux 信号

    SIGHUP挂起信号 SIGINT 中断信号 SIGQUIT 退出信号 SIGILL 非法指令 SIGTRAP 跟...

  • 简单-CPU的结功能构

    CPU功能:1.控制器功能 取指令 分析指令(指令控制) PC IR 执行指令,发出各种操作命令(操作控制)CU ...

  • 文字信号灯

    广播说 跨海大桥的交通信号灯 属于远程控制 信号指令 有时 不能同步显示 今天早晨 我在桥上 艳阳高照 晴空万里 ...

  • 舞钢BB503钢板的技术标准(热处理及性能)

    舞钢BB503钢板的技术标准(热处理及性能) 1、BB503钢板的简介: BB503为镇静钢,是高炉炉壳钢,主要用...

网友评论

      本文标题:503 - 3种指令及控制信号

      本文链接:https://www.haomeiwen.com/subject/skedlxtx.html