jiffies 的使用
每一个技术点都是要靠自己对着书来一步步实践
#include <linux/init.h>
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/types.h>
#include <linux/cdev.h>
#include <linux/fs.h>
#include <linux/uaccess.h> /* copy_*_user */
#include <linux/slab.h>
#include <linux/wait.h>
#include <linux/jiffies.h>
static void __exit hello_exit(void)
{
printk("%d\n", jiffies);
return;
}
static int __init hello_init(void)
{
dev_t dev = 0;
return 0;
}
module_init(hello_init);
module_exit(hello_exit);
调用dmesg查看结果,注意这里获取都是32位的
[ 1724.354757] 355881
[ 1751.993783] 362791
[ 1753.189108] 363090
[ 1754.108915] 363320
下面我继续看64位的获取方法
get_jiffies_64();
输出的结果是:
[ 591.756554] timer:4295039905
防止溢出的回环处理函数
#include <linux/jiffies.h>
int time_after(unsigned long a, unsigned long b);
int time_before(unsigned long a, unsigned long b);
int time_after_eq(unsigned long a, unsigned long b);
int time_before_eq(unsigned long a, unsigned long b);
jiffies 和 timeval 以及 timespace 的转化,timeval使用的是秒和毫秒,timespace使用的是秒和纳秒,内核提供了4个辅助函数

本文介绍了Linux内核中jiffies的使用方法,包括其32位和64位的获取方式,以及如何防止溢出。此外,还探讨了jiffies与timeval、timespace之间的转换,并介绍了更高精度的时间测量方法。
最低0.47元/天 解锁文章
546

被折叠的 条评论
为什么被折叠?



