tor

The Tor anonymity network
git clone https://git.dasho.dev/tor.git
Log | Files | Refs | README | LICENSE

commit c1d98c75e305eaf63e81903ca5a4eb68dcae515b
parent fb5877b9721dcc0d140c2c7c8d16d0b656bbf5d7
Author: Nick Mathewson <nickm@torproject.org>
Date:   Wed,  3 Jan 2018 08:59:59 -0500

Merge branch 'maint-0.3.0' into maint-0.3.1

Diffstat:
Achanges/bug24633 | 5+++++
Msrc/ext/timeouts/timeout-bitops.c | 4++--
2 files changed, 7 insertions(+), 2 deletions(-)

diff --git a/changes/bug24633 b/changes/bug24633 @@ -0,0 +1,5 @@ + o Minor bugfixes (portability, msvc): + - Fix a bug in the bit-counting parts of our timing-wheel code on + MSVC. (Note that MSVC is still not a supported build platform, + due to cyptographic timing channel risks.) Fixes bug 24633; + bugfix on 0.2.9.1-alpha. diff --git a/src/ext/timeouts/timeout-bitops.c b/src/ext/timeouts/timeout-bitops.c @@ -40,7 +40,7 @@ static __inline int clz32(unsigned long val) { DWORD zeros = 0; _BitScanReverse(&zeros, val); - return zeros; + return 31 - zeros; } #ifdef _WIN64 /* According to the documentation, these only exist on Win64. */ @@ -54,7 +54,7 @@ static __inline int clz64(uint64_t val) { DWORD zeros = 0; _BitScanReverse64(&zeros, val); - return zeros; + return 63 - zeros; } #else static __inline int ctz64(uint64_t val)