| Index: src/compiler/s390/instruction-selector-s390.cc
|
| diff --git a/src/compiler/ppc/instruction-selector-ppc.cc b/src/compiler/s390/instruction-selector-s390.cc
|
| similarity index 80%
|
| copy from src/compiler/ppc/instruction-selector-ppc.cc
|
| copy to src/compiler/s390/instruction-selector-s390.cc
|
| index e89506262489db0fa0565240426396571f22d73a..179d88e85751a0c04e024a4138488ed5d3d8237e 100644
|
| --- a/src/compiler/ppc/instruction-selector-ppc.cc
|
| +++ b/src/compiler/s390/instruction-selector-s390.cc
|
| @@ -1,4 +1,4 @@
|
| -// Copyright 2014 the V8 project authors. All rights reserved.
|
| +// Copyright 2015 the V8 project authors. All rights reserved.
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| @@ -6,7 +6,7 @@
|
| #include "src/compiler/instruction-selector-impl.h"
|
| #include "src/compiler/node-matchers.h"
|
| #include "src/compiler/node-properties.h"
|
| -#include "src/ppc/frames-ppc.h"
|
| +#include "src/s390/frames-s390.h"
|
|
|
| namespace v8 {
|
| namespace internal {
|
| @@ -22,11 +22,10 @@ enum ImmediateMode {
|
| kNoImmediate
|
| };
|
|
|
| -
|
| -// Adds PPC-specific methods for generating operands.
|
| -class PPCOperandGenerator final : public OperandGenerator {
|
| +// Adds S390-specific methods for generating operands.
|
| +class S390OperandGenerator final : public OperandGenerator {
|
| public:
|
| - explicit PPCOperandGenerator(InstructionSelector* selector)
|
| + explicit S390OperandGenerator(InstructionSelector* selector)
|
| : OperandGenerator(selector) {}
|
|
|
| InstructionOperand UseOperand(Node* node, ImmediateMode mode) {
|
| @@ -68,37 +67,33 @@ class PPCOperandGenerator final : public OperandGenerator {
|
| }
|
| };
|
|
|
| -
|
| namespace {
|
|
|
| void VisitRR(InstructionSelector* selector, ArchOpcode opcode, Node* node) {
|
| - PPCOperandGenerator g(selector);
|
| + S390OperandGenerator g(selector);
|
| selector->Emit(opcode, g.DefineAsRegister(node),
|
| g.UseRegister(node->InputAt(0)));
|
| }
|
|
|
| -
|
| void VisitRRR(InstructionSelector* selector, ArchOpcode opcode, Node* node) {
|
| - PPCOperandGenerator g(selector);
|
| + S390OperandGenerator g(selector);
|
| selector->Emit(opcode, g.DefineAsRegister(node),
|
| g.UseRegister(node->InputAt(0)),
|
| g.UseRegister(node->InputAt(1)));
|
| }
|
|
|
| -
|
| void VisitRRO(InstructionSelector* selector, ArchOpcode opcode, Node* node,
|
| ImmediateMode operand_mode) {
|
| - PPCOperandGenerator g(selector);
|
| + S390OperandGenerator g(selector);
|
| selector->Emit(opcode, g.DefineAsRegister(node),
|
| g.UseRegister(node->InputAt(0)),
|
| g.UseOperand(node->InputAt(1), operand_mode));
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void VisitTryTruncateDouble(InstructionSelector* selector, ArchOpcode opcode,
|
| Node* node) {
|
| - PPCOperandGenerator g(selector);
|
| + S390OperandGenerator g(selector);
|
| InstructionOperand inputs[] = {g.UseRegister(node->InputAt(0))};
|
| InstructionOperand outputs[2];
|
| size_t output_count = 0;
|
| @@ -113,13 +108,12 @@ void VisitTryTruncateDouble(InstructionSelector* selector, ArchOpcode opcode,
|
| }
|
| #endif
|
|
|
| -
|
| // Shared routine for multiple binary operations.
|
| template <typename Matcher>
|
| void VisitBinop(InstructionSelector* selector, Node* node,
|
| InstructionCode opcode, ImmediateMode operand_mode,
|
| FlagsContinuation* cont) {
|
| - PPCOperandGenerator g(selector);
|
| + S390OperandGenerator g(selector);
|
| Matcher m(node);
|
| InstructionOperand inputs[4];
|
| size_t input_count = 0;
|
| @@ -153,7 +147,6 @@ void VisitBinop(InstructionSelector* selector, Node* node,
|
| }
|
| }
|
|
|
| -
|
| // Shared routine for multiple binary operations.
|
| template <typename Matcher>
|
| void VisitBinop(InstructionSelector* selector, Node* node, ArchOpcode opcode,
|
| @@ -164,46 +157,45 @@ void VisitBinop(InstructionSelector* selector, Node* node, ArchOpcode opcode,
|
|
|
| } // namespace
|
|
|
| -
|
| void InstructionSelector::VisitLoad(Node* node) {
|
| LoadRepresentation load_rep = LoadRepresentationOf(node->op());
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Node* base = node->InputAt(0);
|
| Node* offset = node->InputAt(1);
|
| ArchOpcode opcode = kArchNop;
|
| ImmediateMode mode = kInt16Imm;
|
| switch (load_rep.representation()) {
|
| case MachineRepresentation::kFloat32:
|
| - opcode = kPPC_LoadFloat32;
|
| + opcode = kS390_LoadFloat32;
|
| break;
|
| case MachineRepresentation::kFloat64:
|
| - opcode = kPPC_LoadDouble;
|
| + opcode = kS390_LoadDouble;
|
| break;
|
| case MachineRepresentation::kBit: // Fall through.
|
| case MachineRepresentation::kWord8:
|
| - opcode = load_rep.IsSigned() ? kPPC_LoadWordS8 : kPPC_LoadWordU8;
|
| + opcode = load_rep.IsSigned() ? kS390_LoadWordS8 : kS390_LoadWordU8;
|
| break;
|
| case MachineRepresentation::kWord16:
|
| - opcode = load_rep.IsSigned() ? kPPC_LoadWordS16 : kPPC_LoadWordU16;
|
| + opcode = load_rep.IsSigned() ? kS390_LoadWordS16 : kS390_LoadWordU16;
|
| break;
|
| -#if !V8_TARGET_ARCH_PPC64
|
| +#if !V8_TARGET_ARCH_S390X
|
| case MachineRepresentation::kTagged: // Fall through.
|
| #endif
|
| case MachineRepresentation::kWord32:
|
| - opcode = kPPC_LoadWordS32;
|
| -#if V8_TARGET_ARCH_PPC64
|
| - // TODO(mbrandy): this applies to signed loads only (lwa)
|
| + opcode = kS390_LoadWordS32;
|
| +#if V8_TARGET_ARCH_S390X
|
| + // TODO(john.yan): Remove this mode since s390 do not has this restriction
|
| mode = kInt16Imm_4ByteAligned;
|
| #endif
|
| break;
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| case MachineRepresentation::kTagged: // Fall through.
|
| case MachineRepresentation::kWord64:
|
| - opcode = kPPC_LoadWord64;
|
| + opcode = kS390_LoadWord64;
|
| mode = kInt16Imm_4ByteAligned;
|
| break;
|
| #else
|
| - case MachineRepresentation::kWord64: // Fall through.
|
| + case MachineRepresentation::kWord64: // Fall through.
|
| #endif
|
| case MachineRepresentation::kSimd128: // Fall through.
|
| case MachineRepresentation::kNone:
|
| @@ -222,9 +214,8 @@ void InstructionSelector::VisitLoad(Node* node) {
|
| }
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitStore(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Node* base = node->InputAt(0);
|
| Node* offset = node->InputAt(1);
|
| Node* value = node->InputAt(2);
|
| @@ -239,10 +230,10 @@ void InstructionSelector::VisitStore(Node* node) {
|
| InstructionOperand inputs[3];
|
| size_t input_count = 0;
|
| inputs[input_count++] = g.UseUniqueRegister(base);
|
| - // OutOfLineRecordWrite uses the offset in an 'add' instruction as well as
|
| + // OutOfLineRecordWrite uses the offset in an 'AddP' instruction as well as
|
| // for the store itself, so we must check compatibility with both.
|
| if (g.CanBeImmediate(offset, kInt16Imm)
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| && g.CanBeImmediate(offset, kInt16Imm_4ByteAligned)
|
| #endif
|
| ) {
|
| @@ -281,28 +272,28 @@ void InstructionSelector::VisitStore(Node* node) {
|
| ImmediateMode mode = kInt16Imm;
|
| switch (rep) {
|
| case MachineRepresentation::kFloat32:
|
| - opcode = kPPC_StoreFloat32;
|
| + opcode = kS390_StoreFloat32;
|
| break;
|
| case MachineRepresentation::kFloat64:
|
| - opcode = kPPC_StoreDouble;
|
| + opcode = kS390_StoreDouble;
|
| break;
|
| case MachineRepresentation::kBit: // Fall through.
|
| case MachineRepresentation::kWord8:
|
| - opcode = kPPC_StoreWord8;
|
| + opcode = kS390_StoreWord8;
|
| break;
|
| case MachineRepresentation::kWord16:
|
| - opcode = kPPC_StoreWord16;
|
| + opcode = kS390_StoreWord16;
|
| break;
|
| -#if !V8_TARGET_ARCH_PPC64
|
| +#if !V8_TARGET_ARCH_S390X
|
| case MachineRepresentation::kTagged: // Fall through.
|
| #endif
|
| case MachineRepresentation::kWord32:
|
| - opcode = kPPC_StoreWord32;
|
| + opcode = kS390_StoreWord32;
|
| break;
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| case MachineRepresentation::kTagged: // Fall through.
|
| case MachineRepresentation::kWord64:
|
| - opcode = kPPC_StoreWord64;
|
| + opcode = kS390_StoreWord64;
|
| mode = kInt16Imm_4ByteAligned;
|
| break;
|
| #else
|
| @@ -326,10 +317,9 @@ void InstructionSelector::VisitStore(Node* node) {
|
| }
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitCheckedLoad(Node* node) {
|
| CheckedLoadRepresentation load_rep = CheckedLoadRepresentationOf(node->op());
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Node* const base = node->InputAt(0);
|
| Node* const offset = node->InputAt(1);
|
| Node* const length = node->InputAt(2);
|
| @@ -344,7 +334,7 @@ void InstructionSelector::VisitCheckedLoad(Node* node) {
|
| case MachineRepresentation::kWord32:
|
| opcode = kCheckedLoadWord32;
|
| break;
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| case MachineRepresentation::kWord64:
|
| opcode = kCheckedLoadWord64;
|
| break;
|
| @@ -357,7 +347,7 @@ void InstructionSelector::VisitCheckedLoad(Node* node) {
|
| break;
|
| case MachineRepresentation::kBit: // Fall through.
|
| case MachineRepresentation::kTagged: // Fall through.
|
| -#if !V8_TARGET_ARCH_PPC64
|
| +#if !V8_TARGET_ARCH_S390X
|
| case MachineRepresentation::kWord64: // Fall through.
|
| #endif
|
| case MachineRepresentation::kSimd128: // Fall through.
|
| @@ -371,10 +361,9 @@ void InstructionSelector::VisitCheckedLoad(Node* node) {
|
| g.UseOperand(length, kInt16Imm_Unsigned));
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitCheckedStore(Node* node) {
|
| MachineRepresentation rep = CheckedStoreRepresentationOf(node->op());
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Node* const base = node->InputAt(0);
|
| Node* const offset = node->InputAt(1);
|
| Node* const length = node->InputAt(2);
|
| @@ -390,7 +379,7 @@ void InstructionSelector::VisitCheckedStore(Node* node) {
|
| case MachineRepresentation::kWord32:
|
| opcode = kCheckedStoreWord32;
|
| break;
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| case MachineRepresentation::kWord64:
|
| opcode = kCheckedStoreWord64;
|
| break;
|
| @@ -403,7 +392,7 @@ void InstructionSelector::VisitCheckedStore(Node* node) {
|
| break;
|
| case MachineRepresentation::kBit: // Fall through.
|
| case MachineRepresentation::kTagged: // Fall through.
|
| -#if !V8_TARGET_ARCH_PPC64
|
| +#if !V8_TARGET_ARCH_S390X
|
| case MachineRepresentation::kWord64: // Fall through.
|
| #endif
|
| case MachineRepresentation::kSimd128: // Fall through.
|
| @@ -417,21 +406,20 @@ void InstructionSelector::VisitCheckedStore(Node* node) {
|
| g.UseOperand(length, kInt16Imm_Unsigned), g.UseRegister(value));
|
| }
|
|
|
| -
|
| template <typename Matcher>
|
| static void VisitLogical(InstructionSelector* selector, Node* node, Matcher* m,
|
| ArchOpcode opcode, bool left_can_cover,
|
| bool right_can_cover, ImmediateMode imm_mode) {
|
| - PPCOperandGenerator g(selector);
|
| + S390OperandGenerator g(selector);
|
|
|
| // Map instruction to equivalent operation with inverted right input.
|
| ArchOpcode inv_opcode = opcode;
|
| switch (opcode) {
|
| - case kPPC_And:
|
| - inv_opcode = kPPC_AndComplement;
|
| + case kS390_And:
|
| + inv_opcode = kS390_AndComplement;
|
| break;
|
| - case kPPC_Or:
|
| - inv_opcode = kPPC_OrComplement;
|
| + case kS390_Or:
|
| + inv_opcode = kS390_OrComplement;
|
| break;
|
| default:
|
| UNREACHABLE();
|
| @@ -464,7 +452,6 @@ static void VisitLogical(InstructionSelector* selector, Node* node, Matcher* m,
|
| VisitBinop<Matcher>(selector, node, opcode, imm_mode);
|
| }
|
|
|
| -
|
| static inline bool IsContiguousMask32(uint32_t value, int* mb, int* me) {
|
| int mask_width = base::bits::CountPopulation32(value);
|
| int mask_msb = base::bits::CountLeadingZeros32(value);
|
| @@ -476,8 +463,7 @@ static inline bool IsContiguousMask32(uint32_t value, int* mb, int* me) {
|
| return true;
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| static inline bool IsContiguousMask64(uint64_t value, int* mb, int* me) {
|
| int mask_width = base::bits::CountPopulation64(value);
|
| int mask_msb = base::bits::CountLeadingZeros64(value);
|
| @@ -490,10 +476,8 @@ static inline bool IsContiguousMask64(uint64_t value, int* mb, int* me) {
|
| }
|
| #endif
|
|
|
| -
|
| -// TODO(mbrandy): Absorb rotate-right into rlwinm?
|
| void InstructionSelector::VisitWord32And(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Int32BinopMatcher m(node);
|
| int mb = 0;
|
| int me = 0;
|
| @@ -502,7 +486,6 @@ void InstructionSelector::VisitWord32And(Node* node) {
|
| Node* left = m.left().node();
|
| if ((m.left().IsWord32Shr() || m.left().IsWord32Shl()) &&
|
| CanCover(node, left)) {
|
| - // Try to absorb left/right shift into rlwinm
|
| Int32BinopMatcher mleft(m.left().node());
|
| if (mleft.right().IsInRange(0, 31)) {
|
| left = mleft.left().node();
|
| @@ -518,21 +501,20 @@ void InstructionSelector::VisitWord32And(Node* node) {
|
| }
|
| }
|
| if (mb >= me) {
|
| - Emit(kPPC_RotLeftAndMask32, g.DefineAsRegister(node), g.UseRegister(left),
|
| - g.TempImmediate(sh), g.TempImmediate(mb), g.TempImmediate(me));
|
| + Emit(kS390_RotLeftAndMask32, g.DefineAsRegister(node),
|
| + g.UseRegister(left), g.TempImmediate(sh), g.TempImmediate(mb),
|
| + g.TempImmediate(me));
|
| return;
|
| }
|
| }
|
| VisitLogical<Int32BinopMatcher>(
|
| - this, node, &m, kPPC_And, CanCover(node, m.left().node()),
|
| + this, node, &m, kS390_And, CanCover(node, m.left().node()),
|
| CanCover(node, m.right().node()), kInt16Imm_Unsigned);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| -// TODO(mbrandy): Absorb rotate-right into rldic?
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64And(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Int64BinopMatcher m(node);
|
| int mb = 0;
|
| int me = 0;
|
| @@ -541,7 +523,6 @@ void InstructionSelector::VisitWord64And(Node* node) {
|
| Node* left = m.left().node();
|
| if ((m.left().IsWord64Shr() || m.left().IsWord64Shl()) &&
|
| CanCover(node, left)) {
|
| - // Try to absorb left/right shift into rldic
|
| Int64BinopMatcher mleft(m.left().node());
|
| if (mleft.right().IsInRange(0, 63)) {
|
| left = mleft.left().node();
|
| @@ -562,15 +543,15 @@ void InstructionSelector::VisitWord64And(Node* node) {
|
| int mask;
|
| if (me == 0) {
|
| match = true;
|
| - opcode = kPPC_RotLeftAndClearLeft64;
|
| + opcode = kS390_RotLeftAndClearLeft64;
|
| mask = mb;
|
| } else if (mb == 63) {
|
| match = true;
|
| - opcode = kPPC_RotLeftAndClearRight64;
|
| + opcode = kS390_RotLeftAndClearRight64;
|
| mask = me;
|
| } else if (sh && me <= sh && m.left().IsWord64Shl()) {
|
| match = true;
|
| - opcode = kPPC_RotLeftAndClear64;
|
| + opcode = kS390_RotLeftAndClear64;
|
| mask = mb;
|
| }
|
| if (match) {
|
| @@ -581,59 +562,53 @@ void InstructionSelector::VisitWord64And(Node* node) {
|
| }
|
| }
|
| VisitLogical<Int64BinopMatcher>(
|
| - this, node, &m, kPPC_And, CanCover(node, m.left().node()),
|
| + this, node, &m, kS390_And, CanCover(node, m.left().node()),
|
| CanCover(node, m.right().node()), kInt16Imm_Unsigned);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitWord32Or(Node* node) {
|
| Int32BinopMatcher m(node);
|
| VisitLogical<Int32BinopMatcher>(
|
| - this, node, &m, kPPC_Or, CanCover(node, m.left().node()),
|
| + this, node, &m, kS390_Or, CanCover(node, m.left().node()),
|
| CanCover(node, m.right().node()), kInt16Imm_Unsigned);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64Or(Node* node) {
|
| Int64BinopMatcher m(node);
|
| VisitLogical<Int64BinopMatcher>(
|
| - this, node, &m, kPPC_Or, CanCover(node, m.left().node()),
|
| + this, node, &m, kS390_Or, CanCover(node, m.left().node()),
|
| CanCover(node, m.right().node()), kInt16Imm_Unsigned);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitWord32Xor(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Int32BinopMatcher m(node);
|
| if (m.right().Is(-1)) {
|
| - Emit(kPPC_Not, g.DefineAsRegister(node), g.UseRegister(m.left().node()));
|
| + Emit(kS390_Not, g.DefineAsRegister(node), g.UseRegister(m.left().node()));
|
| } else {
|
| - VisitBinop<Int32BinopMatcher>(this, node, kPPC_Xor, kInt16Imm_Unsigned);
|
| + VisitBinop<Int32BinopMatcher>(this, node, kS390_Xor, kInt16Imm_Unsigned);
|
| }
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64Xor(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Int64BinopMatcher m(node);
|
| if (m.right().Is(-1)) {
|
| - Emit(kPPC_Not, g.DefineAsRegister(node), g.UseRegister(m.left().node()));
|
| + Emit(kS390_Not, g.DefineAsRegister(node), g.UseRegister(m.left().node()));
|
| } else {
|
| - VisitBinop<Int64BinopMatcher>(this, node, kPPC_Xor, kInt16Imm_Unsigned);
|
| + VisitBinop<Int64BinopMatcher>(this, node, kS390_Xor, kInt16Imm_Unsigned);
|
| }
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitWord32Shl(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Int32BinopMatcher m(node);
|
| if (m.left().IsWord32And() && m.right().IsInRange(0, 31)) {
|
| - // Try to absorb logical-and into rlwinm
|
| Int32BinopMatcher mleft(m.left().node());
|
| int sh = m.right().Value();
|
| int mb;
|
| @@ -643,24 +618,22 @@ void InstructionSelector::VisitWord32Shl(Node* node) {
|
| // Adjust the mask such that it doesn't include any rotated bits.
|
| if (me < sh) me = sh;
|
| if (mb >= me) {
|
| - Emit(kPPC_RotLeftAndMask32, g.DefineAsRegister(node),
|
| + Emit(kS390_RotLeftAndMask32, g.DefineAsRegister(node),
|
| g.UseRegister(mleft.left().node()), g.TempImmediate(sh),
|
| g.TempImmediate(mb), g.TempImmediate(me));
|
| return;
|
| }
|
| }
|
| }
|
| - VisitRRO(this, kPPC_ShiftLeft32, node, kShift32Imm);
|
| + VisitRRO(this, kS390_ShiftLeft32, node, kShift32Imm);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64Shl(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Int64BinopMatcher m(node);
|
| // TODO(mbrandy): eliminate left sign extension if right >= 32
|
| if (m.left().IsWord64And() && m.right().IsInRange(0, 63)) {
|
| - // Try to absorb logical-and into rldic
|
| Int64BinopMatcher mleft(m.left().node());
|
| int sh = m.right().Value();
|
| int mb;
|
| @@ -675,15 +648,15 @@ void InstructionSelector::VisitWord64Shl(Node* node) {
|
| int mask;
|
| if (me == 0) {
|
| match = true;
|
| - opcode = kPPC_RotLeftAndClearLeft64;
|
| + opcode = kS390_RotLeftAndClearLeft64;
|
| mask = mb;
|
| } else if (mb == 63) {
|
| match = true;
|
| - opcode = kPPC_RotLeftAndClearRight64;
|
| + opcode = kS390_RotLeftAndClearRight64;
|
| mask = me;
|
| } else if (sh && me <= sh) {
|
| match = true;
|
| - opcode = kPPC_RotLeftAndClear64;
|
| + opcode = kS390_RotLeftAndClear64;
|
| mask = mb;
|
| }
|
| if (match) {
|
| @@ -695,16 +668,14 @@ void InstructionSelector::VisitWord64Shl(Node* node) {
|
| }
|
| }
|
| }
|
| - VisitRRO(this, kPPC_ShiftLeft64, node, kShift64Imm);
|
| + VisitRRO(this, kS390_ShiftLeft64, node, kShift64Imm);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitWord32Shr(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Int32BinopMatcher m(node);
|
| if (m.left().IsWord32And() && m.right().IsInRange(0, 31)) {
|
| - // Try to absorb logical-and into rlwinm
|
| Int32BinopMatcher mleft(m.left().node());
|
| int sh = m.right().Value();
|
| int mb;
|
| @@ -715,23 +686,21 @@ void InstructionSelector::VisitWord32Shr(Node* node) {
|
| if (mb > 31 - sh) mb = 31 - sh;
|
| sh = (32 - sh) & 0x1f;
|
| if (mb >= me) {
|
| - Emit(kPPC_RotLeftAndMask32, g.DefineAsRegister(node),
|
| + Emit(kS390_RotLeftAndMask32, g.DefineAsRegister(node),
|
| g.UseRegister(mleft.left().node()), g.TempImmediate(sh),
|
| g.TempImmediate(mb), g.TempImmediate(me));
|
| return;
|
| }
|
| }
|
| }
|
| - VisitRRO(this, kPPC_ShiftRight32, node, kShift32Imm);
|
| + VisitRRO(this, kS390_ShiftRight32, node, kShift32Imm);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64Shr(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Int64BinopMatcher m(node);
|
| if (m.left().IsWord64And() && m.right().IsInRange(0, 63)) {
|
| - // Try to absorb logical-and into rldic
|
| Int64BinopMatcher mleft(m.left().node());
|
| int sh = m.right().Value();
|
| int mb;
|
| @@ -747,11 +716,11 @@ void InstructionSelector::VisitWord64Shr(Node* node) {
|
| int mask;
|
| if (me == 0) {
|
| match = true;
|
| - opcode = kPPC_RotLeftAndClearLeft64;
|
| + opcode = kS390_RotLeftAndClearLeft64;
|
| mask = mb;
|
| } else if (mb == 63) {
|
| match = true;
|
| - opcode = kPPC_RotLeftAndClearRight64;
|
| + opcode = kS390_RotLeftAndClearRight64;
|
| mask = me;
|
| }
|
| if (match) {
|
| @@ -763,381 +732,323 @@ void InstructionSelector::VisitWord64Shr(Node* node) {
|
| }
|
| }
|
| }
|
| - VisitRRO(this, kPPC_ShiftRight64, node, kShift64Imm);
|
| + VisitRRO(this, kS390_ShiftRight64, node, kShift64Imm);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitWord32Sar(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Int32BinopMatcher m(node);
|
| // Replace with sign extension for (x << K) >> K where K is 16 or 24.
|
| if (CanCover(node, m.left().node()) && m.left().IsWord32Shl()) {
|
| Int32BinopMatcher mleft(m.left().node());
|
| if (mleft.right().Is(16) && m.right().Is(16)) {
|
| - Emit(kPPC_ExtendSignWord16, g.DefineAsRegister(node),
|
| + Emit(kS390_ExtendSignWord16, g.DefineAsRegister(node),
|
| g.UseRegister(mleft.left().node()));
|
| return;
|
| } else if (mleft.right().Is(24) && m.right().Is(24)) {
|
| - Emit(kPPC_ExtendSignWord8, g.DefineAsRegister(node),
|
| + Emit(kS390_ExtendSignWord8, g.DefineAsRegister(node),
|
| g.UseRegister(mleft.left().node()));
|
| return;
|
| }
|
| }
|
| - VisitRRO(this, kPPC_ShiftRightAlg32, node, kShift32Imm);
|
| + VisitRRO(this, kS390_ShiftRightAlg32, node, kShift32Imm);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64Sar(Node* node) {
|
| - VisitRRO(this, kPPC_ShiftRightAlg64, node, kShift64Imm);
|
| + VisitRRO(this, kS390_ShiftRightAlg64, node, kShift64Imm);
|
| }
|
| #endif
|
|
|
| -
|
| -// TODO(mbrandy): Absorb logical-and into rlwinm?
|
| void InstructionSelector::VisitWord32Ror(Node* node) {
|
| - VisitRRO(this, kPPC_RotRight32, node, kShift32Imm);
|
| + VisitRRO(this, kS390_RotRight32, node, kShift32Imm);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| -// TODO(mbrandy): Absorb logical-and into rldic?
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64Ror(Node* node) {
|
| - VisitRRO(this, kPPC_RotRight64, node, kShift64Imm);
|
| + VisitRRO(this, kS390_RotRight64, node, kShift64Imm);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitWord32Clz(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| - Emit(kPPC_Cntlz32, g.DefineAsRegister(node), g.UseRegister(node->InputAt(0)));
|
| + S390OperandGenerator g(this);
|
| + Emit(kS390_Cntlz32, g.DefineAsRegister(node),
|
| + g.UseRegister(node->InputAt(0)));
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64Clz(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| - Emit(kPPC_Cntlz64, g.DefineAsRegister(node), g.UseRegister(node->InputAt(0)));
|
| + S390OperandGenerator g(this);
|
| + Emit(kS390_Cntlz64, g.DefineAsRegister(node),
|
| + g.UseRegister(node->InputAt(0)));
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitWord32Popcnt(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| - Emit(kPPC_Popcnt32, g.DefineAsRegister(node),
|
| + S390OperandGenerator g(this);
|
| + Emit(kS390_Popcnt32, g.DefineAsRegister(node),
|
| g.UseRegister(node->InputAt(0)));
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64Popcnt(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| - Emit(kPPC_Popcnt64, g.DefineAsRegister(node),
|
| + S390OperandGenerator g(this);
|
| + Emit(kS390_Popcnt64, g.DefineAsRegister(node),
|
| g.UseRegister(node->InputAt(0)));
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitWord32Ctz(Node* node) { UNREACHABLE(); }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64Ctz(Node* node) { UNREACHABLE(); }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitWord32ReverseBits(Node* node) { UNREACHABLE(); }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64ReverseBits(Node* node) { UNREACHABLE(); }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitInt32Add(Node* node) {
|
| - VisitBinop<Int32BinopMatcher>(this, node, kPPC_Add, kInt16Imm);
|
| + VisitBinop<Int32BinopMatcher>(this, node, kS390_Add, kInt16Imm);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitInt64Add(Node* node) {
|
| - VisitBinop<Int64BinopMatcher>(this, node, kPPC_Add, kInt16Imm);
|
| + VisitBinop<Int64BinopMatcher>(this, node, kS390_Add, kInt16Imm);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitInt32Sub(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Int32BinopMatcher m(node);
|
| if (m.left().Is(0)) {
|
| - Emit(kPPC_Neg, g.DefineAsRegister(node), g.UseRegister(m.right().node()));
|
| + Emit(kS390_Neg, g.DefineAsRegister(node), g.UseRegister(m.right().node()));
|
| } else {
|
| - VisitBinop<Int32BinopMatcher>(this, node, kPPC_Sub, kInt16Imm_Negate);
|
| + VisitBinop<Int32BinopMatcher>(this, node, kS390_Sub, kInt16Imm_Negate);
|
| }
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitInt64Sub(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Int64BinopMatcher m(node);
|
| if (m.left().Is(0)) {
|
| - Emit(kPPC_Neg, g.DefineAsRegister(node), g.UseRegister(m.right().node()));
|
| + Emit(kS390_Neg, g.DefineAsRegister(node), g.UseRegister(m.right().node()));
|
| } else {
|
| - VisitBinop<Int64BinopMatcher>(this, node, kPPC_Sub, kInt16Imm_Negate);
|
| + VisitBinop<Int64BinopMatcher>(this, node, kS390_Sub, kInt16Imm_Negate);
|
| }
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitInt32Mul(Node* node) {
|
| - VisitRRR(this, kPPC_Mul32, node);
|
| + VisitRRR(this, kS390_Mul32, node);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitInt64Mul(Node* node) {
|
| - VisitRRR(this, kPPC_Mul64, node);
|
| + VisitRRR(this, kS390_Mul64, node);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitInt32MulHigh(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| - Emit(kPPC_MulHigh32, g.DefineAsRegister(node),
|
| + S390OperandGenerator g(this);
|
| + Emit(kS390_MulHigh32, g.DefineAsRegister(node),
|
| g.UseRegister(node->InputAt(0)), g.UseRegister(node->InputAt(1)));
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitUint32MulHigh(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| - Emit(kPPC_MulHighU32, g.DefineAsRegister(node),
|
| + S390OperandGenerator g(this);
|
| + Emit(kS390_MulHighU32, g.DefineAsRegister(node),
|
| g.UseRegister(node->InputAt(0)), g.UseRegister(node->InputAt(1)));
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitInt32Div(Node* node) {
|
| - VisitRRR(this, kPPC_Div32, node);
|
| + VisitRRR(this, kS390_Div32, node);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitInt64Div(Node* node) {
|
| - VisitRRR(this, kPPC_Div64, node);
|
| + VisitRRR(this, kS390_Div64, node);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitUint32Div(Node* node) {
|
| - VisitRRR(this, kPPC_DivU32, node);
|
| + VisitRRR(this, kS390_DivU32, node);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitUint64Div(Node* node) {
|
| - VisitRRR(this, kPPC_DivU64, node);
|
| + VisitRRR(this, kS390_DivU64, node);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitInt32Mod(Node* node) {
|
| - VisitRRR(this, kPPC_Mod32, node);
|
| + VisitRRR(this, kS390_Mod32, node);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitInt64Mod(Node* node) {
|
| - VisitRRR(this, kPPC_Mod64, node);
|
| + VisitRRR(this, kS390_Mod64, node);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitUint32Mod(Node* node) {
|
| - VisitRRR(this, kPPC_ModU32, node);
|
| + VisitRRR(this, kS390_ModU32, node);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitUint64Mod(Node* node) {
|
| - VisitRRR(this, kPPC_ModU64, node);
|
| + VisitRRR(this, kS390_ModU64, node);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitChangeFloat32ToFloat64(Node* node) {
|
| - VisitRR(this, kPPC_Float32ToDouble, node);
|
| + VisitRR(this, kS390_Float32ToDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitRoundInt32ToFloat32(Node* node) {
|
| - VisitRR(this, kPPC_Int32ToFloat32, node);
|
| + VisitRR(this, kS390_Int32ToFloat32, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitRoundUint32ToFloat32(Node* node) {
|
| - VisitRR(this, kPPC_Uint32ToFloat32, node);
|
| + VisitRR(this, kS390_Uint32ToFloat32, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitChangeInt32ToFloat64(Node* node) {
|
| - VisitRR(this, kPPC_Int32ToDouble, node);
|
| + VisitRR(this, kS390_Int32ToDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitChangeUint32ToFloat64(Node* node) {
|
| - VisitRR(this, kPPC_Uint32ToDouble, node);
|
| + VisitRR(this, kS390_Uint32ToDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitChangeFloat64ToInt32(Node* node) {
|
| - VisitRR(this, kPPC_DoubleToInt32, node);
|
| + VisitRR(this, kS390_DoubleToInt32, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitChangeFloat64ToUint32(Node* node) {
|
| - VisitRR(this, kPPC_DoubleToUint32, node);
|
| + VisitRR(this, kS390_DoubleToUint32, node);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitTryTruncateFloat32ToInt64(Node* node) {
|
| - VisitTryTruncateDouble(this, kPPC_DoubleToInt64, node);
|
| + VisitTryTruncateDouble(this, kS390_Float32ToInt64, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitTryTruncateFloat64ToInt64(Node* node) {
|
| - VisitTryTruncateDouble(this, kPPC_DoubleToInt64, node);
|
| + VisitTryTruncateDouble(this, kS390_DoubleToInt64, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitTryTruncateFloat32ToUint64(Node* node) {
|
| - VisitTryTruncateDouble(this, kPPC_DoubleToUint64, node);
|
| + VisitTryTruncateDouble(this, kS390_Float32ToUint64, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitTryTruncateFloat64ToUint64(Node* node) {
|
| - VisitTryTruncateDouble(this, kPPC_DoubleToUint64, node);
|
| + VisitTryTruncateDouble(this, kS390_DoubleToUint64, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitChangeInt32ToInt64(Node* node) {
|
| // TODO(mbrandy): inspect input to see if nop is appropriate.
|
| - VisitRR(this, kPPC_ExtendSignWord32, node);
|
| + VisitRR(this, kS390_ExtendSignWord32, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitChangeUint32ToUint64(Node* node) {
|
| // TODO(mbrandy): inspect input to see if nop is appropriate.
|
| - VisitRR(this, kPPC_Uint32ToUint64, node);
|
| + VisitRR(this, kS390_Uint32ToUint64, node);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitTruncateFloat64ToFloat32(Node* node) {
|
| - VisitRR(this, kPPC_DoubleToFloat32, node);
|
| + VisitRR(this, kS390_DoubleToFloat32, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitTruncateFloat64ToInt32(Node* node) {
|
| switch (TruncationModeOf(node->op())) {
|
| case TruncationMode::kJavaScript:
|
| return VisitRR(this, kArchTruncateDoubleToI, node);
|
| case TruncationMode::kRoundToZero:
|
| - return VisitRR(this, kPPC_DoubleToInt32, node);
|
| + return VisitRR(this, kS390_DoubleToInt32, node);
|
| }
|
| UNREACHABLE();
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitTruncateFloat32ToInt32(Node* node) {
|
| - VisitRR(this, kPPC_DoubleToInt32, node);
|
| + VisitRR(this, kS390_Float32ToInt32, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitTruncateFloat32ToUint32(Node* node) {
|
| - VisitRR(this, kPPC_DoubleToUint32, node);
|
| + VisitRR(this, kS390_Float32ToUint32, node);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitTruncateInt64ToInt32(Node* node) {
|
| // TODO(mbrandy): inspect input to see if nop is appropriate.
|
| - VisitRR(this, kPPC_Int64ToInt32, node);
|
| + VisitRR(this, kS390_Int64ToInt32, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitRoundInt64ToFloat32(Node* node) {
|
| - VisitRR(this, kPPC_Int64ToFloat32, node);
|
| + VisitRR(this, kS390_Int64ToFloat32, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitRoundInt64ToFloat64(Node* node) {
|
| - VisitRR(this, kPPC_Int64ToDouble, node);
|
| + VisitRR(this, kS390_Int64ToDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitRoundUint64ToFloat32(Node* node) {
|
| - VisitRR(this, kPPC_Uint64ToFloat32, node);
|
| + VisitRR(this, kS390_Uint64ToFloat32, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitRoundUint64ToFloat64(Node* node) {
|
| - VisitRR(this, kPPC_Uint64ToDouble, node);
|
| + VisitRR(this, kS390_Uint64ToDouble, node);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitBitcastFloat32ToInt32(Node* node) {
|
| - VisitRR(this, kPPC_BitcastFloat32ToInt32, node);
|
| + VisitRR(this, kS390_BitcastFloat32ToInt32, node);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitBitcastFloat64ToInt64(Node* node) {
|
| - VisitRR(this, kPPC_BitcastDoubleToInt64, node);
|
| + VisitRR(this, kS390_BitcastDoubleToInt64, node);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitBitcastInt32ToFloat32(Node* node) {
|
| - VisitRR(this, kPPC_BitcastInt32ToFloat32, node);
|
| + VisitRR(this, kS390_BitcastInt32ToFloat32, node);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitBitcastInt64ToFloat64(Node* node) {
|
| - VisitRR(this, kPPC_BitcastInt64ToDouble, node);
|
| + VisitRR(this, kS390_BitcastInt64ToDouble, node);
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitFloat32Add(Node* node) {
|
| - VisitRRR(this, kPPC_AddDouble, node);
|
| + VisitRRR(this, kS390_AddFloat, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64Add(Node* node) {
|
| // TODO(mbrandy): detect multiply-add
|
| - VisitRRR(this, kPPC_AddDouble, node);
|
| + VisitRRR(this, kS390_AddDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32Sub(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Float32BinopMatcher m(node);
|
| if (m.left().IsMinusZero()) {
|
| - Emit(kPPC_NegDouble, g.DefineAsRegister(node),
|
| + Emit(kS390_NegDouble, g.DefineAsRegister(node),
|
| g.UseRegister(m.right().node()));
|
| return;
|
| }
|
| - VisitRRR(this, kPPC_SubDouble, node);
|
| + VisitRRR(this, kS390_SubFloat, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64Sub(Node* node) {
|
| // TODO(mbrandy): detect multiply-subtract
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Float64BinopMatcher m(node);
|
| if (m.left().IsMinusZero()) {
|
| if (m.right().IsFloat64RoundDown() &&
|
| @@ -1147,174 +1058,147 @@ void InstructionSelector::VisitFloat64Sub(Node* node) {
|
| Float64BinopMatcher mright0(m.right().InputAt(0));
|
| if (mright0.left().IsMinusZero()) {
|
| // -floor(-x) = ceil(x)
|
| - Emit(kPPC_CeilDouble, g.DefineAsRegister(node),
|
| + Emit(kS390_CeilDouble, g.DefineAsRegister(node),
|
| g.UseRegister(mright0.right().node()));
|
| return;
|
| }
|
| }
|
| }
|
| - Emit(kPPC_NegDouble, g.DefineAsRegister(node),
|
| + Emit(kS390_NegDouble, g.DefineAsRegister(node),
|
| g.UseRegister(m.right().node()));
|
| return;
|
| }
|
| - VisitRRR(this, kPPC_SubDouble, node);
|
| + VisitRRR(this, kS390_SubDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32Mul(Node* node) {
|
| - VisitRRR(this, kPPC_MulDouble, node);
|
| + VisitRRR(this, kS390_MulFloat, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64Mul(Node* node) {
|
| // TODO(mbrandy): detect negate
|
| - VisitRRR(this, kPPC_MulDouble, node);
|
| + VisitRRR(this, kS390_MulDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32Div(Node* node) {
|
| - VisitRRR(this, kPPC_DivDouble, node);
|
| + VisitRRR(this, kS390_DivFloat, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64Div(Node* node) {
|
| - VisitRRR(this, kPPC_DivDouble, node);
|
| + VisitRRR(this, kS390_DivDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64Mod(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| - Emit(kPPC_ModDouble, g.DefineAsFixed(node, d1),
|
| - g.UseFixed(node->InputAt(0), d1),
|
| - g.UseFixed(node->InputAt(1), d2))->MarkAsCall();
|
| + S390OperandGenerator g(this);
|
| + Emit(kS390_ModDouble, g.DefineAsFixed(node, d1),
|
| + g.UseFixed(node->InputAt(0), d1), g.UseFixed(node->InputAt(1), d2))
|
| + ->MarkAsCall();
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32Max(Node* node) { UNREACHABLE(); }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64Max(Node* node) { UNREACHABLE(); }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32Min(Node* node) { UNREACHABLE(); }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64Min(Node* node) { UNREACHABLE(); }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32Abs(Node* node) {
|
| - VisitRR(this, kPPC_AbsDouble, node);
|
| + VisitRR(this, kS390_AbsFloat, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64Abs(Node* node) {
|
| - VisitRR(this, kPPC_AbsDouble, node);
|
| + VisitRR(this, kS390_AbsDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32Sqrt(Node* node) {
|
| - VisitRR(this, kPPC_SqrtDouble, node);
|
| + VisitRR(this, kS390_SqrtFloat, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64Sqrt(Node* node) {
|
| - VisitRR(this, kPPC_SqrtDouble, node);
|
| + VisitRR(this, kS390_SqrtDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32RoundDown(Node* node) {
|
| - VisitRR(this, kPPC_FloorDouble, node);
|
| + VisitRR(this, kS390_FloorFloat, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64RoundDown(Node* node) {
|
| - VisitRR(this, kPPC_FloorDouble, node);
|
| + VisitRR(this, kS390_FloorDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32RoundUp(Node* node) {
|
| - VisitRR(this, kPPC_CeilDouble, node);
|
| + VisitRR(this, kS390_CeilFloat, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64RoundUp(Node* node) {
|
| - VisitRR(this, kPPC_CeilDouble, node);
|
| + VisitRR(this, kS390_CeilDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32RoundTruncate(Node* node) {
|
| - VisitRR(this, kPPC_TruncateDouble, node);
|
| + VisitRR(this, kS390_TruncateFloat, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64RoundTruncate(Node* node) {
|
| - VisitRR(this, kPPC_TruncateDouble, node);
|
| + VisitRR(this, kS390_TruncateDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64RoundTiesAway(Node* node) {
|
| - VisitRR(this, kPPC_RoundDouble, node);
|
| + VisitRR(this, kS390_RoundDouble, node);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32RoundTiesEven(Node* node) {
|
| UNREACHABLE();
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64RoundTiesEven(Node* node) {
|
| UNREACHABLE();
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitInt32AddWithOverflow(Node* node) {
|
| if (Node* ovf = NodeProperties::FindProjection(node, 1)) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kOverflow, ovf);
|
| - return VisitBinop<Int32BinopMatcher>(this, node, kPPC_AddWithOverflow32,
|
| + return VisitBinop<Int32BinopMatcher>(this, node, kS390_AddWithOverflow32,
|
| kInt16Imm, &cont);
|
| }
|
| FlagsContinuation cont;
|
| - VisitBinop<Int32BinopMatcher>(this, node, kPPC_AddWithOverflow32, kInt16Imm,
|
| + VisitBinop<Int32BinopMatcher>(this, node, kS390_AddWithOverflow32, kInt16Imm,
|
| &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitInt32SubWithOverflow(Node* node) {
|
| if (Node* ovf = NodeProperties::FindProjection(node, 1)) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kOverflow, ovf);
|
| - return VisitBinop<Int32BinopMatcher>(this, node, kPPC_SubWithOverflow32,
|
| + return VisitBinop<Int32BinopMatcher>(this, node, kS390_SubWithOverflow32,
|
| kInt16Imm_Negate, &cont);
|
| }
|
| FlagsContinuation cont;
|
| - VisitBinop<Int32BinopMatcher>(this, node, kPPC_SubWithOverflow32,
|
| + VisitBinop<Int32BinopMatcher>(this, node, kS390_SubWithOverflow32,
|
| kInt16Imm_Negate, &cont);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitInt64AddWithOverflow(Node* node) {
|
| if (Node* ovf = NodeProperties::FindProjection(node, 1)) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kOverflow, ovf);
|
| - return VisitBinop<Int64BinopMatcher>(this, node, kPPC_Add, kInt16Imm,
|
| + return VisitBinop<Int64BinopMatcher>(this, node, kS390_Add, kInt16Imm,
|
| &cont);
|
| }
|
| FlagsContinuation cont;
|
| - VisitBinop<Int64BinopMatcher>(this, node, kPPC_Add, kInt16Imm, &cont);
|
| + VisitBinop<Int64BinopMatcher>(this, node, kS390_Add, kInt16Imm, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitInt64SubWithOverflow(Node* node) {
|
| if (Node* ovf = NodeProperties::FindProjection(node, 1)) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kOverflow, ovf);
|
| - return VisitBinop<Int64BinopMatcher>(this, node, kPPC_Sub, kInt16Imm_Negate,
|
| - &cont);
|
| + return VisitBinop<Int64BinopMatcher>(this, node, kS390_Sub,
|
| + kInt16Imm_Negate, &cont);
|
| }
|
| FlagsContinuation cont;
|
| - VisitBinop<Int64BinopMatcher>(this, node, kPPC_Sub, kInt16Imm_Negate, &cont);
|
| + VisitBinop<Int64BinopMatcher>(this, node, kS390_Sub, kInt16Imm_Negate, &cont);
|
| }
|
| #endif
|
|
|
| -
|
| static bool CompareLogical(FlagsContinuation* cont) {
|
| switch (cont->condition()) {
|
| case kUnsignedLessThan:
|
| @@ -1329,14 +1213,13 @@ static bool CompareLogical(FlagsContinuation* cont) {
|
| return false;
|
| }
|
|
|
| -
|
| namespace {
|
|
|
| // Shared routine for multiple compare operations.
|
| void VisitCompare(InstructionSelector* selector, InstructionCode opcode,
|
| InstructionOperand left, InstructionOperand right,
|
| FlagsContinuation* cont) {
|
| - PPCOperandGenerator g(selector);
|
| + S390OperandGenerator g(selector);
|
| opcode = cont->Encode(opcode);
|
| if (cont->IsBranch()) {
|
| selector->Emit(opcode, g.NoOutput(), left, right,
|
| @@ -1350,12 +1233,11 @@ void VisitCompare(InstructionSelector* selector, InstructionCode opcode,
|
| }
|
| }
|
|
|
| -
|
| // Shared routine for multiple word compare operations.
|
| void VisitWordCompare(InstructionSelector* selector, Node* node,
|
| InstructionCode opcode, FlagsContinuation* cont,
|
| bool commutative, ImmediateMode immediate_mode) {
|
| - PPCOperandGenerator g(selector);
|
| + S390OperandGenerator g(selector);
|
| Node* left = node->InputAt(0);
|
| Node* right = node->InputAt(1);
|
|
|
| @@ -1373,45 +1255,40 @@ void VisitWordCompare(InstructionSelector* selector, Node* node,
|
| }
|
| }
|
|
|
| -
|
| void VisitWord32Compare(InstructionSelector* selector, Node* node,
|
| FlagsContinuation* cont) {
|
| ImmediateMode mode = (CompareLogical(cont) ? kInt16Imm_Unsigned : kInt16Imm);
|
| - VisitWordCompare(selector, node, kPPC_Cmp32, cont, false, mode);
|
| + VisitWordCompare(selector, node, kS390_Cmp32, cont, false, mode);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void VisitWord64Compare(InstructionSelector* selector, Node* node,
|
| FlagsContinuation* cont) {
|
| ImmediateMode mode = (CompareLogical(cont) ? kInt16Imm_Unsigned : kInt16Imm);
|
| - VisitWordCompare(selector, node, kPPC_Cmp64, cont, false, mode);
|
| + VisitWordCompare(selector, node, kS390_Cmp64, cont, false, mode);
|
| }
|
| #endif
|
|
|
| -
|
| // Shared routine for multiple float32 compare operations.
|
| void VisitFloat32Compare(InstructionSelector* selector, Node* node,
|
| FlagsContinuation* cont) {
|
| - PPCOperandGenerator g(selector);
|
| + S390OperandGenerator g(selector);
|
| Node* left = node->InputAt(0);
|
| Node* right = node->InputAt(1);
|
| - VisitCompare(selector, kPPC_CmpDouble, g.UseRegister(left),
|
| + VisitCompare(selector, kS390_CmpFloat, g.UseRegister(left),
|
| g.UseRegister(right), cont);
|
| }
|
|
|
| -
|
| // Shared routine for multiple float64 compare operations.
|
| void VisitFloat64Compare(InstructionSelector* selector, Node* node,
|
| FlagsContinuation* cont) {
|
| - PPCOperandGenerator g(selector);
|
| + S390OperandGenerator g(selector);
|
| Node* left = node->InputAt(0);
|
| Node* right = node->InputAt(1);
|
| - VisitCompare(selector, kPPC_CmpDouble, g.UseRegister(left),
|
| + VisitCompare(selector, kS390_CmpDouble, g.UseRegister(left),
|
| g.UseRegister(right), cont);
|
| }
|
|
|
| -
|
| // Shared routine for word comparisons against zero.
|
| void VisitWordCompareZero(InstructionSelector* selector, Node* user,
|
| Node* value, InstructionCode opcode,
|
| @@ -1443,7 +1320,7 @@ void VisitWordCompareZero(InstructionSelector* selector, Node* user,
|
| case IrOpcode::kUint32LessThanOrEqual:
|
| cont->OverwriteAndNegateIfEqual(kUnsignedLessThanOrEqual);
|
| return VisitWord32Compare(selector, value, cont);
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| case IrOpcode::kWord64Equal:
|
| cont->OverwriteAndNegateIfEqual(kEqual);
|
| return VisitWord64Compare(selector, value, cont);
|
| @@ -1494,20 +1371,20 @@ void VisitWordCompareZero(InstructionSelector* selector, Node* user,
|
| case IrOpcode::kInt32AddWithOverflow:
|
| cont->OverwriteAndNegateIfEqual(kOverflow);
|
| return VisitBinop<Int32BinopMatcher>(
|
| - selector, node, kPPC_AddWithOverflow32, kInt16Imm, cont);
|
| + selector, node, kS390_AddWithOverflow32, kInt16Imm, cont);
|
| case IrOpcode::kInt32SubWithOverflow:
|
| cont->OverwriteAndNegateIfEqual(kOverflow);
|
| return VisitBinop<Int32BinopMatcher>(selector, node,
|
| - kPPC_SubWithOverflow32,
|
| + kS390_SubWithOverflow32,
|
| kInt16Imm_Negate, cont);
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| case IrOpcode::kInt64AddWithOverflow:
|
| cont->OverwriteAndNegateIfEqual(kOverflow);
|
| - return VisitBinop<Int64BinopMatcher>(selector, node, kPPC_Add,
|
| + return VisitBinop<Int64BinopMatcher>(selector, node, kS390_Add,
|
| kInt16Imm, cont);
|
| case IrOpcode::kInt64SubWithOverflow:
|
| cont->OverwriteAndNegateIfEqual(kOverflow);
|
| - return VisitBinop<Int64BinopMatcher>(selector, node, kPPC_Sub,
|
| + return VisitBinop<Int64BinopMatcher>(selector, node, kS390_Sub,
|
| kInt16Imm_Negate, cont);
|
| #endif
|
| default:
|
| @@ -1519,8 +1396,7 @@ void VisitWordCompareZero(InstructionSelector* selector, Node* user,
|
| case IrOpcode::kInt32Sub:
|
| return VisitWord32Compare(selector, value, cont);
|
| case IrOpcode::kWord32And:
|
| - // TODO(mbandy): opportunity for rlwinm?
|
| - return VisitWordCompare(selector, value, kPPC_Tst32, cont, true,
|
| + return VisitWordCompare(selector, value, kS390_Tst32, cont, true,
|
| kInt16Imm_Unsigned);
|
| // TODO(mbrandy): Handle?
|
| // case IrOpcode::kInt32Add:
|
| @@ -1530,12 +1406,11 @@ void VisitWordCompareZero(InstructionSelector* selector, Node* user,
|
| // case IrOpcode::kWord32Shl:
|
| // case IrOpcode::kWord32Shr:
|
| // case IrOpcode::kWord32Ror:
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| case IrOpcode::kInt64Sub:
|
| return VisitWord64Compare(selector, value, cont);
|
| case IrOpcode::kWord64And:
|
| - // TODO(mbandy): opportunity for rldic?
|
| - return VisitWordCompare(selector, value, kPPC_Tst64, cont, true,
|
| + return VisitWordCompare(selector, value, kS390_Tst64, cont, true,
|
| kInt16Imm_Unsigned);
|
| // TODO(mbrandy): Handle?
|
| // case IrOpcode::kInt64Add:
|
| @@ -1553,28 +1428,25 @@ void VisitWordCompareZero(InstructionSelector* selector, Node* user,
|
| }
|
|
|
| // Branch could not be combined with a compare, emit compare against 0.
|
| - PPCOperandGenerator g(selector);
|
| + S390OperandGenerator g(selector);
|
| VisitCompare(selector, opcode, g.UseRegister(value), g.TempImmediate(0),
|
| cont);
|
| }
|
|
|
| -
|
| void VisitWord32CompareZero(InstructionSelector* selector, Node* user,
|
| Node* value, FlagsContinuation* cont) {
|
| - VisitWordCompareZero(selector, user, value, kPPC_Cmp32, cont);
|
| + VisitWordCompareZero(selector, user, value, kS390_Cmp32, cont);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void VisitWord64CompareZero(InstructionSelector* selector, Node* user,
|
| Node* value, FlagsContinuation* cont) {
|
| - VisitWordCompareZero(selector, user, value, kPPC_Cmp64, cont);
|
| + VisitWordCompareZero(selector, user, value, kS390_Cmp64, cont);
|
| }
|
| #endif
|
|
|
| } // namespace
|
|
|
| -
|
| void InstructionSelector::VisitBranch(Node* branch, BasicBlock* tbranch,
|
| BasicBlock* fbranch) {
|
| FlagsContinuation cont(kNotEqual, tbranch, fbranch);
|
| @@ -1594,7 +1466,7 @@ void InstructionSelector::VisitDeoptimizeUnless(Node* node) {
|
| }
|
|
|
| void InstructionSelector::VisitSwitch(Node* node, const SwitchInfo& sw) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| InstructionOperand value_operand = g.UseRegister(node->InputAt(0));
|
|
|
| // Emit either ArchTableSwitch or ArchLookupSwitch.
|
| @@ -1609,7 +1481,7 @@ void InstructionSelector::VisitSwitch(Node* node, const SwitchInfo& sw) {
|
| InstructionOperand index_operand = value_operand;
|
| if (sw.min_value) {
|
| index_operand = g.TempRegister();
|
| - Emit(kPPC_Sub, index_operand, value_operand,
|
| + Emit(kS390_Sub, index_operand, value_operand,
|
| g.TempImmediate(sw.min_value));
|
| }
|
| // Generate a table lookup.
|
| @@ -1620,7 +1492,6 @@ void InstructionSelector::VisitSwitch(Node* node, const SwitchInfo& sw) {
|
| return EmitLookupSwitch(sw, value_operand);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitWord32Equal(Node* const node) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kEqual, node);
|
| Int32BinopMatcher m(node);
|
| @@ -1630,34 +1501,29 @@ void InstructionSelector::VisitWord32Equal(Node* const node) {
|
| VisitWord32Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitInt32LessThan(Node* node) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kSignedLessThan, node);
|
| VisitWord32Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitInt32LessThanOrEqual(Node* node) {
|
| FlagsContinuation cont =
|
| FlagsContinuation::ForSet(kSignedLessThanOrEqual, node);
|
| VisitWord32Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitUint32LessThan(Node* node) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kUnsignedLessThan, node);
|
| VisitWord32Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitUint32LessThanOrEqual(Node* node) {
|
| FlagsContinuation cont =
|
| FlagsContinuation::ForSet(kUnsignedLessThanOrEqual, node);
|
| VisitWord32Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| -#if V8_TARGET_ARCH_PPC64
|
| +#if V8_TARGET_ARCH_S390X
|
| void InstructionSelector::VisitWord64Equal(Node* const node) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kEqual, node);
|
| Int64BinopMatcher m(node);
|
| @@ -1667,26 +1533,22 @@ void InstructionSelector::VisitWord64Equal(Node* const node) {
|
| VisitWord64Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitInt64LessThan(Node* node) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kSignedLessThan, node);
|
| VisitWord64Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitInt64LessThanOrEqual(Node* node) {
|
| FlagsContinuation cont =
|
| FlagsContinuation::ForSet(kSignedLessThanOrEqual, node);
|
| VisitWord64Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitUint64LessThan(Node* node) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kUnsignedLessThan, node);
|
| VisitWord64Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitUint64LessThanOrEqual(Node* node) {
|
| FlagsContinuation cont =
|
| FlagsContinuation::ForSet(kUnsignedLessThanOrEqual, node);
|
| @@ -1694,49 +1556,42 @@ void InstructionSelector::VisitUint64LessThanOrEqual(Node* node) {
|
| }
|
| #endif
|
|
|
| -
|
| void InstructionSelector::VisitFloat32Equal(Node* node) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kEqual, node);
|
| VisitFloat32Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32LessThan(Node* node) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kUnsignedLessThan, node);
|
| VisitFloat32Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat32LessThanOrEqual(Node* node) {
|
| FlagsContinuation cont =
|
| FlagsContinuation::ForSet(kUnsignedLessThanOrEqual, node);
|
| VisitFloat32Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64Equal(Node* node) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kEqual, node);
|
| VisitFloat64Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64LessThan(Node* node) {
|
| FlagsContinuation cont = FlagsContinuation::ForSet(kUnsignedLessThan, node);
|
| VisitFloat64Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64LessThanOrEqual(Node* node) {
|
| FlagsContinuation cont =
|
| FlagsContinuation::ForSet(kUnsignedLessThanOrEqual, node);
|
| VisitFloat64Compare(this, node, &cont);
|
| }
|
|
|
| -
|
| void InstructionSelector::EmitPrepareArguments(
|
| ZoneVector<PushParameter>* arguments, const CallDescriptor* descriptor,
|
| Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
|
|
| // Prepare for C function call.
|
| if (descriptor->IsCFunctionCall()) {
|
| @@ -1747,7 +1602,7 @@ void InstructionSelector::EmitPrepareArguments(
|
| // Poke any stack arguments.
|
| int slot = kStackFrameExtraParamSlot;
|
| for (PushParameter input : (*arguments)) {
|
| - Emit(kPPC_StoreToStackSlot, g.NoOutput(), g.UseRegister(input.node()),
|
| + Emit(kS390_StoreToStackSlot, g.NoOutput(), g.UseRegister(input.node()),
|
| g.TempImmediate(slot));
|
| ++slot;
|
| }
|
| @@ -1758,13 +1613,13 @@ void InstructionSelector::EmitPrepareArguments(
|
| for (PushParameter input : (*arguments)) {
|
| if (slot == 0) {
|
| DCHECK(input.node());
|
| - Emit(kPPC_PushFrame, g.NoOutput(), g.UseRegister(input.node()),
|
| + Emit(kS390_PushFrame, g.NoOutput(), g.UseRegister(input.node()),
|
| g.TempImmediate(num_slots));
|
| } else {
|
| // Skip any alignment holes in pushed nodes.
|
| if (input.node()) {
|
| - Emit(kPPC_StoreToStackSlot, g.NoOutput(), g.UseRegister(input.node()),
|
| - g.TempImmediate(slot));
|
| + Emit(kS390_StoreToStackSlot, g.NoOutput(),
|
| + g.UseRegister(input.node()), g.TempImmediate(slot));
|
| }
|
| }
|
| ++slot;
|
| @@ -1772,56 +1627,50 @@ void InstructionSelector::EmitPrepareArguments(
|
| }
|
| }
|
|
|
| -
|
| bool InstructionSelector::IsTailCallAddressImmediate() { return false; }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64ExtractLowWord32(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| - Emit(kPPC_DoubleExtractLowWord32, g.DefineAsRegister(node),
|
| + S390OperandGenerator g(this);
|
| + Emit(kS390_DoubleExtractLowWord32, g.DefineAsRegister(node),
|
| g.UseRegister(node->InputAt(0)));
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64ExtractHighWord32(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| - Emit(kPPC_DoubleExtractHighWord32, g.DefineAsRegister(node),
|
| + S390OperandGenerator g(this);
|
| + Emit(kS390_DoubleExtractHighWord32, g.DefineAsRegister(node),
|
| g.UseRegister(node->InputAt(0)));
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64InsertLowWord32(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Node* left = node->InputAt(0);
|
| Node* right = node->InputAt(1);
|
| if (left->opcode() == IrOpcode::kFloat64InsertHighWord32 &&
|
| CanCover(node, left)) {
|
| left = left->InputAt(1);
|
| - Emit(kPPC_DoubleConstruct, g.DefineAsRegister(node), g.UseRegister(left),
|
| + Emit(kS390_DoubleConstruct, g.DefineAsRegister(node), g.UseRegister(left),
|
| g.UseRegister(right));
|
| return;
|
| }
|
| - Emit(kPPC_DoubleInsertLowWord32, g.DefineSameAsFirst(node),
|
| + Emit(kS390_DoubleInsertLowWord32, g.DefineSameAsFirst(node),
|
| g.UseRegister(left), g.UseRegister(right));
|
| }
|
|
|
| -
|
| void InstructionSelector::VisitFloat64InsertHighWord32(Node* node) {
|
| - PPCOperandGenerator g(this);
|
| + S390OperandGenerator g(this);
|
| Node* left = node->InputAt(0);
|
| Node* right = node->InputAt(1);
|
| if (left->opcode() == IrOpcode::kFloat64InsertLowWord32 &&
|
| CanCover(node, left)) {
|
| left = left->InputAt(1);
|
| - Emit(kPPC_DoubleConstruct, g.DefineAsRegister(node), g.UseRegister(right),
|
| + Emit(kS390_DoubleConstruct, g.DefineAsRegister(node), g.UseRegister(right),
|
| g.UseRegister(left));
|
| return;
|
| }
|
| - Emit(kPPC_DoubleInsertHighWord32, g.DefineSameAsFirst(node),
|
| + Emit(kS390_DoubleInsertHighWord32, g.DefineSameAsFirst(node),
|
| g.UseRegister(left), g.UseRegister(right));
|
| }
|
|
|
| -
|
| // static
|
| MachineOperatorBuilder::Flags
|
| InstructionSelector::SupportedMachineOperatorFlags() {
|
| @@ -1834,7 +1683,6 @@ InstructionSelector::SupportedMachineOperatorFlags() {
|
| MachineOperatorBuilder::kFloat64RoundTiesAway |
|
| MachineOperatorBuilder::kWord32Popcnt |
|
| MachineOperatorBuilder::kWord64Popcnt;
|
| - // We omit kWord32ShiftIsSafe as s[rl]w use 0x3f as a mask rather than 0x1f.
|
| }
|
|
|
| } // namespace compiler
|
|
|