| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 3499 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3510 SmiCheckType smi_check_type) { | 3510 SmiCheckType smi_check_type) { |
| 3511 if (smi_check_type == DO_SMI_CHECK) { | 3511 if (smi_check_type == DO_SMI_CHECK) { |
| 3512 JumpIfSmi(obj, fail); | 3512 JumpIfSmi(obj, fail); |
| 3513 } | 3513 } |
| 3514 lw(scratch, FieldMemOperand(obj, HeapObject::kMapOffset)); | 3514 lw(scratch, FieldMemOperand(obj, HeapObject::kMapOffset)); |
| 3515 LoadRoot(at, index); | 3515 LoadRoot(at, index); |
| 3516 Branch(fail, ne, scratch, Operand(at)); | 3516 Branch(fail, ne, scratch, Operand(at)); |
| 3517 } | 3517 } |
| 3518 | 3518 |
| 3519 | 3519 |
| 3520 void MacroAssembler::GetCFunctionDoubleResult(const DoubleRegister dst) { | 3520 void MacroAssembler::MovFromFloatResult(DoubleRegister dst) { |
| 3521 if (IsMipsSoftFloatABI) { | 3521 if (IsMipsSoftFloatABI) { |
| 3522 Move(dst, v0, v1); | 3522 Move(dst, v0, v1); |
| 3523 } else { | 3523 } else { |
| 3524 Move(dst, f0); // Reg f0 is o32 ABI FP return value. | 3524 Move(dst, f0); // Reg f0 is o32 ABI FP return value. |
| 3525 } | 3525 } |
| 3526 } | 3526 } |
| 3527 | 3527 |
| 3528 | 3528 |
| 3529 void MacroAssembler::GetFromCDoubleArguments(const DoubleRegister dst) { | 3529 void MacroAssembler::MovFromFloatParameter(DoubleRegister dst) { |
| 3530 if (IsMipsSoftFloatABI) { | 3530 if (IsMipsSoftFloatABI) { |
| 3531 Move(dst, a0, a1); | 3531 Move(dst, a0, a1); |
| 3532 } else { | 3532 } else { |
| 3533 Move(dst, f12); // Reg f12 is o32 ABI FP first argument value. | 3533 Move(dst, f12); // Reg f12 is o32 ABI FP first argument value. |
| 3534 } | 3534 } |
| 3535 } | 3535 } |
| 3536 | 3536 |
| 3537 | 3537 |
| 3538 void MacroAssembler::SetCallCDoubleArguments(DoubleRegister dreg) { | 3538 void MacroAssembler::MovToFloatParameter(DoubleRegister src) { |
| 3539 if (!IsMipsSoftFloatABI) { | 3539 if (!IsMipsSoftFloatABI) { |
| 3540 Move(f12, dreg); | 3540 Move(f12, src); |
| 3541 } else { | 3541 } else { |
| 3542 Move(a0, a1, dreg); | 3542 Move(a0, a1, src); |
| 3543 } | 3543 } |
| 3544 } | 3544 } |
| 3545 | 3545 |
| 3546 | 3546 |
| 3547 void MacroAssembler::SetForCDoubleResult(DoubleRegister dreg) { | 3547 void MacroAssembler::MovToFloatResult(DoubleRegister src) { |
| 3548 if (!IsMipsSoftFloatABI) { | 3548 if (!IsMipsSoftFloatABI) { |
| 3549 Move(f0, dreg); | 3549 Move(f0, src); |
| 3550 } else { | 3550 } else { |
| 3551 Move(v0, v1, dreg); | 3551 Move(v0, v1, src); |
| 3552 } | 3552 } |
| 3553 } | 3553 } |
| 3554 | 3554 |
| 3555 | 3555 |
| 3556 void MacroAssembler::SetCallCDoubleArguments(DoubleRegister dreg1, | 3556 void MacroAssembler::MovToFloatParameters(DoubleRegister src1, |
| 3557 DoubleRegister dreg2) { | 3557 DoubleRegister src2) { |
| 3558 if (!IsMipsSoftFloatABI) { | 3558 if (!IsMipsSoftFloatABI) { |
| 3559 if (dreg2.is(f12)) { | 3559 if (src2.is(f12)) { |
| 3560 ASSERT(!dreg1.is(f14)); | 3560 ASSERT(!src1.is(f14)); |
| 3561 Move(f14, dreg2); | 3561 Move(f14, src2); |
| 3562 Move(f12, dreg1); | 3562 Move(f12, src1); |
| 3563 } else { | 3563 } else { |
| 3564 Move(f12, dreg1); | 3564 Move(f12, src1); |
| 3565 Move(f14, dreg2); | 3565 Move(f14, src2); |
| 3566 } | 3566 } |
| 3567 } else { | 3567 } else { |
| 3568 Move(a0, a1, dreg1); | 3568 Move(a0, a1, src1); |
| 3569 Move(a2, a3, dreg2); | 3569 Move(a2, a3, src2); |
| 3570 } | 3570 } |
| 3571 } | 3571 } |
| 3572 | 3572 |
| 3573 | |
| 3574 void MacroAssembler::SetCallCDoubleArguments(DoubleRegister dreg, | |
| 3575 Register reg) { | |
| 3576 if (!IsMipsSoftFloatABI) { | |
| 3577 Move(f12, dreg); | |
| 3578 Move(a2, reg); | |
| 3579 } else { | |
| 3580 Move(a2, reg); | |
| 3581 Move(a0, a1, dreg); | |
| 3582 } | |
| 3583 } | |
| 3584 | |
| 3585 | 3573 |
| 3586 void MacroAssembler::SetCallKind(Register dst, CallKind call_kind) { | 3574 void MacroAssembler::SetCallKind(Register dst, CallKind call_kind) { |
| 3587 // This macro takes the dst register to make the code more readable | 3575 // This macro takes the dst register to make the code more readable |
| 3588 // at the call sites. However, the dst register has to be t1 to | 3576 // at the call sites. However, the dst register has to be t1 to |
| 3589 // follow the calling convention which requires the call type to be | 3577 // follow the calling convention which requires the call type to be |
| 3590 // in t1. | 3578 // in t1. |
| 3591 ASSERT(dst.is(t1)); | 3579 ASSERT(dst.is(t1)); |
| 3592 if (call_kind == CALL_AS_FUNCTION) { | 3580 if (call_kind == CALL_AS_FUNCTION) { |
| 3593 li(dst, Operand(Smi::FromInt(1))); | 3581 li(dst, Operand(Smi::FromInt(1))); |
| 3594 } else { | 3582 } else { |
| (...skipping 2212 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 5807 opcode == BGTZL); | 5795 opcode == BGTZL); |
| 5808 opcode = (cond == eq) ? BEQ : BNE; | 5796 opcode = (cond == eq) ? BEQ : BNE; |
| 5809 instr = (instr & ~kOpcodeMask) | opcode; | 5797 instr = (instr & ~kOpcodeMask) | opcode; |
| 5810 masm_.emit(instr); | 5798 masm_.emit(instr); |
| 5811 } | 5799 } |
| 5812 | 5800 |
| 5813 | 5801 |
| 5814 } } // namespace v8::internal | 5802 } } // namespace v8::internal |
| 5815 | 5803 |
| 5816 #endif // V8_TARGET_ARCH_MIPS | 5804 #endif // V8_TARGET_ARCH_MIPS |
| OLD | NEW |