freebsd-nq/include/ntp_refclock.h

275 lines
8.1 KiB
C
Raw Normal View History

1999-12-09 13:01:21 +00:00
/*
* ntp_refclock.h - definitions for reference clock support
*/
#ifndef NTP_REFCLOCK_H
#define NTP_REFCLOCK_H
#include "ntp_types.h"
#if defined(HAVE_BSD_TTYS)
#include <sgtty.h>
#endif /* HAVE_BSD_TTYS */
#if defined(HAVE_SYSV_TTYS)
#include <termio.h>
#endif /* HAVE_SYSV_TTYS */
#if defined(HAVE_TERMIOS)
# ifdef TERMIOS_NEEDS__SVID3
# define _SVID3
# endif
# include <termios.h>
# ifdef TERMIOS_NEEDS__SVID3
# undef _SVID3
# endif
#endif
#if defined(HAVE_SYS_MODEM_H)
#include <sys/modem.h>
#endif
2001-08-29 14:35:15 +00:00
#if 0 /* If you need that, include ntp_io.h instead */
1999-12-09 13:01:21 +00:00
#if defined(STREAM)
#include <stropts.h>
2001-08-29 14:35:15 +00:00
#if defined(CLK) /* This is never defined, except perhaps by a system header file */
1999-12-09 13:01:21 +00:00
#include <sys/clkdefs.h>
#endif /* CLK */
#endif /* STREAM */
2001-08-29 14:35:15 +00:00
#endif
1999-12-09 13:01:21 +00:00
#include "recvbuff.h"
#if !defined(SYSV_TTYS) && !defined(STREAM) & !defined(BSD_TTYS)
#define BSD_TTYS
#endif /* SYSV_TTYS STREAM BSD_TTYS */
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 */
};
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 */
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 */
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 */
caddr_t srcclock; /* pointer to clock structure */
int datalen; /* lenth of data */
int fd; /* file descriptor */
1999-12-09 13:01:21 +00:00
u_long recvcount; /* count of receive completions */
};
/*
* 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 */
};
/*
* 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 */
/*
* Line discipline flags. These require line discipline or streams
* modules to be installed/loaded in the kernel. If specified, but not
* installed, the code runs as if unspecified.
*/
#define LDISC_STD 0x00 /* standard */
#define LDISC_CLK 0x01 /* tty_clk \n intercept */
#define LDISC_CLKPPS 0x02 /* tty_clk \377 intercept */
#define LDISC_ACTS 0x04 /* tty_clk #* intercept */
#define LDISC_CHU 0x08 /* depredated */
2000-01-28 14:55:50 +00:00
#define LDISC_PPS 0x10 /* ppsclock, ppsapi */
1999-12-09 13:01:21 +00:00
#define LDISC_RAW 0x20 /* raw binary */
#define LDISC_ECHO 0x40 /* enable echo */
#define LDISC_REMOTE 0x80 /* remote mode */
#define LDISC_7O1 0x100 /* 7-bit, odd parity for Z3801A */
1999-12-09 13:01:21 +00:00
struct refclockproc {
struct refclockio io; /* I/O handler structure */
void * unitptr; /* pointer to unit 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 */
char a_lastcode[BMAX]; /* last timecode received */
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 {
int (*clock_start) (int, struct peer *);
void (*clock_shutdown) (int, struct peer *);
void (*clock_poll) (int, struct peer *);
void (*clock_control) (int, struct refclockstat *,
struct refclockstat *, struct peer *);
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
*/
/*
* auxiliary PPS interface (implemented by refclock_atom())
*/
extern int pps_sample (l_fp *);
extern int io_addclock_simple (struct refclockio *);
extern int io_addclock (struct refclockio *);
extern void io_closeclock (struct refclockio *);
1999-12-09 13:01:21 +00:00
#ifdef REFCLOCK
extern void refclock_buginfo (sockaddr_u *,
struct refclockbug *);
extern void refclock_control (sockaddr_u *,
1999-12-09 13:01:21 +00:00
struct refclockstat *,
struct refclockstat *);
extern int refclock_open (char *, u_int, u_int);
extern int refclock_setup (int, u_int, u_int);
extern void refclock_timer (struct peer *);
extern void refclock_transmit (struct peer *);
extern int refclock_ioctl (int, u_int);
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);
extern void refclock_report (struct peer *, int);
extern int refclock_gtlin (struct recvbuf *, char *, int, l_fp *);
extern int refclock_gtraw (struct recvbuf *, char *, int, l_fp *);
1999-12-09 13:01:21 +00:00
#endif /* REFCLOCK */
#endif /* NTP_REFCLOCK_H */