summaryrefslogtreecommitdiff
path: root/src/or/rephist.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/or/rephist.c')
-rw-r--r--src/or/rephist.c63
1 files changed, 47 insertions, 16 deletions
diff --git a/src/or/rephist.c b/src/or/rephist.c
index 30c54fa473..bd4d837fbc 100644
--- a/src/or/rephist.c
+++ b/src/or/rephist.c
@@ -684,7 +684,7 @@ rep_hist_record_mtbf_data(void)
base16_encode(dbuf, sizeof(dbuf), digest, DIGEST_LEN);
PRINTF((f, "R %s\n", dbuf));
- if (hist->start_of_run) {
+ if (hist->start_of_run > 0) {
format_iso_time(time_buf, hist->start_of_run);
t = time_buf;
}
@@ -692,7 +692,7 @@ rep_hist_record_mtbf_data(void)
hist->weighted_run_length, hist->total_run_weights,
t ? " S=" : "", t ? t : ""));
t = NULL;
- if (hist->start_of_downtime) {
+ if (hist->start_of_downtime > 0) {
format_iso_time(time_buf, hist->start_of_downtime);
t = time_buf;
}
@@ -728,6 +728,43 @@ find_next_with(smartlist_t *sl, int i, const char *prefix)
return -1;
}
+static int n_bogus_times = 0;
+/** DOCDOC */
+static int
+parse_possibly_bad_iso_time(const char *s, time_t *time_out)
+{
+ int year;
+ char b[5];
+ strlcpy(b, s, sizeof(b));
+ b[4] = '\0';
+ year = atoi(b);
+ if (year < 1970) {
+ *time_out = 0;
+ ++n_bogus_times;
+ return 0;
+ } else
+ return parse_iso_time(s, time_out);
+}
+
+/** DOCDOC */
+static INLINE time_t
+correct_time(time_t t, time_t now, time_t stored_at, time_t started_measuring)
+{
+ if (t < started_measuring - 24*60*60*365)
+ return 0;
+ else if (t < started_measuring)
+ return started_measuring;
+ else if (t > stored_at)
+ return 0;
+ else {
+ long run_length = stored_at - t;
+ t = now - run_length;
+ if (t < started_measuring)
+ t = started_measuring;
+ return t;
+ }
+}
+
/** Load MTBF data from disk. Returns 0 on success or recoverable error, -1
* on failure. */
int
@@ -799,6 +836,8 @@ rep_hist_load_mtbf_data(time_t now)
if (line && !strcmp(line, "data"))
++i;
+ n_bogus_times = 0;
+
for (; i < smartlist_len(lines); ++i) {
char digest[DIGEST_LEN];
char hexbuf[HEX_DIGEST_LEN+1];
@@ -874,16 +913,12 @@ rep_hist_load_mtbf_data(time_t now)
if (have_mtbf) {
if (mtbf_timebuf[0]) {
mtbf_timebuf[10] = ' ';
- if (parse_iso_time(mtbf_timebuf, &start_of_run)<0)
+ if (parse_possibly_bad_iso_time(mtbf_timebuf, &start_of_run)<0)
log_warn(LD_GENERAL, "Couldn't parse time %s",
escaped(mtbf_timebuf));
}
- if (!start_of_run || start_of_run > stored_at) {
- hist->start_of_run = 0;
- } else {
- long run_length = stored_at - start_of_run;
- hist->start_of_run = now - run_length;
- }
+ hist->start_of_run = correct_time(start_of_run, now, stored_at,
+ tracked_since);
if (hist->start_of_run < latest_possible_start + wrl)
latest_possible_start = hist->start_of_run - wrl;
@@ -893,16 +928,12 @@ rep_hist_load_mtbf_data(time_t now)
if (have_wfu) {
if (wfu_timebuf[0]) {
wfu_timebuf[10] = ' ';
- if (parse_iso_time(wfu_timebuf, &start_of_downtime)<0)
+ if (parse_possibly_bad_iso_time(wfu_timebuf, &start_of_downtime)<0)
log_warn(LD_GENERAL, "Couldn't parse time %s", escaped(wfu_timebuf));
}
}
- if (!start_of_downtime || start_of_downtime > stored_at) {
- hist->start_of_downtime = 0;
- } else {
- long down_length = stored_at - start_of_downtime;
- hist->start_of_downtime = start_of_downtime - down_length;
- }
+ hist->start_of_downtime = correct_time(start_of_downtime, now, stored_at,
+ tracked_since);
hist->weighted_uptime = wt_uptime;
hist->total_weighted_time = total_wt_time;
}