- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是一个理论问题,我觉得卡住了。假设我采用 ARM ISA 和流水线数据路径。我正在使用一个分支预测器,为了简单起见,它总是预测一个分支被采用。很明显,如果确实要采用该分支,则它会起作用,否则会失败。如果失败,它必须回滚并撤消所有更改,即冲洗管道。
它应该怎么做?
如果某个值被写入某个寄存器会怎样?
那么我怎样才能将该寄存器恢复到它以前的值呢?旗帜也一样吗?
最佳答案
由于这是在架构中定义的,您将始终可以保证,如果一个分支被错误预测并且它必须刷新管道,则所有后续指令都不会对架构产生明显的影响。
有几种方法:在简单实现(短流水线)中,一般会在保证不在分支(A load that can fault)时提交指令(即写一个架构可见的修改)阴影了。
在更复杂的 CPU、更长的流水线和乱序的内核中,通常使用的技术是寄存器重命名:
https://en.wikipedia.org/wiki/Register_renaming
在这种情况下,指令将能够完成,将结果写入临时寄存器或位置,并且 CPU 将具有恢复状态(在刷新的情况下)或仅将临时结果提交给体系结构的机制当它有保证时注册这些结果不能再被刷新。
关于arm - 如何冲洗管道?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36435377/
除了如何像文件一样读取和写入套接字之外,我对套接字知之甚少。我对使用套接字选择器有一些了解。我不明白为什么你必须刷新一个套接字,那里实际发生了什么?这些位只是卡在内存中的某个地方,直到它们被推开?我在
我想监控下载数据的进度。我想在传输一定量的数据后进行记录。我的代码: int contentLength = 0; final int bufferSize = 1024*8; byte[] buff
你好, 我编写了一个 Java 程序,它使用 Process 对象和 Runtime.exec() 函数调用启动多个 C++ 编写的程序。 C++ 程序使用 cout 和 cin 作为输入和输出。 J
几天前,我通过阅读官方文档开始对 Rust 进行编程。现在,我正在尝试通过阅读 Brian P. Hogan(The Pragmatic Programmers)所著的“程序员练习”一书来挑战我对 R
我正在使用 Mojolicious::Lite 模块来运行 websockets 服务器来处理协议(protocol)。这是我目前用于客户端的测试代码: socket.onopen = functio
我正在为我的一门类(class)和作业学习 C#,我需要从控制台获取用户输入。 在我的程序中我有: choice = (char)System.Console.Read(); 稍后在我使用的程序中 i
我是一名优秀的程序员,十分优秀!