[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] r17169: {tor} Fix a possible negative shift in address comparison. May fix (in tor/trunk: . src/common)



Author: nickm
Date: 2008-10-29 09:29:54 -0400 (Wed, 29 Oct 2008)
New Revision: 17169

Modified:
   tor/trunk/ChangeLog
   tor/trunk/src/common/address.c
Log:
Fix a possible negative shift in address comparison.  May fix bug 845 and bug 811

Modified: tor/trunk/ChangeLog
===================================================================
--- tor/trunk/ChangeLog	2008-10-28 17:43:55 UTC (rev 17168)
+++ tor/trunk/ChangeLog	2008-10-29 13:29:54 UTC (rev 17169)
@@ -41,6 +41,8 @@
       prevent possible guess-the-streamid injection attacks from
       intermediate hops.  Fixes another case of bug 446. Based on patch
       from rovv.
+    - Avoid using a negative right-shift when comparing 32-bit
+      addresses.  Possible fix for bug 845 and bug 811.
 
 
 Changes in version 0.2.1.6-alpha - 2008-09-30

Modified: tor/trunk/src/common/address.c
===================================================================
--- tor/trunk/src/common/address.c	2008-10-28 17:43:55 UTC (rev 17168)
+++ tor/trunk/src/common/address.c	2008-10-29 13:29:54 UTC (rev 17169)
@@ -686,6 +686,8 @@
       case AF_INET: {
         uint32_t a1 = ntohl(addr1->addr.in_addr.s_addr);
         uint32_t a2 = ntohl(addr2->addr.in_addr.s_addr);
+        if (mbits > 32)
+          mbits = 32;
         a1 >>= (32-mbits);
         a2 >>= (32-mbits);
         return (a1 < a2) ? -1 : (a1 == a2) ? 0 : 1;