summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-11-06 19:42:37 +0000
committerNick Mathewson <nickm@torproject.org>2007-11-06 19:42:37 +0000
commitbe1a5191f8e0ca14b6db0880660d5897964fef40 (patch)
tree5771fb6c2eae9f52c62155178d556bae8c6601be /src
parent28dd56f98263035c8c50b78bb63badf45a6fc1ac (diff)
downloadtor-be1a5191f8e0ca14b6db0880660d5897964fef40.tar.gz
tor-be1a5191f8e0ca14b6db0880660d5897964fef40.zip
r16462@catbus: nickm | 2007-11-06 14:40:58 -0500
Fix bug 544: do not allow buckets to overflow. Backportable. svn:r12400
Diffstat (limited to 'src')
-rw-r--r--src/or/connection.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/or/connection.c b/src/or/connection.c
index daf1e5a7f0..40aa72d56c 100644
--- a/src/or/connection.c
+++ b/src/or/connection.c
@@ -1638,14 +1638,20 @@ connection_bucket_init(void)
}
}
+/** DOCDOC */
static void
connection_bucket_refill_helper(int *bucket, int rate, int burst,
int seconds_elapsed, const char *name)
{
- if (*bucket < burst) {
- *bucket += rate*seconds_elapsed;
- if (*bucket > burst)
+ int starting_bucket = *bucket;
+ if (starting_bucket < burst) {
+ int incr = rate*seconds_elapsed;
+ *bucket += incr;
+ if (*bucket > burst || *bucket < starting_bucket) {
+ /* If we overflow the burst, or underflow our starting bucket,
+ * cap the bucket value to burst. */
*bucket = burst;
+ }
log(LOG_DEBUG, LD_NET,"%s now %d.", name, *bucket);
}
}