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
}

相关内容

热门资讯

黑科技辅助(aa扑克发牌机制)... 您好,aa扑克发牌机制这款游戏可以开挂的,确实是有挂的,需要了解加威信【136704302】很多玩家...
黑科技讲解!红龙扑克机制(we... 黑科技讲解!红龙扑克机制(wepoke黑科技)都是是有挂(有挂ai辅助)-哔哩哔哩进入游戏-大厅左侧...
黑科技好牌(wepokeai代... 黑科技好牌(wepokeai代打)wepokewepoke透视挂怎么测试(wePokE)一直真的是有...
黑科技ai代打(wpk最新黑科... 黑科技ai代打(wpk最新黑科技)wpk线上实战(WPK)总是是有挂(有挂助手)-哔哩哔哩;1、下载...
黑科技辅助(来玩app辅助工具... 黑科技辅助(来玩app辅助工具)从来是真的有挂(软件透明挂)玩家教你(有挂教程)-哔哩哔哩是一款可以...
黑科技规律(wpk ai辅助)... 黑科技规律(wpk ai辅助)wpk真的有辅助插件吗(WPk)真是有挂(有挂猫腻)-哔哩哔哩1、不需...
黑科技有挂!微扑克辅助透视技能... 黑科技有挂!微扑克辅助透视技能教程(wepokeai代打)总是真的有挂(有挂透明挂黑科技)-哔哩哔哩...
黑科技软件(wepokeai代... 黑科技软件(wepokeai代打)wepower系统规律(wepoker)真是真的有挂(有挂讲解)-...
黑科技辅助(wpk ai辅助)... 黑科技辅助(wpk ai辅助)wpk ai辅助(Wpk)一贯是真的有挂(有挂方针)-哔哩哔哩;1、用...
黑科技辅助(wpk线上德州俱乐... 黑科技辅助(wpk线上德州俱乐部)切实真的是有挂(ai辅助)技巧教程(有挂助手)-哔哩哔哩(1)黑科...