| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #if V8_TARGET_ARCH_MIPS | 5 #if V8_TARGET_ARCH_MIPS |
| 6 | 6 |
| 7 // Note on Mips implementation: | 7 // Note on Mips implementation: |
| 8 // | 8 // |
| 9 // The result_register() for mips is the 'v0' register, which is defined | 9 // The result_register() for mips is the 'v0' register, which is defined |
| 10 // by the ABI to contain function return values. However, the first | 10 // by the ABI to contain function return values. However, the first |
| (...skipping 948 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 959 | 959 |
| 960 __ Branch(&next_test, ne, a1, Operand(a0)); | 960 __ Branch(&next_test, ne, a1, Operand(a0)); |
| 961 __ Drop(1); // Switch value is no longer needed. | 961 __ Drop(1); // Switch value is no longer needed. |
| 962 __ Branch(clause->body_target()); | 962 __ Branch(clause->body_target()); |
| 963 | 963 |
| 964 __ bind(&slow_case); | 964 __ bind(&slow_case); |
| 965 } | 965 } |
| 966 | 966 |
| 967 // Record position before stub call for type feedback. | 967 // Record position before stub call for type feedback. |
| 968 SetExpressionPosition(clause); | 968 SetExpressionPosition(clause); |
| 969 Handle<Code> ic = CodeFactory::CompareIC(isolate(), Token::EQ_STRICT, | 969 Handle<Code> ic = |
| 970 strength(language_mode())).code(); | 970 CodeFactory::CompareIC(isolate(), Token::EQ_STRICT).code(); |
| 971 CallIC(ic, clause->CompareId()); | 971 CallIC(ic, clause->CompareId()); |
| 972 patch_site.EmitPatchInfo(); | 972 patch_site.EmitPatchInfo(); |
| 973 | 973 |
| 974 Label skip; | 974 Label skip; |
| 975 __ Branch(&skip); | 975 __ Branch(&skip); |
| 976 PrepareForBailout(clause, TOS_REG); | 976 PrepareForBailout(clause, TOS_REG); |
| 977 __ LoadRoot(at, Heap::kTrueValueRootIndex); | 977 __ LoadRoot(at, Heap::kTrueValueRootIndex); |
| 978 __ Branch(&next_test, ne, v0, Operand(at)); | 978 __ Branch(&next_test, ne, v0, Operand(at)); |
| 979 __ Drop(1); | 979 __ Drop(1); |
| 980 __ Branch(clause->body_target()); | 980 __ Branch(clause->body_target()); |
| (...skipping 1162 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2143 __ pop(left); | 2143 __ pop(left); |
| 2144 __ mov(a0, result_register()); | 2144 __ mov(a0, result_register()); |
| 2145 | 2145 |
| 2146 // Perform combined smi check on both operands. | 2146 // Perform combined smi check on both operands. |
| 2147 __ Or(scratch1, left, Operand(right)); | 2147 __ Or(scratch1, left, Operand(right)); |
| 2148 STATIC_ASSERT(kSmiTag == 0); | 2148 STATIC_ASSERT(kSmiTag == 0); |
| 2149 JumpPatchSite patch_site(masm_); | 2149 JumpPatchSite patch_site(masm_); |
| 2150 patch_site.EmitJumpIfSmi(scratch1, &smi_case); | 2150 patch_site.EmitJumpIfSmi(scratch1, &smi_case); |
| 2151 | 2151 |
| 2152 __ bind(&stub_call); | 2152 __ bind(&stub_call); |
| 2153 Handle<Code> code = | 2153 Handle<Code> code = CodeFactory::BinaryOpIC(isolate(), op).code(); |
| 2154 CodeFactory::BinaryOpIC(isolate(), op, strength(language_mode())).code(); | |
| 2155 CallIC(code, expr->BinaryOperationFeedbackId()); | 2154 CallIC(code, expr->BinaryOperationFeedbackId()); |
| 2156 patch_site.EmitPatchInfo(); | 2155 patch_site.EmitPatchInfo(); |
| 2157 __ jmp(&done); | 2156 __ jmp(&done); |
| 2158 | 2157 |
| 2159 __ bind(&smi_case); | 2158 __ bind(&smi_case); |
| 2160 // Smi case. This code works the same way as the smi-smi case in the type | 2159 // Smi case. This code works the same way as the smi-smi case in the type |
| 2161 // recording binary operation stub, see | 2160 // recording binary operation stub, see |
| 2162 switch (op) { | 2161 switch (op) { |
| 2163 case Token::SAR: | 2162 case Token::SAR: |
| 2164 __ GetLeastBitsFromSmi(scratch1, right, 5); | 2163 __ GetLeastBitsFromSmi(scratch1, right, 5); |
| (...skipping 106 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2271 default: | 2270 default: |
| 2272 UNREACHABLE(); | 2271 UNREACHABLE(); |
| 2273 } | 2272 } |
| 2274 } | 2273 } |
| 2275 } | 2274 } |
| 2276 | 2275 |
| 2277 | 2276 |
| 2278 void FullCodeGenerator::EmitBinaryOp(BinaryOperation* expr, Token::Value op) { | 2277 void FullCodeGenerator::EmitBinaryOp(BinaryOperation* expr, Token::Value op) { |
| 2279 __ mov(a0, result_register()); | 2278 __ mov(a0, result_register()); |
| 2280 __ pop(a1); | 2279 __ pop(a1); |
| 2281 Handle<Code> code = | 2280 Handle<Code> code = CodeFactory::BinaryOpIC(isolate(), op).code(); |
| 2282 CodeFactory::BinaryOpIC(isolate(), op, strength(language_mode())).code(); | |
| 2283 JumpPatchSite patch_site(masm_); // unbound, signals no inlined smi code. | 2281 JumpPatchSite patch_site(masm_); // unbound, signals no inlined smi code. |
| 2284 CallIC(code, expr->BinaryOperationFeedbackId()); | 2282 CallIC(code, expr->BinaryOperationFeedbackId()); |
| 2285 patch_site.EmitPatchInfo(); | 2283 patch_site.EmitPatchInfo(); |
| 2286 context()->Plug(v0); | 2284 context()->Plug(v0); |
| 2287 } | 2285 } |
| 2288 | 2286 |
| 2289 | 2287 |
| 2290 void FullCodeGenerator::EmitAssignment(Expression* expr, | 2288 void FullCodeGenerator::EmitAssignment(Expression* expr, |
| 2291 FeedbackVectorSlot slot) { | 2289 FeedbackVectorSlot slot) { |
| 2292 DCHECK(expr->IsValidReferenceExpressionOrThis()); | 2290 DCHECK(expr->IsValidReferenceExpressionOrThis()); |
| (...skipping 1813 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4106 } | 4104 } |
| 4107 } | 4105 } |
| 4108 } | 4106 } |
| 4109 | 4107 |
| 4110 __ bind(&stub_call); | 4108 __ bind(&stub_call); |
| 4111 __ mov(a1, v0); | 4109 __ mov(a1, v0); |
| 4112 __ li(a0, Operand(Smi::FromInt(count_value))); | 4110 __ li(a0, Operand(Smi::FromInt(count_value))); |
| 4113 | 4111 |
| 4114 SetExpressionPosition(expr); | 4112 SetExpressionPosition(expr); |
| 4115 | 4113 |
| 4116 | 4114 Handle<Code> code = CodeFactory::BinaryOpIC(isolate(), Token::ADD).code(); |
| 4117 Handle<Code> code = CodeFactory::BinaryOpIC(isolate(), Token::ADD, | |
| 4118 strength(language_mode())).code(); | |
| 4119 CallIC(code, expr->CountBinOpFeedbackId()); | 4115 CallIC(code, expr->CountBinOpFeedbackId()); |
| 4120 patch_site.EmitPatchInfo(); | 4116 patch_site.EmitPatchInfo(); |
| 4121 __ bind(&done); | 4117 __ bind(&done); |
| 4122 | 4118 |
| 4123 if (is_strong(language_mode())) { | 4119 if (is_strong(language_mode())) { |
| 4124 PrepareForBailoutForId(expr->ToNumberId(), TOS_REG); | 4120 PrepareForBailoutForId(expr->ToNumberId(), TOS_REG); |
| 4125 } | 4121 } |
| 4126 // Store the value returned in v0. | 4122 // Store the value returned in v0. |
| 4127 switch (assign_type) { | 4123 switch (assign_type) { |
| 4128 case VARIABLE: | 4124 case VARIABLE: |
| (...skipping 207 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4336 bool inline_smi_code = ShouldInlineSmiCase(op); | 4332 bool inline_smi_code = ShouldInlineSmiCase(op); |
| 4337 JumpPatchSite patch_site(masm_); | 4333 JumpPatchSite patch_site(masm_); |
| 4338 if (inline_smi_code) { | 4334 if (inline_smi_code) { |
| 4339 Label slow_case; | 4335 Label slow_case; |
| 4340 __ Or(a2, a0, Operand(a1)); | 4336 __ Or(a2, a0, Operand(a1)); |
| 4341 patch_site.EmitJumpIfNotSmi(a2, &slow_case); | 4337 patch_site.EmitJumpIfNotSmi(a2, &slow_case); |
| 4342 Split(cc, a1, Operand(a0), if_true, if_false, NULL); | 4338 Split(cc, a1, Operand(a0), if_true, if_false, NULL); |
| 4343 __ bind(&slow_case); | 4339 __ bind(&slow_case); |
| 4344 } | 4340 } |
| 4345 | 4341 |
| 4346 Handle<Code> ic = CodeFactory::CompareIC( | 4342 Handle<Code> ic = CodeFactory::CompareIC(isolate(), op).code(); |
| 4347 isolate(), op, strength(language_mode())).code(); | |
| 4348 CallIC(ic, expr->CompareOperationFeedbackId()); | 4343 CallIC(ic, expr->CompareOperationFeedbackId()); |
| 4349 patch_site.EmitPatchInfo(); | 4344 patch_site.EmitPatchInfo(); |
| 4350 PrepareForBailoutBeforeSplit(expr, true, if_true, if_false); | 4345 PrepareForBailoutBeforeSplit(expr, true, if_true, if_false); |
| 4351 Split(cc, v0, Operand(zero_reg), if_true, if_false, fall_through); | 4346 Split(cc, v0, Operand(zero_reg), if_true, if_false, fall_through); |
| 4352 } | 4347 } |
| 4353 } | 4348 } |
| 4354 | 4349 |
| 4355 // Convert the result of the comparison into one expected for this | 4350 // Convert the result of the comparison into one expected for this |
| 4356 // expression's context. | 4351 // expression's context. |
| 4357 context()->Plug(if_true, if_false); | 4352 context()->Plug(if_true, if_false); |
| (...skipping 224 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4582 reinterpret_cast<uint32_t>( | 4577 reinterpret_cast<uint32_t>( |
| 4583 isolate->builtins()->OsrAfterStackCheck()->entry())); | 4578 isolate->builtins()->OsrAfterStackCheck()->entry())); |
| 4584 return OSR_AFTER_STACK_CHECK; | 4579 return OSR_AFTER_STACK_CHECK; |
| 4585 } | 4580 } |
| 4586 | 4581 |
| 4587 | 4582 |
| 4588 } // namespace internal | 4583 } // namespace internal |
| 4589 } // namespace v8 | 4584 } // namespace v8 |
| 4590 | 4585 |
| 4591 #endif // V8_TARGET_ARCH_MIPS | 4586 #endif // V8_TARGET_ARCH_MIPS |
| OLD | NEW |