boottime.c 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. /*
  2. * Copyright (c) 2006-2023, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2023-07-10 xqyjlj The first version.
  9. */
  10. #include "ktime.h"
  11. #define __KTIME_MUL ((1000ULL * 1000 * 1000) / RT_TICK_PER_SECOND)
  12. rt_weak rt_err_t rt_ktime_boottime_get_us(struct timeval *tv)
  13. {
  14. RT_ASSERT(tv != RT_NULL);
  15. rt_uint64_t ns = (rt_ktime_cputimer_getcnt() * rt_ktime_cputimer_getres()) / RT_KTIME_RESMUL;
  16. tv->tv_sec = ns / (1000ULL * 1000 * 1000);
  17. tv->tv_usec = (ns % (1000ULL * 1000 * 1000)) / 1000;
  18. return RT_EOK;
  19. }
  20. rt_weak rt_err_t rt_ktime_boottime_get_s(time_t *t)
  21. {
  22. RT_ASSERT(t != RT_NULL);
  23. rt_uint64_t ns = (rt_ktime_cputimer_getcnt() * rt_ktime_cputimer_getres()) / RT_KTIME_RESMUL;
  24. *t = ns / (1000ULL * 1000 * 1000);
  25. return RT_EOK;
  26. }
  27. rt_weak rt_err_t rt_ktime_boottime_get_ns(struct timespec *ts)
  28. {
  29. RT_ASSERT(ts != RT_NULL);
  30. rt_uint64_t ns = (rt_ktime_cputimer_getcnt() * rt_ktime_cputimer_getres()) / RT_KTIME_RESMUL;
  31. ts->tv_sec = ns / (1000ULL * 1000 * 1000);
  32. ts->tv_nsec = ns % (1000ULL * 1000 * 1000);
  33. return RT_EOK;
  34. }