1999-12-09 13:01:21 +00:00
|
|
|
/*
|
|
|
|
* ntp_refclock.h - definitions for reference clock support
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef NTP_REFCLOCK_H
|
|
|
|
#define NTP_REFCLOCK_H
|
|
|
|
|
|
|
|
#if defined(HAVE_SYS_MODEM_H)
|
|
|
|
#include <sys/modem.h>
|
|
|
|
#endif
|
|
|
|
|
2014-12-20 22:52:39 +00:00
|
|
|
#include "ntp_types.h"
|
|
|
|
#include "ntp_tty.h"
|
1999-12-09 13:01:21 +00:00
|
|
|
#include "recvbuff.h"
|
|
|
|
|
|
|
|
|
2004-07-20 15:01:56 +00:00
|
|
|
#define SAMPLE(x) pp->coderecv = (pp->coderecv + 1) % MAXSTAGE; \
|
|
|
|
pp->filter[pp->coderecv] = (x); \
|
|
|
|
if (pp->coderecv == pp->codeproc) \
|
|
|
|
pp->codeproc = (pp->codeproc + 1) % MAXSTAGE;
|
1999-12-09 13:01:21 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Macros to determine the clock type and unit numbers from a
|
|
|
|
* 127.127.t.u address
|
|
|
|
*/
|
|
|
|
#define REFCLOCKTYPE(srcadr) ((SRCADR(srcadr) >> 8) & 0xff)
|
|
|
|
#define REFCLOCKUNIT(srcadr) (SRCADR(srcadr) & 0xff)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* List of reference clock names and descriptions. These must agree with
|
|
|
|
* lib/clocktypes.c and ntpd/refclock_conf.c.
|
|
|
|
*/
|
|
|
|
struct clktype {
|
|
|
|
int code; /* driver "major" number */
|
|
|
|
const char *clocktype; /* long description */
|
|
|
|
const char *abbrev; /* short description */
|
|
|
|
};
|
2008-08-18 14:26:05 +00:00
|
|
|
extern struct clktype clktypes[];
|
1999-12-09 13:01:21 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Configuration flag values
|
|
|
|
*/
|
|
|
|
#define CLK_HAVETIME1 0x1
|
|
|
|
#define CLK_HAVETIME2 0x2
|
|
|
|
#define CLK_HAVEVAL1 0x4
|
|
|
|
#define CLK_HAVEVAL2 0x8
|
|
|
|
|
|
|
|
#define CLK_FLAG1 0x1
|
|
|
|
#define CLK_FLAG2 0x2
|
|
|
|
#define CLK_FLAG3 0x4
|
|
|
|
#define CLK_FLAG4 0x8
|
|
|
|
|
|
|
|
#define CLK_HAVEFLAG1 0x10
|
|
|
|
#define CLK_HAVEFLAG2 0x20
|
|
|
|
#define CLK_HAVEFLAG3 0x40
|
|
|
|
#define CLK_HAVEFLAG4 0x80
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Constant for disabling event reporting in
|
|
|
|
* refclock_receive. ORed in leap
|
|
|
|
* parameter
|
|
|
|
*/
|
|
|
|
#define REFCLOCK_OWN_STATES 0x80
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Structure for returning clock status
|
|
|
|
*/
|
|
|
|
struct refclockstat {
|
|
|
|
u_char type; /* clock type */
|
|
|
|
u_char flags; /* clock flags */
|
|
|
|
u_char haveflags; /* bit array of valid flags */
|
|
|
|
u_short lencode; /* length of last timecode */
|
|
|
|
const char *p_lastcode; /* last timecode received */
|
|
|
|
u_int32 polls; /* transmit polls */
|
|
|
|
u_int32 noresponse; /* no response to poll */
|
|
|
|
u_int32 badformat; /* bad format timecode received */
|
|
|
|
u_int32 baddata; /* invalid data timecode received */
|
|
|
|
u_int32 timereset; /* driver resets */
|
|
|
|
const char *clockdesc; /* ASCII description */
|
|
|
|
double fudgetime1; /* configure fudge time1 */
|
|
|
|
double fudgetime2; /* configure fudge time2 */
|
|
|
|
int32 fudgeval1; /* configure fudge value1 */
|
2013-12-04 21:33:17 +00:00
|
|
|
u_int32 fudgeval2; /* configure fudge value2 */
|
1999-12-09 13:01:21 +00:00
|
|
|
u_char currentstatus; /* clock status */
|
|
|
|
u_char lastevent; /* last exception event */
|
|
|
|
u_char leap; /* leap bits */
|
|
|
|
struct ctl_var *kv_list; /* additional variables */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Reference clock I/O structure. Used to provide an interface between
|
|
|
|
* the reference clock drivers and the I/O module.
|
|
|
|
*/
|
|
|
|
struct refclockio {
|
|
|
|
struct refclockio *next; /* link to next structure */
|
2013-12-04 21:33:17 +00:00
|
|
|
void (*clock_recv) (struct recvbuf *); /* completion routine */
|
|
|
|
int (*io_input) (struct recvbuf *); /* input routine -
|
1999-12-09 13:01:21 +00:00
|
|
|
to avoid excessive buffer use
|
|
|
|
due to small bursts
|
|
|
|
of refclock input data */
|
2014-12-20 22:52:39 +00:00
|
|
|
struct peer *srcclock; /* refclock peer */
|
|
|
|
int datalen; /* length of data */
|
2013-12-04 21:33:17 +00:00
|
|
|
int fd; /* file descriptor */
|
1999-12-09 13:01:21 +00:00
|
|
|
u_long recvcount; /* count of receive completions */
|
2014-12-20 22:52:39 +00:00
|
|
|
int active; /* nonzero when in use */
|
|
|
|
|
|
|
|
#ifdef HAVE_IO_COMPLETION_PORT
|
2016-04-27 05:37:54 +00:00
|
|
|
void * ioreg_ctx; /* IO registration context */
|
|
|
|
void * device_ctx; /* device-related data for i/o subsystem */
|
2014-12-20 22:52:39 +00:00
|
|
|
#endif
|
1999-12-09 13:01:21 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Structure for returning debugging info
|
|
|
|
*/
|
|
|
|
#define NCLKBUGVALUES 16
|
|
|
|
#define NCLKBUGTIMES 32
|
|
|
|
|
|
|
|
struct refclockbug {
|
|
|
|
u_char nvalues; /* values following */
|
|
|
|
u_char ntimes; /* times following */
|
|
|
|
u_short svalues; /* values format sign array */
|
|
|
|
u_int32 stimes; /* times format sign array */
|
|
|
|
u_int32 values[NCLKBUGVALUES]; /* real values */
|
|
|
|
l_fp times[NCLKBUGTIMES]; /* real times */
|
|
|
|
};
|
|
|
|
|
2014-12-20 22:52:39 +00:00
|
|
|
#ifdef HAVE_IO_COMPLETION_PORT
|
|
|
|
extern HANDLE WaitableIoEventHandle;
|
|
|
|
#endif
|
|
|
|
|
1999-12-09 13:01:21 +00:00
|
|
|
/*
|
|
|
|
* Structure interface between the reference clock support
|
|
|
|
* ntp_refclock.c and the driver utility routines
|
|
|
|
*/
|
|
|
|
#define MAXSTAGE 60 /* max median filter stages */
|
|
|
|
#define NSTAGE 5 /* default median filter stages */
|
|
|
|
#define BMAX 128 /* max timecode length */
|
|
|
|
#define GMT 0 /* I hope nobody sees this */
|
|
|
|
#define MAXDIAL 60 /* max length of modem dial strings */
|
|
|
|
|
|
|
|
|
|
|
|
struct refclockproc {
|
2013-12-04 21:33:17 +00:00
|
|
|
void * unitptr; /* pointer to unit structure */
|
2014-12-20 22:52:39 +00:00
|
|
|
struct refclock * conf; /* refclock_conf[type] */
|
|
|
|
struct refclockio io; /* I/O handler structure */
|
1999-12-09 13:01:21 +00:00
|
|
|
u_char leap; /* leap/synchronization code */
|
|
|
|
u_char currentstatus; /* clock status */
|
|
|
|
u_char lastevent; /* last exception event */
|
|
|
|
u_char type; /* clock type */
|
|
|
|
const char *clockdesc; /* clock description */
|
2014-12-20 22:52:39 +00:00
|
|
|
u_long nextaction; /* local activity timeout */
|
|
|
|
void (*action)(struct peer *); /* timeout callback */
|
1999-12-09 13:01:21 +00:00
|
|
|
|
|
|
|
char a_lastcode[BMAX]; /* last timecode received */
|
2013-12-04 21:33:17 +00:00
|
|
|
int lencode; /* length of last timecode */
|
1999-12-09 13:01:21 +00:00
|
|
|
|
|
|
|
int year; /* year of eternity */
|
|
|
|
int day; /* day of year */
|
|
|
|
int hour; /* hour of day */
|
|
|
|
int minute; /* minute of hour */
|
|
|
|
int second; /* second of minute */
|
2004-07-20 15:01:56 +00:00
|
|
|
long nsec; /* nanosecond of second */
|
1999-12-09 13:01:21 +00:00
|
|
|
u_long yearstart; /* beginning of year */
|
|
|
|
int coderecv; /* put pointer */
|
|
|
|
int codeproc; /* get pointer */
|
2004-07-20 15:01:56 +00:00
|
|
|
l_fp lastref; /* reference timestamp */
|
|
|
|
l_fp lastrec; /* receive timestamp */
|
1999-12-09 13:01:21 +00:00
|
|
|
double offset; /* mean offset */
|
|
|
|
double disp; /* sample dispersion */
|
2001-08-29 14:35:15 +00:00
|
|
|
double jitter; /* jitter (mean squares) */
|
1999-12-09 13:01:21 +00:00
|
|
|
double filter[MAXSTAGE]; /* median filter */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Configuration data
|
|
|
|
*/
|
|
|
|
double fudgetime1; /* fudge time1 */
|
|
|
|
double fudgetime2; /* fudge time2 */
|
2004-07-20 15:01:56 +00:00
|
|
|
u_char stratum; /* server stratum */
|
1999-12-09 13:01:21 +00:00
|
|
|
u_int32 refid; /* reference identifier */
|
|
|
|
u_char sloppyclockflag; /* fudge flags */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Status tallies
|
|
|
|
*/
|
|
|
|
u_long timestarted; /* time we started this */
|
|
|
|
u_long polls; /* polls sent */
|
|
|
|
u_long noreply; /* no replies to polls */
|
|
|
|
u_long badformat; /* bad format reply */
|
|
|
|
u_long baddata; /* bad data reply */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Structure interface between the reference clock support
|
|
|
|
* ntp_refclock.c and particular clock drivers. This must agree with the
|
|
|
|
* structure defined in the driver.
|
|
|
|
*/
|
|
|
|
#define noentry 0 /* flag for null routine */
|
|
|
|
#define NOFLAGS 0 /* flag for null flags */
|
|
|
|
|
|
|
|
struct refclock {
|
2013-12-04 21:33:17 +00:00
|
|
|
int (*clock_start) (int, struct peer *);
|
|
|
|
void (*clock_shutdown) (int, struct peer *);
|
|
|
|
void (*clock_poll) (int, struct peer *);
|
2014-12-20 22:52:39 +00:00
|
|
|
void (*clock_control) (int, const struct refclockstat *,
|
|
|
|
struct refclockstat *, struct peer *);
|
2013-12-04 21:33:17 +00:00
|
|
|
void (*clock_init) (void);
|
|
|
|
void (*clock_buginfo) (int, struct refclockbug *, struct peer *);
|
|
|
|
void (*clock_timer) (int, struct peer *);
|
1999-12-09 13:01:21 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Function prototypes
|
|
|
|
*/
|
2013-12-04 21:33:17 +00:00
|
|
|
extern int io_addclock (struct refclockio *);
|
|
|
|
extern void io_closeclock (struct refclockio *);
|
1999-12-09 13:01:21 +00:00
|
|
|
|
|
|
|
#ifdef REFCLOCK
|
2014-12-20 22:52:39 +00:00
|
|
|
extern void refclock_buginfo(sockaddr_u *,
|
|
|
|
struct refclockbug *);
|
|
|
|
extern void refclock_control(sockaddr_u *,
|
|
|
|
const struct refclockstat *,
|
|
|
|
struct refclockstat *);
|
2016-01-08 08:06:14 +00:00
|
|
|
extern int refclock_open (const char *, u_int, u_int);
|
2013-12-04 21:33:17 +00:00
|
|
|
extern int refclock_setup (int, u_int, u_int);
|
|
|
|
extern void refclock_timer (struct peer *);
|
2014-12-20 22:52:39 +00:00
|
|
|
extern void refclock_transmit(struct peer *);
|
|
|
|
extern int refclock_process(struct refclockproc *);
|
|
|
|
extern int refclock_process_f(struct refclockproc *, double);
|
|
|
|
extern void refclock_process_offset(struct refclockproc *, l_fp,
|
|
|
|
l_fp, double);
|
2013-12-04 21:33:17 +00:00
|
|
|
extern void refclock_report (struct peer *, int);
|
|
|
|
extern int refclock_gtlin (struct recvbuf *, char *, int, l_fp *);
|
2014-12-20 22:52:39 +00:00
|
|
|
extern int refclock_gtraw (struct recvbuf *, char *, int, l_fp *);
|
|
|
|
extern int indicate_refclock_packet(struct refclockio *,
|
|
|
|
struct recvbuf *);
|
|
|
|
extern void process_refclock_packet(struct recvbuf *);
|
1999-12-09 13:01:21 +00:00
|
|
|
#endif /* REFCLOCK */
|
|
|
|
|
|
|
|
#endif /* NTP_REFCLOCK_H */
|