《大话处理器》连载——微架构(7) 流水线上的冒险——数据冒险

本文介绍了处理器流水线中的数据冒险问题,如寄存器访问和内存访问的数据冒险,并探讨了如何通过增加等待周期和直通(Forwarding)技术来解决这些问题,以避免执行错误并提高处理器效率。然而,直通并不总能避免停顿(stall),在某些情况下仍需要额外的等待周期。
摘要由CSDN通过智能技术生成

(2) 数据冒险

        流水线使原先有先后顺序的指令同时处理,当出现某些指令的组合时,可能会导致指令使用了错误的数据。

看下面这个例子:

寄存器访问的数据冒险

 

        add R1,R2,R3将寄存器R2和R3的和赋给R1,add R4,R1,R5将寄存器R1和R5的和赋给R4,很明显,R1在第1条指令中被更新,然后在第2条指令中使用,可是R1必须在第5个cycle之后才被更新,而指令2再第4个cycle就要访问R1,这时的R1还不是正确的值,执行结果出错。

        一种解决方法是在这2条语句之间增加2个cycle的等待:

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值