time.h 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  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(struct timespec *lhs, 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(struct timeval *lhs, 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;
  79. void timekeeping_init(void);
  80. static inline unsigned long get_seconds(void)
  81. {
  82. return xtime.tv_sec;
  83. }
  84. struct timespec current_kernel_time(void);
  85. #define CURRENT_TIME (current_kernel_time())
  86. #define CURRENT_TIME_SEC ((struct timespec) { xtime.tv_sec, 0 })
  87. extern void do_gettimeofday(struct timeval *tv);
  88. extern int do_settimeofday(struct timespec *tv);
  89. extern int do_sys_settimeofday(struct timespec *tv, struct timezone *tz);
  90. #define do_posix_clock_monotonic_gettime(ts) ktime_get_ts(ts)
  91. extern long do_utimes(int dfd, char __user *filename, struct timeval *times);
  92. struct itimerval;
  93. extern int do_setitimer(int which, struct itimerval *value,
  94. struct itimerval *ovalue);
  95. extern unsigned int alarm_setitimer(unsigned int seconds);
  96. extern int do_getitimer(int which, struct itimerval *value);
  97. extern void getnstimeofday(struct timespec *tv);
  98. extern struct timespec timespec_trunc(struct timespec t, unsigned gran);
  99. extern int timekeeping_is_continuous(void);
  100. /**
  101. * timespec_to_ns - Convert timespec to nanoseconds
  102. * @ts: pointer to the timespec variable to be converted
  103. *
  104. * Returns the scalar nanosecond representation of the timespec
  105. * parameter.
  106. */
  107. static inline s64 timespec_to_ns(const struct timespec *ts)
  108. {
  109. return ((s64) ts->tv_sec * NSEC_PER_SEC) + ts->tv_nsec;
  110. }
  111. /**
  112. * timeval_to_ns - Convert timeval to nanoseconds
  113. * @ts: pointer to the timeval variable to be converted
  114. *
  115. * Returns the scalar nanosecond representation of the timeval
  116. * parameter.
  117. */
  118. static inline s64 timeval_to_ns(const struct timeval *tv)
  119. {
  120. return ((s64) tv->tv_sec * NSEC_PER_SEC) +
  121. tv->tv_usec * NSEC_PER_USEC;
  122. }
  123. /**
  124. * ns_to_timespec - Convert nanoseconds to timespec
  125. * @nsec: the nanoseconds value to be converted
  126. *
  127. * Returns the timespec representation of the nsec parameter.
  128. */
  129. extern struct timespec ns_to_timespec(const s64 nsec);
  130. /**
  131. * ns_to_timeval - Convert nanoseconds to timeval
  132. * @nsec: the nanoseconds value to be converted
  133. *
  134. * Returns the timeval representation of the nsec parameter.
  135. */
  136. extern struct timeval ns_to_timeval(const s64 nsec);
  137. /**
  138. * timespec_add_ns - Adds nanoseconds to a timespec
  139. * @a: pointer to timespec to be incremented
  140. * @ns: unsigned nanoseconds value to be added
  141. */
  142. static inline void timespec_add_ns(struct timespec *a, u64 ns)
  143. {
  144. ns += a->tv_nsec;
  145. while(unlikely(ns >= NSEC_PER_SEC)) {
  146. ns -= NSEC_PER_SEC;
  147. a->tv_sec++;
  148. }
  149. a->tv_nsec = ns;
  150. }
  151. #endif /* __KERNEL__ */
  152. #define NFDBITS __NFDBITS
  153. #define FD_SETSIZE __FD_SETSIZE
  154. #define FD_SET(fd,fdsetp) __FD_SET(fd,fdsetp)
  155. #define FD_CLR(fd,fdsetp) __FD_CLR(fd,fdsetp)
  156. #define FD_ISSET(fd,fdsetp) __FD_ISSET(fd,fdsetp)
  157. #define FD_ZERO(fdsetp) __FD_ZERO(fdsetp)
  158. /*
  159. * Names of the interval timers, and structure
  160. * defining a timer setting:
  161. */
  162. #define ITIMER_REAL 0
  163. #define ITIMER_VIRTUAL 1
  164. #define ITIMER_PROF 2
  165. struct itimerspec {
  166. struct timespec it_interval; /* timer period */
  167. struct timespec it_value; /* timer expiration */
  168. };
  169. struct itimerval {
  170. struct timeval it_interval; /* timer interval */
  171. struct timeval it_value; /* current value */
  172. };
  173. /*
  174. * The IDs of the various system clocks (for POSIX.1b interval timers):
  175. */
  176. #define CLOCK_REALTIME 0
  177. #define CLOCK_MONOTONIC 1
  178. #define CLOCK_PROCESS_CPUTIME_ID 2
  179. #define CLOCK_THREAD_CPUTIME_ID 3
  180. /*
  181. * The IDs of various hardware clocks:
  182. */
  183. #define CLOCK_SGI_CYCLE 10
  184. #define MAX_CLOCKS 16
  185. #define CLOCKS_MASK (CLOCK_REALTIME | CLOCK_MONOTONIC)
  186. #define CLOCKS_MONO CLOCK_MONOTONIC
  187. /*
  188. * The various flags for setting POSIX.1b interval timers:
  189. */
  190. #define TIMER_ABSTIME 0x01
  191. #endif