如何在内核中打印当前时间?

我是linux的初学者。 (抱歉我的英语不好)我应该打印当前时间并通过linux中的系统调用做一些事情。我做了其他事情,但未能打印当前时间..我写的像

#include<linux/kernel.h>
#include<linux/time.h>
...
asmlinkage long sys_printtime(void) {
     ...
     struct timeval time;
     struct tm tm1;
     ...

     do_gettimeofday(&time);
     local_time=(u32)(time.tv_sec -(sys_tz.tz_minuteswest * 60));
     time_to_tm(local_time,(3600*9),&tm1);
     printk(KERN_DEBUG "time @(%04d-%02d-%02d %02d:%02d:%02d)\n", tm1.tm_year+1900,tm1.tm_mon+1,tm1.tm_mday,tm1.tm_hour,tm1.tm_min,tm1.tm_sec);
    ...
    return 0;
}

但它不起作用。

错误说我不能使用do_gettimeofday,我终于知道我不能再使用do_gettimeofday了,因为kernel5不支持。我在google和stackoverflow上搜索,但我不知道如何在kernel5中打印当前时间..任何人都可以帮助我吗?

0
投票

是的,由于do_gettimeofday问题,y2038已被删除。相反,内核提供了时间界面,您可以根据需要使用它们。查看文档https://www.kernel.org/doc/html/latest/core-api/timekeeping.html。

例如,你有ktime_get_ts64(struct timespec64 *ts),它将为你提供秒和纳秒的时间。

struct timespec64 {
    time64_t    tv_sec;         /* seconds */
    long        tv_nsec;        /* nanoseconds */
};

如果你只需要纳秒,你可以使用u64 ktime_get_ns(void)。请查看上面的文档,了解适合您的用途。您还可以查看timekeeping.h和ktime.h以获取更多信息。

如果要查找示例,只需使用grep -rni <func name>或使用cscope在内核源代码中搜索函数名称。您也可以在线搜索here