Commit f9cceb90 authored by michael_dawson's avatar michael_dawson Committed by Commit bot

PPC: Implement turbofan Float64Min and Float64Max machine operators.

R=danno@chromium.org, svenpanne@chromium.org

BUG=

Review URL: https://codereview.chromium.org/1006913002

Cr-Commit-Position: refs/heads/master@{#27202}
parent 523dec12
...@@ -339,6 +339,22 @@ Condition FlagsConditionToCondition(FlagsCondition condition) { ...@@ -339,6 +339,22 @@ Condition FlagsConditionToCondition(FlagsCondition condition) {
} while (0) } while (0)
#define ASSEMBLE_FLOAT_MAX(scratch_reg) \
do { \
__ fsub(scratch_reg, i.InputDoubleRegister(0), i.InputDoubleRegister(1)); \
__ fsel(i.OutputDoubleRegister(), scratch_reg, i.InputDoubleRegister(0), \
i.InputDoubleRegister(1)); \
} while (0)
#define ASSEMBLE_FLOAT_MIN(scratch_reg) \
do { \
__ fsub(scratch_reg, i.InputDoubleRegister(0), i.InputDoubleRegister(1)); \
__ fsel(i.OutputDoubleRegister(), scratch_reg, i.InputDoubleRegister(1), \
i.InputDoubleRegister(0)); \
} while (0)
#define ASSEMBLE_LOAD_FLOAT(asm_instr, asm_instrx) \ #define ASSEMBLE_LOAD_FLOAT(asm_instr, asm_instrx) \
do { \ do { \
DoubleRegister result = i.OutputDoubleRegister(); \ DoubleRegister result = i.OutputDoubleRegister(); \
...@@ -799,6 +815,12 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) { ...@@ -799,6 +815,12 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) {
case kPPC_Neg64: case kPPC_Neg64:
__ neg(i.OutputRegister(), i.InputRegister(0), LeaveOE, i.OutputRCBit()); __ neg(i.OutputRegister(), i.InputRegister(0), LeaveOE, i.OutputRCBit());
break; break;
case kPPC_MaxFloat64:
ASSEMBLE_FLOAT_MAX(kScratchDoubleReg);
break;
case kPPC_MinFloat64:
ASSEMBLE_FLOAT_MIN(kScratchDoubleReg);
break;
case kPPC_SqrtFloat64: case kPPC_SqrtFloat64:
ASSEMBLE_FLOAT_UNOP_RC(fsqrt); ASSEMBLE_FLOAT_UNOP_RC(fsqrt);
break; break;
......
...@@ -67,6 +67,8 @@ namespace compiler { ...@@ -67,6 +67,8 @@ namespace compiler {
V(PPC_CeilFloat64) \ V(PPC_CeilFloat64) \
V(PPC_TruncateFloat64) \ V(PPC_TruncateFloat64) \
V(PPC_RoundFloat64) \ V(PPC_RoundFloat64) \
V(PPC_MaxFloat64) \
V(PPC_MinFloat64) \
V(PPC_Cmp32) \ V(PPC_Cmp32) \
V(PPC_Cmp64) \ V(PPC_Cmp64) \
V(PPC_CmpFloat64) \ V(PPC_CmpFloat64) \
......
...@@ -963,10 +963,14 @@ void InstructionSelector::VisitFloat64Mod(Node* node) { ...@@ -963,10 +963,14 @@ void InstructionSelector::VisitFloat64Mod(Node* node) {
} }
void InstructionSelector::VisitFloat64Max(Node* node) { UNREACHABLE(); } void InstructionSelector::VisitFloat64Max(Node* node) {
VisitRRRFloat64(this, node, kPPC_MaxFloat64);
}
void InstructionSelector::VisitFloat64Min(Node* node) { UNREACHABLE(); } void InstructionSelector::VisitFloat64Min(Node* node) {
VisitRRRFloat64(this, node, kPPC_MinFloat64);
}
void InstructionSelector::VisitFloat64Sqrt(Node* node) { void InstructionSelector::VisitFloat64Sqrt(Node* node) {
...@@ -1491,7 +1495,9 @@ void InstructionSelector::VisitFloat64InsertHighWord32(Node* node) { ...@@ -1491,7 +1495,9 @@ void InstructionSelector::VisitFloat64InsertHighWord32(Node* node) {
// static // static
MachineOperatorBuilder::Flags MachineOperatorBuilder::Flags
InstructionSelector::SupportedMachineOperatorFlags() { InstructionSelector::SupportedMachineOperatorFlags() {
return MachineOperatorBuilder::kFloat64RoundDown | return MachineOperatorBuilder::kFloat64Max |
MachineOperatorBuilder::kFloat64Min |
MachineOperatorBuilder::kFloat64RoundDown |
MachineOperatorBuilder::kFloat64RoundTruncate | MachineOperatorBuilder::kFloat64RoundTruncate |
MachineOperatorBuilder::kFloat64RoundTiesAway; MachineOperatorBuilder::kFloat64RoundTiesAway;
// We omit kWord32ShiftIsSafe as s[rl]w use 0x3f as a mask rather than 0x1f. // We omit kWord32ShiftIsSafe as s[rl]w use 0x3f as a mask rather than 0x1f.
......
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