1*4d495c6eSApple OSS Distributions /*- 2*4d495c6eSApple OSS Distributions *********************************************************************** 3*4d495c6eSApple OSS Distributions * * 4*4d495c6eSApple OSS Distributions * Copyright (c) David L. Mills 1993-2001 * 5*4d495c6eSApple OSS Distributions * Copyright (c) Poul-Henning Kamp 2000-2001 * 6*4d495c6eSApple OSS Distributions * * 7*4d495c6eSApple OSS Distributions * Permission to use, copy, modify, and distribute this software and * 8*4d495c6eSApple OSS Distributions * its documentation for any purpose and without fee is hereby * 9*4d495c6eSApple OSS Distributions * granted, provided that the above copyright notice appears in all * 10*4d495c6eSApple OSS Distributions * copies and that both the copyright notice and this permission * 11*4d495c6eSApple OSS Distributions * notice appear in supporting documentation, and that the name * 12*4d495c6eSApple OSS Distributions * University of Delaware not be used in advertising or publicity * 13*4d495c6eSApple OSS Distributions * pertaining to distribution of the software without specific, * 14*4d495c6eSApple OSS Distributions * written prior permission. The University of Delaware makes no * 15*4d495c6eSApple OSS Distributions * representations about the suitability this software for any * 16*4d495c6eSApple OSS Distributions * purpose. It is provided "as is" without express or implied * 17*4d495c6eSApple OSS Distributions * warranty. * 18*4d495c6eSApple OSS Distributions * * 19*4d495c6eSApple OSS Distributions *********************************************************************** 20*4d495c6eSApple OSS Distributions * 21*4d495c6eSApple OSS Distributions * $FreeBSD$ 22*4d495c6eSApple OSS Distributions * 23*4d495c6eSApple OSS Distributions * This header file defines the Network Time Protocol (NTP) interfaces 24*4d495c6eSApple OSS Distributions * for user and daemon application programs. 25*4d495c6eSApple OSS Distributions * 26*4d495c6eSApple OSS Distributions * This file was originally created 17 Sep 93 by David L. Mills, Professor 27*4d495c6eSApple OSS Distributions * of University of Delaware, building on work which had already been ongoing 28*4d495c6eSApple OSS Distributions * for a decade and a half at that point in time. 29*4d495c6eSApple OSS Distributions * 30*4d495c6eSApple OSS Distributions * In 2000 the APIs got a upgrade from microseconds to nanoseconds, 31*4d495c6eSApple OSS Distributions * a joint work between Poul-Henning Kamp and David L. Mills. 32*4d495c6eSApple OSS Distributions * 33*4d495c6eSApple OSS Distributions */ 34*4d495c6eSApple OSS Distributions 35*4d495c6eSApple OSS Distributions /* 36*4d495c6eSApple OSS Distributions * Copyright (c) 2017 Apple Computer, Inc. All rights reserved. 37*4d495c6eSApple OSS Distributions * 38*4d495c6eSApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ 39*4d495c6eSApple OSS Distributions * 40*4d495c6eSApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code 41*4d495c6eSApple OSS Distributions * as defined in and that are subject to the Apple Public Source License 42*4d495c6eSApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in 43*4d495c6eSApple OSS Distributions * compliance with the License. The rights granted to you under the License 44*4d495c6eSApple OSS Distributions * may not be used to create, or enable the creation or redistribution of, 45*4d495c6eSApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to 46*4d495c6eSApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any 47*4d495c6eSApple OSS Distributions * terms of an Apple operating system software license agreement. 48*4d495c6eSApple OSS Distributions * 49*4d495c6eSApple OSS Distributions * Please obtain a copy of the License at 50*4d495c6eSApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file. 51*4d495c6eSApple OSS Distributions * 52*4d495c6eSApple OSS Distributions * The Original Code and all software distributed under the License are 53*4d495c6eSApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 54*4d495c6eSApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 55*4d495c6eSApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 56*4d495c6eSApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 57*4d495c6eSApple OSS Distributions * Please see the License for the specific language governing rights and 58*4d495c6eSApple OSS Distributions * limitations under the License. 59*4d495c6eSApple OSS Distributions * 60*4d495c6eSApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ 61*4d495c6eSApple OSS Distributions */ 62*4d495c6eSApple OSS Distributions 63*4d495c6eSApple OSS Distributions #ifndef _SYS_TIMEX_H_ 64*4d495c6eSApple OSS Distributions #define _SYS_TIMEX_H_ 1 65*4d495c6eSApple OSS Distributions 66*4d495c6eSApple OSS Distributions #include <sys/time.h> 67*4d495c6eSApple OSS Distributions 68*4d495c6eSApple OSS Distributions #define NTP_API 4 /* NTP API version */ 69*4d495c6eSApple OSS Distributions 70*4d495c6eSApple OSS Distributions /* 71*4d495c6eSApple OSS Distributions * The following defines establish the performance envelope of the 72*4d495c6eSApple OSS Distributions * kernel discipline loop. Phase or frequency errors greater than 73*4d495c6eSApple OSS Distributions * NAXPHASE or MAXFREQ are clamped to these maxima. For update intervals 74*4d495c6eSApple OSS Distributions * less than MINSEC, the loop always operates in PLL mode; while, for 75*4d495c6eSApple OSS Distributions * update intervals greater than MAXSEC, the loop always operates in FLL 76*4d495c6eSApple OSS Distributions * mode. Between these two limits the operating mode is selected by the 77*4d495c6eSApple OSS Distributions * STA_FLL bit in the status word. 78*4d495c6eSApple OSS Distributions */ 79*4d495c6eSApple OSS Distributions 80*4d495c6eSApple OSS Distributions #define MAXPHASE 500000000L /* max phase error (ns) */ 81*4d495c6eSApple OSS Distributions #define MAXFREQ 500000L /* max freq error (ns/s) */ 82*4d495c6eSApple OSS Distributions #define MINSEC 256 /* min FLL update interval (s) */ 83*4d495c6eSApple OSS Distributions #define MAXSEC 2048 /* max PLL update interval (s) */ 84*4d495c6eSApple OSS Distributions #define NANOSECOND 1000000000L /* nanoseconds in one second */ 85*4d495c6eSApple OSS Distributions #define SCALE_PPM (65536 / 1000) /* crude ns/s to scaled PPM */ 86*4d495c6eSApple OSS Distributions #define MAXTC 10 /* max time constant */ 87*4d495c6eSApple OSS Distributions 88*4d495c6eSApple OSS Distributions /* Codes for PPS (pulse-per-second) signals or leap seconds are not used but kept 89*4d495c6eSApple OSS Distributions * unchanged and commented for future compatibility. 90*4d495c6eSApple OSS Distributions */ 91*4d495c6eSApple OSS Distributions 92*4d495c6eSApple OSS Distributions /* 93*4d495c6eSApple OSS Distributions * Control mode codes (timex.modes) 94*4d495c6eSApple OSS Distributions */ 95*4d495c6eSApple OSS Distributions #define MOD_OFFSET 0x0001 /* set time offset */ 96*4d495c6eSApple OSS Distributions #define MOD_FREQUENCY 0x0002 /* set frequency offset */ 97*4d495c6eSApple OSS Distributions #define MOD_MAXERROR 0x0004 /* set maximum time error */ 98*4d495c6eSApple OSS Distributions #define MOD_ESTERROR 0x0008 /* set estimated time error */ 99*4d495c6eSApple OSS Distributions #define MOD_STATUS 0x0010 /* set clock status bits */ 100*4d495c6eSApple OSS Distributions #define MOD_TIMECONST 0x0020 /* set PLL time constant */ 101*4d495c6eSApple OSS Distributions #define MOD_PPSMAX 0x0040 /* set PPS maximum averaging time */ 102*4d495c6eSApple OSS Distributions #define MOD_TAI 0x0080 /* set TAI offset */ 103*4d495c6eSApple OSS Distributions #define MOD_MICRO 0x1000 /* select microsecond resolution */ 104*4d495c6eSApple OSS Distributions #define MOD_NANO 0x2000 /* select nanosecond resolution */ 105*4d495c6eSApple OSS Distributions #define MOD_CLKB 0x4000 /* select clock B */ 106*4d495c6eSApple OSS Distributions #define MOD_CLKA 0x8000 /* select clock A */ 107*4d495c6eSApple OSS Distributions 108*4d495c6eSApple OSS Distributions /* 109*4d495c6eSApple OSS Distributions * Status codes (timex.status) 110*4d495c6eSApple OSS Distributions */ 111*4d495c6eSApple OSS Distributions #define STA_PLL 0x0001 /* enable PLL updates (rw) */ 112*4d495c6eSApple OSS Distributions #define STA_PPSFREQ 0x0002 /* enable PPS freq discipline (rw) */ 113*4d495c6eSApple OSS Distributions #define STA_PPSTIME 0x0004 /* enable PPS time discipline (rw) */ 114*4d495c6eSApple OSS Distributions #define STA_FLL 0x0008 /* enable FLL mode (rw) */ 115*4d495c6eSApple OSS Distributions #define STA_INS 0x0010 /* insert leap (rw) */ 116*4d495c6eSApple OSS Distributions #define STA_DEL 0x0020 /* delete leap (rw) */ 117*4d495c6eSApple OSS Distributions #define STA_UNSYNC 0x0040 /* clock unsynchronized (rw) */ 118*4d495c6eSApple OSS Distributions #define STA_FREQHOLD 0x0080 /* hold frequency (rw) */ 119*4d495c6eSApple OSS Distributions #define STA_PPSSIGNAL 0x0100 /* PPS signal present (ro) */ 120*4d495c6eSApple OSS Distributions #define STA_PPSJITTER 0x0200 /* PPS signal jitter exceeded (ro) */ 121*4d495c6eSApple OSS Distributions #define STA_PPSWANDER 0x0400 /* PPS signal wander exceeded (ro) */ 122*4d495c6eSApple OSS Distributions #define STA_PPSERROR 0x0800 /* PPS signal calibration error (ro) */ 123*4d495c6eSApple OSS Distributions #define STA_CLOCKERR 0x1000 /* clock hardware fault (ro) */ 124*4d495c6eSApple OSS Distributions #define STA_NANO 0x2000 /* resolution (0 = us, 1 = ns) (ro) */ 125*4d495c6eSApple OSS Distributions #define STA_MODE 0x4000 /* mode (0 = PLL, 1 = FLL) (ro) */ 126*4d495c6eSApple OSS Distributions #define STA_CLK 0x8000 /* clock source (0 = A, 1 = B) (ro) */ 127*4d495c6eSApple OSS Distributions 128*4d495c6eSApple OSS Distributions #define STA_RONLY (STA_PPSSIGNAL | STA_PPSJITTER | STA_PPSWANDER | \ 129*4d495c6eSApple OSS Distributions STA_PPSERROR | STA_CLOCKERR | STA_NANO | STA_MODE | STA_CLK) 130*4d495c6eSApple OSS Distributions 131*4d495c6eSApple OSS Distributions #define STA_SUPPORTED (STA_PLL | STA_FLL | STA_UNSYNC | STA_FREQHOLD | \ 132*4d495c6eSApple OSS Distributions STA_CLOCKERR | STA_NANO | STA_MODE | STA_CLK) 133*4d495c6eSApple OSS Distributions 134*4d495c6eSApple OSS Distributions /* 135*4d495c6eSApple OSS Distributions * Clock states (ntptimeval.time_state) 136*4d495c6eSApple OSS Distributions */ 137*4d495c6eSApple OSS Distributions #define TIME_OK 0 /* no leap second warning */ 138*4d495c6eSApple OSS Distributions #define TIME_INS 1 /* insert leap second warning */ 139*4d495c6eSApple OSS Distributions #define TIME_DEL 2 /* delete leap second warning */ 140*4d495c6eSApple OSS Distributions #define TIME_OOP 3 /* leap second in progress */ 141*4d495c6eSApple OSS Distributions #define TIME_WAIT 4 /* leap second has occurred */ 142*4d495c6eSApple OSS Distributions #define TIME_ERROR 5 /* error (see status word) */ 143*4d495c6eSApple OSS Distributions 144*4d495c6eSApple OSS Distributions /* 145*4d495c6eSApple OSS Distributions * NTP user interface -- ntp_gettime - used to read kernel clock values 146*4d495c6eSApple OSS Distributions */ 147*4d495c6eSApple OSS Distributions struct ntptimeval { 148*4d495c6eSApple OSS Distributions struct timespec time; /* current time (ns) (ro) */ 149*4d495c6eSApple OSS Distributions long maxerror; /* maximum error (us) (ro) */ 150*4d495c6eSApple OSS Distributions long esterror; /* estimated error (us) (ro) */ 151*4d495c6eSApple OSS Distributions long tai; /* TAI offset */ 152*4d495c6eSApple OSS Distributions int time_state; /* time status */ 153*4d495c6eSApple OSS Distributions }; 154*4d495c6eSApple OSS Distributions 155*4d495c6eSApple OSS Distributions /* 156*4d495c6eSApple OSS Distributions * NTP daemon interface -- ntp_adjtime -- used to discipline CPU clock 157*4d495c6eSApple OSS Distributions * oscillator and control/determine status. 158*4d495c6eSApple OSS Distributions * 159*4d495c6eSApple OSS Distributions * Note: The offset, precision and jitter members are in microseconds if 160*4d495c6eSApple OSS Distributions * STA_NANO is zero and nanoseconds if not. 161*4d495c6eSApple OSS Distributions */ 162*4d495c6eSApple OSS Distributions struct timex { 163*4d495c6eSApple OSS Distributions unsigned int modes; /* clock mode bits (wo) */ 164*4d495c6eSApple OSS Distributions long offset; /* time offset (ns/us) (rw) */ 165*4d495c6eSApple OSS Distributions long freq; /* frequency offset (scaled PPM) (rw) */ 166*4d495c6eSApple OSS Distributions long maxerror; /* maximum error (us) (rw) */ 167*4d495c6eSApple OSS Distributions long esterror; /* estimated error (us) (rw) */ 168*4d495c6eSApple OSS Distributions int status; /* clock status bits (rw) */ 169*4d495c6eSApple OSS Distributions long constant; /* poll interval (log2 s) (rw) */ 170*4d495c6eSApple OSS Distributions long precision; /* clock precision (ns/us) (ro) */ 171*4d495c6eSApple OSS Distributions long tolerance; /* clock frequency tolerance (scaled 172*4d495c6eSApple OSS Distributions * PPM) (ro) */ 173*4d495c6eSApple OSS Distributions /* 174*4d495c6eSApple OSS Distributions * The following read-only structure members are used by 175*4d495c6eSApple OSS Distributions * the PPS signal discipline that is currently not supported. 176*4d495c6eSApple OSS Distributions * They are included for compatibility. 177*4d495c6eSApple OSS Distributions */ 178*4d495c6eSApple OSS Distributions long ppsfreq; /* PPS frequency (scaled PPM) (ro) */ 179*4d495c6eSApple OSS Distributions long jitter; /* PPS jitter (ns/us) (ro) */ 180*4d495c6eSApple OSS Distributions int shift; /* interval duration (s) (shift) (ro) */ 181*4d495c6eSApple OSS Distributions long stabil; /* PPS stability (scaled PPM) (ro) */ 182*4d495c6eSApple OSS Distributions long jitcnt; /* jitter limit exceeded (ro) */ 183*4d495c6eSApple OSS Distributions long calcnt; /* calibration intervals (ro) */ 184*4d495c6eSApple OSS Distributions long errcnt; /* calibration errors (ro) */ 185*4d495c6eSApple OSS Distributions long stbcnt; /* stability limit exceeded (ro) */ 186*4d495c6eSApple OSS Distributions }; 187*4d495c6eSApple OSS Distributions 188*4d495c6eSApple OSS Distributions #ifdef KERNEL 189*4d495c6eSApple OSS Distributions #ifdef XNU_KERNEL_PRIVATE 190*4d495c6eSApple OSS Distributions #include <sys/_types/_user32_timex.h> 191*4d495c6eSApple OSS Distributions #include <sys/_types/_user64_timex.h> 192*4d495c6eSApple OSS Distributions #include <sys/_types/_user32_ntptimeval.h> 193*4d495c6eSApple OSS Distributions #include <sys/_types/_user64_ntptimeval.h> 194*4d495c6eSApple OSS Distributions #include <kern/clock.h> 195*4d495c6eSApple OSS Distributions 196*4d495c6eSApple OSS Distributions int64_t ntp_get_freq(void); 197*4d495c6eSApple OSS Distributions void ntp_update_second(int64_t *adjustment, clock_sec_t secs); 198*4d495c6eSApple OSS Distributions void ntp_init(void); 199*4d495c6eSApple OSS Distributions #endif 200*4d495c6eSApple OSS Distributions #else /* !_KERNEL */ 201*4d495c6eSApple OSS Distributions #include <sys/cdefs.h> 202*4d495c6eSApple OSS Distributions 203*4d495c6eSApple OSS Distributions __BEGIN_DECLS 204*4d495c6eSApple OSS Distributions #if !defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE) 205*4d495c6eSApple OSS Distributions int ntp_adjtime(struct timex *); 206*4d495c6eSApple OSS Distributions int ntp_gettime(struct ntptimeval *); 207*4d495c6eSApple OSS Distributions #endif /* (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */ 208*4d495c6eSApple OSS Distributions __END_DECLS 209*4d495c6eSApple OSS Distributions #endif /* KERNEL */ 210*4d495c6eSApple OSS Distributions 211*4d495c6eSApple OSS Distributions 212*4d495c6eSApple OSS Distributions #endif /* !_SYS_TIMEX_H_ */ 213