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

目录

计算机指令流水线

流水线冒险

结构冒险

数据冒险

控制冒险


计算机指令流水线

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

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

MIPS 流水化的数据通路

流水线冒险

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

结构冒险

数据冒险

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

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

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

前推/旁路(forwarding/bypassing)

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

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

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

前推+阻塞

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

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

控制冒险

分支预测

更有效的分析预测

相关推荐
郝学胜-神的一滴26 分钟前
使用Linux系统函数递归遍历指定目录
linux·运维·服务器·开发语言·c++·软件工程
pusue_the_sun32 分钟前
操作系统:进程的短程调度
运维·服务器
landian00433 分钟前
kubuntu24.04 换国内ustc源
linux·kubuntu24.04
七度光阴;1 小时前
Docker入门手册
运维·docker·容器
DuHz2 小时前
C程序中的数组与指针共生关系
linux·c语言·开发语言·嵌入式硬件·算法
shuair2 小时前
mysql8支持远程访问 -mysql5.7支持远程访问
linux·mysql
软件技术员2 小时前
使用ACME自动签发SSL 证书
服务器·网络协议·ssl
Murphy_lx2 小时前
Linux系统--信号(4--信号捕捉、信号递达)陌生概念篇
linux·运维·服务器
weixin_405023373 小时前
使用docker 安装部署easy-mock
运维·docker·容器
Asuncion0073 小时前
Docker核心揭秘:轻量级虚拟化的革命
服务器·开发语言·docker·云原生