| Index: src/x87/lithium-codegen-x87.cc
|
| diff --git a/src/x87/lithium-codegen-x87.cc b/src/x87/lithium-codegen-x87.cc
|
| index 4f79f84cbbac8e778dd764fa5c61c11f65f425cb..00bbe5e72bab8245367fd7619bdd6c09b94b1414 100644
|
| --- a/src/x87/lithium-codegen-x87.cc
|
| +++ b/src/x87/lithium-codegen-x87.cc
|
| @@ -4021,12 +4021,65 @@ void LCodeGen::DoMathFround(LMathFround* instr) {
|
|
|
|
|
| void LCodeGen::DoMathSqrt(LMathSqrt* instr) {
|
| - X87Register input_reg = ToX87Register(instr->value());
|
| - X87Register output_reg = ToX87Register(instr->result());
|
| - DCHECK(output_reg.is(input_reg));
|
| - USE(output_reg);
|
| - X87Fxch(input_reg);
|
| - __ fsqrt();
|
| + X87Register input = ToX87Register(instr->value());
|
| + X87Register result_reg = ToX87Register(instr->result());
|
| + Register temp_result = ToRegister(instr->temp1());
|
| + Register temp = ToRegister(instr->temp2());
|
| + Label slow, done, smi, finish;
|
| + DCHECK(result_reg.is(input));
|
| +
|
| + // Store input into Heap number and call runtime function kMathExpRT.
|
| + if (FLAG_inline_new) {
|
| + __ AllocateHeapNumber(temp_result, temp, no_reg, &slow);
|
| + __ jmp(&done, Label::kNear);
|
| + }
|
| +
|
| + // Slow case: Call the runtime system to do the number allocation.
|
| + __ bind(&slow);
|
| + {
|
| + // TODO(3095996): Put a valid pointer value in the stack slot where the
|
| + // result register is stored, as this register is in the pointer map, but
|
| + // contains an integer value.
|
| + __ Move(temp_result, Immediate(0));
|
| +
|
| + // Preserve the value of all registers.
|
| + PushSafepointRegistersScope scope(this);
|
| +
|
| + __ mov(esi, Operand(ebp, StandardFrameConstants::kContextOffset));
|
| + __ CallRuntimeSaveDoubles(Runtime::kAllocateHeapNumber);
|
| + RecordSafepointWithRegisters(
|
| + instr->pointer_map(), 0, Safepoint::kNoLazyDeopt);
|
| + __ StoreToSafepointRegisterSlot(temp_result, eax);
|
| + }
|
| + __ bind(&done);
|
| + X87LoadForUsage(input);
|
| + __ fstp_d(FieldOperand(temp_result, HeapNumber::kValueOffset));
|
| +
|
| + {
|
| + // Preserve the value of all registers.
|
| + PushSafepointRegistersScope scope(this);
|
| +
|
| + __ mov(esi, Operand(ebp, StandardFrameConstants::kContextOffset));
|
| + __ push(temp_result);
|
| + __ CallRuntimeSaveDoubles(Runtime::kMathSqrtRT);
|
| + RecordSafepointWithRegisters(
|
| + instr->pointer_map(), 0, Safepoint::kNoLazyDeopt);
|
| + __ StoreToSafepointRegisterSlot(temp_result, eax);
|
| + }
|
| + X87PrepareToWrite(result_reg);
|
| + // return value of MathExpRT is Smi or Heap Number.
|
| + __ JumpIfSmi(temp_result, &smi);
|
| + // Heap number(double)
|
| + __ fld_d(FieldOperand(temp_result, HeapNumber::kValueOffset));
|
| + __ jmp(&finish);
|
| + // SMI
|
| + __ bind(&smi);
|
| + __ SmiUntag(temp_result);
|
| + __ push(temp_result);
|
| + __ fild_s(MemOperand(esp, 0));
|
| + __ pop(temp_result);
|
| + __ bind(&finish);
|
| + X87CommitWrite(result_reg);
|
| }
|
|
|
|
|
| @@ -5302,9 +5355,10 @@ void LCodeGen::DoDoubleToI(LDoubleToI* instr) {
|
| Label lost_precision, is_nan, minus_zero, done;
|
| X87Register input_reg = ToX87Register(input);
|
| X87Fxch(input_reg);
|
| + Label::Distance dist = DeoptEveryNTimes() ? Label::kFar : Label::kNear;
|
| __ X87TOSToI(result_reg, instr->hydrogen()->GetMinusZeroMode(),
|
| - &lost_precision, &is_nan, &minus_zero, Label::kNear);
|
| - __ jmp(&done, Label::kNear);
|
| + &lost_precision, &is_nan, &minus_zero, dist);
|
| + __ jmp(&done);
|
| __ bind(&lost_precision);
|
| DeoptimizeIf(no_condition, instr, "lost precision");
|
| __ bind(&is_nan);
|
| @@ -5326,10 +5380,10 @@ void LCodeGen::DoDoubleToSmi(LDoubleToSmi* instr) {
|
| Label lost_precision, is_nan, minus_zero, done;
|
| X87Register input_reg = ToX87Register(input);
|
| X87Fxch(input_reg);
|
| + Label::Distance dist = DeoptEveryNTimes() ? Label::kFar : Label::kNear;
|
| __ X87TOSToI(result_reg, instr->hydrogen()->GetMinusZeroMode(),
|
| - &lost_precision, &is_nan, &minus_zero,
|
| - DeoptEveryNTimes() ? Label::kFar : Label::kNear);
|
| - __ jmp(&done, Label::kNear);
|
| + &lost_precision, &is_nan, &minus_zero, dist);
|
| + __ jmp(&done);
|
| __ bind(&lost_precision);
|
| DeoptimizeIf(no_condition, instr, "lost precision");
|
| __ bind(&is_nan);
|
|
|