在向MIPS单周期数据路径添加更多功能方面需要帮助 [英] Need help in adding more functionality to MIPS Single Cycle Datapath
本文介绍了在向MIPS单周期数据路径添加更多功能方面需要帮助的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在尝试将jal功能添加到以下内容中,但我仍然坚持如何工作.我知道它将旧的PC+4
值存储在$ra
寄存器中,然后将控件转移到通过返回$ra
来转移回控件的函数中,但是我该如何在硬件中实现它呢?
I am trying to add jal functionality to the following but I am stuck with how does it work. I know that it stores the old PC+4
value in the $ra
register and then transfers the control to the function which transfers back the control by return $ra
but how do I implement it in the hardware?
推荐答案
您需要做两件事.
- 在寄存器的输入处添加一个多路复用器,以便可以选择PC + 4值作为要写入的数据.使用适当的控制信号,这将使您可以编写PC + 4,作为"jal $ ra"指令的附加效果.
- 执行返回的"jr $ ra"指令.您将需要在一个逻辑链中添加一个多路复用器,以选择下一个PC,以便当指令为"jr xxx"时,可以将寄存器文件中的读取数据1"选择为下一个PC.
这篇关于在向MIPS单周期数据路径添加更多功能方面需要帮助的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文