- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
编辑:我感到困惑,因为通过预测采用哪个分支,您肯定也在有效地进行目标预测?
这个问题与我关于该主题的第一个问题有着内在的联系:
branch prediction vs branch target prediction
查看已接受的答案:
Unconditional branch, fixed target
- Infinite loop
goto
statementbreak
orcontinue
statement- End of the 'then' clause of an
if/else
statement (to jump past theelse
clause)- Non-virtual function call
Unconditional branch, variable target
- Returning from a function
- Virtual function call
- Function pointer call
switch
statement (if compiled into a jump table)Conditional branch, fixed target
if
statementswitch
statement (if compiled into a series ofif/else
statements)- Loop condition tests
- The
&&
and||
operators- The ternary
?:
operatorConditional branch, variable target
- Less likely to show up under normal conditions, but the compiler may synthesize one as an optimization, combining two of the above cases. For example, on x86, the compiler may optimize code like
if
into a conditional indirect jump like
(condition) { obj->VirtualFunctionCall(); }jne *%eax
if it appears at the end of a function due to tail call optimization.
如果我有以下代码:
if(something){
//a
}
else{
//b
}
(BP =“分支预测”和 BTP =“分支目标预测”)
它非常明显的 BP 用于评估条件某物
。不过,我试图了解 BTP 是否也参与确定分支 a
中发生的情况。 BTP是否也恰好根据BP的结果确定了位于分支a
/b
的代码的地址?
我在此维基百科页面上询问( http://en.wikipedia.org/wiki/Branch_target_predictor ):
In computer architecture, a branch target predictor is the part of a processor that predicts the target of a taken conditional branch or an unconditional branch instruction before the target of the branch instruction is computed by the execution unit of the processor.
这表明在预测条件后使用 BTP 来预测目标。
1)有人可以澄清上述内容吗?
第二个相关问题 - BP 和 BTP 与 CPU 的获取/解码/执行/回写管道交互的方式有何不同? BP 是从取指阶段开始还是从解码阶段开始?在条件代码的执行阶段之后,我们可以检查预测是否正确并更新分支预测缓存。
2) BTP 在获取/解码/执行/回写 CPU 阶段如何工作?
最佳答案
请阅读英特尔优化手册,当前下载位置 is here 。当过时时(他们一直在移动东西),然后在英特尔网站上搜索“架构优化手册”。请记住,那里的信息相当通用,它们仅披露允许编写高效代码所需的信息。分支预测实现细节被视为商业 secret ,并且在架构之间确实会发生变化。在手册中搜索“分支预测”以查找引用资料,它在各个章节中分布相当广泛。
我将总结手册中的内容,并在适当的地方添加详细信息:
分支预测是核心中的BPU单元(Branch Prediction Unit)的工作。与您问题中的“BP”大致相关。它包含几个子单元:
分支历史表。该表跟踪先前采用的条件分支,并由预测器引用来决定是否可能采用分支。指令引退单元向 Is 提供条目,该指令引退单元知道分支是否实际被采用。随着架构的改进,这是变化最大的子单元,随着更多的可用空间变得更深入、更智能。
BTB,分支目标缓冲区。该缓冲区存储先前进行的间接跳转或调用的目标地址。这与您问题中的“BTP”相关。手册没有说明缓冲区是否可以在每个地址存储多个目标,由历史表索引,我认为这可能适用于以后的架构。
返回堆栈缓冲区。该缓冲区充当“影子”堆栈,存储 CALL 指令的返回地址,从而使 RET 指令的目标可以高度可信地可用,而处理器不必依赖 BTB,而 BTB 不太可能对调用有效。据记录,它有 16 层深。
Bullet 2) 有点难以准确回答,手册只讨论了“前端”,并没有分解管道的细节。足够合适了,它严重依赖于架构。第 2.2.5 节中的图表可能具有说明性。执行跟踪缓存发挥了作用,它存储先前解码的指令,因此是 BPU 协商的主要来源。否则就在指令翻译器(又名解码器)之后。
关于x86 - 分支目标预测与分支预测结合?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21787457/
我创建了一个基于命令行可移植脚本的工业化不可知构建系统,可用于快速构建多个依赖项目,而不必依赖特定的 IDE 或构建工厂。它是不可知的,因为它不是基于单个构建引擎。我使用 cmake 创建了第一个版本
我最初使用 Java 目标开发了一个语法(用于 TestRig 支持),然后将其移植到 Python(从 git hub 语法存储库扩展了 Python3 语法,因此需要将操作移植到 Python
我有一个以 iPhone 和 watchOS 为目标的 Xcode 项目。 iPhone 目标使用加速度计,模拟器不支持。我可以只启动 iPhone 应用程序而不启动 watch 目标吗?我从: Ca
您好,我想创建一个批处理文件,用于在 .eml 文件(目标 A)中查找某些关键字,然后删除它们所在的行。之后,我需要批处理文件将"new"文件放入(目标 B)中的单独 .eml 文件中。文件也可以是
当尝试通过 IntelliJ 运行示例 CorDapp (GitHub CorDapp) 时,我收到以下错误: Cannot inline bytecode built with JVM target
我在尝试向我的 kotlin spring 项目添加一些依赖项时遇到问题。我使用 spring boot 初始化程序来运行一个基本项目。 我的问题:如果我取消对 jackson 或 Koin 依赖项的
这是有问题的网站: http://www.onepixelroom.com/londonrefurb 当我点击关于部分后面的多个圆圈时,我希望它更改上面文本中的引号。 到目前为止,我得到它来显示 文本
单击后,我将删除两个元素 $(this) 和 $("#foo")。 目前我的代码如下所示: $(this).remove(); $("#foo").remove(); 如何在不重复自己的情况下优化它?
我有一个小脚本,可将 Markdown 文件编译为 html,并将其与一些样式表和 javascript 一起插入到模板的主体中。我有一个 GNU makefile 来完成这个: output.htm
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
一些背景知识: 在android中我们开发了同样的应用,基本上我们先开发了Android应用,现在我们创建了它的IOS版本,所以这个应用有多个客户端。在 android 中,我们实际上是使用 Andr
我想知道是否可以使用 knockout 来更改html中的目标() 我的所有其他信息都在 JavaScript 中,所以这对我来说是一个大问题。这是我的 JavaScript: var library
这个问题在这里已经有了答案: Selecting and manipulating CSS pseudo-elements such as ::before and ::after using j
我在我的有向图中添加了一堆节点和顶点,使用设置 typedef boost::adjacency_list graph; 创建 Node有一个节点名称字符串,Edge它的分数有一个整数。我试图遍历所有
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 8 年前。 Improve
如何存储我在 NSUserDefaults 中创建的 Goal 类型的对象数组? ( swift ) 代码如下: func saveGoalList ( newGoalList : [Goal] ){
Array.prototype.indexOf 和 Date.now 已在 ES5 中引入。如果我编译存储在文件 test.ts 中的以下代码,为什么 Typescript 不能转译? Date.no
我正在阅读有关属性的内容,并了解到可以使用您的代码将它们应用于不同的目标实体 -(请参阅 Attribute Targets)。 因此,查看我项目中的 AssemblyInfo.cs 文件,我可以看到
给定一个 Makefile: all: build/a build/b build/c # need to change this to all: build/* build/a:
我有一个带有多框架目标的项目- netstandard2.0;net471 . 我想为 netframework 构建解决方案和 netstandard分别。 目前我使用这个 MSBuild 命令:
我是一名优秀的程序员,十分优秀!