503 - 3种指令及控制信号

运算指令的控制信号

加法指令的操作步骤

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

分支指令的控制信号

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容