master
  1/*	$NetBSD: timex.h,v 1.20 2022/10/26 23:23:52 riastradh Exp $	*/
  2
  3/*-
  4 ***********************************************************************
  5 *								       *
  6 * Copyright (c) David L. Mills 1993-2001			       *
  7 *								       *
  8 * Permission to use, copy, modify, and distribute this software and   *
  9 * its documentation for any purpose and without fee is hereby	       *
 10 * granted, provided that the above copyright notice appears in all    *
 11 * copies and that both the copyright notice and this permission       *
 12 * notice appear in supporting documentation, and that the name        *
 13 * University of Delaware not be used in advertising or publicity      *
 14 * pertaining to distribution of the software without specific,	       *
 15 * written prior permission. The University of Delaware makes no       *
 16 * representations about the suitability this software for any	       *
 17 * purpose. It is provided "as is" without express or implied	       *
 18 * warranty.							       *
 19 *								       *
 20 **********************************************************************/
 21
 22/*
 23 * Modification history timex.h
 24 *
 25 * 16 Aug 00	David L. Mills
 26 *	API Version 4. Added MOD_TAI and tai member of ntptimeval
 27 *	structure.
 28 *
 29 * 17 Nov 98	David L. Mills
 30 *	Revised for nanosecond kernel and user interface.
 31 *
 32 * 26 Sep 94	David L. Mills
 33 *	Added defines for hybrid phase/frequency-lock loop.
 34 *
 35 * 19 Mar 94	David L. Mills
 36 *	Moved defines from kernel routines to header file and added new
 37 *	defines for PPS phase-lock loop.
 38 *
 39 * 20 Feb 94	David L. Mills
 40 *	Revised status codes and structures for external clock and PPS
 41 *	signal discipline.
 42 *
 43 * 28 Nov 93	David L. Mills
 44 *	Adjusted parameters to improve stability and increase poll
 45 *	interval.
 46 *
 47 * 17 Sep 93    David L. Mills
 48 *      Created file
 49 *
 50 * $FreeBSD: src/sys/sys/timex.h,v 1.18 2005/01/07 02:29:24 imp Exp $
 51 */
 52/*
 53 * This header file defines the Network Time Protocol (NTP) interfaces
 54 * for user and daemon application programs. These are implemented using
 55 * defined syscalls and data structures and require specific kernel
 56 * support.
 57 *
 58 * The original precision time kernels developed from 1993 have an
 59 * ultimate resolution of one microsecond; however, the most recent
 60 * kernels have an ultimate resolution of one nanosecond. In these
 61 * kernels, a ntp_adjtime() syscalls can be used to determine which
 62 * resolution is in use and to select either one at any time. The
 63 * resolution selected affects the scaling of certain fields in the
 64 * ntp_gettime() and ntp_adjtime() syscalls, as described below.
 65 *
 66 * NAME
 67 *	ntp_gettime - NTP user application interface
 68 *
 69 * SYNOPSIS
 70 *	#include <sys/timex.h>
 71 *
 72 *	int ntp_gettime(struct ntptimeval *ntv);
 73 *
 74 * DESCRIPTION
 75 *	The time returned by ntp_gettime() is in a timespec structure,
 76 *	but may be in either microsecond (seconds and microseconds) or
 77 *	nanosecond (seconds and nanoseconds) format. The particular
 78 *	format in use is determined by the STA_NANO bit of the status
 79 *	word returned by the ntp_adjtime() syscall.
 80 *
 81 * NAME
 82 *	ntp_adjtime - NTP daemon application interface
 83 *
 84 * SYNOPSIS
 85 *	#include <sys/timex.h>
 86 *	#include <sys/syscall.h>
 87 *
 88 *	int syscall(SYS_ntp_adjtime, tptr);
 89 *	int SYS_ntp_adjtime;
 90 *	struct timex *tptr;
 91 *
 92 * DESCRIPTION
 93 *	Certain fields of the timex structure are interpreted in either
 94 *	microseconds or nanoseconds according to the state of the
 95 *	STA_NANO bit in the status word. See the description below for
 96 *	further information.
 97 */
 98
 99#ifndef _SYS_TIMEX_H_
