Commit b9de3af6 authored by Predrag Rudic's avatar Predrag Rudic Committed by Commit Bot

[wasm] Add big endian support for S8x16Shuffle

Change-Id: Id661452207cd65445e7390d86f5379b1cc4f1495
Reviewed-on: https://chromium-review.googlesource.com/988012Reviewed-by: 's avatarBill Budge <bbudge@chromium.org>
Commit-Queue: Ivica Bogosavljevic <ivica.bogosavljevic@mips.com>
Cr-Commit-Position: refs/heads/master@{#52381}
parent 4d595e02
...@@ -1181,7 +1181,12 @@ void SimdScalarLowering::LowerNode(Node* node) { ...@@ -1181,7 +1181,12 @@ void SimdScalarLowering::LowerNode(Node* node) {
Node** rep_node = zone()->NewArray<Node*>(16); Node** rep_node = zone()->NewArray<Node*>(16);
for (int i = 0; i < 16; i++) { for (int i = 0; i < 16; i++) {
int lane = shuffle[i]; int lane = shuffle[i];
#if defined(V8_TARGET_BIG_ENDIAN)
rep_node[15 - i] =
lane < 16 ? rep_left[15 - lane] : rep_right[31 - lane];
#else
rep_node[i] = lane < 16 ? rep_left[lane] : rep_right[lane - 16]; rep_node[i] = lane < 16 ? rep_left[lane] : rep_right[lane - 16];
#endif
} }
ReplaceNode(node, rep_node, 16); ReplaceNode(node, rep_node, 16);
break; break;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment