ntpd: make it work w/o -g too :(
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
8eda4a9005
commit
fae9f499b2
@ -1,5 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
# (using bashisms: "function", arrays)
|
# (using bashism: arrays)
|
||||||
|
|
||||||
|
service="${PWD##*/}"
|
||||||
|
rundir="/var/run/service/$service"
|
||||||
|
|
||||||
user=root
|
user=root
|
||||||
extif=if
|
extif=if
|
||||||
@ -10,9 +13,6 @@ sv o .
|
|||||||
# Debug
|
# Debug
|
||||||
#date '+%Y-%m-%d %H:%M:%S' >>"$0.log"
|
#date '+%Y-%m-%d %H:%M:%S' >>"$0.log"
|
||||||
|
|
||||||
service=`basename "$PWD"`
|
|
||||||
rundir="/var/run/service/$service"
|
|
||||||
|
|
||||||
### filter This is the default table (if no -t option is passed). It contains
|
### filter This is the default table (if no -t option is passed). It contains
|
||||||
### the built-in chains INPUT (for packets coming into the box itself),
|
### the built-in chains INPUT (for packets coming into the box itself),
|
||||||
### FORWARD (for packets being routed through the box), and OUTPUT (for
|
### FORWARD (for packets being routed through the box), and OUTPUT (for
|
||||||
|
@ -180,8 +180,8 @@ struct globals {
|
|||||||
llist_t *ntp_peers;
|
llist_t *ntp_peers;
|
||||||
ntp_status_t status;
|
ntp_status_t status;
|
||||||
uint32_t scale;
|
uint32_t scale;
|
||||||
uint8_t settime;
|
uint8_t time_is_set;
|
||||||
uint8_t firstadj;
|
uint8_t first_adj_done;
|
||||||
};
|
};
|
||||||
#define G (*ptr_to_globals)
|
#define G (*ptr_to_globals)
|
||||||
|
|
||||||
@ -454,23 +454,25 @@ adjtime_wrap(void)
|
|||||||
G.status.leap = peers[middle]->update.status.leap;
|
G.status.leap = peers[middle]->update.status.leap;
|
||||||
|
|
||||||
bb_info_msg("adjusting local clock by %fs", offset_median);
|
bb_info_msg("adjusting local clock by %fs", offset_median);
|
||||||
|
errno = 0;
|
||||||
d_to_tv(offset_median, &tv);
|
d_to_tv(offset_median, &tv);
|
||||||
if (adjtime(&tv, &olddelta) == -1)
|
if (adjtime(&tv, &olddelta) == -1) {
|
||||||
bb_error_msg("adjtime failed");
|
bb_perror_msg("adjtime failed"); //TODO: maybe _and_die?
|
||||||
else if (!G.firstadj
|
} else
|
||||||
|
if (G.first_adj_done
|
||||||
&& olddelta.tv_sec == 0
|
&& olddelta.tv_sec == 0
|
||||||
&& olddelta.tv_usec == 0
|
&& olddelta.tv_usec == 0
|
||||||
&& !G.status.synced
|
&& !G.status.synced
|
||||||
) {
|
) {
|
||||||
bb_info_msg("clock synced");
|
bb_info_msg("clock synced");
|
||||||
G.status.synced = 1;
|
G.status.synced = 1;
|
||||||
} else if (G.status.synced) {
|
} else
|
||||||
|
if (G.status.synced) {
|
||||||
bb_info_msg("clock unsynced");
|
bb_info_msg("clock unsynced");
|
||||||
G.status.synced = 0;
|
G.status.synced = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
G.firstadj = 0;
|
G.first_adj_done = 1;
|
||||||
G.status.reftime = gettime1900fp();
|
G.status.reftime = gettime1900fp();
|
||||||
G.status.stratum++; /* one more than selected peer */
|
G.status.stratum++; /* one more than selected peer */
|
||||||
G.scale = updated_scale(offset_median);
|
G.scale = updated_scale(offset_median);
|
||||||
@ -495,7 +497,7 @@ adjtime_wrap(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
settime(double offset)
|
step_time_once(double offset)
|
||||||
{
|
{
|
||||||
ntp_peer_t *p;
|
ntp_peer_t *p;
|
||||||
llist_t *item;
|
llist_t *item;
|
||||||
@ -503,10 +505,9 @@ settime(double offset)
|
|||||||
char buf[80];
|
char buf[80];
|
||||||
time_t tval;
|
time_t tval;
|
||||||
|
|
||||||
if (!G.settime)
|
if (G.time_is_set)
|
||||||
goto bail;
|
goto bail;
|
||||||
|
G.time_is_set = 1;
|
||||||
G.settime = 0;
|
|
||||||
|
|
||||||
/* if the offset is small, don't call settimeofday */
|
/* if the offset is small, don't call settimeofday */
|
||||||
if (offset < SETTIME_MIN_OFFSET && offset > -SETTIME_MIN_OFFSET)
|
if (offset < SETTIME_MIN_OFFSET && offset > -SETTIME_MIN_OFFSET)
|
||||||
@ -514,6 +515,7 @@ settime(double offset)
|
|||||||
|
|
||||||
gettimeofday(&curtime, NULL); /* never fails */
|
gettimeofday(&curtime, NULL); /* never fails */
|
||||||
|
|
||||||
|
//isn't it simpler to: offset += curtime.tv_sec; offset += 1.0e-6 * curtime.tv_usec?
|
||||||
d_to_tv(offset, &tv);
|
d_to_tv(offset, &tv);
|
||||||
curtime.tv_usec += tv.tv_usec + 1000000;
|
curtime.tv_usec += tv.tv_usec + 1000000;
|
||||||
curtime.tv_sec += tv.tv_sec - 1 + (curtime.tv_usec / 1000000);
|
curtime.tv_sec += tv.tv_sec - 1 + (curtime.tv_usec / 1000000);
|
||||||
@ -708,7 +710,7 @@ recv_and_process_peer_pkt(ntp_peer_t *p)
|
|||||||
offset->offset, offset->delay, (int) interval);
|
offset->offset, offset->delay, (int) interval);
|
||||||
|
|
||||||
update_peer_data(p);
|
update_peer_data(p);
|
||||||
settime(offset->offset);
|
step_time_once(offset->offset);
|
||||||
|
|
||||||
p->shift++;
|
p->shift++;
|
||||||
if (p->shift >= OFFSET_ARRAY_SIZE)
|
if (p->shift >= OFFSET_ARRAY_SIZE)
|
||||||
@ -892,8 +894,9 @@ static NOINLINE void ntp_init(char **argv)
|
|||||||
&peers, &G.verbose);
|
&peers, &G.verbose);
|
||||||
if (!(opts & (OPT_p|OPT_l)))
|
if (!(opts & (OPT_p|OPT_l)))
|
||||||
bb_show_usage();
|
bb_show_usage();
|
||||||
if (opts & OPT_g)
|
//WRONG
|
||||||
G.settime = 1;
|
// if (opts & OPT_g)
|
||||||
|
// G.time_is_set = 1;
|
||||||
while (peers)
|
while (peers)
|
||||||
add_peers(llist_pop(&peers));
|
add_peers(llist_pop(&peers));
|
||||||
if (!(opts & OPT_n)) {
|
if (!(opts & OPT_n)) {
|
||||||
@ -931,7 +934,6 @@ static NOINLINE void ntp_init(char **argv)
|
|||||||
G.status.precision = prec;
|
G.status.precision = prec;
|
||||||
}
|
}
|
||||||
G.scale = 1;
|
G.scale = 1;
|
||||||
G.firstadj = 1;
|
|
||||||
|
|
||||||
bb_signals((1 << SIGTERM) | (1 << SIGINT), record_signo);
|
bb_signals((1 << SIGTERM) | (1 << SIGINT), record_signo);
|
||||||
bb_signals((1 << SIGPIPE) | (1 << SIGHUP), SIG_IGN);
|
bb_signals((1 << SIGPIPE) | (1 << SIGHUP), SIG_IGN);
|
||||||
@ -1019,7 +1021,7 @@ int ntpd_main(int argc UNUSED_PARAM, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ((trial_cnt > 0 && sent_cnt == 0) || g.peer_cnt == 0)
|
if ((trial_cnt > 0 && sent_cnt == 0) || g.peer_cnt == 0)
|
||||||
settime(0); /* no good peers, don't wait */
|
step_time_once(0); /* no good peers, don't wait */
|
||||||
|
|
||||||
timeout = nextaction - cur_time;
|
timeout = nextaction - cur_time;
|
||||||
if (timeout < 0)
|
if (timeout < 0)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user