• Zhi An Ng's avatar
    [x64][ia32][wasm-simd] Optimize v128.bitselect · 8e9ad4f8
    Zhi An Ng authored
    Couple of optimizations for v128.bitselect on both ia32 and x64.
    
    1. Remove an extra movaps when AVX is supported, since we have 3-operand
    instructions
    2. Tweak the algorithm from:
         xor(and(xor(src1, src2), mask) src2)
    
       To:
         or(and(src1, mask), andnot(src2, mask))
       It is easier to read and understand, and also eliminate a dependency
       chain (on kScratchDoubleReg) in the older algorithm.
    3. Use integer forms of the logical ops. Older processors have higher
    throughput on these, compared to the floating point ops. However, the
    integer forms are 1 byte longer, so on SSE, we stick to the floating
    point ops.
    
    For AVX, this reduces instruction count from 9948 to 9868.
    
    Change-Id: Idd5d26b99a76255dbfa63e2c304e6af3760c4ec6
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2591859Reviewed-by: 's avatarBill Budge <bbudge@chromium.org>
    Commit-Queue: Zhi An Ng <zhin@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#71845}
    8e9ad4f8
Name
Last commit
Last update
..
arm Loading commit data...
arm64 Loading commit data...
ia32 Loading commit data...
mips Loading commit data...
mips64 Loading commit data...
ppc Loading commit data...
s390 Loading commit data...
x64 Loading commit data...
DIR_METADATA Loading commit data...
OWNERS Loading commit data...
code-generator-impl.h Loading commit data...
code-generator.cc Loading commit data...
code-generator.h Loading commit data...
frame-elider.cc Loading commit data...
frame-elider.h Loading commit data...
gap-resolver.cc Loading commit data...
gap-resolver.h Loading commit data...
instruction-codes.h Loading commit data...
instruction-scheduler.cc Loading commit data...
instruction-scheduler.h Loading commit data...
instruction-selector-impl.h Loading commit data...
instruction-selector.cc Loading commit data...
instruction-selector.h Loading commit data...
instruction.cc Loading commit data...
instruction.h Loading commit data...
jump-threading.cc Loading commit data...
jump-threading.h Loading commit data...
mid-tier-register-allocator.cc Loading commit data...
mid-tier-register-allocator.h Loading commit data...
move-optimizer.cc Loading commit data...
move-optimizer.h Loading commit data...
register-allocation.h Loading commit data...
register-allocator-verifier.cc Loading commit data...
register-allocator-verifier.h Loading commit data...
register-allocator.cc Loading commit data...
register-allocator.h Loading commit data...
spill-placer.cc Loading commit data...
spill-placer.h Loading commit data...
unwinding-info-writer.h Loading commit data...