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

目录

计算机指令流水线

流水线冒险

结构冒险

数据冒险

控制冒险


计算机指令流水线

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

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

MIPS 流水化的数据通路

流水线冒险

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

结构冒险

数据冒险

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

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

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

前推/旁路(forwarding/bypassing)

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

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

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

前推+阻塞

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

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

控制冒险

分支预测

更有效的分析预测

相关推荐
zhanghaofaowhrql7 小时前
Cursor+GitOps:自动化运维新姿势
运维·自动化
weixin_471383038 小时前
Docker - 05 - 构建流程
运维·docker·容器
夏玉林的学习之路9 小时前
如何远程连接服务器
运维·服务器
风曦Kisaki10 小时前
#Linux数据库管理Day06:主从同步与MaxScale读写分离
linux·运维·数据库
小楼昨夜又东风12610 小时前
使用python快速拉包
linux
影寂ldy10 小时前
C# try-catch 异常处理全套笔记
服务器·数据库·c#
fei_sun11 小时前
黑洞路由(Null Route/空接口路由)
服务器·前端·javascript
Tipriest_11 小时前
ubuntu创建和更换当前swap大小
linux·运维·ubuntu
雨辰AI11 小时前
生产级实战:人大金仓 V9 标准化运维手册(日常巡检 + 监控告警 + 应急处置)
java·运维·数据库·后端
ejinxian12 小时前
微虚拟机 smolvm 与Docker 容器比较
运维·docker·容器·smolvm