现在的位置: 首页 > 综合 > 正文

内核中的unlikey和likely宏的说明

2018年08月16日 ⁄ 综合 ⁄ 共 564字 ⁄ 字号 评论关闭
 在内核代码中经常会看到unlikely和likely的踪影,他们实际上是定义在linux/compiler中的两个宏,定义如下。
#definelikely(x)    __builtin_expect(!!(x), 1)        // 表示x的值为真的可能性更大
#defineunlikely(x)  __builtin_expect(!!(x), 0)        // 表示x的值为假的可能性更大
    也就是说,使用likely()后执行if后面的代码机会更大,使用unlikely后执行else后面的代码机会更大。
    而其中的__built_expect()函数是gcc(version>= 2.96)的內建函数,目的是将“分支转移”的信息提供给编译器,这样编译器可以对代码进行优化,以减少指令跳转所带来的性能下降问题。
    因此,在内核代码中使用这两个宏的主要目的是为了进行代码的优化,减少指令跳转带来性能上的下降,提高系统执行速度。
需要明确的一点是:if(linkely(a>b))和if(a>b)/if(unlikely(a<b))和if(a<b)在功能上是等价的,只不过两者编译生成的二进制代码有所不同(gcc -c编译后使用objdump查看汇编)。
    总之,likely和unlikely的功能就是增加cache的命中率,提供系统的执行速度。

抱歉!评论已关闭.