计算机指令的流水线执行与流水线冒险

目录

计算机指令流水线

流水线冒险

结构冒险

数据冒险

控制冒险


计算机指令流水线

流水线方式的洗衣房可以以并行的方式提高性能

计算机执行指令,同样可以以流水线的方式并行

MIPS 流水化的数据通路

流水线冒险

下一周期不能按时执行下一条指令

结构冒险

数据冒险

一条指令依赖于前面某条执行的计算结果

add s0, t0, t1 sub t2, s0, t3

下一条指令需要气泡停顿等待前面计算出结果

前推/旁路(forwarding/bypassing)

不要等待计算结果保存到目的寄存器,增加一条额外数据通路,将计算的结果直接传给下一条指令计算的输入

但是并非所有冒险都能通过前推来避免气泡停顿

lw s0, 20(t1)
sub t2, s0, $t3

前推+阻塞

在需要使用前一个指令的结果时,前一个指令还没有拿到结果,此时需要停顿一下

还可以通过调整指令的顺序来避免阻塞等待

控制冒险

分支预测

更有效的分析预测

相关推荐
咕噜签名-铁蛋2 分钟前
双雄争霸:Windows与Linux操作系统的技术博弈与生态进化
服务器
看-清15 分钟前
Docker离线安装部署xxl-job流程
运维·docker·容器
建群新人小猿27 分钟前
陀螺匠企业助手-我的日程
android·大数据·运维·开发语言·容器
徐安安ye40 分钟前
Flutter 车载系统开发:打造符合 Automotive Grade Linux 标准的 HMI 应用
linux·flutter·车载系统
webbodys1 小时前
Python文件操作与异常处理:构建健壮的应用程序
java·服务器·python
lifewange1 小时前
Linux 服务管理故障排查小手册
linux·运维·服务器
十六年开源服务商1 小时前
WordPress网站信誉评价与运维服务怎样提升
运维
LUCIFER1 小时前
[驱动之路(九)——UART(串口)子系统]学习总结,万字长篇,一文彻底搞懂UART(串口)子系统(含串口数据收发流程解析)
linux·驱动开发
无代码专家1 小时前
生产ERP解决方案:重构制造企业数字化运营体系
运维·低代码·重构·制造
忙里偷闲学python1 小时前
ceph介绍和安装
linux·ceph·kubernetes