在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
芯片精品文章合集(500篇!) 创芯人才网--重磅上线啦!
查看: 5585|回复: 11

[求助] 请教一个mips汇编的问题

[复制链接]
发表于 2010-11-11 01:23:22 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
如果在带流水线的设计中,
有这样两条指令,





  1. add $t0, $t1, $t2    # t0=t1+t2
  2. sub $t3, $t0, $t4    # t3=t0-t4



复制代码


如果我是需要做t3=t1+t2-t4,这里有一个data hazard
但假如我是需要先做t3=t0-t4, 然后再更新t0到新值,也就是t0=t1+t2,那么是不是应该把sub语句放到add语句之前。
像现在这样add在前,sub在后,是无法做出上述操作的。

如果硬件中没有对data hazard的处理,看起来是可以那么做,但所有data hazard就要人工处理;
如果硬件中有对data hazard的处理,看起来就不可以这么做,所以需要调整一下语句的顺序。


请问,是这样吗?谢谢。
发表于 2010-11-13 23:35:38 | 显示全部楼层
现在的硬件应该都可以检测出data hazard,你那两条指令执行下来结果就是t3=t1+t2-t4
 楼主| 发表于 2010-11-14 12:53:47 | 显示全部楼层
其实我想自己实现一个,在写模拟器,遇到这么个问题,想看看人家是怎么实现的。
网上下了几个模拟器,一般都不带流水,没法参考。。。
谢谢楼上,我大概知道该怎么做了。
发表于 2010-12-5 18:52:37 | 显示全部楼层
多谢louzhu分享!
发表于 2010-12-8 00:05:02 | 显示全部楼层
这个,要学习一下哦!!
发表于 2011-2-19 14:22:53 | 显示全部楼层
对于DATA HAZARD的处理,MIPS是通过的流水线的forwarding path技术避免流水停顿,提高其执行效率的.
发表于 2011-10-10 22:47:47 | 显示全部楼层
回复 7# haikuo


    forwarding bus只能是提前一个时钟周期的时间,不能从根本上解决楼主的问题吧。这个可以做硬件的指令优化来实现。也可以对编译器进行优化。
发表于 2011-11-19 16:33:15 | 显示全部楼层
回复 4# patrick007

请问下怎么在网上找mips的模拟器啊,我想找个带bootloader,编译器,cpu功能级模拟的。但是在网上没找到啊。
请问你这里有这样的模拟器么我的邮箱a68405819@hotmail.com。要是你没有,能给我说下你以前找的模拟器是叫什么名字吗
 楼主| 发表于 2011-11-25 09:26:57 | 显示全部楼层
回复 9# ttandtt


    我找过一些,只有MARS最好使。你可以搜一下
 楼主| 发表于 2011-11-25 09:28:33 | 显示全部楼层
但是MARS没有流水的体现。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条


小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-12-22 20:18 , Processed in 0.027422 second(s), 10 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表