| Index: src/compiler/wasm-compiler.cc
|
| diff --git a/src/compiler/wasm-compiler.cc b/src/compiler/wasm-compiler.cc
|
| index 0e886cf75acb13655b4c3f2e34b2c6f6f75b76b2..d3d21eb8d69a04d80dc8093a0224ca710ab07aa5 100644
|
| --- a/src/compiler/wasm-compiler.cc
|
| +++ b/src/compiler/wasm-compiler.cc
|
| @@ -3124,9 +3124,6 @@ Node* WasmGraphBuilder::SimdOp(wasm::WasmOpcode opcode,
|
| case wasm::kExprI32x4Add:
|
| return graph()->NewNode(jsgraph()->machine()->Int32x4Add(), inputs[0],
|
| inputs[1]);
|
| - case wasm::kExprF32x4ExtractLane:
|
| - return graph()->NewNode(jsgraph()->machine()->Float32x4ExtractLane(),
|
| - inputs[0], inputs[1]);
|
| case wasm::kExprF32x4Splat:
|
| return graph()->NewNode(jsgraph()->machine()->CreateFloat32x4(),
|
| inputs[0], inputs[0], inputs[0], inputs[0]);
|
| @@ -3152,6 +3149,20 @@ Node* WasmGraphBuilder::SimdExtractLane(wasm::WasmOpcode opcode, uint8_t lane,
|
| }
|
| }
|
|
|
| +Node* WasmGraphBuilder::SimdReplaceLane(wasm::WasmOpcode opcode, uint8_t lane,
|
| + Node* input, Node* replacement) {
|
| + switch (opcode) {
|
| + case wasm::kExprI32x4ReplaceLane:
|
| + return graph()->NewNode(jsgraph()->machine()->Int32x4ReplaceLane(), input,
|
| + Int32Constant(lane), replacement);
|
| + case wasm::kExprF32x4ReplaceLane:
|
| + return graph()->NewNode(jsgraph()->machine()->Float32x4ReplaceLane(),
|
| + input, Int32Constant(lane), replacement);
|
| + default:
|
| + return graph()->NewNode(UnsupportedOpcode(opcode), nullptr);
|
| + }
|
| +}
|
| +
|
| static void RecordFunctionCompilation(CodeEventListener::LogEventsAndTags tag,
|
| Isolate* isolate, Handle<Code> code,
|
| const char* message, uint32_t index,
|
|
|