gpt4 book ai didi

linux - Linux 内核中可能/不太可能的宏是如何工作的,它们有什么好处?

转载 作者:IT老高 更新时间:2023-10-28 12:15:59 24 4
gpt4 key购买 nike

我一直在研究 Linux 内核的某些部分,发现了这样的调用:

if (unlikely(fd < 0))
{
/* Do something */
}

if (likely(!err))
{
/* Do something */
}

我找到了它们的定义:

#define likely(x)       __builtin_expect((x),1)
#define unlikely(x) __builtin_expect((x),0)

我知道它们是为了优化,但它们是如何工作的?使用它们可以减少多少性能/尺寸?至少在瓶颈代码中(当然是在用户空间中)是否值得麻烦(并且可能会失去可移植性)。

最佳答案

它们提示编译器发出指令,这些指令将导致分支预测偏向于跳转指令的“可能”一侧。这可能是一个巨大的胜利,如果预测正确,则意味着跳转指令基本上是免费的,并且将占用零个周期。另一方面,如果预测错误,则意味着需要刷新处理器流水线,并且可能会花费几个周期。只要预测在大多数情况下都是正确的,这往往对性能有好处。

与所有此类性能优化一样,您应该仅在进行广泛的分析后才执行此操作,以确保代码确实处于瓶颈状态,并且可能考虑到它在紧密循环中运行的微观性质。一般来说,Linux 开发人员非常有经验,所以我想他们会这样做。他们并不太关心可移植性,因为他们只针对 gcc,并且他们非常了解他们希望它生成的程序集。

关于linux - Linux 内核中可能/不太可能的宏是如何工作的,它们有什么好处?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/109710/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com