Add the DragonFly cvs id and perform general cleanups on cvs/rcs/sccs ids. Most
[dragonfly.git] / usr.sbin / timed / timed / globals.h
1 /*-
2  * Copyright (c) 1985, 1993
3  *      The Regents of the University of California.  All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  * 3. All advertising materials mentioning features or use of this software
14  *    must display the following acknowledgement:
15  *      This product includes software developed by the University of
16  *      California, Berkeley and its contributors.
17  * 4. Neither the name of the University nor the names of its contributors
18  *    may be used to endorse or promote products derived from this software
19  *    without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31  * SUCH DAMAGE.
32  *
33  *      @(#)globals.h   8.1 (Berkeley) 6/6/93
34  *      $FreeBSD: src/usr.sbin/timed/timed/globals.h,v 1.5 2000/03/03 13:01:56 shin Exp $
35  *      $DragonFly: src/usr.sbin/timed/timed/globals.h,v 1.2 2003/06/17 04:30:03 dillon Exp $
36  */
37
38 #include <sys/param.h>
39 #include <sys/time.h>
40 #include <sys/socket.h>
41
42 #include <netinet/in.h>
43 #include <arpa/inet.h>
44
45 #include <err.h>
46 #include <errno.h>
47 #include <limits.h>
48 #include <netdb.h>
49 #include <stdio.h>
50 #include <stdlib.h>
51 #include <string.h>
52 #include <syslog.h>
53 #include <syslog.h>
54 #include <unistd.h>
55
56 #include <protocols/timed.h>
57 #ifdef sgi
58 #include <bstring.h>
59 #include <sys/clock.h>
60 /* use the constant HZ instead of the function CLK_TCK */
61 #undef CLK_TCK
62 #define CLK_TCK HZ
63 #else
64 #define SECHR   (60*60)
65 #define SECDAY  (24*SECHR)
66 #endif /* sgi */
67
68 extern int sock;
69
70 /* Best expected round trip for a measurement.
71  * This is essentially the number of milliseconds per CPU tick (CLK_TCK?).
72  * All delays shorter than this are usually reported as 0.
73  */
74 #define MIN_ROUND ((1000-1)/CLK_TCK)
75
76
77 #define SAMPLEINTVL     240             /* synch() freq for master in sec */
78 #define MAXADJ          20              /* max adjtime() correction in sec */
79
80 #define MAX_TRIM        3000000         /* max drift in nsec/sec, 0.3% */
81 #define BIG_ADJ         (MAX_TRIM/1000*SAMPLEINTVL*2)   /* max good adj */
82
83 #define MINTOUT         360             /* election delays, 6-15 minutes */
84 #define MAXTOUT         900
85
86 #define BAD_STATUS      (-1)
87 #define GOOD            1
88 #define UNREACHABLE     2
89 #define NONSTDTIME      3
90 #define HOSTDOWN        0x7fffffff
91
92 #define OFF             0
93 #define ON              1
94
95 #define MAX_HOPCNT      10              /* max value for tsp_hpcnt */
96
97 #define LOSTHOST        3               /* forget after this many failures */
98
99 #define VALID_RANGE (MAXADJ*1000)       /* good times in milliseconds */
100 #define GOOD_RANGE (MIN_ROUND*2)
101 #define VGOOD_RANGE (MIN_ROUND-1)
102
103
104 /*
105  * Global and per-network states.
106  */
107 #define NOMASTER        0               /* no good master */
108 #define SLAVE           1
109 #define MASTER          2
110 #define IGNORE          4
111 #define ALL             (SLAVE|MASTER|IGNORE)
112 #define SUBMASTER       (SLAVE|MASTER)
113
114 #define NHOSTS          1013            /* max of hosts controlled by timed
115                                          * This must be a prime number.
116                                          */
117 struct hosttbl {
118         struct  hosttbl *h_bak;         /* hash chain */
119         struct  hosttbl *h_fwd;
120         struct  hosttbl *l_bak;         /* "sequential" list */
121         struct  hosttbl *l_fwd;
122         struct  netinfo *ntp;
123         struct  sockaddr_in addr;
124         char    name[MAXHOSTNAMELEN];
125         u_char  head;                   /* 1=head of hash chain */
126         u_char  good;                   /* 0=trusted host, for averaging */
127         u_char  noanswer;               /* count of failures to answer */
128         u_char  need_set;               /* need a SETTIME */
129         u_short seq;
130         long    delta;
131 };
132
133 /* closed hash table with internal chaining */
134 extern struct hosttbl hosttbl[NHOSTS+1];
135 #define self hosttbl[0]
136 #define hostname (self.name)
137
138
139 struct netinfo {
140         struct  netinfo *next;
141         struct  in_addr net;
142         u_int32_t       mask;
143         struct  in_addr my_addr;
144         struct  sockaddr_in dest_addr;  /* broadcast addr or point-point */
145         long    status;
146         struct timeval slvwait;         /* delay before sending our time */
147         int     quit_count;             /* recent QUITs */
148 };
149
150 #include "extern.h"
151
152 #define tvtomsround(tv) ((tv).tv_sec*1000 + ((tv).tv_usec + 500)/1000)
153
154 extern struct netinfo *nettab;
155 extern int status;
156 extern int trace;
157 extern int sock;
158 extern struct sockaddr_in from;
159 extern struct timeval from_when;        /* when the last msg arrived */
160 extern u_short sequence;                /* TSP message sequence number */
161 extern struct netinfo *fromnet, *slavenet;
162 extern FILE *fd;
163 extern long delay1, delay2;
164 extern int nslavenets;                  /* nets were I could be a slave */
165 extern int nmasternets;                 /* nets were I could be a master */
166 extern int nignorednets;                /* ignored nets */
167 extern int nnets;                       /* nets I am connected to */
168
169
170 #define trace_msg(msg)          {if (trace) fprintf(fd, msg);}
171
172 #define trace_sendto_err(addr) {                                        \
173         int st_errno = errno;                                           \
174         syslog(LOG_ERR, "%s %d: sendto %s: %m",                         \
175                 __FILE__, __LINE__, inet_ntoa(addr));                   \
176         if (trace)                                                      \
177                 fprintf(fd, "%s %d: sendto %s: %d", __FILE__, __LINE__, \
178                         inet_ntoa(addr), st_errno);                     \
179 }
180
181
182 # define max(a,b)       (a<b ? b : a)
183 # define min(a,b)       (a>b ? b : a)
184 # define abs(x)         (x>=0 ? x : -(x))