linux timestamp

驱动或应用中获取时间戳的接口。

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

#include <time.h>

#include <sys/time.h>

#if 0

#include <linux/ktime.h>

/* 内核驱动中获取时间戳 */

static ktime_t get_kernel_timestamp(void)

{

ktime_t ktime = ktime_get(); // 获取当前时间

u64 timestamp = ktime_to_ns(ktime); // 将ktime转换为纳秒时间戳

printk(KERN_INFO "Current timestamp: %llu nanoseconds\n", timestamp);

return ktime;

}

#endif

int convert_utc_time( unsigned long long utc, char * ptime)

{

struct tm *tm;

time_t t = 0;

if (utc == 0) {

strncpy(ptime, "no time", 8);

return -1;

}

t = utc / 1000 + 8 * 3600;

tm = gmtime(&t);

sprintf(ptime, "%04d:%02d:%02d %02d:%02d:%02d.%03d", tm->tm_year+1900, tm->tm_mon+1, tm->tm_mday,

tm->tm_hour, tm->tm_min, tm->tm_sec, (int)utc%1000);

printf("utc time for ac debug : [%s]\n", ptime);

return 0;

}

static unsigned long long GetSystemClock_ns()

{

struct timespec time_start, time_end;

clock_gettime(CLOCK_REALTIME, &time_start);

return (long long unsigned)time_start.tv_sec * 1000000000 + (long long unsigned)time_start.tv_nsec;

}

static inline struct timeval AC_TIME_COMMON_GetMonotonic()

{

struct timespec stTime;

struct timeval stRet;

clock_gettime(CLOCK_REALTIME, &stTime);

stRet.tv_sec = stTime.tv_sec - timezone;

stRet.tv_usec = stTime.tv_nsec/1000;

return stRet;

}

static unsigned long long GetSystemClock()

{

struct timeval tv;

unsigned long long tv_sen;

unsigned long long gltime;

gettimeofday(&tv, NULL);

tv_sen = tv.tv_sec;

gltime = tv_sen * 1000 + tv.tv_usec / 1000;

return gltime;

}

int main()

{

char u_time[32] = {0};

unsigned long long system_time = 0;

struct timeval tmData = AC_TIME_COMMON_GetMonotonic();

system_time = tmData.tv_sec*1000 + tmData.tv_usec / 1000;

printf("get time %lld\n", system_time); // 1655445920614 : 2022:06:17 14:05:20.654

system_time = 0;

system_time = GetSystemClock();

printf("get time %lld\n", system_time); // 1655446828225 : 2022:06:17 14:20:28.265

system_time = 0;

system_time = GetSystemClock_ns(); // 1721875113493839086

printf("get time %lld\n", system_time);

convert_utc_time(1655356228, u_time);

convert_utc_time(1823430235, u_time);

convert_utc_time(1918628771, u_time);

convert_utc_time(1655445920614, u_time); // 2022:06:17 14:05:20.654

convert_utc_time(1655446828225, u_time); // 2022:06:17 14:20:28.265

}

相关推荐
小Tomkk14 分钟前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
赌博羊14 分钟前
ImportError: /lib/x86_64-linux-gnu/libc.so.6: version `GLIBC_2.32‘ not found
linux·运维·gnu
木卫二号Coding16 分钟前
第七十九篇-E5-2680V4+V100-32G+llama-cpp编译运行+Qwen3-Next-80B
linux·llama
getapi25 分钟前
Ubuntu 22.04 服务器的系统架构是否为 amd64 x86_64
linux·服务器·ubuntu
消失的旧时光-194342 分钟前
Linux 入门核心命令清单(工程版)
linux·运维·服务器
艾莉丝努力练剑1 小时前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法
Trouvaille ~1 小时前
【Linux】TCP Socket编程实战(一):API详解与单连接Echo Server
linux·运维·服务器·网络·c++·tcp/ip·socket
旖旎夜光2 小时前
Linux(13)(中)
linux·网络
威迪斯特3 小时前
CentOS图形化操作界面:理论解析与实践指南
linux·运维·centos·组件·图形化·桌面·xserver
一方热衷.3 小时前
在线安装对应版本NVIDIA驱动
linux·运维·服务器