timex.h 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. /* Copyright (C) 1995, 1996, 1997, 1999 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3. The GNU C Library is free software; you can redistribute it and/or
  4. modify it under the terms of the GNU Lesser General Public
  5. License as published by the Free Software Foundation; either
  6. version 2.1 of the License, or (at your option) any later version.
  7. The GNU C Library is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  10. Lesser General Public License for more details.
  11. You should have received a copy of the GNU Lesser General Public
  12. License along with the GNU C Library; if not, see
  13. <http://www.gnu.org/licenses/>. */
  14. #ifndef _SYS_TIMEX_H
  15. #define _SYS_TIMEX_H 1
  16. #include <features.h>
  17. #include <sys/time.h>
  18. #include <time.h>
  19. /* These definitions from linux/timex.h as of 2.2.0. */
  20. struct ntptimeval
  21. {
  22. struct timeval time; /* current time (ro) */
  23. long int maxerror; /* maximum error (us) (ro) */
  24. long int esterror; /* estimated error (us) (ro) */
  25. };
  26. struct timex
  27. {
  28. unsigned int modes; /* mode selector */
  29. long int offset; /* time offset (usec) */
  30. long int freq; /* frequency offset (scaled ppm) */
  31. long int maxerror; /* maximum error (usec) */
  32. long int esterror; /* estimated error (usec) */
  33. int status; /* clock command/status */
  34. long int constant; /* pll time constant */
  35. long int precision; /* clock precision (usec) (read only) */
  36. long int tolerance; /* clock frequency tolerance (ppm) (read only) */
  37. struct timeval time; /* (read only) */
  38. long int tick; /* (modified) usecs between clock ticks */
  39. long int ppsfreq; /* pps frequency (scaled ppm) (ro) */
  40. long int jitter; /* pps jitter (us) (ro) */
  41. int shift; /* interval duration (s) (shift) (ro) */
  42. long int stabil; /* pps stability (scaled ppm) (ro) */
  43. long int jitcnt; /* jitter limit exceeded (ro) */
  44. long int calcnt; /* calibration intervals (ro) */
  45. long int errcnt; /* calibration errors (ro) */
  46. long int stbcnt; /* stability limit exceeded (ro) */
  47. /* ??? */
  48. int :32; int :32; int :32; int :32;
  49. int :32; int :32; int :32; int :32;
  50. int :32; int :32; int :32; int :32;
  51. };
  52. /* Mode codes (timex.mode) */
  53. #define ADJ_OFFSET 0x0001 /* time offset */
  54. #define ADJ_FREQUENCY 0x0002 /* frequency offset */
  55. #define ADJ_MAXERROR 0x0004 /* maximum time error */
  56. #define ADJ_ESTERROR 0x0008 /* estimated time error */
  57. #define ADJ_STATUS 0x0010 /* clock status */
  58. #define ADJ_TIMECONST 0x0020 /* pll time constant */
  59. #define ADJ_TAI 0x0080 /* set TAI offset */
  60. #define ADJ_MICRO 0x1000 /* select microsecond resolution */
  61. #define ADJ_NANO 0x2000 /* select nanosecond resolution */
  62. #define ADJ_TICK 0x4000 /* tick value */
  63. #define ADJ_OFFSET_SINGLESHOT 0x8001 /* old-fashioned adjtime */
  64. #define ADJ_OFFSET_SS_READ 0xa001 /* read-only adjtime */
  65. /* xntp 3.4 compatibility names */
  66. #define MOD_OFFSET ADJ_OFFSET
  67. #define MOD_FREQUENCY ADJ_FREQUENCY
  68. #define MOD_MAXERROR ADJ_MAXERROR
  69. #define MOD_ESTERROR ADJ_ESTERROR
  70. #define MOD_STATUS ADJ_STATUS
  71. #define MOD_TIMECONST ADJ_TIMECONST
  72. #define MOD_CLKB ADJ_TICK
  73. #define MOD_CLKA ADJ_OFFSET_SINGLESHOT /* 0x8000 in original */
  74. /* Status codes (timex.status) */
  75. #define STA_PLL 0x0001 /* enable PLL updates (rw) */
  76. #define STA_PPSFREQ 0x0002 /* enable PPS freq discipline (rw) */
  77. #define STA_PPSTIME 0x0004 /* enable PPS time discipline (rw) */
  78. #define STA_FLL 0x0008 /* select frequency-lock mode (rw) */
  79. #define STA_INS 0x0010 /* insert leap (rw) */
  80. #define STA_DEL 0x0020 /* delete leap (rw) */
  81. #define STA_UNSYNC 0x0040 /* clock unsynchronized (rw) */
  82. #define STA_FREQHOLD 0x0080 /* hold frequency (rw) */
  83. #define STA_PPSSIGNAL 0x0100 /* PPS signal present (ro) */
  84. #define STA_PPSJITTER 0x0200 /* PPS signal jitter exceeded (ro) */
  85. #define STA_PPSWANDER 0x0400 /* PPS signal wander exceeded (ro) */
  86. #define STA_PPSERROR 0x0800 /* PPS signal calibration error (ro) */
  87. #define STA_CLOCKERR 0x1000 /* clock hardware fault (ro) */
  88. #define STA_RONLY (STA_PPSSIGNAL | STA_PPSJITTER | STA_PPSWANDER | \
  89. STA_PPSERROR | STA_CLOCKERR) /* read-only bits */
  90. /* Clock states (time_state) */
  91. #define TIME_OK 0 /* clock synchronized, no leap second */
  92. #define TIME_INS 1 /* insert leap second */
  93. #define TIME_DEL 2 /* delete leap second */
  94. #define TIME_OOP 3 /* leap second in progress */
  95. #define TIME_WAIT 4 /* leap second has occurred */
  96. #define TIME_ERROR 5 /* clock not synchronized */
  97. #define TIME_BAD TIME_ERROR /* bw compat */
  98. /* Maximum time constant of the PLL. */
  99. #define MAXTC 6
  100. __BEGIN_DECLS
  101. extern int __adjtimex (struct timex *__ntx) __THROW;
  102. extern int adjtimex (struct timex *__ntx) __THROW;
  103. libc_hidden_proto(adjtimex)
  104. #if defined __UCLIBC_NTP_LEGACY__
  105. extern int ntp_gettime (struct ntptimeval *__ntv) __THROW;
  106. extern int ntp_adjtime (struct timex *__tntx) __THROW;
  107. #endif
  108. #if defined __UCLIBC_HAS_REALTIME__
  109. extern int clock_adjtime (clockid_t __clock_id, struct timex *__ntx) __THROW;
  110. #endif
  111. __END_DECLS
  112. #endif /* sys/timex.h */