Linux内核API getnstimeofday

getnstimeofday函数功能描述:此函数用于获取当前系统内核时间,此时间是使用与时间1970-01-01:00:00:00的时间差表示的,表示方法是将时间差存放在结构体变量中,用秒数和纳秒数表示,秒数是64位的整数形式,所以有一定的表示范围,如果当前内核时间距离1970-01-01 00:00:00太长,会出现溢出现象。

getnstimeofday文件包含

#include<linux/timekeeping.h>

getnstimeofday函数定义

在内核源码中的位置:linux-3.19.36/include/linux/timekeeping.h

函数定义格式:

static inline void getnstimeofday(struct timespec *tv)
{
    getnstimeofday64(tv);
}

getnstimeofday输入参数说明:**

输入的参数是一个结构体变量,定义见文件linux3.19.3/include/uapi/linux/time.h,用于存储当前的时间,其定义如下:

struct timespec
{
    __kernel_time_t         tv_sec;         /* 秒数 */
    long                    tv_nsec;        /*纳秒数*/
};

字段tv_sec表示秒数,字段tv_nsec表示纳秒数,表示不足一秒的部分,在此的有效取值范围是0~999999999。

getnstimeofday返回参数说明

  • 此函数的返回值是void型的变量,即不返回任何结果。

getnstimeofday实例解析

编写测试文件:getnstimeofday.c

头文件引用:

#include <linux/module.h>
#include<linux/time.h>
MODULE_LICENSE("GPL");

模块加载函数定义:

int __init getnstimeofday_init(void)
{
    printk("getnstimeofday test begin.\n");
    struct timespec now=
    {
        .tv_sec=0,
        .tv_nsec=0
    };  //声明一个变量
    getnstimeofday(&now); //调用函数获取时间,此时间是距离1970-01-01 00:00:00的时间
    /*显示当前时间*/
    printk("the seconds of the day is:%ld\n", now.tv_sec);           //秒数
    printk("the nanoseconds of the day is:%ld\n", now.tv_nsec);      //纳秒数
    printk("getnstimeofday test over.\n");
    return 0;
}

模块退出函数定义:

void __exit getnstimeofday_exit(void)
{
    printk("Goodbye getnstimeofday test\n");
}

模块加载、退出函数调用:

module_init(getnstimeofday_init);
module_exit(getnstimeofday_exit);

实例运行结果及分析:

执行命令insmod getnstimeofday.ko插入模块,然后输入命令dmesg -c查看内核输出信息,出现如图所示结果。

Linux内核API getnstimeofday

结果分析:

输出的结果1449368772是当前时间的秒数部分,627252416是当前时间不足一秒的部分,是纳秒数。为了说明函数的正确性可以将显示的秒数反向粗略地转换成年月日,在1970-01-01的基础上进行验证即可。

赞(0)
未经允许不得转载:极客笔记 » Linux内核API getnstimeofday
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址