[tor-commits] [tor/master] Have tor_parse_*long functions check for negative bases

nickm at torproject.org nickm at torproject.org
Fri Mar 30 14:38:35 UTC 2012


commit 56e0959d2ab9cae45d39c5b9d72b1bb1b8ad03b7
Author: Nick Mathewson <nickm at torproject.org>
Date:   Fri Mar 30 10:34:05 2012 -0400

    Have tor_parse_*long functions check for negative bases
    
    One of our unit tests checks that they behave correctly (giving an
    error) when the base is negative.  But there isn't a guarantee that
    strtol and friends actually handle negative bases correctly.
    
    Found by Coverity Scan; fix for CID 504.
---
 src/common/util.c |   16 ++++++++++++++++
 1 files changed, 16 insertions(+), 0 deletions(-)

diff --git a/src/common/util.c b/src/common/util.c
index 1807ee7..266368c 100644
--- a/src/common/util.c
+++ b/src/common/util.c
@@ -906,6 +906,11 @@ tor_parse_long(const char *s, int base, long min, long max,
   char *endptr;
   long r;
 
+  if (base < 0) {
+    if (ok)
+      *ok = 0;
+    return 0;
+  }
   r = strtol(s, &endptr, base);
   CHECK_STRTOX_RESULT();
 }
@@ -918,6 +923,11 @@ tor_parse_ulong(const char *s, int base, unsigned long min,
   char *endptr;
   unsigned long r;
 
+  if (base < 0) {
+    if (ok)
+      *ok = 0;
+    return 0;
+  }
   r = strtoul(s, &endptr, base);
   CHECK_STRTOX_RESULT();
 }
@@ -942,6 +952,12 @@ tor_parse_uint64(const char *s, int base, uint64_t min,
   char *endptr;
   uint64_t r;
 
+  if (base < 0) {
+    if (ok)
+      *ok = 0;
+    return 0;
+  }
+
 #ifdef HAVE_STRTOULL
   r = (uint64_t)strtoull(s, &endptr, base);
 #elif defined(_WIN32)



More information about the tor-commits mailing list