PPC: [turbofan] Fixed the second return value of TryTruncateFloatXXToUint64.

Port 0794c3c9b9

Original commit message:
    As required by the spec, the second return value now returns success
    also for the range between 0 and -1 where the conversion results in 0.

R=ahaas@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
BUG=

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

Cr-Commit-Position: refs/heads/master@{#32972}
This commit is contained in:
mbrandy 2015-12-18 11:14:45 -08:00 committed by Commit bot
parent b10d24ff2c
commit 98cf73104f

View File

@ -1191,27 +1191,18 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) {
#if V8_TARGET_ARCH_PPC64
case kPPC_DoubleToUint64: {
bool check_conversion = (i.OutputCount() > 1);
Label done;
if (check_conversion) {
// Set 2nd output to zero if conversion fails.
// We must check explicitly for negative values here since the
// conversion instruction rounds the input toward zero before
// checking for validity (otherwise, values between -1 and 0
// would produce incorrect results).
__ li(i.OutputRegister(1), Operand::Zero());
__ fcmpu(i.InputDoubleRegister(0), kDoubleRegZero);
__ blt(&done);
__ mtfsb0(VXCVI); // clear FPSCR:VXCVI bit
}
__ ConvertDoubleToUnsignedInt64(i.InputDoubleRegister(0),
i.OutputRegister(0), kScratchDoubleReg);
if (check_conversion) {
// Set 2nd output to zero if conversion fails.
CRBit crbit = static_cast<CRBit>(VXCVI % CRWIDTH);
__ mcrfs(cr7, VXCVI); // extract FPSCR field containing VXCVI into cr7
__ li(i.OutputRegister(1), Operand(1));
__ isel(i.OutputRegister(1), r0, i.OutputRegister(1),
v8::internal::Assembler::encode_crbit(cr7, crbit));
__ bind(&done);
}
DCHECK_EQ(LeaveRC, i.OutputRCBit());
break;