| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /***************************************************************************** | 
|  | 2 | *                                                                           * | 
|  | 3 | * Copyright (c) David L. Mills 1993                                         * | 
|  | 4 | *                                                                           * | 
|  | 5 | * Permission to use, copy, modify, and distribute this software and its     * | 
|  | 6 | * documentation for any purpose and without fee is hereby granted, provided * | 
|  | 7 | * that the above copyright notice appears in all copies and that both the   * | 
|  | 8 | * copyright notice and this permission notice appear in supporting          * | 
|  | 9 | * documentation, and that the name University of Delaware not be used in    * | 
|  | 10 | * advertising or publicity pertaining to distribution of the software       * | 
|  | 11 | * without specific, written prior permission.  The University of Delaware   * | 
|  | 12 | * makes no representations about the suitability this software for any      * | 
|  | 13 | * purpose.  It is provided "as is" without express or implied warranty.     * | 
|  | 14 | *                                                                           * | 
|  | 15 | *****************************************************************************/ | 
|  | 16 |  | 
|  | 17 | /* | 
|  | 18 | * Modification history timex.h | 
|  | 19 | * | 
|  | 20 | * 29 Dec 97	Russell King | 
|  | 21 | *	Moved CLOCK_TICK_RATE, CLOCK_TICK_FACTOR and FINETUNE to asm/timex.h | 
|  | 22 | *	for ARM machines | 
|  | 23 | * | 
|  | 24 | *  9 Jan 97    Adrian Sun | 
|  | 25 | *      Shifted LATCH define to allow access to alpha machines. | 
|  | 26 | * | 
|  | 27 | * 26 Sep 94	David L. Mills | 
|  | 28 | *	Added defines for hybrid phase/frequency-lock loop. | 
|  | 29 | * | 
|  | 30 | * 19 Mar 94	David L. Mills | 
|  | 31 | *	Moved defines from kernel routines to header file and added new | 
|  | 32 | *	defines for PPS phase-lock loop. | 
|  | 33 | * | 
|  | 34 | * 20 Feb 94	David L. Mills | 
|  | 35 | *	Revised status codes and structures for external clock and PPS | 
|  | 36 | *	signal discipline. | 
|  | 37 | * | 
|  | 38 | * 28 Nov 93	David L. Mills | 
|  | 39 | *	Adjusted parameters to improve stability and increase poll | 
|  | 40 | *	interval. | 
|  | 41 | * | 
|  | 42 | * 17 Sep 93    David L. Mills | 
|  | 43 | *      Created file $NTP/include/sys/timex.h | 
|  | 44 | * 07 Oct 93    Torsten Duwe | 
|  | 45 | *      Derived linux/timex.h | 
|  | 46 | * 1995-08-13    Torsten Duwe | 
|  | 47 | *      kernel PLL updated to 1994-12-13 specs (rfc-1589) | 
|  | 48 | * 1997-08-30    Ulrich Windl | 
|  | 49 | *      Added new constant NTP_PHASE_LIMIT | 
|  | 50 | * 2004-08-12    Christoph Lameter | 
|  | 51 | *      Reworked time interpolation logic | 
|  | 52 | */ | 
|  | 53 | #ifndef _LINUX_TIMEX_H | 
|  | 54 | #define _LINUX_TIMEX_H | 
|  | 55 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 56 | #include <linux/compiler.h> | 
|  | 57 | #include <linux/time.h> | 
|  | 58 |  | 
|  | 59 | #include <asm/param.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 60 |  | 
|  | 61 | /* | 
|  | 62 | * SHIFT_KG and SHIFT_KF establish the damping of the PLL and are chosen | 
|  | 63 | * for a slightly underdamped convergence characteristic. SHIFT_KH | 
|  | 64 | * establishes the damping of the FLL and is chosen by wisdom and black | 
|  | 65 | * art. | 
|  | 66 | * | 
|  | 67 | * MAXTC establishes the maximum time constant of the PLL. With the | 
|  | 68 | * SHIFT_KG and SHIFT_KF values given and a time constant range from | 
|  | 69 | * zero to MAXTC, the PLL will converge in 15 minutes to 16 hours, | 
|  | 70 | * respectively. | 
|  | 71 | */ | 
| Roman Zippel | f199239 | 2006-09-30 23:28:28 -0700 | [diff] [blame] | 72 | #define SHIFT_PLL	4	/* PLL frequency factor (shift) */ | 
|  | 73 | #define SHIFT_FLL	2	/* FLL frequency factor (shift) */ | 
|  | 74 | #define MAXTC		10	/* maximum time constant (shift) */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 75 |  | 
|  | 76 | /* | 
| Roman Zippel | 0883d89 | 2006-09-30 23:28:29 -0700 | [diff] [blame] | 77 | * The SHIFT_UPDATE define establishes the decimal point of the | 
|  | 78 | * time_offset variable which represents the current offset with | 
|  | 79 | * respect to standard time. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 80 | * | 
|  | 81 | * SHIFT_USEC defines the scaling (shift) of the time_freq and | 
|  | 82 | * time_tolerance variables, which represent the current frequency | 
|  | 83 | * offset and maximum frequency tolerance. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 84 | */ | 
| Roman Zippel | 3d3675c | 2006-09-30 23:28:25 -0700 | [diff] [blame] | 85 | #define SHIFT_UPDATE (SHIFT_HZ + 1) /* time offset scale (shift) */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 86 | #define SHIFT_USEC 16		/* frequency offset scale (shift) */ | 
| Roman Zippel | 04b617e | 2006-09-30 23:28:27 -0700 | [diff] [blame] | 87 | #define SHIFT_NSEC 12		/* kernel frequency offset scale */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 88 |  | 
|  | 89 | #define MAXPHASE 512000L        /* max phase error (us) */ | 
|  | 90 | #define MAXFREQ (512L << SHIFT_USEC)  /* max frequency error (ppm) */ | 
| Roman Zippel | 04b617e | 2006-09-30 23:28:27 -0700 | [diff] [blame] | 91 | #define MAXFREQ_NSEC (512000L << SHIFT_NSEC) /* max frequency error (ppb) */ | 
| Roman Zippel | f199239 | 2006-09-30 23:28:28 -0700 | [diff] [blame] | 92 | #define MINSEC 256		/* min interval between updates (s) */ | 
|  | 93 | #define MAXSEC 2048		/* max interval between updates (s) */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 94 | #define	NTP_PHASE_LIMIT	(MAXPHASE << 5)	/* beyond max. dispersion */ | 
|  | 95 |  | 
|  | 96 | /* | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 97 | * syscall interface - used (mainly by NTP daemon) | 
|  | 98 | * to discipline kernel clock oscillator | 
|  | 99 | */ | 
|  | 100 | struct timex { | 
|  | 101 | unsigned int modes;	/* mode selector */ | 
|  | 102 | long offset;		/* time offset (usec) */ | 
|  | 103 | long freq;		/* frequency offset (scaled ppm) */ | 
|  | 104 | long maxerror;		/* maximum error (usec) */ | 
|  | 105 | long esterror;		/* estimated error (usec) */ | 
|  | 106 | int status;		/* clock command/status */ | 
|  | 107 | long constant;		/* pll time constant */ | 
|  | 108 | long precision;		/* clock precision (usec) (read only) */ | 
|  | 109 | long tolerance;		/* clock frequency tolerance (ppm) | 
|  | 110 | * (read only) | 
|  | 111 | */ | 
|  | 112 | struct timeval time;	/* (read only) */ | 
|  | 113 | long tick;		/* (modified) usecs between clock ticks */ | 
|  | 114 |  | 
|  | 115 | long ppsfreq;           /* pps frequency (scaled ppm) (ro) */ | 
|  | 116 | long jitter;            /* pps jitter (us) (ro) */ | 
|  | 117 | int shift;              /* interval duration (s) (shift) (ro) */ | 
|  | 118 | long stabil;            /* pps stability (scaled ppm) (ro) */ | 
|  | 119 | long jitcnt;            /* jitter limit exceeded (ro) */ | 
|  | 120 | long calcnt;            /* calibration intervals (ro) */ | 
|  | 121 | long errcnt;            /* calibration errors (ro) */ | 
|  | 122 | long stbcnt;            /* stability limit exceeded (ro) */ | 
|  | 123 |  | 
|  | 124 | int  :32; int  :32; int  :32; int  :32; | 
|  | 125 | int  :32; int  :32; int  :32; int  :32; | 
|  | 126 | int  :32; int  :32; int  :32; int  :32; | 
|  | 127 | }; | 
|  | 128 |  | 
|  | 129 | /* | 
|  | 130 | * Mode codes (timex.mode) | 
|  | 131 | */ | 
|  | 132 | #define ADJ_OFFSET		0x0001	/* time offset */ | 
|  | 133 | #define ADJ_FREQUENCY		0x0002	/* frequency offset */ | 
|  | 134 | #define ADJ_MAXERROR		0x0004	/* maximum time error */ | 
|  | 135 | #define ADJ_ESTERROR		0x0008	/* estimated time error */ | 
|  | 136 | #define ADJ_STATUS		0x0010	/* clock status */ | 
|  | 137 | #define ADJ_TIMECONST		0x0020	/* pll time constant */ | 
|  | 138 | #define ADJ_TICK		0x4000	/* tick value */ | 
|  | 139 | #define ADJ_OFFSET_SINGLESHOT	0x8001	/* old-fashioned adjtime */ | 
|  | 140 |  | 
|  | 141 | /* xntp 3.4 compatibility names */ | 
|  | 142 | #define MOD_OFFSET	ADJ_OFFSET | 
|  | 143 | #define MOD_FREQUENCY	ADJ_FREQUENCY | 
|  | 144 | #define MOD_MAXERROR	ADJ_MAXERROR | 
|  | 145 | #define MOD_ESTERROR	ADJ_ESTERROR | 
|  | 146 | #define MOD_STATUS	ADJ_STATUS | 
|  | 147 | #define MOD_TIMECONST	ADJ_TIMECONST | 
|  | 148 | #define MOD_CLKB	ADJ_TICK | 
|  | 149 | #define MOD_CLKA	ADJ_OFFSET_SINGLESHOT /* 0x8000 in original */ | 
|  | 150 |  | 
|  | 151 |  | 
|  | 152 | /* | 
|  | 153 | * Status codes (timex.status) | 
|  | 154 | */ | 
|  | 155 | #define STA_PLL		0x0001	/* enable PLL updates (rw) */ | 
|  | 156 | #define STA_PPSFREQ	0x0002	/* enable PPS freq discipline (rw) */ | 
|  | 157 | #define STA_PPSTIME	0x0004	/* enable PPS time discipline (rw) */ | 
|  | 158 | #define STA_FLL		0x0008	/* select frequency-lock mode (rw) */ | 
|  | 159 |  | 
|  | 160 | #define STA_INS		0x0010	/* insert leap (rw) */ | 
|  | 161 | #define STA_DEL		0x0020	/* delete leap (rw) */ | 
|  | 162 | #define STA_UNSYNC	0x0040	/* clock unsynchronized (rw) */ | 
|  | 163 | #define STA_FREQHOLD	0x0080	/* hold frequency (rw) */ | 
|  | 164 |  | 
|  | 165 | #define STA_PPSSIGNAL	0x0100	/* PPS signal present (ro) */ | 
|  | 166 | #define STA_PPSJITTER	0x0200	/* PPS signal jitter exceeded (ro) */ | 
|  | 167 | #define STA_PPSWANDER	0x0400	/* PPS signal wander exceeded (ro) */ | 
|  | 168 | #define STA_PPSERROR	0x0800	/* PPS signal calibration error (ro) */ | 
|  | 169 |  | 
|  | 170 | #define STA_CLOCKERR	0x1000	/* clock hardware fault (ro) */ | 
|  | 171 |  | 
|  | 172 | #define STA_RONLY (STA_PPSSIGNAL | STA_PPSJITTER | STA_PPSWANDER | \ | 
|  | 173 | STA_PPSERROR | STA_CLOCKERR) /* read-only bits */ | 
|  | 174 |  | 
|  | 175 | /* | 
|  | 176 | * Clock states (time_state) | 
|  | 177 | */ | 
|  | 178 | #define TIME_OK		0	/* clock synchronized, no leap second */ | 
|  | 179 | #define TIME_INS	1	/* insert leap second */ | 
|  | 180 | #define TIME_DEL	2	/* delete leap second */ | 
|  | 181 | #define TIME_OOP	3	/* leap second in progress */ | 
|  | 182 | #define TIME_WAIT	4	/* leap second has occurred */ | 
|  | 183 | #define TIME_ERROR	5	/* clock not synchronized */ | 
|  | 184 | #define TIME_BAD	TIME_ERROR /* bw compat */ | 
|  | 185 |  | 
|  | 186 | #ifdef __KERNEL__ | 
| David Woodhouse | ee6baf8 | 2006-09-12 20:36:03 -0700 | [diff] [blame] | 187 | #include <asm/timex.h> | 
|  | 188 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 189 | /* | 
|  | 190 | * kernel variables | 
|  | 191 | * Note: maximum error = NTP synch distance = dispersion + delay / 2; | 
|  | 192 | * estimated error = NTP dispersion. | 
|  | 193 | */ | 
|  | 194 | extern unsigned long tick_usec;		/* USER_HZ period (usec) */ | 
|  | 195 | extern unsigned long tick_nsec;		/* ACTHZ          period (nsec) */ | 
|  | 196 | extern int tickadj;			/* amount of adjustment per tick */ | 
|  | 197 |  | 
|  | 198 | /* | 
|  | 199 | * phase-lock loop variables | 
|  | 200 | */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 201 | extern int time_status;		/* clock synchronization status bits */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 202 | extern long time_maxerror;	/* maximum error */ | 
|  | 203 | extern long time_esterror;	/* estimated error */ | 
|  | 204 |  | 
|  | 205 | extern long time_freq;		/* frequency offset (scaled ppm) */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 206 |  | 
|  | 207 | extern long time_adjust;	/* The amount of adjtime left */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 208 |  | 
| Roman Zippel | b0ee755 | 2006-09-30 23:28:22 -0700 | [diff] [blame] | 209 | extern void ntp_clear(void); | 
| john stultz | b149ee2 | 2005-09-06 15:17:46 -0700 | [diff] [blame] | 210 |  | 
|  | 211 | /** | 
|  | 212 | * ntp_synced - Returns 1 if the NTP status is not UNSYNC | 
|  | 213 | * | 
|  | 214 | */ | 
|  | 215 | static inline int ntp_synced(void) | 
|  | 216 | { | 
|  | 217 | return !(time_status & STA_UNSYNC); | 
|  | 218 | } | 
|  | 219 |  | 
| john stultz | 1bb34a4 | 2005-10-30 15:01:42 -0800 | [diff] [blame] | 220 | /* Required to safely shift negative values */ | 
|  | 221 | #define shift_right(x, s) ({	\ | 
|  | 222 | __typeof__(x) __x = (x);	\ | 
|  | 223 | __typeof__(s) __s = (s);	\ | 
|  | 224 | __x < 0 ? -(-__x >> __s) : __x >> __s;	\ | 
|  | 225 | }) | 
|  | 226 |  | 
| Roman Zippel | 19923c1 | 2006-06-26 00:25:18 -0700 | [diff] [blame] | 227 | #define TICK_LENGTH_SHIFT	32 | 
|  | 228 |  | 
| john stultz | f4304ab | 2007-02-16 01:27:26 -0800 | [diff] [blame] | 229 | #ifdef CONFIG_NO_HZ | 
|  | 230 | #define NTP_INTERVAL_FREQ  (2) | 
|  | 231 | #else | 
|  | 232 | #define NTP_INTERVAL_FREQ  (HZ) | 
|  | 233 | #endif | 
|  | 234 | #define NTP_INTERVAL_LENGTH (NSEC_PER_SEC/NTP_INTERVAL_FREQ) | 
|  | 235 |  | 
| Paul Mackerras | 726c14b | 2006-02-17 10:30:23 +1100 | [diff] [blame] | 236 | /* Returns how long ticks are at present, in ns / 2^(SHIFT_SCALE-10). */ | 
| Roman Zippel | 19923c1 | 2006-06-26 00:25:18 -0700 | [diff] [blame] | 237 | extern u64 current_tick_length(void); | 
| Paul Mackerras | 726c14b | 2006-02-17 10:30:23 +1100 | [diff] [blame] | 238 |  | 
| john stultz | 4c7ee8d | 2006-09-30 23:28:22 -0700 | [diff] [blame] | 239 | extern void second_overflow(void); | 
|  | 240 | extern void update_ntp_one_tick(void); | 
| Stephen Rothwell | 3158e94 | 2006-03-26 01:37:29 -0800 | [diff] [blame] | 241 | extern int do_adjtimex(struct timex *); | 
|  | 242 |  | 
| Roman Zippel | 7236e97 | 2006-10-06 00:43:54 -0700 | [diff] [blame] | 243 | /* Don't use! Compatibility define for existing users. */ | 
|  | 244 | #define tickadj	(500/HZ ? : 1) | 
|  | 245 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 246 | #endif /* KERNEL */ | 
|  | 247 |  | 
|  | 248 | #endif /* LINUX_TIMEX_H */ |