- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我理解有五个阶段 -> IF、ID、EX、MEM、WB。并且时钟周期由最长的阶段决定。我不明白的是当指令没有使用所有阶段时会发生什么,例如,添加不需要 MEM 阶段的指令,假设时钟周期为 200ps,这意味着对于使用所有阶段的指令,执行需要 1000ps。执行不使用 MEM stege 的指令是否需要相同的 1000ps(这意味着浪费了 200ps)?谢谢!
最佳答案
如果指令不需要 MEM 阶段,它不会在该阶段驱动任何与内存相关的信号,但它仍然需要通过它。
这是在浪费时间,但仍然比非流水线处理有所改进。
让经典 MIPS 5 级机器按需跳过 MEM 的一个想法是添加从 EX 到 WB 的数据路径并添加一些逻辑。
如果在加载/存储之后出现 R 型指令,则会出现冲突:
IF ID EX MEM WB
IF ID EX WB <-- Conflict: two instructions in WB
CPU 可以将 EX 的输出发送到 MEM 和 WB,此外,MEM 阶段会在需要该阶段时屏蔽从 EX 到 WB 的数据路径,并在不需要时屏蔽 MEM - WB 数据路径。
这样当 MEM 中已经有一条指令时,EX 中的下一条指令将在下一个周期进入 MEM(而不是 WB):
IF ID EX MEM <-- Here EX-WB is masked (since MEM is used) and MEM-WB is allowed
IF ID EX <-- Can go to both MEM and WB but EX-WB is masked off
IF ID EX MEM WB <-- So this instruction's next stage is WB (as usual)
IF ID EX MEM <-- This goes to MEM instead, so the pipe keeps flowing
如果前面的指令不需要MEM,可以跳过一个阶段:
IF ID EX <-- Here EX-WB is allowed (assume no prev instructions) and MEM-WB is not since (MEM was not used)
IF ID
IF ID EX WB <-- Instruction skips MEM stage since EX-WB was allowed
IF ID EX <-- Next instruction, again, EX-WB is allowed since MEM was not used
IF ID EX WB <-- Done
IF ID EX WB <-- Stage MEM skipped
附录
值得注意的是,如果第一个示例中的 WB 堆栈链接发生冲突,最好将整个流水线停止一个周期,否则冲突将永远无法解决,所有后续指令都将通过 MEM阶段不管他们的类型。
没有摊位:
mem = Useless MEM stage but necessary to avoid a WB confict
MEM = Instruction uses the MEM stage
IF ID EX MEM WB
IF ID EX mem WB
IF ID EX mem Wb
如果我们引入一个周期的停顿,我们就解决了冲突:
Lowercase names means stalled cycles
IF ID EX MEM WB
IF ID EX ex WB
IF ID id EX WB
IF if ID EX WB
IF ID EX WB
IF ID EX WB
请注意,从吞吐量的角度来看,这种优化并没有真正带来任何有用的东西。
流水线稳定到较短的长度,但如果将此图与强制执行 MEM 的图进行比较,您会在相同的周期中获得所有 WB 阶段!
如果 A 依赖于 B,则 A 需要等待 B 到达其 WB 阶段(或 EX,如果管道中有转发)并且由于 WB(或 EX)阶段的位置在有或没有此优化的情况下都是相同的,软件不能直接观察到它(即它没有任何好处)。
然而,较短的管道消耗的能量较少,刷新后重新填充的速度更快,但要真正利用跳过阶段的能力,需要一个超标量 CPU(具有多个执行单元,以便 EX 和 MEM 可以重叠) .
关于assembly - MIPS 流水线阶段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52344098/
这是贪吃蛇游戏的部分代码。我想做的是制作关卡(大约3个),如果分数达到一定的分数(100或200),关卡就会改变。 在这段代码中,我尝试让分数达到 100 时进入第 2 阶段。但正如我编码的那样,它只
我是移相器新手。我开始看 youtube 系列,我首先有问题。我的背景图片无法加载。我有这个js代码 /* global Phaser */ var game = new Phaser.Game(12
我有一个包含 2 个阶段的应用程序,我不希望用户关闭第二个阶段,只需将其图标化即可。 目前我正在使用 oncloseRequest 处理程序来最小化窗口 - secondaryStage.setOnC
现在,我有一台运行服务器的基本LAMP配置。生产服务器是slicehost。但是我想知道将代码/数据库实例推送到阶段dev> stage> production的最佳方法是什么。它与您创建阶段的方式有
我在舞台上有一个场景。场景的宽度为 337.0 像素。但是,当我将它添加到舞台时,舞台的大小为 337.6 像素,由于 0.6 像素的差异,在屏幕的右边缘留下了一个白色间隙。 我尝试使用 stage.
我有这个未修饰的窗口: public static void initStartPage(final Stage primaryStage) { final Stage startPa
有什么方法可以在 Maven 构建中执行特定阶段。例如,如果我只想运行那些在预集成阶段执行的插件,Maven 是否提供了一种方法来做到这一点? e.g. mvn pre-integration-pha
仅在构建特定分支时如何运行构建步骤/阶段? 例如,仅当分支名为 deployment 时才运行部署步骤,其他所有内容保持不变。 最佳答案 在声明性管道语法中执行相同的操作,下面是一些示例: stage
我有一个简单的查询,试图在Hive 0.14中运行: select sum(tb.field1), sum(tb.field2), tb.month from dbwork.mytable tb gr
在 Mercurial 中,我经常使用 secret 变更集来跟踪我对尚未准备好推送的内容的工作。然后,如果我需要对某些文件进行紧急更改,我可以更新到公共(public)修订版,进行更改并推送它,而不
我一直在为 Heroku 的新附加组件工作,目前它是 alpha 阶段。因此,目前,我无法在我创建的应用程序上添加该附加组件,因为没有按钮可供我添加它。有人可以向我指出一些可以帮助我解决问题的资源吗?
我有 2 个线程正在运行,一个正在监听 soket 等待命令,另一个启动 javafx 应用程序 public class GraphicInterface extends Application i
在我的 Java Fx 应用程序中,我创建了两个阶段。第一阶段是主 Controller 类 HomeController 中的默认阶段。第二个 AddNewEmailController 是通过调用
我正在编写一个简单的 JavaFX 应用程序,它具有三个阶段:登录、注册 (Anmeldung) 和欢迎 (Anwendung)。 抱歉采用德语命名! 我已经在 App 类中创建了每个舞台及其场景,在
问题是我正在使用 jQuery("form")[0].reset(); 在需要时重置表单。此方法正在将形式重置到初始阶段。这里初始阶段的意思是“表单第一次加载到页面时带有一些值的阶段”。 但我需要的是
我有一个带有 pre-integration-test 和 post-integration-test 阶段的 Maven POM,如下所示。 start-server pre-in
我遇到一个错误,我已经为网络制作了一个 UIPageController,但我似乎无法找到它的问题,只有一个错误,请帮忙。代码如下 - 更多代码点播。 @interface ContentViewCo
考虑在其中放置一些文本的大型 (2000x1000) 舞台。舞台缩小到 1000x500,使文本不可读。然后我们尝试通过放大来放大文本。 预期:文本应该在某个时候再次变得可读。 实际:无论我们放大多少
试图在网页中居中 KineticJS 阶段。 尝试过: 但它集中在舞台的左侧,而不是舞台的中间。我错过了什么? 最佳答案 margin:auto 可以对齐这个div中心 关于htm
我正在 jboss 中部署一个简单的 Web 应用程序,其中包含一个 servlet、一个 jsp 文件和一个 easy EJB。这是 servlet 的代码: package webejb; imp
我是一名优秀的程序员,十分优秀!