Blame view
include/linux/timex.h
10.1 KB
1da177e4c
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 |
/***************************************************************************** * * * Copyright (c) David L. Mills 1993 * * * * Permission to use, copy, modify, and distribute this software and its * * documentation for any purpose and without fee is hereby granted, provided * * that the above copyright notice appears in all copies and that both the * * copyright notice and this permission notice appear in supporting * * documentation, and that the name University of Delaware not be used in * * advertising or publicity pertaining to distribution of the software * * without specific, written prior permission. The University of Delaware * * makes no representations about the suitability this software for any * * purpose. It is provided "as is" without express or implied warranty. * * * *****************************************************************************/ /* * Modification history timex.h * * 29 Dec 97 Russell King * Moved CLOCK_TICK_RATE, CLOCK_TICK_FACTOR and FINETUNE to asm/timex.h * for ARM machines * * 9 Jan 97 Adrian Sun * Shifted LATCH define to allow access to alpha machines. * * 26 Sep 94 David L. Mills * Added defines for hybrid phase/frequency-lock loop. * * 19 Mar 94 David L. Mills * Moved defines from kernel routines to header file and added new * defines for PPS phase-lock loop. * * 20 Feb 94 David L. Mills * Revised status codes and structures for external clock and PPS * signal discipline. * * 28 Nov 93 David L. Mills * Adjusted parameters to improve stability and increase poll * interval. * * 17 Sep 93 David L. Mills * Created file $NTP/include/sys/timex.h * 07 Oct 93 Torsten Duwe * Derived linux/timex.h * 1995-08-13 Torsten Duwe * kernel PLL updated to 1994-12-13 specs (rfc-1589) * 1997-08-30 Ulrich Windl * Added new constant NTP_PHASE_LIMIT * 2004-08-12 Christoph Lameter * Reworked time interpolation logic */ #ifndef _LINUX_TIMEX_H #define _LINUX_TIMEX_H |
1da177e4c
|
55 |
#include <linux/time.h> |
eea83d896
|
56 |
#define NTP_API 4 /* NTP API version */ |
1da177e4c
|
57 |
/* |
1da177e4c
|
58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 |
* syscall interface - used (mainly by NTP daemon) * to discipline kernel clock oscillator */ struct timex { unsigned int modes; /* mode selector */ long offset; /* time offset (usec) */ long freq; /* frequency offset (scaled ppm) */ long maxerror; /* maximum error (usec) */ long esterror; /* estimated error (usec) */ int status; /* clock command/status */ long constant; /* pll time constant */ long precision; /* clock precision (usec) (read only) */ long tolerance; /* clock frequency tolerance (ppm) * (read only) */ struct timeval time; /* (read only) */ long tick; /* (modified) usecs between clock ticks */ long ppsfreq; /* pps frequency (scaled ppm) (ro) */ long jitter; /* pps jitter (us) (ro) */ int shift; /* interval duration (s) (shift) (ro) */ long stabil; /* pps stability (scaled ppm) (ro) */ long jitcnt; /* jitter limit exceeded (ro) */ long calcnt; /* calibration intervals (ro) */ long errcnt; /* calibration errors (ro) */ long stbcnt; /* stability limit exceeded (ro) */ |
153b5d054
|
84 |
int tai; /* TAI offset (ro) */ |
1da177e4c
|
85 86 |
int :32; int :32; int :32; int :32; int :32; int :32; int :32; int :32; |
153b5d054
|
87 |
int :32; int :32; int :32; |
1da177e4c
|
88 89 90 91 92 93 94 95 96 97 98 |
}; /* * Mode codes (timex.mode) */ #define ADJ_OFFSET 0x0001 /* time offset */ #define ADJ_FREQUENCY 0x0002 /* frequency offset */ #define ADJ_MAXERROR 0x0004 /* maximum time error */ #define ADJ_ESTERROR 0x0008 /* estimated time error */ #define ADJ_STATUS 0x0010 /* clock status */ #define ADJ_TIMECONST 0x0020 /* pll time constant */ |
153b5d054
|
99 |
#define ADJ_TAI 0x0080 /* set TAI offset */ |
eea83d896
|
100 101 |
#define ADJ_MICRO 0x1000 /* select microsecond resolution */ #define ADJ_NANO 0x2000 /* select nanosecond resolution */ |
1da177e4c
|
102 |
#define ADJ_TICK 0x4000 /* tick value */ |
916c7a855
|
103 104 105 106 107 108 |
#ifdef __KERNEL__ #define ADJ_ADJTIME 0x8000 /* switch between adjtime/adjtimex modes */ #define ADJ_OFFSET_SINGLESHOT 0x0001 /* old-fashioned adjtime */ #define ADJ_OFFSET_READONLY 0x2000 /* read-only adjtime */ #else |
1da177e4c
|
109 |
#define ADJ_OFFSET_SINGLESHOT 0x8001 /* old-fashioned adjtime */ |
916c7a855
|
110 111 |
#define ADJ_OFFSET_SS_READ 0xa001 /* read-only adjtime */ #endif |
1da177e4c
|
112 |
|
c95b4502a
|
113 |
/* NTP userland likes the MOD_ prefix better */ |
1da177e4c
|
114 115 116 117 118 119 |
#define MOD_OFFSET ADJ_OFFSET #define MOD_FREQUENCY ADJ_FREQUENCY #define MOD_MAXERROR ADJ_MAXERROR #define MOD_ESTERROR ADJ_ESTERROR #define MOD_STATUS ADJ_STATUS #define MOD_TIMECONST ADJ_TIMECONST |
c95b4502a
|
120 121 122 |
#define MOD_TAI ADJ_TAI #define MOD_MICRO ADJ_MICRO #define MOD_NANO ADJ_NANO |
1da177e4c
|
123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 |
/* * Status codes (timex.status) */ #define STA_PLL 0x0001 /* enable PLL updates (rw) */ #define STA_PPSFREQ 0x0002 /* enable PPS freq discipline (rw) */ #define STA_PPSTIME 0x0004 /* enable PPS time discipline (rw) */ #define STA_FLL 0x0008 /* select frequency-lock mode (rw) */ #define STA_INS 0x0010 /* insert leap (rw) */ #define STA_DEL 0x0020 /* delete leap (rw) */ #define STA_UNSYNC 0x0040 /* clock unsynchronized (rw) */ #define STA_FREQHOLD 0x0080 /* hold frequency (rw) */ #define STA_PPSSIGNAL 0x0100 /* PPS signal present (ro) */ #define STA_PPSJITTER 0x0200 /* PPS signal jitter exceeded (ro) */ #define STA_PPSWANDER 0x0400 /* PPS signal wander exceeded (ro) */ #define STA_PPSERROR 0x0800 /* PPS signal calibration error (ro) */ #define STA_CLOCKERR 0x1000 /* clock hardware fault (ro) */ |
eea83d896
|
144 145 146 |
#define STA_NANO 0x2000 /* resolution (0 = us, 1 = ns) (ro) */ #define STA_MODE 0x4000 /* mode (0 = PLL, 1 = FLL) (ro) */ #define STA_CLK 0x8000 /* clock source (0 = A, 1 = B) (ro) */ |
1da177e4c
|
147 |
|
eea83d896
|
148 |
/* read-only bits */ |
1da177e4c
|
149 |
#define STA_RONLY (STA_PPSSIGNAL | STA_PPSJITTER | STA_PPSWANDER | \ |
eea83d896
|
150 |
STA_PPSERROR | STA_CLOCKERR | STA_NANO | STA_MODE | STA_CLK) |
1da177e4c
|
151 152 153 154 155 156 157 158 159 160 161 162 163 |
/* * Clock states (time_state) */ #define TIME_OK 0 /* clock synchronized, no leap second */ #define TIME_INS 1 /* insert leap second */ #define TIME_DEL 2 /* delete leap second */ #define TIME_OOP 3 /* leap second in progress */ #define TIME_WAIT 4 /* leap second has occurred */ #define TIME_ERROR 5 /* clock not synchronized */ #define TIME_BAD TIME_ERROR /* bw compat */ #ifdef __KERNEL__ |
c29541b24
|
164 165 166 |
#include <linux/compiler.h> #include <linux/types.h> #include <linux/param.h> |
ee6baf884
|
167 |
#include <asm/timex.h> |
1da177e4c
|
168 |
/* |
22cfbbfd9
|
169 170 171 172 173 174 175 176 |
* SHIFT_PLL is used as a dampening factor to define how much we * adjust the frequency correction for a given offset in PLL mode. * It also used in dampening the offset correction, to define how * much of the current value in time_offset we correct for each * second. Changing this value changes the stiffness of the ntp * adjustment code. A lower value makes it more flexible, reducing * NTP convergence time. A higher value makes it stiffer, increasing * convergence time, but making the clock more stable. |
c29541b24
|
177 |
* |
e13cf6e04
|
178 |
* In David Mills' nanokernel reference implementation SHIFT_PLL is 4. |
22cfbbfd9
|
179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 |
* However this seems to increase convergence time much too long. * * https://lists.ntp.org/pipermail/hackers/2008-January/003487.html * * In the above mailing list discussion, it seems the value of 4 * was appropriate for other Unix systems with HZ=100, and that * SHIFT_PLL should be decreased as HZ increases. However, Linux's * clock steering implementation is HZ independent. * * Through experimentation, a SHIFT_PLL value of 2 was found to allow * for fast convergence (very similar to the NTPv3 code used prior to * v2.6.19), with good clock stability. * * * SHIFT_FLL is used as a dampening factor to define how much we * adjust the frequency correction for a given offset in FLL mode. |
e13cf6e04
|
195 |
* In David Mills' nanokernel reference implementation SHIFT_FLL is 2. |
22cfbbfd9
|
196 197 |
* * MAXTC establishes the maximum time constant of the PLL. |
c29541b24
|
198 |
*/ |
22cfbbfd9
|
199 |
#define SHIFT_PLL 2 /* PLL frequency factor (shift) */ |
c29541b24
|
200 201 202 203 204 205 206 207 208 |
#define SHIFT_FLL 2 /* FLL frequency factor (shift) */ #define MAXTC 10 /* maximum time constant (shift) */ /* * SHIFT_USEC defines the scaling (shift) of the time_freq and * time_tolerance variables, which represent the current frequency * offset and maximum frequency tolerance. */ #define SHIFT_USEC 16 /* frequency offset scale (shift) */ |
2b9d1496e
|
209 |
#define PPM_SCALE ((s64)NSEC_PER_USEC << (NTP_SCALE_SHIFT - SHIFT_USEC)) |
c29541b24
|
210 |
#define PPM_SCALE_INV_SHIFT 19 |
22cfbbfd9
|
211 |
#define PPM_SCALE_INV ((1LL << (PPM_SCALE_INV_SHIFT + NTP_SCALE_SHIFT)) / \ |
c29541b24
|
212 |
PPM_SCALE + 1) |
22cfbbfd9
|
213 |
#define MAXPHASE 500000000L /* max phase error (ns) */ |
c29541b24
|
214 215 216 217 218 219 220 |
#define MAXFREQ 500000 /* max frequency error (ns/s) */ #define MAXFREQ_SCALED ((s64)MAXFREQ << NTP_SCALE_SHIFT) #define MINSEC 256 /* min interval between updates (s) */ #define MAXSEC 2048 /* max interval between updates (s) */ #define NTP_PHASE_LIMIT ((MAXPHASE / NSEC_PER_USEC) << 5) /* beyond max. dispersion */ /* |
1da177e4c
|
221 222 223 224 225 226 |
* kernel variables * Note: maximum error = NTP synch distance = dispersion + delay / 2; * estimated error = NTP dispersion. */ extern unsigned long tick_usec; /* USER_HZ period (usec) */ extern unsigned long tick_nsec; /* ACTHZ period (nsec) */ |
1da177e4c
|
227 228 229 230 |
/* * phase-lock loop variables */ |
1da177e4c
|
231 |
extern int time_status; /* clock synchronization status bits */ |
1da177e4c
|
232 |
|
7dffa3c67
|
233 |
extern void ntp_init(void); |
b0ee75561
|
234 |
extern void ntp_clear(void); |
b149ee223
|
235 236 237 238 239 240 241 242 243 |
/** * ntp_synced - Returns 1 if the NTP status is not UNSYNC * */ static inline int ntp_synced(void) { return !(time_status & STA_UNSYNC); } |
1bb34a412
|
244 245 246 247 248 249 |
/* Required to safely shift negative values */ #define shift_right(x, s) ({ \ __typeof__(x) __x = (x); \ __typeof__(s) __s = (s); \ __x < 0 ? -(-__x >> __s) : __x >> __s; \ }) |
7fc5c7840
|
250 |
#define NTP_SCALE_SHIFT 32 |
19923c190
|
251 |
|
f4304ab21
|
252 |
#define NTP_INTERVAL_FREQ (HZ) |
10a398d04
|
253 |
#define NTP_INTERVAL_LENGTH (NSEC_PER_SEC/NTP_INTERVAL_FREQ) |
f4304ab21
|
254 |
|
8383c4239
|
255 256 |
/* Returns how long ticks are at present, in ns / 2^NTP_SCALE_SHIFT. */ extern u64 tick_length; |
726c14bf4
|
257 |
|
4c7ee8de9
|
258 259 |
extern void second_overflow(void); extern void update_ntp_one_tick(void); |
3158e9411
|
260 |
extern int do_adjtimex(struct timex *); |
025b40abe
|
261 |
extern void hardpps(const struct timespec *, const struct timespec *); |
3158e9411
|
262 |
|
941e492bd
|
263 |
int read_current_timer(unsigned long *timer_val); |
08604bd99
|
264 265 |
/* The clock frequency of the i8253/i8254 PIT */ #define PIT_TICK_RATE 1193182ul |
1da177e4c
|
266 267 268 |
#endif /* KERNEL */ #endif /* LINUX_TIMEX_H */ |