| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 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 #include "src/crankshaft/ppc/lithium-codegen-ppc.h" | 5 #include "src/crankshaft/ppc/lithium-codegen-ppc.h" |
| 6 | 6 |
| 7 #include "src/base/bits.h" | 7 #include "src/base/bits.h" |
| 8 #include "src/builtins/builtins-constructor.h" | 8 #include "src/builtins/builtins-constructor.h" |
| 9 #include "src/code-factory.h" | 9 #include "src/code-factory.h" |
| 10 #include "src/code-stubs.h" | 10 #include "src/code-stubs.h" |
| (...skipping 4336 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4347 __ LoadP(result, ToMemOperand(instr->object())); | 4347 __ LoadP(result, ToMemOperand(instr->object())); |
| 4348 } | 4348 } |
| 4349 | 4349 |
| 4350 LOperand* key = instr->key(); | 4350 LOperand* key = instr->key(); |
| 4351 if (key->IsConstantOperand()) { | 4351 if (key->IsConstantOperand()) { |
| 4352 LConstantOperand* constant_key = LConstantOperand::cast(key); | 4352 LConstantOperand* constant_key = LConstantOperand::cast(key); |
| 4353 int32_t int_key = ToInteger32(constant_key); | 4353 int32_t int_key = ToInteger32(constant_key); |
| 4354 if (Smi::IsValid(int_key)) { | 4354 if (Smi::IsValid(int_key)) { |
| 4355 __ LoadSmiLiteral(r6, Smi::FromInt(int_key)); | 4355 __ LoadSmiLiteral(r6, Smi::FromInt(int_key)); |
| 4356 } else { | 4356 } else { |
| 4357 // We should never get here at runtime because there is a smi check on | 4357 Abort(kArrayIndexConstantValueTooBig); |
| 4358 // the key before this point. | |
| 4359 __ stop("expected smi"); | |
| 4360 } | 4358 } |
| 4361 } else { | 4359 } else { |
| 4360 Label is_smi; |
| 4361 #if V8_TARGET_ARCH_PPC64 |
| 4362 __ SmiTag(r6, ToRegister(key)); | 4362 __ SmiTag(r6, ToRegister(key)); |
| 4363 #else |
| 4364 // Deopt if the key is outside Smi range. The stub expects Smi and would |
| 4365 // bump the elements into dictionary mode (and trigger a deopt) anyways. |
| 4366 __ SmiTagCheckOverflow(r6, ToRegister(key), r0); |
| 4367 __ BranchOnNoOverflow(&is_smi); |
| 4368 __ PopSafepointRegisters(); |
| 4369 DeoptimizeIf(al, instr, DeoptimizeReason::kOverflow, cr0); |
| 4370 __ bind(&is_smi); |
| 4371 #endif |
| 4363 } | 4372 } |
| 4364 | 4373 |
| 4365 GrowArrayElementsStub stub(isolate(), instr->hydrogen()->kind()); | 4374 GrowArrayElementsStub stub(isolate(), instr->hydrogen()->kind()); |
| 4366 __ CallStub(&stub); | 4375 __ CallStub(&stub); |
| 4367 RecordSafepointWithLazyDeopt( | 4376 RecordSafepointWithLazyDeopt( |
| 4368 instr, RECORD_SAFEPOINT_WITH_REGISTERS_AND_NO_ARGUMENTS); | 4377 instr, RECORD_SAFEPOINT_WITH_REGISTERS_AND_NO_ARGUMENTS); |
| 4369 __ StoreToSafepointRegisterSlot(result, result); | 4378 __ StoreToSafepointRegisterSlot(result, result); |
| 4370 } | 4379 } |
| 4371 | 4380 |
| 4372 // Deopt on smi, which means the elements array changed to dictionary mode. | 4381 // Deopt on smi, which means the elements array changed to dictionary mode. |
| (...skipping 1315 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 5688 __ LoadP(result, | 5697 __ LoadP(result, |
| 5689 FieldMemOperand(scratch, FixedArray::kHeaderSize - kPointerSize)); | 5698 FieldMemOperand(scratch, FixedArray::kHeaderSize - kPointerSize)); |
| 5690 __ bind(deferred->exit()); | 5699 __ bind(deferred->exit()); |
| 5691 __ bind(&done); | 5700 __ bind(&done); |
| 5692 } | 5701 } |
| 5693 | 5702 |
| 5694 #undef __ | 5703 #undef __ |
| 5695 | 5704 |
| 5696 } // namespace internal | 5705 } // namespace internal |
| 5697 } // namespace v8 | 5706 } // namespace v8 |
| OLD | NEW |