aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-09-08 19:08:46 +0000
committerNick Mathewson <nickm@torproject.org>2007-09-08 19:08:46 +0000
commit509bc3b4a055c9bee80d943111e01cf031db81f8 (patch)
tree84a47fa5fd338c4f879c9dd88a0092044087ab22 /src
parenteb3f24f027e9d160c5b5658e7d7f86a2acda880f (diff)
downloadtor-509bc3b4a055c9bee80d943111e01cf031db81f8.tar.gz
tor-509bc3b4a055c9bee80d943111e01cf031db81f8.zip
r14359@Kushana: nickm | 2007-09-08 15:07:17 -0400
Add some generic skew-and-tolerance functions so we can handle time more sanely. svn:r11406
Diffstat (limited to 'src')
-rw-r--r--src/common/util.c64
-rw-r--r--src/common/util.h9
2 files changed, 73 insertions, 0 deletions
diff --git a/src/common/util.c b/src/common/util.c
index d8e89395ad..e0eeee282a 100644
--- a/src/common/util.c
+++ b/src/common/util.c
@@ -1251,6 +1251,70 @@ parse_http_time(const char *date, struct tm *tm)
}
/* =====
+ * Fuzzy time
+ * ===== */
+
+/* In a perfect world, everybody would run ntp, and ntp would be perfect, so
+ * if we wanted to know "Is the current time before time X?" we could just say
+ * "time(NULL) < X".
+ *
+ * But unfortunately, many users are running Tor in an imperfect world, on
+ * even more imperfect computers. Hence, we need to track time oddly. We
+ * model the user's computer as being "skewed" from accurate time by
+ * -<b>ftime_skew</b> seconds, such that our best guess of the current time is
+ * time(NULL)+ftime_skew. We also assume that our measurements of time may
+ * have up to <b>ftime_slop</b> seconds of inaccuracy; hence, the
+ * measurements;
+ */
+static int ftime_skew = 0;
+static int ftime_slop = 60;
+void
+ftime_set_maximum_sloppiness(int seconds)
+{
+ tor_assert(seconds >= 0);
+ ftime_slop = seconds;
+}
+void
+ftime_set_estimated_skew(int seconds)
+{
+ ftime_skew = seconds;
+}
+#if 0
+void
+ftime_get_window(time_t now, ftime_t *ft_out)
+{
+ ft_out->earliest = now + ftime_skew - ftime_slop;
+ ft_out->latest = now + ftime_skew + ftime_slop;
+}
+#endif
+int
+ftime_maybe_after(time_t now, time_t when)
+{
+ /* It may be after when iff the latest possible current time is after when. */
+ return (now + ftime_skew + ftime_slop) >= when;
+}
+int
+ftime_maybe_before(time_t now, time_t when)
+{
+ /* It may be before when iff the earliest possible current time is before. */
+ return (now + ftime_skew - ftime_slop) < when;
+}
+int
+ftime_definitely_after(time_t now, time_t when)
+{
+ /* It is definitely after when if the earliest time it could be is still
+ * after when. */
+ return (now + ftime_skew - ftime_slop) >= when;
+}
+int
+ftime_definitely_before(time_t now, time_t when)
+{
+ /* It is definitely before when if the latest time it could be is still
+ * before when. */
+ return (now + ftime_skew + ftime_slop) < when;
+}
+
+/* =====
* File helpers
* ===== */
diff --git a/src/common/util.h b/src/common/util.h
index d973948c50..950de9bacc 100644
--- a/src/common/util.h
+++ b/src/common/util.h
@@ -206,6 +206,15 @@ void format_local_iso_time(char *buf, time_t t);
void format_iso_time(char *buf, time_t t);
int parse_iso_time(const char *buf, time_t *t);
int parse_http_time(const char *buf, struct tm *tm);
+/* Fuzzy time. */
+void ftime_set_maximum_sloppiness(int seconds);
+void ftime_set_estimated_skew(int seconds);
+/* typedef struct ftime_t { time_t earliest; time_t latest; } ftime_t; */
+/* void ftime_get_window(time_t now, ftime_t *ft_out); */
+int ftime_maybe_after(time_t now, time_t when);
+int ftime_maybe_before(time_t now, time_t when);
+int ftime_definitely_after(time_t now, time_t when);
+int ftime_definitely_before(time_t now, time_t when);
/* File helpers */
int write_all(int fd, const char *buf, size_t count, int isSocket);