time.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. /* SPDX-License-Identifier: LGPL-2.1 OR MIT */
  2. /*
  3. * time function definitions for NOLIBC
  4. * Copyright (C) 2017-2022 Willy Tarreau <w@1wt.eu>
  5. */
  6. /* make sure to include all global symbols */
  7. #include "nolibc.h"
  8. #ifndef _NOLIBC_TIME_H
  9. #define _NOLIBC_TIME_H
  10. #include "std.h"
  11. #include "arch.h"
  12. #include "types.h"
  13. #include "sys.h"
  14. #include <linux/signal.h>
  15. #include <linux/time.h>
  16. #define __nolibc_assert_time64_type(t) \
  17. __nolibc_static_assert(sizeof(t) == 8)
  18. #define __nolibc_assert_native_time64() \
  19. __nolibc_assert_time64_type(__kernel_old_time_t)
  20. /*
  21. * int clock_getres(clockid_t clockid, struct timespec *res);
  22. * int clock_gettime(clockid_t clockid, struct timespec *tp);
  23. * int clock_settime(clockid_t clockid, const struct timespec *tp);
  24. * int clock_nanosleep(clockid_t clockid, int flags, const struct timespec *rqtp,
  25. * struct timespec *rmtp)
  26. */
  27. static __attribute__((unused))
  28. int sys_clock_getres(clockid_t clockid, struct timespec *res)
  29. {
  30. #if defined(__NR_clock_getres_time64)
  31. __nolibc_assert_time64_type(res->tv_sec);
  32. return my_syscall2(__NR_clock_getres_time64, clockid, res);
  33. #else
  34. __nolibc_assert_native_time64();
  35. return my_syscall2(__NR_clock_getres, clockid, res);
  36. #endif
  37. }
  38. static __attribute__((unused))
  39. int clock_getres(clockid_t clockid, struct timespec *res)
  40. {
  41. return __sysret(sys_clock_getres(clockid, res));
  42. }
  43. static __attribute__((unused))
  44. int sys_clock_gettime(clockid_t clockid, struct timespec *tp)
  45. {
  46. #if defined(__NR_clock_gettime64)
  47. __nolibc_assert_time64_type(tp->tv_sec);
  48. return my_syscall2(__NR_clock_gettime64, clockid, tp);
  49. #else
  50. __nolibc_assert_native_time64();
  51. return my_syscall2(__NR_clock_gettime, clockid, tp);
  52. #endif
  53. }
  54. static __attribute__((unused))
  55. int clock_gettime(clockid_t clockid, struct timespec *tp)
  56. {
  57. return __sysret(sys_clock_gettime(clockid, tp));
  58. }
  59. static __attribute__((unused))
  60. int sys_clock_settime(clockid_t clockid, struct timespec *tp)
  61. {
  62. #if defined(__NR_clock_settime64)
  63. __nolibc_assert_time64_type(tp->tv_sec);
  64. return my_syscall2(__NR_clock_settime64, clockid, tp);
  65. #else
  66. __nolibc_assert_native_time64();
  67. return my_syscall2(__NR_clock_settime, clockid, tp);
  68. #endif
  69. }
  70. static __attribute__((unused))
  71. int clock_settime(clockid_t clockid, struct timespec *tp)
  72. {
  73. return __sysret(sys_clock_settime(clockid, tp));
  74. }
  75. static __attribute__((unused))
  76. int sys_clock_nanosleep(clockid_t clockid, int flags, const struct timespec *rqtp,
  77. struct timespec *rmtp)
  78. {
  79. #if defined(__NR_clock_nanosleep_time64)
  80. __nolibc_assert_time64_type(rqtp->tv_sec);
  81. return my_syscall4(__NR_clock_nanosleep_time64, clockid, flags, rqtp, rmtp);
  82. #else
  83. __nolibc_assert_native_time64();
  84. return my_syscall4(__NR_clock_nanosleep, clockid, flags, rqtp, rmtp);
  85. #endif
  86. }
  87. static __attribute__((unused))
  88. int clock_nanosleep(clockid_t clockid, int flags, const struct timespec *rqtp,
  89. struct timespec *rmtp)
  90. {
  91. /* Directly return a positive error number */
  92. return -sys_clock_nanosleep(clockid, flags, rqtp, rmtp);
  93. }
  94. static __inline__
  95. double difftime(time_t time1, time_t time2)
  96. {
  97. return time1 - time2;
  98. }
  99. static __inline__
  100. int nanosleep(const struct timespec *rqtp, struct timespec *rmtp)
  101. {
  102. return __sysret(sys_clock_nanosleep(CLOCK_REALTIME, 0, rqtp, rmtp));
  103. }
  104. static __attribute__((unused))
  105. time_t time(time_t *tptr)
  106. {
  107. struct timeval tv;
  108. /* note, cannot fail here */
  109. sys_gettimeofday(&tv, NULL);
  110. if (tptr)
  111. *tptr = tv.tv_sec;
  112. return tv.tv_sec;
  113. }
  114. /*
  115. * int timer_create(clockid_t clockid, struct sigevent *evp, timer_t *timerid);
  116. * int timer_gettime(timer_t timerid, struct itimerspec *curr_value);
  117. * int timer_settime(timer_t timerid, int flags, const struct itimerspec *new_value, struct itimerspec *old_value);
  118. */
  119. static __attribute__((unused))
  120. int sys_timer_create(clockid_t clockid, struct sigevent *evp, timer_t *timerid)
  121. {
  122. return my_syscall3(__NR_timer_create, clockid, evp, timerid);
  123. }
  124. static __attribute__((unused))
  125. int timer_create(clockid_t clockid, struct sigevent *evp, timer_t *timerid)
  126. {
  127. return __sysret(sys_timer_create(clockid, evp, timerid));
  128. }
  129. static __attribute__((unused))
  130. int sys_timer_delete(timer_t timerid)
  131. {
  132. return my_syscall1(__NR_timer_delete, timerid);
  133. }
  134. static __attribute__((unused))
  135. int timer_delete(timer_t timerid)
  136. {
  137. return __sysret(sys_timer_delete(timerid));
  138. }
  139. static __attribute__((unused))
  140. int sys_timer_gettime(timer_t timerid, struct itimerspec *curr_value)
  141. {
  142. #if defined(__NR_timer_gettime64)
  143. __nolibc_assert_time64_type(curr_value->it_value.tv_sec);
  144. return my_syscall2(__NR_timer_gettime64, timerid, curr_value);
  145. #else
  146. __nolibc_assert_native_time64();
  147. return my_syscall2(__NR_timer_gettime, timerid, curr_value);
  148. #endif
  149. }
  150. static __attribute__((unused))
  151. int timer_gettime(timer_t timerid, struct itimerspec *curr_value)
  152. {
  153. return __sysret(sys_timer_gettime(timerid, curr_value));
  154. }
  155. static __attribute__((unused))
  156. int sys_timer_settime(timer_t timerid, int flags,
  157. const struct itimerspec *new_value, struct itimerspec *old_value)
  158. {
  159. #if defined(__NR_timer_settime64)
  160. __nolibc_assert_time64_type(new_value->it_value.tv_sec);
  161. return my_syscall4(__NR_timer_settime64, timerid, flags, new_value, old_value);
  162. #else
  163. __nolibc_assert_native_time64();
  164. return my_syscall4(__NR_timer_settime, timerid, flags, new_value, old_value);
  165. #endif
  166. }
  167. static __attribute__((unused))
  168. int timer_settime(timer_t timerid, int flags,
  169. const struct itimerspec *new_value, struct itimerspec *old_value)
  170. {
  171. return __sysret(sys_timer_settime(timerid, flags, new_value, old_value));
  172. }
  173. #endif /* _NOLIBC_TIME_H */