• Zhi An Ng's avatar
    [x64][wasm-simd] Pattern match 32x4 rotate · 7c98abdb
    Zhi An Ng authored
    Code like:
    
      x = wasm_v32x4_shuffle(x, x, 1, 2, 3, 0);
    
    is currently matched by S8x16Concat, which lowers to two instructions:
    
      movapd xmm_dst, xmm_src
      palignr xmm_dst, xmm_src, 0x4
    
    There is a special case after a S8x16Concat is matched:.
    
    - is_swizzle, the inputs are the same
    - it is a 32x4 shuffle (offset % 4 == 0)
    
    Which can have a better codegen:
    
    - (dst == src) shufps dst, src, 0b00111001
    - (dst != src) pshufd dst, src, 0b00111001
    
    Add a new simd shuffle matcher which will match 32x4 rotate, and
    construct the appropriate indices referring to the 32x4 elements.
    
    pshufd for the given example. However, this matching happens after
    S8x16Concat, so we get the palignr first. We could move the pattern
    matching cases around, but it will lead to some cases where
    where it would have matched a S8x16Concat, but now matches a
    S32x4shuffle instead, leading to worse codegen.
    
    Note: we also pattern match on 32x4Swizzle, which correctly generates
    Change-Id: Ie3aca53bbc06826be2cf49632de4c24ec73d0a9a
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2589062Reviewed-by: 's avatarBill Budge <bbudge@chromium.org>
    Commit-Queue: Zhi An Ng <zhin@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#71754}
    7c98abdb
Name
Last commit
Last update
..
api Loading commit data...
asmjs Loading commit data...
ast Loading commit data...
base Loading commit data...
builtins Loading commit data...
codegen Loading commit data...
common Loading commit data...
compiler Loading commit data...
compiler-dispatcher Loading commit data...
d8 Loading commit data...
date Loading commit data...
debug Loading commit data...
deoptimizer Loading commit data...
diagnostics Loading commit data...
execution Loading commit data...
extensions Loading commit data...
flags Loading commit data...
handles Loading commit data...
heap Loading commit data...
ic Loading commit data...
init Loading commit data...
inspector Loading commit data...
interpreter Loading commit data...
json Loading commit data...
libplatform Loading commit data...
libsampler Loading commit data...
logging Loading commit data...
numbers Loading commit data...
objects Loading commit data...
parsing Loading commit data...
profiler Loading commit data...
protobuf Loading commit data...
regexp Loading commit data...
roots Loading commit data...
runtime Loading commit data...
sanitizer Loading commit data...
snapshot Loading commit data...
strings Loading commit data...
tasks Loading commit data...
third_party Loading commit data...
torque Loading commit data...
tracing Loading commit data...
trap-handler Loading commit data...
utils Loading commit data...
wasm Loading commit data...
zone Loading commit data...
DEPS Loading commit data...
DIR_METADATA Loading commit data...
OWNERS Loading commit data...