码迷,mamicode.com
首页 > 系统相关 > 详细

linux内核计算时间差以及jiffies溢出

时间:2017-06-10 15:34:06      阅读:564      评论:0      收藏:0      [点我收藏+]

标签:避免   linux内核   nbsp   成功   中断   mod   post   时间   延时   

jiffies是每一个时钟中断,都会加1。这就导致一个问题。不管jiffies(一般来说是unsigned long类型)多少个字节,总有溢出的时候。

更极端的时候。当期jiffies是0xffffffff。下一个时刻就是0x0

这样。当你计算延时/时差 的时候0x0 - 0xffffffff结果是 0xffffffff,实际上仅仅是过了一个时钟周期,这样的区别是巨大的。

那么怎样防止这样的情况发生呢?

非常easy

如果t1是之前记录的jiffies,t2是当前的jiffies,你想要计算两者差值:

(long) t2 - (long)t1

这样就能成功避免之前的情况。

由于:

(long)0xffffffff 是0x1

(long)0x0 是0x0

所以(long)0xffffffff - (long)0x0 差值正好是1,即正确的结果。

linux内核计算时间差以及jiffies溢出

标签:避免   linux内核   nbsp   成功   中断   mod   post   时间   延时   

原文地址:http://www.cnblogs.com/jhcelue/p/6978518.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!