diff options
author | David Goulet <dgoulet@torproject.org> | 2018-01-25 09:44:21 -0500 |
---|---|---|
committer | David Goulet <dgoulet@torproject.org> | 2018-01-30 09:18:16 -0500 |
commit | 82de4ea900c5d3513214b127421890595343bfaa (patch) | |
tree | 27d926d2666961490eaf53eda267e6c2a9bae136 /src/or/geoip.c | |
parent | 14a8b87852887f8c20a424ff32a2b6746105dd6c (diff) | |
download | tor-82de4ea900c5d3513214b127421890595343bfaa.tar.gz tor-82de4ea900c5d3513214b127421890595343bfaa.zip |
dos: Clear connection tracked flag if geoip entry is removed
Imagine this scenario. We had 10 connections over the 24h lifetime of a geoip
cache entry. The lifetime of the entry has been reached so it is about to get
freed but 2 connections remain for it. After the free, a third connection
comes in thus making us create a new geoip entry for that address matching the
2 previous ones that are still alive. If they end up being closed, we'll have
a concurrent count desynch from what the reality is.
To mitigate this probably very rare scenario in practice, when we free a geoip
entry and it has a concurrent count above 0, we'll go over all connections
matching the address and clear out the tracked flag. So once they are closed,
we don't try to decrement the count.
Signed-off-by: David Goulet <dgoulet@torproject.org>
Diffstat (limited to 'src/or/geoip.c')
-rw-r--r-- | src/or/geoip.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/or/geoip.c b/src/or/geoip.c index 5f0b04b568..4e4f6e639a 100644 --- a/src/or/geoip.c +++ b/src/or/geoip.c @@ -516,6 +516,10 @@ clientmap_entry_free(clientmap_entry_t *ent) if (!ent) return; + /* This entry is about to be freed so pass it to the DoS subsystem to see if + * any actions can be taken about it. */ + dos_geoip_entry_about_to_free(ent); + tor_free(ent->transport_name); tor_free(ent); } |