summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2011-06-06 16:20:22 -0400
committerNick Mathewson <nickm@torproject.org>2011-06-06 16:20:22 -0400
commit8cd5a3c1865c2115d88b08041a27e2cfdd7d24d2 (patch)
tree276594ce339e57431164adaf37c84a855cec34f0 /src
parent96da10aace8aa9486872a21986a191b07821a506 (diff)
parent9e3fc5f61685f937d76e60c5fa1781b80aa5bf68 (diff)
downloadtor-8cd5a3c1865c2115d88b08041a27e2cfdd7d24d2.tar.gz
tor-8cd5a3c1865c2115d88b08041a27e2cfdd7d24d2.zip
Merge remote-tracking branch 'origin/maint-0.2.2'
Diffstat (limited to 'src')
-rw-r--r--src/common/crypto.c5
-rw-r--r--src/or/circuitbuild.c10
2 files changed, 12 insertions, 3 deletions
diff --git a/src/common/crypto.c b/src/common/crypto.c
index 424a6f4175..05c1ce9ea2 100644
--- a/src/common/crypto.c
+++ b/src/common/crypto.c
@@ -2145,13 +2145,14 @@ crypto_rand(char *to, size_t n)
}
/** Return a pseudorandom integer, chosen uniformly from the values
- * between 0 and <b>max</b>-1. */
+ * between 0 and <b>max</b>-1 inclusive. <b>max</b> must be between 1 and
+ * INT_MAX+1, inclusive. */
int
crypto_rand_int(unsigned int max)
{
unsigned int val;
unsigned int cutoff;
- tor_assert(max < UINT_MAX);
+ tor_assert(max <= ((unsigned int)INT_MAX)+1);
tor_assert(max > 0); /* don't div by 0 */
/* We ignore any values that are >= 'cutoff,' to avoid biasing the
diff --git a/src/or/circuitbuild.c b/src/or/circuitbuild.c
index 96cd333819..68ca569649 100644
--- a/src/or/circuitbuild.c
+++ b/src/or/circuitbuild.c
@@ -679,7 +679,15 @@ circuit_build_times_shuffle_and_store_array(circuit_build_times_t *cbt,
log_notice(LD_CIRC, "The number of circuit times that this Tor version "
"uses to calculate build times is less than the number stored "
"in your state file. Decreasing the circuit time history from "
- "%d to %d.", num_times, CBT_NCIRCUITS_TO_OBSERVE);
+ "%lu to %d.", (unsigned long)num_times,
+ CBT_NCIRCUITS_TO_OBSERVE);
+ }
+
+ if (n > INT_MAX-1) {
+ log_warn(LD_CIRC, "For some insane reasons, you had %lu circuit build "
+ "observations in your state file. That's far too many; probably "
+ "there's a bug here.", (unsigned long)n);
+ n = INT_MAX-1;
}
/* This code can only be run on a compact array */