100#define _SYS_TIMEX_H_ 1
101#define NTP_API		4	/* NTP API version */
102
103#include <sys/syscall.h>
104
105/*
106 * The following defines establish the performance envelope of the
107 * kernel discipline loop. Phase or frequency errors greater than
108 * NAXPHASE or MAXFREQ are clamped to these maxima. For update intervals
109 * less than MINSEC, the loop always operates in PLL mode; while, for
110 * update intervals greater than MAXSEC, the loop always operates in FLL
111 * mode. Between these two limits the operating mode is selected by the
112 * STA_FLL bit in the status word.
113 */
114#define MAXPHASE	500000000L /* max phase error (ns) */
115#define MAXFREQ		500000L	/* max freq error (ns/s) */
116#define MINSEC		256	/* min FLL update interval (s) */
117#define MAXSEC		2048	/* max PLL update interval (s) */
118#define NANOSECOND	1000000000L /* nanoseconds in one second */
119#define SCALE_PPM	(65536 / 1000) /* crude ns/s to scaled PPM */
120#define MAXTC		10	/* max time constant */
121
122/*
123 * The following defines and structures define the user interface for
124 * the ntp_gettime() and ntp_adjtime() syscalls.
125 *
126 * Control mode codes (timex.modes)
127 */
128#define MOD_OFFSET	0x0001	/* set time offset */
129#define MOD_FREQUENCY	0x0002	/* set frequency offset */
130#define MOD_MAXERROR	0x0004	/* set maximum time error */
131#define MOD_ESTERROR	0x0008	/* set estimated time error */
132#define MOD_STATUS	0x0010	/* set clock status bits */
133#define MOD_TIMECONST	0x0020	/* set PLL time constant */
134#define MOD_PPSMAX	0x0040	/* set PPS maximum averaging time */
135#define MOD_TAI		0x0080	/* set TAI offset */
136#define	MOD_MICRO	0x1000	/* select microsecond resolution */
137#define	MOD_NANO	0x2000	/* select nanosecond resolution */
138#define MOD_CLKB	0x4000	/* select clock B */
139#define MOD_CLKA	0x8000	/* select clock A */
140
141/*
142 * Status codes (timex.status)
143 */
144#define STA_PLL		0x0001	/* enable PLL updates (rw) */
145#define STA_PPSFREQ	0x0002	/* enable PPS freq discipline (rw) */
146#define STA_PPSTIME	0x0004	/* enable PPS time discipline (rw) */
147#define STA_FLL		0x0008	/* enable FLL mode (rw) */
148#define STA_INS		0x0010	/* insert leap (rw) */
149#define STA_DEL		0x0020	/* delete leap (rw) */
150#define STA_UNSYNC	0x0040	/* clock unsynchronized (rw) */
151#define STA_FREQHOLD	0x0080	/* hold frequency (rw) */
152#define STA_PPSSIGNAL	0x0100	/* PPS signal present (ro) */
153#define STA_PPSJITTER	0x0200	/* PPS signal jitter exceeded (ro) */
154#define STA_PPSWANDER	0x0400	/* PPS signal wander exceeded (ro) */
155#define STA_PPSERROR	0x0800	/* PPS signal calibration error (ro) */
156#define STA_CLOCKERR	0x1000	/* clock hardware fault (ro) */
157#define STA_NANO	0x2000	/* resolution (0 = us, 1 = ns) (ro) */
158#define STA_MODE	0x4000	/* mode (0 = PLL, 1 = FLL) (ro) */
159#define STA_CLK		0x8000	/* clock source (0 = A, 1 = B) (ro) */
160
161#define STA_FMT	"\177\020\
162b\0PLL\0\
163b\1PPSFREQ\0\
164b\2PPSTIME\0\
165b\3FLL\0\
166b\4INS\0\
167b\5DEL\0\
168b\6UNSYNC\0\
169b\7FREQHOLD\0\
170b\10PPSSIGNAL\0\
171b\11PPSJITTER\0\
172b\12PPSWANDER\0\
173b\13PPSERROR\0\
174b\14CLOCKERR\0\
175b\15NANO\0\
176f\16\1MODE\0=\0PLL\0=\1FLL\0\
177f\17\1CLK\0=\0A\0=\1B\0"
178
179#define STA_RONLY (STA_PPSSIGNAL | STA_PPSJITTER | STA_PPSWANDER | \
180    STA_PPSERROR | STA_CLOCKERR | STA_NANO | STA_MODE | STA_CLK)
181
182/*
183 * Clock states (time_state)
184 */
185#define TIME_OK		0	/* no leap second warning */
186#define TIME_INS	1	/* insert leap second warning */
187#define TIME_DEL	2	/* delete leap second warning */
188#define TIME_OOP	3	/* leap second in progress */
189#define TIME_WAIT	4	/* leap second has occurred */
190#define TIME_ERROR	5	/* error (see status word) */
191
192/*
193 * NTP user interface (ntp_gettime()) - used to read kernel clock values
194 *
195 * Note: The time member is in microseconds if STA_NANO is zero and
196 * nanoseconds if not.
197 */
198struct ntptimeval {
199	struct timespec time;	/* current time (ns) (ro) */
200	long maxerror;		/* maximum error (us) (ro) */
201	long esterror;		/* estimated error (us) (ro) */
202	long tai;		/* TAI offset */
203	int time_state;		/* time status */
204};
205
206/*
207 * NTP daemon interface (ntp_adjtime()) - used to discipline CPU clock
208 * oscillator and determine status.
209 *
210 * Note: The offset, precision and jitter members are in microseconds if
211 * STA_NANO is zero and nanoseconds if not.
212 */
213struct timex {
214	unsigned int modes;	/* clock mode bits (wo) */
215	long	offset;		/* time offset (ns/us) (rw) */
216	long	freq;		/* frequency offset (scaled PPM) (rw) */
217	long	maxerror;	/* maximum error (us) (rw) */
218	long	esterror;	/* estimated error (us) (rw) */
219	int	status;		/* clock status bits (rw) */
220	long	constant;	/* poll interval (log2 s) (rw) */
221	long	precision;	/* clock precision (ns/us) (ro) */
222	long	tolerance;	/* clock frequency tolerance (scaled
223				 * PPM) (ro) */
224	/*
225	 * The following read-only structure members are implemented
226	 * only if the PPS signal discipline is configured in the
227	 * kernel. They are included in all configurations to insure
228	 * portability.
229	 */
230	long	ppsfreq;	/* PPS frequency (scaled PPM) (ro) */
231	long	jitter;		/* PPS jitter (ns/us) (ro) */
232	int	shift;		/* interval duration (s) (shift) (ro) */
233	long	stabil;		/* PPS stability (scaled PPM) (ro) */
234	long	jitcnt;		/* jitter limit exceeded (ro) */
235	long	calcnt;		/* calibration intervals (ro) */
236	long	errcnt;		/* calibration errors (ro) */
237	long	stbcnt;		/* stability limit exceeded (ro) */
238};
239
240#ifdef _KERNEL
241
242#include <sys/mutex.h>
243
244void	ntp_update_second(int64_t *adjustment, time_t *newsec);
245void	ntp_adjtime1(struct timex *);
246void	ntp_gettime(struct ntptimeval *);
247int ntp_timestatus(void);
248
249extern kmutex_t timecounter_lock;
250
251extern int64_t time_adjtime;
252
253#else /* !_KERNEL */
254
255__BEGIN_DECLS
256#ifndef __LIBC12_SOURCE__
257int ntp_gettime(struct ntptimeval *) __RENAME(__ntp_gettime50);
258#endif
259int ntp_adjtime(struct timex *);
260__END_DECLS
261
262#endif /* _KERNEL */
263
264#endif /* _SYS_TIMEX_H_ */