体系结构 | 流水线 | 流水线相关 | 流水线冲突

目录

相关:

相关有3种类型

一、数据相关

二、名相关

三、控制相关

流水线冲突

一、结构冲突

二.数据冲突

三、控制冲突


相关:

两条指令之间存在某种依赖关系。如果两条指令相关,则它们就有可能不能在流水线中重叠执行或者只能部分重叠执行。

相关有3种类型

  1. 数据相关(也称真数据相关)
  2. 名相关
  3. 控制相关

一、数据相关

对于两条指令i(在前,下同)和j(在后,下同),如果下述条件之一成立,则称指令j指令i数据相关。

  1. 指令j使用指令i产生的结果;
  2. 指令j与指令k数据相关,而指令k又与指令i数据相关。

数据相关具有传递性。数据相关反映了数据的流动关系,即如何从其产生者流动到其消费者。

当数据的流动是经过寄存器时,相关的检测比较直观和容易。

当数据的流动是经过存储器时,检测比较复杂。

相同形式的地址其有效地址未必相同;

形式不同的地址其有效地址却可能相同。

二、名相关

名:指令所访问的寄存器或存储器单元的名称。

如果两条指令使用相同的名,但是它们之间并没有数据流动,则称这两条指令存在名相关。

指令j指令i之间的名相关有两种:

  • 反相关:如果指令j写的名与指令i读的名相同,则称指令ij发生了反相关。

指令j写的名=指令i读的名

  • 输出相关:如果指令j和指令i写相同的名,则称指ij发生了输出相关。

指令j写的名=指令i写的名

名相关的两条指令之间并没有数据的传送。如果一条指令中的名改变了,并不影响另外一条指令的执行。

换名技术:通过改变指令中操作数的名来消除名相关。对于寄存器操作数进行换名称为寄存器换名。既可以用编译器静态实现,也可以用硬件动态完成。

三、控制相关

流水线冲突

一、结构冲突

有时流水线设计者允许结构冲突的存在

主要原因:减少硬件成本如果把流水线中的所有功能单元完全流水化,或者 重复设置足够份数,那么所花费的成本将相当高。

二.数据冲突

      当相关的指令靠得足够近时,它们在流水线中的重叠执行或者重新排序会改变指令读/写操作数的顺序,使之不同于它们串行执行时的顺序,则发生了数据冲突。

数据冲突分为三种:写后读冲突、写后写冲突、读后写冲突

三、控制冲突

  • 21
    点赞
  • 117
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
很抱歉,作为人工智能,我无法提供思维导图。但我可以为您介绍一下流水线工作原理和冲突处理方法。 计算机体系结构流水线的工作原理: 流水线是一种计算机结构,用于提高指令处理速度。流水线将一个指令处理分成若干个流水段,每个流水段负责执行一个指令处理的一部分。同时,多条指令可以在不同的流水段同时处理,从而提高了处理效率。 流水线中一般包含以下五个流水段: 1. 取指令(IF):从内存中读取指令。 2. 指令译码(ID):将指令翻译为计算机可以理解的指令。 3. 执行指令(EX):执行指令的操作。 4. 存储访问(MEM):访问内存来获取数据。 5. 写回结果(WB):将执行的结果写回内存或寄存器中。 冲突处理方法: 1. 数据相关(Data Hazards):当一条指令需要用到另一条指令才能执行时,就会出现数据相关。 解决方法: ① 前推技术(Forwarding):让结果直接流动到需要的地方,绕过数据相关的指令。 ② 排队技术(Stalling):将流水线暂停,等待需要的数据指令完成。 2. 控制相关(Control Hazards):当分支指令的结果未知时,即分支指令的条件尚未满足,就会出现控制相关。 解决方法: ① 预测分支指令的结果,提前预测好接下来的指令,以减少等待时间。 ② 延迟槽技术(Delayed Branch):在分支指令之后加入一个无操作指令,使得下一条指令一定会执行。 以上是计算机体系结构流水线相关冲突处理方法的介绍,希望对您有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值