| OLD | NEW |
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 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 3104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3115 __ b(&done, eq); | 3115 __ b(&done, eq); |
| 3116 | 3116 |
| 3117 // Add +0 to convert -0 to +0. | 3117 // Add +0 to convert -0 to +0. |
| 3118 __ vadd(result, input, kDoubleRegZero); | 3118 __ vadd(result, input, kDoubleRegZero); |
| 3119 __ vsqrt(result, result); | 3119 __ vsqrt(result, result); |
| 3120 __ bind(&done); | 3120 __ bind(&done); |
| 3121 } | 3121 } |
| 3122 | 3122 |
| 3123 | 3123 |
| 3124 void LCodeGen::DoPower(LPower* instr) { | 3124 void LCodeGen::DoPower(LPower* instr) { |
| 3125 LOperand* left = instr->InputAt(0); | |
| 3126 LOperand* right = instr->InputAt(1); | |
| 3127 Register scratch = scratch0(); | |
| 3128 DoubleRegister result_reg = ToDoubleRegister(instr->result()); | |
| 3129 Representation exponent_type = instr->hydrogen()->right()->representation(); | 3125 Representation exponent_type = instr->hydrogen()->right()->representation(); |
| 3130 if (exponent_type.IsDouble()) { | 3126 // Having marked this as a call, we can use any registers. |
| 3131 // Prepare arguments and call C function. | 3127 // Just make sure that the input/output registers are the expected ones. |
| 3132 __ PrepareCallCFunction(0, 2, scratch); | 3128 ASSERT(!instr->InputAt(1)->IsDoubleRegister() || |
| 3133 __ SetCallCDoubleArguments(ToDoubleRegister(left), | 3129 ToDoubleRegister(instr->InputAt(1)).is(d2)); |
| 3134 ToDoubleRegister(right)); | 3130 ASSERT(!instr->InputAt(1)->IsRegister() || |
| 3135 __ CallCFunction( | 3131 ToRegister(instr->InputAt(1)).is(r2)); |
| 3136 ExternalReference::power_double_double_function(isolate()), 0, 2); | 3132 ASSERT(ToDoubleRegister(instr->InputAt(0)).is(d1)); |
| 3133 ASSERT(ToDoubleRegister(instr->result()).is(d3)); |
| 3134 |
| 3135 if (exponent_type.IsTagged()) { |
| 3136 Label no_deopt; |
| 3137 __ JumpIfSmi(r2, &no_deopt); |
| 3138 __ ldr(r7, FieldMemOperand(r2, HeapObject::kMapOffset)); |
| 3139 __ LoadRoot(ip, Heap::kHeapNumberMapRootIndex); |
| 3140 __ cmp(r7, Operand(ip)); |
| 3141 DeoptimizeIf(ne, instr->environment()); |
| 3142 __ bind(&no_deopt); |
| 3143 MathPowStub stub(MathPowStub::TAGGED); |
| 3144 __ CallStub(&stub); |
| 3137 } else if (exponent_type.IsInteger32()) { | 3145 } else if (exponent_type.IsInteger32()) { |
| 3138 ASSERT(ToRegister(right).is(r0)); | 3146 MathPowStub stub(MathPowStub::INTEGER); |
| 3139 // Prepare arguments and call C function. | 3147 __ CallStub(&stub); |
| 3140 __ PrepareCallCFunction(1, 1, scratch); | |
| 3141 __ SetCallCDoubleArguments(ToDoubleRegister(left), ToRegister(right)); | |
| 3142 __ CallCFunction( | |
| 3143 ExternalReference::power_double_int_function(isolate()), 1, 1); | |
| 3144 } else { | 3148 } else { |
| 3145 ASSERT(exponent_type.IsTagged()); | 3149 ASSERT(exponent_type.IsDouble()); |
| 3146 ASSERT(instr->hydrogen()->left()->representation().IsDouble()); | 3150 MathPowStub stub(MathPowStub::DOUBLE); |
| 3147 | 3151 __ CallStub(&stub); |
| 3148 Register right_reg = ToRegister(right); | |
| 3149 | |
| 3150 // Check for smi on the right hand side. | |
| 3151 Label non_smi, call; | |
| 3152 __ JumpIfNotSmi(right_reg, &non_smi); | |
| 3153 | |
| 3154 // Untag smi and convert it to a double. | |
| 3155 __ SmiUntag(right_reg); | |
| 3156 SwVfpRegister single_scratch = double_scratch0().low(); | |
| 3157 __ vmov(single_scratch, right_reg); | |
| 3158 __ vcvt_f64_s32(result_reg, single_scratch); | |
| 3159 __ jmp(&call); | |
| 3160 | |
| 3161 // Heap number map check. | |
| 3162 __ bind(&non_smi); | |
| 3163 __ ldr(scratch, FieldMemOperand(right_reg, HeapObject::kMapOffset)); | |
| 3164 __ LoadRoot(ip, Heap::kHeapNumberMapRootIndex); | |
| 3165 __ cmp(scratch, Operand(ip)); | |
| 3166 DeoptimizeIf(ne, instr->environment()); | |
| 3167 int32_t value_offset = HeapNumber::kValueOffset - kHeapObjectTag; | |
| 3168 __ add(scratch, right_reg, Operand(value_offset)); | |
| 3169 __ vldr(result_reg, scratch, 0); | |
| 3170 | |
| 3171 // Prepare arguments and call C function. | |
| 3172 __ bind(&call); | |
| 3173 __ PrepareCallCFunction(0, 2, scratch); | |
| 3174 __ SetCallCDoubleArguments(ToDoubleRegister(left), result_reg); | |
| 3175 __ CallCFunction( | |
| 3176 ExternalReference::power_double_double_function(isolate()), 0, 2); | |
| 3177 } | 3152 } |
| 3178 // Store the result in the result register. | |
| 3179 __ GetCFunctionDoubleResult(result_reg); | |
| 3180 } | 3153 } |
| 3181 | 3154 |
| 3182 | 3155 |
| 3183 void LCodeGen::DoMathLog(LUnaryMathOperation* instr) { | 3156 void LCodeGen::DoMathLog(LUnaryMathOperation* instr) { |
| 3184 ASSERT(ToDoubleRegister(instr->result()).is(d2)); | 3157 ASSERT(ToDoubleRegister(instr->result()).is(d2)); |
| 3185 TranscendentalCacheStub stub(TranscendentalCache::LOG, | 3158 TranscendentalCacheStub stub(TranscendentalCache::LOG, |
| 3186 TranscendentalCacheStub::UNTAGGED); | 3159 TranscendentalCacheStub::UNTAGGED); |
| 3187 CallCode(stub.GetCode(), RelocInfo::CODE_TARGET, instr); | 3160 CallCode(stub.GetCode(), RelocInfo::CODE_TARGET, instr); |
| 3188 } | 3161 } |
| 3189 | 3162 |
| (...skipping 1539 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4729 ASSERT(osr_pc_offset_ == -1); | 4702 ASSERT(osr_pc_offset_ == -1); |
| 4730 osr_pc_offset_ = masm()->pc_offset(); | 4703 osr_pc_offset_ = masm()->pc_offset(); |
| 4731 } | 4704 } |
| 4732 | 4705 |
| 4733 | 4706 |
| 4734 | 4707 |
| 4735 | 4708 |
| 4736 #undef __ | 4709 #undef __ |
| 4737 | 4710 |
| 4738 } } // namespace v8::internal | 4711 } } // namespace v8::internal |
| OLD | NEW |