• Ng Zhi An's avatar
    [wasm-simd] Optimize codegen when shift is constant · 19be4913
    Ng Zhi An authored
    Define a macro in code-generator-x64 to help identify cases when the
    shift value is an immediate/constant. In those cases we can directly
    emit the shifts without any masking, since the instruction selector
    would have modulo-ed the shift value. We also don't need any temporaries
    in this case.
    
    This is only x64 codegen, optimizations for other archs will come in
    future patches (and will probably look very similar to this).
    
    The current test case passes the shifts as an immediate, so we add a new
    path that loads the shift value from memory, thereby exercising the
    slower path of non-immediate shift value.
    
    Bug: v8:10115
    Change-Id: Iaf13d81595714882a8f5418734e031b8bc654af3
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2026067Reviewed-by: 's avatarDeepti Gandluri <gdeepti@chromium.org>
    Commit-Queue: Zhi An Ng <zhin@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#66074}
    19be4913
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...
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...
live-range-separator.cc Loading commit data...
live-range-separator.h Loading commit data...
move-optimizer.cc Loading commit data...
move-optimizer.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...
unwinding-info-writer.h Loading commit data...