linux timestamp
创始人
2024-11-17 18:06:38
0

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

#include
#include
#include
#include
#include

#if 0
#include
/* 内核驱动中获取时间戳 */
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
}

相关内容

热门资讯

第七分钟了解!werplan辅... 第七分钟了解!werplan辅助(透视)原来是真的挂,新版2025教程(新版有挂)-哔哩哔哩1、we...
透视最新!wepoker国外版... 透视最新!wepoker国外版透视(透视)竟然真的是有挂,爆料教程(有挂app)-哔哩哔哩1、玩家可...
透视游戏!wepoker辅助透... 透视游戏!wepoker辅助透视软件,wepoker透视方法,烘培教程(新版有挂)-哔哩哔哩1、we...
第十分钟专业!德州机器人代打脚... 第十分钟专业!德州机器人代打脚本(透视)确实是有挂,安装教程(有挂教学)-哔哩哔哩1、完成德州机器人...
透视透视!we poker插件... 透视透视!we poker插件(透视)都是是有挂,介绍教程(有挂神器)-哔哩哔哩1、该软件可以轻松地...
透视软件!wpk模拟器多开,w... 透视软件!wpk模拟器多开,wepoker俱乐部辅助器,练习教程(有挂猫腻)-哔哩哔哩1、wepok...
2分钟详情!聚星ai辅助工具激... 2分钟详情!聚星ai辅助工具激活码(透视)本来是真的挂,扑克教程(有挂规律)-哔哩哔哩1、全新机制【...
透视规律!哈糖大菠萝破解器(透... 透视规律!哈糖大菠萝破解器(透视)切实是有挂,必胜教程(有挂识别)-哔哩哔哩;1、下载好哈糖大菠萝破...
透视代打!hhpoker可以开... 透视代打!hhpoker可以开挂吗,wepoker新号好一点吗,绝活儿教程(有挂细节)-哔哩哔哩暗藏...
第六分钟分享!wepoker破... 第六分钟分享!wepoker破解游戏盒子(透视)真是有挂,可靠技巧(有挂秘笈)-哔哩哔哩1、游戏颠覆...