diff options
author | Nick Mathewson <nickm@torproject.org> | 2011-03-17 14:06:04 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2011-03-17 14:06:04 -0400 |
commit | 547635c0049ec92e929e0f360f729b5dd308a215 (patch) | |
tree | 6812fbf9a23b001ff0ed4497c39530e3ea61a6c1 /src/or/geoip.c | |
parent | 56bdc844ba68ac0911efc7ad3398f1eafeaaac76 (diff) | |
download | tor-547635c0049ec92e929e0f360f729b5dd308a215.tar.gz tor-547635c0049ec92e929e0f360f729b5dd308a215.zip |
Futz with the clang patch a bit and tidy some geoip.c stuff
Diffstat (limited to 'src/or/geoip.c')
-rw-r--r-- | src/or/geoip.c | 21 |
1 files changed, 13 insertions, 8 deletions
diff --git a/src/or/geoip.c b/src/or/geoip.c index f3e0b72e66..a99165488a 100644 --- a/src/or/geoip.c +++ b/src/or/geoip.c @@ -278,19 +278,24 @@ geoip_is_loaded(void) return geoip_countries != NULL && geoip_entries != NULL; } -#define MAX_LAST_SEEN_IN_MINUTES 0x3FFFFFFFu - /** Entry in a map from IP address to the last time we've seen an incoming * connection from that IP address. Used by bridges only, to track which * countries have them blocked. */ typedef struct clientmap_entry_t { HT_ENTRY(clientmap_entry_t) node; uint32_t ipaddr; + /** Time when we last saw this IP address, in MINUTES since the epoch. + * + * (This will run out of space around 4011 CE. If Tor is still in use around + * 4000 CE, please remember to add more bits to last_seen_in_minutes.) */ unsigned int last_seen_in_minutes:30; unsigned int action:2; } clientmap_entry_t; -#define ACTION_MASK 3 +/** Largest allowable value for last_seen_in_minutes. (It's a 30-bit field, + * so it can hold up to (1u<<30)-1, or 0x3fffffffu. + */ +#define MAX_LAST_SEEN_IN_MINUTES 0X3FFFFFFFu /** Map from client IP address to last time seen. */ static HT_HEAD(clientmap, clientmap_entry_t) client_history = @@ -415,16 +420,16 @@ geoip_note_client_seen(geoip_client_action_t action, lookup.ipaddr = addr; lookup.action = (int)action; ent = HT_FIND(clientmap, &client_history, &lookup); - tor_assert(now / 60 <= MAX_LAST_SEEN_IN_MINUTES); - if (ent) { - ent->last_seen_in_minutes = (unsigned)(now/60); - } else { + if (! ent) { ent = tor_malloc_zero(sizeof(clientmap_entry_t)); ent->ipaddr = addr; - ent->last_seen_in_minutes = (unsigned)(now/60); ent->action = (int)action; HT_INSERT(clientmap, &client_history, ent); } + if (now / 60 <= MAX_LAST_SEEN_IN_MINUTES && now >= 0) + ent->last_seen_in_minutes = (unsigned)(now/60); + else + ent->last_seen_in_minutes = 0; if (action == GEOIP_CLIENT_NETWORKSTATUS || action == GEOIP_CLIENT_NETWORKSTATUS_V2) { |