summaryrefslogtreecommitdiff
path: root/src/common/util.c
diff options
context:
space:
mode:
authorRoger Dingledine <arma@torproject.org>2005-01-10 16:30:51 +0000
committerRoger Dingledine <arma@torproject.org>2005-01-10 16:30:51 +0000
commit74bc4e5af02a569652a2bf4892117bc44887ad0b (patch)
tree692874790345462a214a16698c1c28a6d7a94d13 /src/common/util.c
parent4b6d55afdf48761eaa1b64f390adb76a12077541 (diff)
downloadtor-74bc4e5af02a569652a2bf4892117bc44887ad0b.tar.gz
tor-74bc4e5af02a569652a2bf4892117bc44887ad0b.zip
help avoid overflow from len_in + (len_in/n)*len_ins
nick, do you think this does it? if so, we should maybe backport too. svn:r3334
Diffstat (limited to 'src/common/util.c')
-rw-r--r--src/common/util.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/src/common/util.c b/src/common/util.c
index e4a2889d76..11dbd2b71d 100644
--- a/src/common/util.c
+++ b/src/common/util.c
@@ -215,6 +215,8 @@ int tor_strpartition(char *dest, size_t dest_len,
tor_assert(dest_len < SIZE_T_CEILING);
len_in = strlen(s);
len_ins = strlen(insert);
+ tor_assert(len_in < SIZE_T_CEILING);
+ tor_assert(len_in/n < SIZE_T_CEILING/len_ins); /* avoid overflow */
len_out = len_in + (len_in/n)*len_ins;
is_even = (len_in%n) == 0;
switch (rule)