Commit 6f52d980 authored by jing.bao's avatar jing.bao Committed by Commit Bot

[ia32][wasm] Add S128 Zero/Not/And/Or/Xor

Bug: 
Change-Id: I0868da7ee73f1c7637d9c79b6c78f27557cd14a4
Reviewed-on: https://chromium-review.googlesource.com/792653Reviewed-by: 's avatarBenedikt Meurer <bmeurer@chromium.org>
Reviewed-by: 's avatarBill Budge <bbudge@chromium.org>
Commit-Queue: Jing Bao <jing.bao@intel.com>
Cr-Commit-Position: refs/heads/master@{#49774}
parent d84efe12
...@@ -2774,6 +2774,63 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -2774,6 +2774,63 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
__ vpcmpeqb(i.OutputSimd128Register(), kScratchDoubleReg, src2); __ vpcmpeqb(i.OutputSimd128Register(), kScratchDoubleReg, src2);
break; break;
} }
case kIA32S128Zero: {
XMMRegister dst = i.OutputSimd128Register();
__ Pxor(dst, dst);
break;
}
case kSSES128Not: {
XMMRegister dst = i.OutputSimd128Register();
Operand src = i.InputOperand(0);
if (src.is_reg(dst)) {
__ movaps(kScratchDoubleReg, dst);
__ pcmpeqd(dst, dst);
__ pxor(dst, kScratchDoubleReg);
} else {
__ pcmpeqd(dst, dst);
__ pxor(dst, src);
}
break;
}
case kAVXS128Not: {
CpuFeatureScope avx_scope(tasm(), AVX);
__ vpcmpeqd(kScratchDoubleReg, kScratchDoubleReg, kScratchDoubleReg);
__ vpxor(i.OutputSimd128Register(), kScratchDoubleReg, i.InputOperand(0));
break;
}
case kSSES128And: {
DCHECK_EQ(i.OutputSimd128Register(), i.InputSimd128Register(0));
__ pand(i.OutputSimd128Register(), i.InputOperand(1));
break;
}
case kAVXS128And: {
CpuFeatureScope avx_scope(tasm(), AVX);
__ vpand(i.OutputSimd128Register(), i.InputSimd128Register(0),
i.InputOperand(1));
break;
}
case kSSES128Or: {
DCHECK_EQ(i.OutputSimd128Register(), i.InputSimd128Register(0));
__ por(i.OutputSimd128Register(), i.InputOperand(1));
break;
}
case kAVXS128Or: {
CpuFeatureScope avx_scope(tasm(), AVX);
__ vpor(i.OutputSimd128Register(), i.InputSimd128Register(0),
i.InputOperand(1));
break;
}
case kSSES128Xor: {
DCHECK_EQ(i.OutputSimd128Register(), i.InputSimd128Register(0));
__ pxor(i.OutputSimd128Register(), i.InputOperand(1));
break;
}
case kAVXS128Xor: {
CpuFeatureScope avx_scope(tasm(), AVX);
__ vpxor(i.OutputSimd128Register(), i.InputSimd128Register(0),
i.InputOperand(1));
break;
}
case kCheckedLoadInt8: case kCheckedLoadInt8:
ASSEMBLE_CHECKED_LOAD_INTEGER(movsx_b); ASSEMBLE_CHECKED_LOAD_INTEGER(movsx_b);
break; break;
......
...@@ -229,7 +229,16 @@ namespace compiler { ...@@ -229,7 +229,16 @@ namespace compiler {
V(SSEI8x16GtU) \ V(SSEI8x16GtU) \
V(AVXI8x16GtU) \ V(AVXI8x16GtU) \
V(SSEI8x16GeU) \ V(SSEI8x16GeU) \
V(AVXI8x16GeU) V(AVXI8x16GeU) \
V(IA32S128Zero) \
V(SSES128Not) \
V(AVXS128Not) \
V(SSES128And) \
V(AVXS128And) \
V(SSES128Or) \
V(AVXS128Or) \
V(SSES128Xor) \
V(AVXS128Xor)
// Addressing modes represent the "shape" of inputs to an instruction. // Addressing modes represent the "shape" of inputs to an instruction.
// Many instructions support multiple addressing modes. Addressing modes // Many instructions support multiple addressing modes. Addressing modes
......
...@@ -216,6 +216,15 @@ int InstructionScheduler::GetTargetInstructionFlags( ...@@ -216,6 +216,15 @@ int InstructionScheduler::GetTargetInstructionFlags(
case kAVXI8x16GtU: case kAVXI8x16GtU:
case kSSEI8x16GeU: case kSSEI8x16GeU:
case kAVXI8x16GeU: case kAVXI8x16GeU:
case kIA32S128Zero:
case kSSES128Not:
case kAVXS128Not:
case kSSES128And:
case kAVXS128And:
case kSSES128Or:
case kAVXS128Or:
case kSSES128Xor:
case kAVXS128Xor:
return (instr->addressing_mode() == kMode_None) return (instr->addressing_mode() == kMode_None)
? kNoOpcodeFlags ? kNoOpcodeFlags
: kIsLoadOperation | kHasSideEffect; : kIsLoadOperation | kHasSideEffect;
......
...@@ -1948,7 +1948,10 @@ VISIT_ATOMIC_BINOP(Xor) ...@@ -1948,7 +1948,10 @@ VISIT_ATOMIC_BINOP(Xor)
V(I8x16MinU) \ V(I8x16MinU) \
V(I8x16MaxU) \ V(I8x16MaxU) \
V(I8x16GtU) \ V(I8x16GtU) \
V(I8x16GeU) V(I8x16GeU) \
V(S128And) \
V(S128Or) \
V(S128Xor)
#define SIMD_UNOP_LIST(V) \ #define SIMD_UNOP_LIST(V) \
V(I32x4Neg) \ V(I32x4Neg) \
...@@ -1963,6 +1966,17 @@ VISIT_ATOMIC_BINOP(Xor) ...@@ -1963,6 +1966,17 @@ VISIT_ATOMIC_BINOP(Xor)
V(I16x8ShrS) \ V(I16x8ShrS) \
V(I16x8ShrU) V(I16x8ShrU)
void InstructionSelector::VisitS128Zero(Node* node) {
IA32OperandGenerator g(this);
Emit(kIA32S128Zero, g.DefineAsRegister(node));
}
void InstructionSelector::VisitS128Not(Node* node) {
IA32OperandGenerator g(this);
InstructionCode opcode = IsSupported(AVX) ? kAVXS128Not : kSSES128Not;
Emit(opcode, g.DefineAsRegister(node), g.Use(node->InputAt(0)));
}
#define VISIT_SIMD_SPLAT(Type) \ #define VISIT_SIMD_SPLAT(Type) \
void InstructionSelector::Visit##Type##Splat(Node* node) { \ void InstructionSelector::Visit##Type##Splat(Node* node) { \
VisitRO(this, node, kIA32##Type##Splat); \ VisitRO(this, node, kIA32##Type##Splat); \
......
...@@ -2410,12 +2410,7 @@ void InstructionSelector::VisitI8x16MaxU(Node* node) { UNIMPLEMENTED(); } ...@@ -2410,12 +2410,7 @@ void InstructionSelector::VisitI8x16MaxU(Node* node) { UNIMPLEMENTED(); }
void InstructionSelector::VisitI8x16GtU(Node* node) { UNIMPLEMENTED(); } void InstructionSelector::VisitI8x16GtU(Node* node) { UNIMPLEMENTED(); }
void InstructionSelector::VisitI8x16GeU(Node* node) { UNIMPLEMENTED(); } void InstructionSelector::VisitI8x16GeU(Node* node) { UNIMPLEMENTED(); }
#endif // !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_X64
// && !V8_TARGET_ARCH_IA32 && !V8_TARGET_ARCH_MIPS &&
// !V8_TARGET_ARCH_MIPS64
#if !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_X64 && \
!V8_TARGET_ARCH_MIPS && !V8_TARGET_ARCH_MIPS64
void InstructionSelector::VisitS128And(Node* node) { UNIMPLEMENTED(); } void InstructionSelector::VisitS128And(Node* node) { UNIMPLEMENTED(); }
void InstructionSelector::VisitS128Or(Node* node) { UNIMPLEMENTED(); } void InstructionSelector::VisitS128Or(Node* node) { UNIMPLEMENTED(); }
...@@ -2425,7 +2420,12 @@ void InstructionSelector::VisitS128Xor(Node* node) { UNIMPLEMENTED(); } ...@@ -2425,7 +2420,12 @@ void InstructionSelector::VisitS128Xor(Node* node) { UNIMPLEMENTED(); }
void InstructionSelector::VisitS128Not(Node* node) { UNIMPLEMENTED(); } void InstructionSelector::VisitS128Not(Node* node) { UNIMPLEMENTED(); }
void InstructionSelector::VisitS128Zero(Node* node) { UNIMPLEMENTED(); } void InstructionSelector::VisitS128Zero(Node* node) { UNIMPLEMENTED(); }
#endif // !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_X64
// && !V8_TARGET_ARCH_IA32 && !V8_TARGET_ARCH_MIPS &&
// !V8_TARGET_ARCH_MIPS64
#if !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_X64 && \
!V8_TARGET_ARCH_MIPS && !V8_TARGET_ARCH_MIPS64
void InstructionSelector::VisitS128Select(Node* node) { UNIMPLEMENTED(); } void InstructionSelector::VisitS128Select(Node* node) { UNIMPLEMENTED(); }
#endif // !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_X64 #endif // !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_X64
// && !V8_TARGET_ARCH_MIPS && !V8_TARGET_ARCH_MIPS64 // && !V8_TARGET_ARCH_MIPS && !V8_TARGET_ARCH_MIPS64
......
...@@ -935,9 +935,11 @@ WASM_SIMD_TEST(I32x4Neg) { ...@@ -935,9 +935,11 @@ WASM_SIMD_TEST(I32x4Neg) {
RunI32x4UnOpTest(execution_mode, kExprI32x4Neg, Negate); RunI32x4UnOpTest(execution_mode, kExprI32x4Neg, Negate);
} }
#if V8_TARGET_ARCH_ARM || V8_TARGET_ARCH_ARM64 || V8_TARGET_ARCH_X64 #if V8_TARGET_ARCH_ARM || V8_TARGET_ARCH_ARM64 || V8_TARGET_ARCH_X64 || \
V8_TARGET_ARCH_IA32
WASM_SIMD_TEST(S128Not) { RunI32x4UnOpTest(execution_mode, kExprS128Not, Not); } WASM_SIMD_TEST(S128Not) { RunI32x4UnOpTest(execution_mode, kExprS128Not, Not); }
#endif // V8_TARGET_ARCH_ARM || V8_TARGET_ARCH_ARM64 || V8_TARGET_ARCH_X64 #endif // V8_TARGET_ARCH_ARM || V8_TARGET_ARCH_ARM64 || V8_TARGET_ARCH_X64 ||
// V8_TARGET_ARCH_IA32
void RunI32x4BinOpTest(WasmExecutionMode execution_mode, WasmOpcode simd_op, void RunI32x4BinOpTest(WasmExecutionMode execution_mode, WasmOpcode simd_op,
Int32BinOp expected_op) { Int32BinOp expected_op) {
...@@ -986,8 +988,6 @@ WASM_SIMD_TEST(I32x4MaxU) { ...@@ -986,8 +988,6 @@ WASM_SIMD_TEST(I32x4MaxU) {
RunI32x4BinOpTest(execution_mode, kExprI32x4MaxU, UnsignedMaximum); RunI32x4BinOpTest(execution_mode, kExprI32x4MaxU, UnsignedMaximum);
} }
#if V8_TARGET_ARCH_ARM || V8_TARGET_ARCH_ARM64 || V8_TARGET_ARCH_X64 || \
V8_TARGET_ARCH_MIPS || V8_TARGET_ARCH_MIPS64
WASM_SIMD_TEST(S128And) { WASM_SIMD_TEST(S128And) {
RunI32x4BinOpTest(execution_mode, kExprS128And, And); RunI32x4BinOpTest(execution_mode, kExprS128And, And);
} }
...@@ -997,8 +997,6 @@ WASM_SIMD_TEST(S128Or) { RunI32x4BinOpTest(execution_mode, kExprS128Or, Or); } ...@@ -997,8 +997,6 @@ WASM_SIMD_TEST(S128Or) { RunI32x4BinOpTest(execution_mode, kExprS128Or, Or); }
WASM_SIMD_TEST(S128Xor) { WASM_SIMD_TEST(S128Xor) {
RunI32x4BinOpTest(execution_mode, kExprS128Xor, Xor); RunI32x4BinOpTest(execution_mode, kExprS128Xor, Xor);
} }
#endif // V8_TARGET_ARCH_ARM || V8_TARGET_ARCH_ARM64 || V8_TARGET_ARCH_X64 ||
// V8_TARGET_ARCH_MIPS || V8_TARGET_ARCH_MIPS64
void RunI32x4CompareOpTest(WasmExecutionMode execution_mode, WasmOpcode simd_op, void RunI32x4CompareOpTest(WasmExecutionMode execution_mode, WasmOpcode simd_op,
Int32CompareOp expected_op) { Int32CompareOp expected_op) {
......
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