• Clemens Hammacher's avatar
    [bits] Consolidate Count{Leading,Trailing}Zeros · 7d231e57
    Clemens Hammacher authored
    Instead of having one method for 32 bit integers and one for 64 bit,
    plus a templatized version to choose from those two, just implement one
    version which handles unsigned integers of any size. Also, make them
    constexpr.
    The Count{Leading,Trailing}Zeros{32,64} methods are kept for now in
    order to keep the amount of code changes small. Also, sometimes it
    improves readability by stating exactly the size of the argument,
    especially for leading zeros (where zero-extending would add more
    leading zeros).
    
    CountLeadingZeros now uses a binary search inspired implementation
    as proposed in Hacker's Delight. It's more than 20% faster on x64 if
    the builtins are disabled.
    CountTrailingZeros falls back to CountPopulation instead of counting in
    a naive loop. This is ~50% faster.
    
    R=mstarzinger@chromium.org
    
    Change-Id: I1d8bf1d7295b930724163248150444bd17fbb34e
    Reviewed-on: https://chromium-review.googlesource.com/741231Reviewed-by: 's avatarMichael Starzinger <mstarzinger@chromium.org>
    Commit-Queue: Clemens Hammacher <clemensh@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#49106}
    7d231e57
Name
Last commit
Last update
..
benchmarks Loading commit data...
cctest Loading commit data...
common Loading commit data...
debugger Loading commit data...
fuzzer Loading commit data...
inspector Loading commit data...
intl Loading commit data...
js-perf-test Loading commit data...
memory Loading commit data...
message Loading commit data...
mjsunit Loading commit data...
mkgrokdump Loading commit data...
mozilla Loading commit data...
preparser Loading commit data...
promises-aplus Loading commit data...
test262 Loading commit data...
unittests Loading commit data...
wasm-spec-tests Loading commit data...
webkit Loading commit data...
BUILD.gn Loading commit data...
bot_default.gyp Loading commit data...
bot_default.isolate Loading commit data...
default.gyp Loading commit data...
default.isolate Loading commit data...
optimize_for_size.gyp Loading commit data...
optimize_for_size.isolate Loading commit data...
perf.gyp Loading commit data...
perf.isolate Loading commit data...