注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

还东国的博客

行之苟有恒,久久自芬芳

 
 
 

日志

 
 

likely和unlikely宏  

2011-12-16 12:24:14|  分类: LINUX内核驱动 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

likely和unlikely宏
这两个在看内核时经常可以看到,跳到定义处是:
#define likely(x) __builtin_expect(!!(x), 1)
#define unlikely(x) __builtin_expect(!!(x), 0)
它们在include\LINUX\err.h文件里。
这两个宏的意义是对不肯定的机率预测可能性的大小,比如为1或者为0,所以说这两个宏还是有区别的。这么说有点儿不明白,举个例子吧,比如在运行一个条件分支时,有两种可能,一种执行成功,一种执行失败,而失败的可能性是存在的,不过却很低,就像打开一个文件,正常情况下,百分之九十以上都可以打开,但如果文件损坏,名字不对,内存不足等等都可以引起打开失败,但这种可能性是很低的,所以这就可以对上上面的宏了。对于某一个是小概率事件,使用unlikely,大概率事件为likely。
这个有什么好处呢,对于这两种情况,编译器可以把大概率的代码拷进CACHE中,增加命中的概率,命中概率有什么用?这个,看书吧。
另外S3C2410_NFREG这个宏,觉着有点儿意思:#define S3C2410_NFREG(x) (x)
目前看不出有啥特别的用处来,不就是定义个地址的偏移么,还至于单弄个宏?可能还是理解不够吧。
这两天看MTD的代码大有进步,终于把代码和DATASHEET对好了。
好好学习,天天向上。

  评论这张
 
阅读(458)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017