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

目录

计算机指令流水线

流水线冒险

结构冒险

数据冒险

控制冒险


计算机指令流水线

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

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

MIPS 流水化的数据通路

流水线冒险

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

结构冒险

数据冒险

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

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

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

前推/旁路(forwarding/bypassing)

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

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

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

前推+阻塞

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

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

控制冒险

分支预测

更有效的分析预测

相关推荐
gis分享者3 分钟前
如何在 Shell 脚本中使用管道(pipeline)实现数据传递?(容易)
linux·pipeline·shell·脚本·管道·数据传递
2501_916007478 分钟前
在 CICD 中实践 Fastlane + Appuploader 命令行,构建可复制的 iOS 自动化发布流程
android·运维·ios·小程序·uni-app·自动化·iphone
model20059 分钟前
Alibaba linux 3安装LAMP(2)
linux·运维·服务器
喵了meme14 分钟前
Linux学习日记16:守护进程
linux·服务器·学习
一匹电信狗18 分钟前
【Linux我做主】进程实践:手动实现Shell
linux·运维·服务器·c++·ubuntu·小程序·开源
ccmedu22 分钟前
Docker 安装mysql8.0 主从同步
运维·docker·容器
BUG_MeDe28 分钟前
Linux 下VRF的简单应用
linux·运维·服务器
babytiger34 分钟前
用python在服务器上开个可以输入帐号密码的代理服务器
运维·服务器
Sleepy MargulisItG37 分钟前
Linux 基础指令详解(常用)
linux
向山行_wolf39 分钟前
ubuntu22.04鼠标速度配置
运维·服务器