|
|
1.1 root 1: /*
2: * Copyright (c) 1983 Regents of the University of California.
3: * All rights reserved.
4: *
5: * Redistribution and use in source and binary forms are permitted
6: * provided that the above copyright notice and this paragraph are
7: * duplicated in all such forms and that any documentation,
8: * advertising materials, and other materials related to such
9: * distribution and use acknowledge that the software was developed
10: * by the University of California, Berkeley. The name of the
11: * University may not be used to endorse or promote products derived
12: * from this software without specific prior written permission.
13: * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
14: * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
15: * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
16: *
17: * @(#)timed.h 1.8 (Berkeley) 6/27/88
18: */
19:
20: /*
21: * Time Synchronization Protocol
22: */
23:
24: #define TSPVERSION 1
25: #define ANYADDR NULL
26:
27: struct tsp {
28: u_char tsp_type;
29: u_char tsp_vers;
30: u_short tsp_seq;
31: union {
32: struct timeval tspu_time;
33: char tspu_hopcnt;
34: } tsp_u;
35: char tsp_name[MAXHOSTNAMELEN];
36: };
37:
38: #define tsp_time tsp_u.tspu_time
39: #define tsp_hopcnt tsp_u.tspu_hopcnt
40:
41: /*
42: * Command types.
43: */
44: #define TSP_ANY 0 /* match any types */
45: #define TSP_ADJTIME 1 /* send adjtime */
46: #define TSP_ACK 2 /* generic acknowledgement */
47: #define TSP_MASTERREQ 3 /* ask for master's name */
48: #define TSP_MASTERACK 4 /* acknowledge master request */
49: #define TSP_SETTIME 5 /* send network time */
50: #define TSP_MASTERUP 6 /* inform slaves that master is up */
51: #define TSP_SLAVEUP 7 /* slave is up but not polled */
52: #define TSP_ELECTION 8 /* advance candidature for master */
53: #define TSP_ACCEPT 9 /* support candidature of master */
54: #define TSP_REFUSE 10 /* reject candidature of master */
55: #define TSP_CONFLICT 11 /* two or more masters present */
56: #define TSP_RESOLVE 12 /* masters' conflict resolution */
57: #define TSP_QUIT 13 /* reject candidature if master is up */
58: #define TSP_DATE 14 /* reset the time (date command) */
59: #define TSP_DATEREQ 15 /* remote request to reset the time */
60: #define TSP_DATEACK 16 /* acknowledge time setting */
61: #define TSP_TRACEON 17 /* turn tracing on */
62: #define TSP_TRACEOFF 18 /* turn tracing off */
63: #define TSP_MSITE 19 /* find out master's site */
64: #define TSP_MSITEREQ 20 /* remote master's site request */
65: #define TSP_TEST 21 /* for testing election algo */
66: #define TSP_SETDATE 22 /* New from date command */
67: #define TSP_SETDATEREQ 23 /* New remote for above */
68: #define TSP_LOOP 24 /* loop detection packet */
69:
70: #define TSPTYPENUMBER 25
71:
72: #ifdef TSPTYPES
73: char *tsptype[TSPTYPENUMBER] =
74: { "ANY", "ADJTIME", "ACK", "MASTERREQ", "MASTERACK", "SETTIME", "MASTERUP",
75: "SLAVEUP", "ELECTION", "ACCEPT", "REFUSE", "CONFLICT", "RESOLVE", "QUIT",
76: "DATE", "DATEREQ", "DATEACK", "TRACEON", "TRACEOFF", "MSITE", "MSITEREQ",
77: "TEST", "SETDATE", "SETDATEREQ", "LOOP" };
78: #endif
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.