| 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_IA32 | 5 #if V8_TARGET_ARCH_IA32 |
| 6 | 6 |
| 7 #include "src/code-factory.h" | 7 #include "src/code-factory.h" |
| 8 #include "src/code-stubs.h" | 8 #include "src/code-stubs.h" |
| 9 #include "src/codegen.h" | 9 #include "src/codegen.h" |
| 10 #include "src/debug/debug.h" | 10 #include "src/debug/debug.h" |
| (...skipping 1672 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1683 for (; array_index < length; array_index++) { | 1683 for (; array_index < length; array_index++) { |
| 1684 Expression* subexpr = subexprs->at(array_index); | 1684 Expression* subexpr = subexprs->at(array_index); |
| 1685 if (subexpr->IsSpread()) break; | 1685 if (subexpr->IsSpread()) break; |
| 1686 | 1686 |
| 1687 // If the subexpression is a literal or a simple materialized literal it | 1687 // If the subexpression is a literal or a simple materialized literal it |
| 1688 // is already set in the cloned array. | 1688 // is already set in the cloned array. |
| 1689 if (CompileTimeValue::IsCompileTimeValue(subexpr)) continue; | 1689 if (CompileTimeValue::IsCompileTimeValue(subexpr)) continue; |
| 1690 | 1690 |
| 1691 if (!result_saved) { | 1691 if (!result_saved) { |
| 1692 __ push(eax); // array literal. | 1692 __ push(eax); // array literal. |
| 1693 __ push(Immediate(Smi::FromInt(expr->literal_index()))); | |
| 1694 result_saved = true; | 1693 result_saved = true; |
| 1695 } | 1694 } |
| 1696 VisitForAccumulatorValue(subexpr); | 1695 VisitForAccumulatorValue(subexpr); |
| 1697 | 1696 |
| 1698 __ mov(StoreDescriptor::NameRegister(), | 1697 __ mov(StoreDescriptor::NameRegister(), |
| 1699 Immediate(Smi::FromInt(array_index))); | 1698 Immediate(Smi::FromInt(array_index))); |
| 1700 __ mov(StoreDescriptor::ReceiverRegister(), Operand(esp, kPointerSize)); | 1699 __ mov(StoreDescriptor::ReceiverRegister(), Operand(esp, 0)); |
| 1701 EmitLoadStoreICSlot(expr->LiteralFeedbackSlot()); | 1700 EmitLoadStoreICSlot(expr->LiteralFeedbackSlot()); |
| 1702 Handle<Code> ic = | 1701 Handle<Code> ic = |
| 1703 CodeFactory::KeyedStoreIC(isolate(), language_mode()).code(); | 1702 CodeFactory::KeyedStoreIC(isolate(), language_mode()).code(); |
| 1704 CallIC(ic); | 1703 CallIC(ic); |
| 1705 PrepareForBailoutForId(expr->GetIdForElement(array_index), NO_REGISTERS); | 1704 PrepareForBailoutForId(expr->GetIdForElement(array_index), NO_REGISTERS); |
| 1706 } | 1705 } |
| 1707 | 1706 |
| 1708 // In case the array literal contains spread expressions it has two parts. The | 1707 // In case the array literal contains spread expressions it has two parts. The |
| 1709 // first part is the "static" array which has a literal index is handled | 1708 // first part is the "static" array which has a literal index is handled |
| 1710 // above. The second part is the part after the first spread expression | 1709 // above. The second part is the part after the first spread expression |
| 1711 // (inclusive) and these elements gets appended to the array. Note that the | 1710 // (inclusive) and these elements gets appended to the array. Note that the |
| 1712 // number elements an iterable produces is unknown ahead of time. | 1711 // number elements an iterable produces is unknown ahead of time. |
| 1713 if (array_index < length && result_saved) { | 1712 if (array_index < length && result_saved) { |
| 1714 __ Drop(1); // literal index | |
| 1715 __ Pop(eax); | 1713 __ Pop(eax); |
| 1716 result_saved = false; | 1714 result_saved = false; |
| 1717 } | 1715 } |
| 1718 for (; array_index < length; array_index++) { | 1716 for (; array_index < length; array_index++) { |
| 1719 Expression* subexpr = subexprs->at(array_index); | 1717 Expression* subexpr = subexprs->at(array_index); |
| 1720 | 1718 |
| 1721 __ Push(eax); | 1719 __ Push(eax); |
| 1722 if (subexpr->IsSpread()) { | 1720 if (subexpr->IsSpread()) { |
| 1723 VisitForStackValue(subexpr->AsSpread()->expression()); | 1721 VisitForStackValue(subexpr->AsSpread()->expression()); |
| 1724 __ InvokeBuiltin(Context::CONCAT_ITERABLE_TO_ARRAY_BUILTIN_INDEX, | 1722 __ InvokeBuiltin(Context::CONCAT_ITERABLE_TO_ARRAY_BUILTIN_INDEX, |
| 1725 CALL_FUNCTION); | 1723 CALL_FUNCTION); |
| 1726 } else { | 1724 } else { |
| 1727 VisitForStackValue(subexpr); | 1725 VisitForStackValue(subexpr); |
| 1728 __ CallRuntime(Runtime::kAppendElement, 2); | 1726 __ CallRuntime(Runtime::kAppendElement, 2); |
| 1729 } | 1727 } |
| 1730 | 1728 |
| 1731 PrepareForBailoutForId(expr->GetIdForElement(array_index), NO_REGISTERS); | 1729 PrepareForBailoutForId(expr->GetIdForElement(array_index), NO_REGISTERS); |
| 1732 } | 1730 } |
| 1733 | 1731 |
| 1734 if (result_saved) { | 1732 if (result_saved) { |
| 1735 __ Drop(1); // literal index | |
| 1736 context()->PlugTOS(); | 1733 context()->PlugTOS(); |
| 1737 } else { | 1734 } else { |
| 1738 context()->Plug(eax); | 1735 context()->Plug(eax); |
| 1739 } | 1736 } |
| 1740 } | 1737 } |
| 1741 | 1738 |
| 1742 | 1739 |
| 1743 void FullCodeGenerator::VisitAssignment(Assignment* expr) { | 1740 void FullCodeGenerator::VisitAssignment(Assignment* expr) { |
| 1744 DCHECK(expr->target()->IsValidReferenceExpressionOrThis()); | 1741 DCHECK(expr->target()->IsValidReferenceExpressionOrThis()); |
| 1745 | 1742 |
| (...skipping 3173 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4919 Assembler::target_address_at(call_target_address, | 4916 Assembler::target_address_at(call_target_address, |
| 4920 unoptimized_code)); | 4917 unoptimized_code)); |
| 4921 return OSR_AFTER_STACK_CHECK; | 4918 return OSR_AFTER_STACK_CHECK; |
| 4922 } | 4919 } |
| 4923 | 4920 |
| 4924 | 4921 |
| 4925 } // namespace internal | 4922 } // namespace internal |
| 4926 } // namespace v8 | 4923 } // namespace v8 |
| 4927 | 4924 |
| 4928 #endif // V8_TARGET_ARCH_IA32 | 4925 #endif // V8_TARGET_ARCH_IA32 |
| OLD | NEW |