[Git][NTPsec/ntpsec][master] De-globaled clock control flags.
Ian Bruene
gitlab at mg.gitlab.com
Sun May 20 22:24:20 UTC 2018
Ian Bruene pushed to branch master at NTPsec / ntpsec
Commits:
c2eb57fd by Ian Bruene at 2018-05-20T22:19:04Z
De-globaled clock control flags.
- - - - -
10 changed files:
- include/ntpd.h
- ntpd/ntp_config.c
- ntpd/ntp_loopfilter.c
- ntpd/ntp_peer.c
- ntpd/ntp_proto.c
- ntpd/ntp_refclock.c
- ntpd/ntp_timer.c
- ntpd/ntpd.c
- ntpd/refclock_generic.c
- ntpd/refclock_oncore.c
Changes:
=====================================
include/ntpd.h
=====================================
--- a/include/ntpd.h
+++ b/include/ntpd.h
@@ -263,14 +263,17 @@ extern double clock_phi; /* dispersion rate (s/s) */
/*
* Clock state machine control flags
*/
-extern bool ntp_enable; /* clock discipline enabled */
-extern bool pll_control; /* kernel support available */
-extern bool kern_enable; /* kernel support enabled */
-extern bool hardpps_enable; /* kernel PPS discipline enabled */
+struct clock_control_flags {
+ bool ntp_enable; /* clock discipline enabled */
+ bool pll_control; /* kernel support available */
+ bool kern_enable; /* kernel support enabled */
+ bool hardpps_enable; /* kernel PPS discipline enabled */
+ bool allow_panic; /* allow panic correction (-g) */
+ bool force_step_once; /* always step time once at startup (-G) */
+ bool mode_ntpdate; /* exit on first clock set (-q) */
+};
+extern struct clock_control_flags clock_ctl;
extern bool cal_enable; /* refclock calibrate enable */
-extern bool allow_panic; /* allow panic correction (-g) */
-extern bool force_step_once; /* always step time once at startup (-G) */
-extern bool mode_ntpdate; /* exit on first clock set (-q) */
extern int peer_ntpdate; /* count of ntpdate peers */
/*
=====================================
ntpd/ntp_config.c
=====================================
--- a/ntpd/ntp_config.c
+++ b/ntpd/ntp_config.c
@@ -2616,7 +2616,7 @@ peer_config(
* are.
*/
ctl->flags |= FLAG_CONFIG;
- if (mode_ntpdate)
+ if (clock_ctl.mode_ntpdate)
ctl->flags |= FLAG_IBURST;
return newpeer(srcadr, hostname, dstadr, hmode,
ctl, cast_flags, true);
=====================================
ntpd/ntp_loopfilter.c
=====================================
--- a/ntpd/ntp_loopfilter.c
+++ b/ntpd/ntp_loopfilter.c
@@ -148,13 +148,15 @@ static void stop_kern_loop(void);
/*
* Clock state machine control flags
*/
-bool ntp_enable = true; /* clock discipline enabled */
-bool pll_control = false; /* kernel support available */
-bool kern_enable = true; /* kernel support enabled */
-bool hardpps_enable; /* kernel PPS discipline enabled */
-bool allow_panic = false; /* allow panic correction (-g) */
-bool force_step_once = false; /* always step time once at startup (-G) */
-bool mode_ntpdate = false; /* exit on first clock set (-q) */
+struct clock_control_flags clock_ctl = {
+ .ntp_enable = true, /* clock discipline enabled */
+ .pll_control = false, /* kernel support available */
+ .kern_enable = true, /* kernel support enabled */
+ .hardpps_enable = false, /* kernel PPS discipline enabled */
+ .allow_panic = false, /* allow panic correction (-g) */
+ .force_step_once = false, /* always step time once at startup (-G) */
+ .mode_ntpdate = false /* exit on first clock set (-q) */
+};
int freq_cnt; /* initial frequency clamp */
static int freq_set; /* initial set frequency switch */
@@ -466,7 +468,7 @@ local_clock(
#ifdef ENABLE_LOCKCLOCK
{
#else
- if (!ntp_enable) {
+ if (!clock_ctl.ntp_enable) {
#endif /* ENABLE_LOCKCLOCK */
record_loop_stats(fp_offset, drift_comp, clock_jitter,
clock_stability, sys_poll);
@@ -484,7 +486,7 @@ local_clock(
* than the step threshold; so, subsequent panics will exit.
*/
if (fabs(fp_offset) > clock_panic && clock_panic > 0 &&
- !allow_panic) {
+ !clock_ctl.allow_panic) {
snprintf(tbuf, sizeof(tbuf),
"%+.0f s; set clock manually within %.0f s.",
fp_offset, clock_panic);
@@ -501,7 +503,7 @@ local_clock(
* terminal does not detach, so the termination message prints
* directly to the terminal.
*/
- if (mode_ntpdate) {
+ if (clock_ctl.mode_ntpdate) {
if ( ( fp_offset > clock_max_fwd && clock_max_fwd > 0)
|| (-fp_offset > clock_max_back && clock_max_back > 0)) {
step_systime(fp_offset, ntp_set_tod);
@@ -563,9 +565,9 @@ local_clock(
rval = 1;
if ( ( fp_offset > clock_max_fwd && clock_max_fwd > 0)
|| (-fp_offset > clock_max_back && clock_max_back > 0)
- || force_step_once ) {
- if (force_step_once) {
- force_step_once = false; /* we want this only once after startup */
+ || clock_ctl.force_step_once ) {
+ if (clock_ctl.force_step_once) {
+ clock_ctl.force_step_once = false; /* we want this only once after startup */
msyslog(LOG_NOTICE, "CLOCK: Doing intital time step" );
}
@@ -687,7 +689,7 @@ local_clock(
* startup until the initial transient has subsided.
*/
default:
- allow_panic = false;
+ clock_ctl.allow_panic = false;
if (freq_cnt == 0) {
/*
@@ -735,7 +737,7 @@ local_clock(
* lead to overflow problems. This might occur if some misguided
* lad set the step threshold to something ridiculous.
*/
- if (pll_control && kern_enable && freq_cnt == 0) {
+ if (clock_ctl.pll_control && clock_ctl.kern_enable && freq_cnt == 0) {
static int kernel_status; /* from ntp_adjtime */
/*
@@ -779,7 +781,7 @@ local_clock(
/*
* Enable/disable the PPS if requested.
*/
- if (hardpps_enable) {
+ if (clock_ctl.hardpps_enable) {
ntv.status |= (STA_PPSTIME | STA_PPSFREQ);
if (!(pll_status & STA_PPSTIME))
sync_status("PPS enabled",
@@ -808,7 +810,7 @@ local_clock(
*/
if ((0 > ntp_adj_ret) || (ntp_adj_ret != kernel_status)) {
kernel_status = ntp_adj_ret;
- ntp_adjtime_error_handler(__func__, &ntv, ntp_adj_ret, errno, hardpps_enable, false, __LINE__ - 1);
+ ntp_adjtime_error_handler(__func__, &ntv, ntp_adj_ret, errno, clock_ctl.hardpps_enable, false, __LINE__ - 1);
}
pll_status = ntv.status;
clock_offset = ntv.offset * S_PER_NS;
@@ -935,7 +937,7 @@ adj_host_clock(
*/
sys_vars.sys_rootdisp += clock_phi;
#ifndef ENABLE_LOCKCLOCK
- if (!ntp_enable || mode_ntpdate)
+ if (!clock_ctl.ntp_enable || clock_ctl.mode_ntpdate)
return;
/*
* Determine the phase adjustment. The gain factor (denominator)
@@ -948,7 +950,7 @@ adj_host_clock(
} else if (freq_cnt > 0) {
offset_adj = clock_offset / (CLOCK_PLL * ULOGTOD(1));
freq_cnt--;
- } else if (pll_control && kern_enable) {
+ } else if (clock_ctl.pll_control && clock_ctl.kern_enable) {
offset_adj = 0.;
} else {
offset_adj = clock_offset / (CLOCK_PLL * ULOGTOD(sys_poll));
@@ -960,7 +962,7 @@ adj_host_clock(
* set_freq(). Otherwise it is a component of the adj_systime()
* offset.
*/
- if (pll_control && kern_enable)
+ if (clock_ctl.pll_control && clock_ctl.kern_enable)
freq_adj = 0.;
else
freq_adj = drift_comp;
@@ -1054,11 +1056,11 @@ set_freq(
drift_comp = freq;
loop_desc = "ntpd";
- if (pll_control) {
+ if (clock_ctl.pll_control) {
int ntp_adj_ret;
ZERO(ntv);
ntv.modes = MOD_FREQUENCY;
- if (kern_enable) {
+ if (clock_ctl.kern_enable) {
loop_desc = "kernel";
ntv.freq = DTOFREQ(drift_comp);
}
@@ -1077,7 +1079,7 @@ start_kern_loop(void)
static bool atexit_done;
int ntp_adj_ret;
- pll_control = true;
+ clock_ctl.pll_control = true;
ZERO(ntv);
ntv.modes = MOD_BITS;
ntv.status = STA_PLL;
@@ -1094,7 +1096,7 @@ start_kern_loop(void)
newsigsys.sa_flags = 0;
if (sigaction(SIGSYS, &newsigsys, &sigsys)) {
msyslog(LOG_ERR, "ERR: sigaction() trap SIGSYS: %m");
- pll_control = false;
+ clock_ctl.pll_control = false;
} else {
if (sigsetjmp(env, 1) == 0) {
if ((ntp_adj_ret = ntp_adjtime_ns(&ntv)) != 0) {
@@ -1104,7 +1106,7 @@ start_kern_loop(void)
if (sigaction(SIGSYS, &sigsys, NULL)) {
msyslog(LOG_ERR,
"ERR: sigaction() restore SIGSYS: %m");
- pll_control = false;
+ clock_ctl.pll_control = false;
}
}
#else /* SIGSYS */
@@ -1118,7 +1120,7 @@ start_kern_loop(void)
* if available.
*/
pll_status = ntv.status;
- if (pll_control) {
+ if (clock_ctl.pll_control) {
if (!atexit_done) {
atexit_done = true;
atexit(&stop_kern_loop);
@@ -1136,7 +1138,7 @@ start_kern_loop(void)
static void
stop_kern_loop(void)
{
- if (pll_control && kern_enable)
+ if (clock_ctl.pll_control && clock_ctl.kern_enable)
report_event(EVNT_KERN, NULL,
"kernel time sync disabled");
}
@@ -1150,12 +1152,12 @@ select_loop(
int use_kern_loop
)
{
- if (kern_enable == use_kern_loop)
+ if (clock_ctl.kern_enable == use_kern_loop)
return;
- if (pll_control && !use_kern_loop)
+ if (clock_ctl.pll_control && !use_kern_loop)
stop_kern_loop();
- kern_enable = use_kern_loop;
- if (pll_control && use_kern_loop)
+ clock_ctl.kern_enable = use_kern_loop;
+ if (clock_ctl.pll_control && use_kern_loop)
start_kern_loop();
/*
* If this loop selection change occurs after initial startup,
@@ -1163,7 +1165,7 @@ select_loop(
* from the kernel loop.
*/
#if !defined(ENABLE_LOCKCLOCK)
- if (pll_control && loop_started)
+ if (clock_ctl.pll_control && loop_started)
set_freq(drift_comp);
#endif
}
@@ -1213,7 +1215,7 @@ loop_config(
*/
case LOOP_DRIFTINIT:
#ifndef ENABLE_LOCKCLOCK
- if (mode_ntpdate)
+ if (clock_ctl.mode_ntpdate)
break;
start_kern_loop();
@@ -1241,7 +1243,7 @@ loop_config(
case LOOP_KERN_CLEAR:
#if 0 /* XXX: needs more review, and how can we get here? */
#ifndef ENABLE_LOCKCLOCK
- if (pll_control && kern_enable) {
+ if (clock_ctl.pll_control && clock_ctl.kern_enable) {
memset((char *)&ntv, 0, sizeof(ntv));
ntv.modes = MOD_STATUS;
ntv.status = STA_UNSYNC;
@@ -1344,7 +1346,7 @@ pll_trap(
)
{
UNUSED_ARG(arg);
- pll_control = false;
+ clock_ctl.pll_control = false;
siglongjmp(env, 1);
}
#endif /* SIGSYS */
=====================================
ntpd/ntp_peer.c
=====================================
--- a/ntpd/ntp_peer.c
+++ b/ntpd/ntp_peer.c
@@ -664,7 +664,7 @@ newpeer(
peer_clear(peer, "BCST", initializing1);
else
peer_clear(peer, "INIT", initializing1);
- if (mode_ntpdate)
+ if (clock_ctl.mode_ntpdate)
peer_ntpdate++;
/*
=====================================
ntpd/ntp_proto.c
=====================================
--- a/ntpd/ntp_proto.c
+++ b/ntpd/ntp_proto.c
@@ -940,7 +940,7 @@ transmit(
* set and all peers have completed the burst,
* we declare a successful failure.
*/
- if (mode_ntpdate) {
+ if (clock_ctl.mode_ntpdate) {
peer_ntpdate--;
if (peer_ntpdate == 0) {
msyslog(LOG_NOTICE,
@@ -2755,7 +2755,7 @@ init_proto(const bool verbose)
orphwait = current_time + (unsigned long)sys_orphwait;
proto_clr_stats();
stat_count.use_stattime = current_time;
- hardpps_enable = false;
+ clock_ctl.hardpps_enable = false;
stats_control = true;
}
@@ -2803,11 +2803,11 @@ proto_config(
break;
case PROTO_NTP: /* NTP discipline (ntp) */
- ntp_enable = (bool)value;
+ clock_ctl.ntp_enable = (bool)value;
break;
case PROTO_PPS: /* PPS discipline (pps) */
- hardpps_enable = (bool)value;
+ clock_ctl.hardpps_enable = (bool)value;
break;
case PROTO_FILEGEN: /* statistics (stats) */
=====================================
ntpd/ntp_refclock.c
=====================================
--- a/ntpd/ntp_refclock.c
+++ b/ntpd/ntp_refclock.c
@@ -991,7 +991,7 @@ refclock_params(
"REFCLOCK: refclock_params: time_pps_kcbind: %m");
return false;
}
- hardpps_enable = true;
+ clock_ctl.hardpps_enable = true;
}
return true;
}
=====================================
ntpd/ntp_timer.c
=====================================
--- a/ntpd/ntp_timer.c
+++ b/ntpd/ntp_timer.c
@@ -373,7 +373,7 @@ check_leapsec(
leap_result_t lsdata;
uint32_t lsprox;
- leapsec_electric((pll_control && kern_enable) ? electric_on : electric_off);
+ leapsec_electric((clock_ctl.pll_control && clock_ctl.kern_enable) ? electric_on : electric_off);
#ifdef ENABLE_LEAP_SMEAR
leap_smear.enabled = (leap_smear_intv != 0);
#endif
=====================================
ntpd/ntpd.c
=====================================
--- a/ntpd/ntpd.c
+++ b/ntpd/ntpd.c
@@ -261,10 +261,10 @@ parse_cmdline_opts(
driftfile = ntp_optarg;
break;
case 'g':
- allow_panic = true;
+ clock_ctl.allow_panic = true;
break;
case 'G':
- force_step_once = true;
+ clock_ctl.force_step_once = true;
break;
case 'h':
ntpd_usage();
@@ -316,7 +316,7 @@ parse_cmdline_opts(
}
break;
case 'q':
- mode_ntpdate = true;
+ clock_ctl.mode_ntpdate = true;
nofork = true;
break;
case 'r':
@@ -835,9 +835,9 @@ ntpdmain(
if (driftfile)
fprintf(stdout, "driftfile \"%s\";\n", driftfile);
fprintf(stdout, "#allow_panic = %s\n",
- allow_panic ? "true" : "false");
+ clock_ctl.allow_panic ? "true" : "false");
fprintf(stdout, "#force_step_once = %s\n",
- force_step_once ? "true" : "false");
+ clock_ctl.force_step_once ? "true" : "false");
#ifdef ENABLE_DROPROOT
if (chrootdir)
fprintf(stdout, "#chrootdir = \"%s\";\n", chrootdir);
@@ -860,7 +860,7 @@ ntpdmain(
fprintf(stdout, "pidfile \"%s\";\n", pidfile);
/* FIXME: dump priority */
fprintf(stdout, "#mode_ntpdate = %s\n",
- mode_ntpdate ? "true" : "false");
+ clock_ctl.mode_ntpdate ? "true" : "false");
if (statsdir[0])
fprintf(stdout, "statsdir \"%s\";\n", statsdir);
fprintf(stdout, "#interface_interval = %d\n", interface_interval);
=====================================
ntpd/refclock_generic.c
=====================================
--- a/ntpd/refclock_generic.c
+++ b/ntpd/refclock_generic.c
@@ -2402,7 +2402,7 @@ parse_hardpps(
* tell the rest, that we have a kernel PPS source, iff we ever enable HARDPPS
*/
if (mode == PARSE_HARDPPS_ENABLE)
- hardpps_enable = true;
+ clock_ctl.hardpps_enable = true;
}
}
=====================================
ntpd/refclock_oncore.c
=====================================
--- a/ntpd/refclock_oncore.c
+++ b/ntpd/refclock_oncore.c
@@ -908,7 +908,7 @@ oncore_ppsapi(
return false;
}
- hardpps_enable = true;
+ clock_ctl.hardpps_enable = true;
}
return true;
}
View it on GitLab: https://gitlab.com/NTPsec/ntpsec/commit/c2eb57fdec36bd4d62bdf7b17997ea2789659c06
--
View it on GitLab: https://gitlab.com/NTPsec/ntpsec/commit/c2eb57fdec36bd4d62bdf7b17997ea2789659c06
You're receiving this email because of your account on gitlab.com.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.ntpsec.org/pipermail/vc/attachments/20180520/64fa365b/attachment.html>
More information about the vc
mailing list