• Ng Zhi An's avatar
    [wasm-simd][x64] Optimize f32x4 splat and extract lanes · 4068b3d2
    Ng Zhi An authored
    For splats, we can make use of vshufps to avoid a movss. Without
    AVX, specific dst to be same as src in the instruction selector.
    
    For extract lane, we can use vshufps to extract a float into a dst xmm,
    and leave junk in the higher bits.
    
    On the meshopt_decoder.js benchmark in linked bug, it removes about 7
    movss instructions that did nothing. Hardware can do register renaming,
    but let's not rely on that :)
    
    R=bbudge@chromium.org
    
    Bug: v8:10116
    Change-Id: I4d68c10536a79659de673060d537d58113308477
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2481473
    Commit-Queue: Zhi An Ng <zhin@chromium.org>
    Reviewed-by: 's avatarBill Budge <bbudge@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#70628}
    4068b3d2
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...
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...