summaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
authorRoger Dingledine <arma@torproject.org>2005-02-19 03:02:33 +0000
committerRoger Dingledine <arma@torproject.org>2005-02-19 03:02:33 +0000
commit596d65ec3b3d54b9b7dc29fef54b5a193498e427 (patch)
treea2318a997087f79ecc80fac8bb91746f4b796d9e /src/common
parentf30916830175a54bd8a3cf91e9ffc2402a064bd9 (diff)
downloadtor-596d65ec3b3d54b9b7dc29fef54b5a193498e427.tar.gz
tor-596d65ec3b3d54b9b7dc29fef54b5a193498e427.zip
avoid case (not yet triggered) where smartlists could grow out
of control svn:r3636
Diffstat (limited to 'src/common')
-rw-r--r--src/common/container.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/common/container.c b/src/common/container.c
index 4dc0a7ad77..1824645ad5 100644
--- a/src/common/container.c
+++ b/src/common/container.c
@@ -88,7 +88,9 @@ void smartlist_truncate(smartlist_t *sl, int len)
/** Append element to the end of the list. */
void smartlist_add(smartlist_t *sl, void *element) {
if (sl->num_used >= sl->capacity) {
- sl->capacity *= 2;
+ int higher = sl->capacity * 2;
+ tor_assert(higher > sl->capacity); /* detect overflow */
+ sl->capacity = higher;
sl->list = tor_realloc(sl->list, sizeof(void*)*sl->capacity);
}
sl->list[sl->num_used++] = element;