1 /* vi: set sw=4 ts=4: */
3 * adjtimex.c - read, and possibly modify, the Linux kernel `timex' variables.
5 * Originally written: October 1997
6 * Last hack: March 2001
7 * Copyright 1997, 2000, 2001 Larry Doolittle <LRDoolittle@lbl.gov>
9 * busyboxed 20 March 2001, Larry Doolittle <ldoolitt@recycle.lbl.gov>
11 * Licensed under GPLv2 or later, see file License in this tarball for details.
16 #include <sys/types.h>
19 #include <sys/timex.h>
21 static const struct {int bit; const char *name;} statlist[] = {
23 { STA_PPSFREQ, "PPSFREQ" },
24 { STA_PPSTIME, "PPSTIME" },
28 { STA_UNSYNC, "UNSYNC" },
29 { STA_FREQHOLD, "FREQHOLD" },
30 { STA_PPSSIGNAL, "PPSSIGNAL" },
31 { STA_PPSJITTER, "PPSJITTER" },
32 { STA_PPSWANDER, "PPSWANDER" },
33 { STA_PPSERROR, "PPSERROR" },
34 { STA_CLOCKERR, "CLOCKERR" },
37 static const char * const ret_code_descript[] = {
41 "leap second in progress",
42 "leap second has occurred",
43 "clock not synchronized" };
45 int adjtimex_main(int argc, char **argv)
53 c = getopt( argc, argv, "qo:f:p:t:");
60 txc.offset = atoi(optarg);
61 txc.modes |= ADJ_OFFSET_SINGLESHOT;
64 txc.freq = atoi(optarg);
65 txc.modes |= ADJ_FREQUENCY;
68 txc.constant = atoi(optarg);
69 txc.modes |= ADJ_TIMECONST;
72 txc.tick = atoi(optarg);
73 txc.modes |= ADJ_TICK;
80 if (argc != optind) { /* no valid non-option parameters */
87 if (ret < 0) perror("adjtimex");
89 if (!quiet && ret>=0) {
97 txc.modes, txc.offset, txc.freq, txc.maxerror,
98 txc.esterror, txc.status);
100 /* representative output of next code fragment:
103 for (i=0; statlist[i].name; i++) {
104 if (txc.status & statlist[i].bit) {
105 if (sep) fputs(" | ",stdout);
106 fputs(statlist[i].name,stdout);
112 if (ret >= 0 && ret <= 5) descript = ret_code_descript[ret];
114 "-p timeconstant: %ld\n"
118 " time.tv_sec: %ld\n"
119 " time.tv_usec: %ld\n"
120 " return value: %d (%s)\n",
122 txc.precision, txc.tolerance, txc.tick,
123 (long)txc.time.tv_sec, (long)txc.time.tv_usec, ret, descript);