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

目录

计算机指令流水线

流水线冒险

结构冒险

数据冒险

控制冒险


计算机指令流水线

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

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

MIPS 流水化的数据通路

流水线冒险

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

结构冒险

数据冒险

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

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

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

前推/旁路(forwarding/bypassing)

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

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

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

前推+阻塞

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

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

控制冒险

分支预测

更有效的分析预测

相关推荐
网硕互联的小客服9 分钟前
Windows2008 如何禁用FSO?
运维·服务器·网络·windows·安全
不惑_18 分钟前
[特殊字符] 在 Linux 上设置 SQLite
linux·jvm·sqlite
上线就吃代码32 分钟前
【等保测评】数据库数据库配置have_ssl参数为yes
服务器·数据库·ssl
塔能物联运维39 分钟前
物联网运维中的多模态数据融合与智能决策优化技术
运维·物联网
xingyue_S42 分钟前
LVS负载均衡群集(一) -- NAT模式
运维·负载均衡·lvs
淮北49444 分钟前
如何在ubuntu调用exe文件
linux·运维·ubuntu
Pailugou1 小时前
使用socket实现TCP服务端
服务器·网络·tcp/ip
蒋星熠1 小时前
全栈开发实战指南:从架构设计到部署运维
运维·c++·python·系统架构·node.js·devops·c5全栈
HalvmånEver1 小时前
Linux:基础开发工具(一)
linux·运维·服务器·开发语言·学习·进阶学习
real_haha2 小时前
Fabric 学习资料总结 持续更新
运维·fabric