time.h 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. #ifndef _LINUX_TIME_H
  2. #define _LINUX_TIME_H
  3. #include <linux/types.h>
  4. #ifdef __KERNEL__
  5. # include <linux/seqlock.h>
  6. #endif
  7. #ifndef _STRUCT_TIMESPEC
  8. #define _STRUCT_TIMESPEC
  9. struct timespec {
  10. time_t tv_sec; /* seconds */
  11. long tv_nsec; /* nanoseconds */
  12. };
  13. #endif
  14. struct timeval {
  15. time_t tv_sec; /* seconds */
  16. suseconds_t tv_usec; /* microseconds */
  17. };
  18. struct timezone {
  19. int tz_minuteswest; /* minutes west of Greenwich */
  20. int tz_dsttime; /* type of dst correction */
  21. };
  22. #ifdef __KERNEL__
  23. /* Parameters used to convert the timespec values: */
  24. #define MSEC_PER_SEC 1000L
  25. #define USEC_PER_MSEC 1000L
  26. #define NSEC_PER_USEC 1000L
  27. #define NSEC_PER_MSEC 1000000L
  28. #define USEC_PER_SEC 1000000L
  29. #define NSEC_PER_SEC 1000000000L
  30. #define FSEC_PER_SEC 1000000000000000L
  31. static inline int timespec_equal(struct timespec *a, struct timespec *b)
  32. {
  33. return (a->tv_sec == b->tv_sec) && (a->tv_nsec == b->tv_nsec);
  34. }
  35. /*
  36. * lhs < rhs: return <0
  37. * lhs == rhs: return 0
  38. * lhs > rhs: return >0
  39. */
  40. static inline int timespec_compare(const struct timespec *lhs, const struct timespec *rhs)
  41. {
  42. if (lhs->tv_sec < rhs->tv_sec)
  43. return -1;
  44. if (lhs->tv_sec > rhs->tv_sec)
  45. return 1;
  46. return lhs->tv_nsec - rhs->tv_nsec;
  47. }
  48. static inline int timeval_compare(const struct timeval *lhs, const struct timeval *rhs)
  49. {
  50. if (lhs->tv_sec < rhs->tv_sec)
  51. return -1;
  52. if (lhs->tv_sec > rhs->tv_sec)
  53. return 1;
  54. return lhs->tv_usec - rhs->tv_usec;
  55. }
  56. extern unsigned long mktime(const unsigned int year, const unsigned int mon,
  57. const unsigned int day, const unsigned int hour,
  58. const unsigned int min, const unsigned int sec);
  59. extern void set_normalized_timespec(struct timespec *ts, time_t sec, long nsec);
  60. /*
  61. * sub = lhs - rhs, in normalized form
  62. */
  63. static inline struct timespec timespec_sub(struct timespec lhs,
  64. struct timespec rhs)
  65. {
  66. struct timespec ts_delta;
  67. set_normalized_timespec(&ts_delta, lhs.tv_sec - rhs.tv_sec,
  68. lhs.tv_nsec - rhs.tv_nsec);
  69. return ts_delta;
  70. }
  71. /*
  72. * Returns true if the timespec is norm, false if denorm:
  73. */
  74. #define timespec_valid(ts) \
  75. (((ts)->tv_sec >= 0) && (((unsigned long) (ts)->tv_nsec) < NSEC_PER_SEC))
  76. extern struct timespec xtime;
  77. extern struct timespec wall_to_monotonic;
  78. extern seqlock_t xtime_lock __attribute__((weak));
  79. extern unsigned long read_persistent_clock(void);
  80. void timekeeping_init(void);
  81. static inline unsigned long get_seconds(void)
  82. {
  83. return xtime.tv_sec;
  84. }
  85. struct timespec current_kernel_time(void);
  86. #define CURRENT_TIME (current_kernel_time())
  87. #define CURRENT_TIME_SEC ((struct timespec) { xtime.tv_sec, 0 })
  88. extern void do_gettimeofday(struct timeval *tv);
  89. extern int do_settimeofday(struct timespec *tv);
  90. extern int do_sys_settimeofday(struct timespec *tv, struct timezone *tz);
  91. #define do_posix_clock_monotonic_gettime(ts) ktime_get_ts(ts)
  92. extern long do_utimes(int dfd, char __user *filename, struct timespec *times, int flags);
  93. struct itimerval;
  94. extern int do_setitimer(int which, struct itimerval *value,
  95. struct itimerval *ovalue);
  96. extern unsigned int alarm_setitimer(unsigned int seconds);
  97. extern int do_getitimer(int which, struct itimerval *value);
  98. extern void getnstimeofday(struct timespec *tv);
  99. extern void getboottime(struct timespec *ts);
  100. extern void monotonic_to_bootbased(struct timespec *ts);
  101. extern struct timespec timespec_trunc(struct timespec t, unsigned gran);
  102. extern int timekeeping_is_continuous(void);
  103. extern void update_wall_time(void);
  104. /**
  105. * timespec_to_ns - Convert timespec to nanoseconds
  106. * @ts: pointer to the timespec variable to be converted
  107. *
  108. * Returns the scalar nanosecond representation of the timespec
  109. * parameter.
  110. */
  111. static inline s64 timespec_to_ns(const struct timespec *ts)
  112. {
  113. return ((s64) ts->tv_sec * NSEC_PER_SEC) + ts->tv_nsec;
  114. }
  115. /**
  116. * timeval_to_ns - Convert timeval to nanoseconds
  117. * @ts: pointer to the timeval variable to be converted
  118. *
  119. * Returns the scalar nanosecond representation of the timeval
  120. * parameter.
  121. */
  122. static inline s64 timeval_to_ns(const struct timeval *tv)
  123. {
  124. return ((s64) tv->tv_sec * NSEC_PER_SEC) +
  125. tv->tv_usec * NSEC_PER_USEC;
  126. }
  127. /**
  128. * ns_to_timespec - Convert nanoseconds to timespec
  129. * @nsec: the nanoseconds value to be converted
  130. *
  131. * Returns the timespec representation of the nsec parameter.
  132. */
  133. extern struct timespec ns_to_timespec(const s64 nsec);
  134. /**
  135. * ns_to_timeval - Convert nanoseconds to timeval
  136. * @nsec: the nanoseconds value to be converted
  137. *
  138. * Returns the timeval representation of the nsec parameter.
  139. */
  140. extern struct timeval ns_to_timeval(const s64 nsec);
  141. /**
  142. * timespec_add_ns - Adds nanoseconds to a timespec
  143. * @a: pointer to timespec to be incremented
  144. * @ns: unsigned nanoseconds value to be added
  145. */
  146. static inline void timespec_add_ns(struct timespec *a, u64 ns)
  147. {
  148. ns += a->tv_nsec;
  149. while(unlikely(ns >= NSEC_PER_SEC)) {
  150. ns -= NSEC_PER_SEC;
  151. a->tv_sec++;
  152. }
  153. a->tv_nsec = ns;
  154. }
  155. #endif /* __KERNEL__ */
  156. #define NFDBITS __NFDBITS
  157. #define FD_SETSIZE __FD_SETSIZE
  158. #define FD_SET(fd,fdsetp) __FD_SET(fd,fdsetp)
  159. #define FD_CLR(fd,fdsetp) __FD_CLR(fd,fdsetp)
  160. #define FD_ISSET(fd,fdsetp) __FD_ISSET(fd,fdsetp)
  161. #define FD_ZERO(fdsetp) __FD_ZERO(fdsetp)
  162. /*
  163. * Names of the interval timers, and structure
  164. * defining a timer setting:
  165. */
  166. #define ITIMER_REAL 0
  167. #define ITIMER_VIRTUAL 1
  168. #define ITIMER_PROF 2
  169. struct itimerspec {
  170. struct timespec it_interval; /* timer period */
  171. struct timespec it_value; /* timer expiration */
  172. };
  173. struct itimerval {
  174. struct timeval it_interval; /* timer interval */
  175. struct timeval it_value; /* current value */
  176. };
  177. /*
  178. * The IDs of the various system clocks (for POSIX.1b interval timers):
  179. */
  180. #define CLOCK_REALTIME 0
  181. #define CLOCK_MONOTONIC 1
  182. #define CLOCK_PROCESS_CPUTIME_ID 2
  183. #define CLOCK_THREAD_CPUTIME_ID 3
  184. /*
  185. * The IDs of various hardware clocks:
  186. */
  187. #define CLOCK_SGI_CYCLE 10
  188. #define MAX_CLOCKS 16
  189. #define CLOCKS_MASK (CLOCK_REALTIME | CLOCK_MONOTONIC)
  190. #define CLOCKS_MONO CLOCK_MONOTONIC
  191. /*
  192. * The various flags for setting POSIX.1b interval timers:
  193. */
  194. #define TIMER_ABSTIME 0x01
  195. #endif