| 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/codegen.h" | 8 #include "src/codegen.h" |
| 9 #include "src/deoptimizer.h" | 9 #include "src/deoptimizer.h" |
| 10 #include "src/full-codegen/full-codegen.h" | 10 #include "src/full-codegen/full-codegen.h" |
| (...skipping 1601 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1612 __ PushReturnAddressFrom(ecx); | 1612 __ PushReturnAddressFrom(ecx); |
| 1613 } | 1613 } |
| 1614 | 1614 |
| 1615 // ----------- S t a t e ------------- | 1615 // ----------- S t a t e ------------- |
| 1616 // -- ebx : argArray | 1616 // -- ebx : argArray |
| 1617 // -- edi : receiver | 1617 // -- edi : receiver |
| 1618 // -- esp[0] : return address | 1618 // -- esp[0] : return address |
| 1619 // -- esp[4] : thisArg | 1619 // -- esp[4] : thisArg |
| 1620 // ----------------------------------- | 1620 // ----------------------------------- |
| 1621 | 1621 |
| 1622 // 2. Make sure the receiver is actually callable. | 1622 // 2. We don't need to check explicitly for callable receiver here, |
| 1623 Label receiver_not_callable; | 1623 // since that's the first thing the Call/CallWithArrayLike builtins |
| 1624 __ JumpIfSmi(edi, &receiver_not_callable, Label::kNear); | 1624 // will do. |
| 1625 __ mov(ecx, FieldOperand(edi, HeapObject::kMapOffset)); | |
| 1626 __ test_b(FieldOperand(ecx, Map::kBitFieldOffset), | |
| 1627 Immediate(1 << Map::kIsCallable)); | |
| 1628 __ j(zero, &receiver_not_callable, Label::kNear); | |
| 1629 | 1625 |
| 1630 // 3. Tail call with no arguments if argArray is null or undefined. | 1626 // 3. Tail call with no arguments if argArray is null or undefined. |
| 1631 Label no_arguments; | 1627 Label no_arguments; |
| 1632 __ JumpIfRoot(ebx, Heap::kNullValueRootIndex, &no_arguments, Label::kNear); | 1628 __ JumpIfRoot(ebx, Heap::kNullValueRootIndex, &no_arguments, Label::kNear); |
| 1633 __ JumpIfRoot(ebx, Heap::kUndefinedValueRootIndex, &no_arguments, | 1629 __ JumpIfRoot(ebx, Heap::kUndefinedValueRootIndex, &no_arguments, |
| 1634 Label::kNear); | 1630 Label::kNear); |
| 1635 | 1631 |
| 1636 // 4a. Apply the receiver to the given argArray. | 1632 // 4a. Apply the receiver to the given argArray. |
| 1637 __ Jump(masm->isolate()->builtins()->CallWithArrayLike(), | 1633 __ Jump(masm->isolate()->builtins()->CallWithArrayLike(), |
| 1638 RelocInfo::CODE_TARGET); | 1634 RelocInfo::CODE_TARGET); |
| 1639 | 1635 |
| 1640 // 4b. The argArray is either null or undefined, so we tail call without any | 1636 // 4b. The argArray is either null or undefined, so we tail call without any |
| 1641 // arguments to the receiver. | 1637 // arguments to the receiver. |
| 1642 __ bind(&no_arguments); | 1638 __ bind(&no_arguments); |
| 1643 { | 1639 { |
| 1644 __ Set(eax, 0); | 1640 __ Set(eax, 0); |
| 1645 __ Jump(masm->isolate()->builtins()->Call(), RelocInfo::CODE_TARGET); | 1641 __ Jump(masm->isolate()->builtins()->Call(), RelocInfo::CODE_TARGET); |
| 1646 } | 1642 } |
| 1647 | |
| 1648 // 4c. The receiver is not callable, throw an appropriate TypeError. | |
| 1649 __ bind(&receiver_not_callable); | |
| 1650 { | |
| 1651 __ mov(Operand(esp, kPointerSize), edi); | |
| 1652 __ TailCallRuntime(Runtime::kThrowApplyNonFunction); | |
| 1653 } | |
| 1654 } | 1643 } |
| 1655 | 1644 |
| 1656 // static | 1645 // static |
| 1657 void Builtins::Generate_FunctionPrototypeCall(MacroAssembler* masm) { | 1646 void Builtins::Generate_FunctionPrototypeCall(MacroAssembler* masm) { |
| 1658 // Stack Layout: | 1647 // Stack Layout: |
| 1659 // esp[0] : Return address | 1648 // esp[0] : Return address |
| 1660 // esp[8] : Argument n | 1649 // esp[8] : Argument n |
| 1661 // esp[16] : Argument n-1 | 1650 // esp[16] : Argument n-1 |
| 1662 // ... | 1651 // ... |
| 1663 // esp[8 * n] : Argument 1 | 1652 // esp[8 * n] : Argument 1 |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1732 __ PushReturnAddressFrom(ecx); | 1721 __ PushReturnAddressFrom(ecx); |
| 1733 } | 1722 } |
| 1734 | 1723 |
| 1735 // ----------- S t a t e ------------- | 1724 // ----------- S t a t e ------------- |
| 1736 // -- ebx : argumentsList | 1725 // -- ebx : argumentsList |
| 1737 // -- edi : target | 1726 // -- edi : target |
| 1738 // -- esp[0] : return address | 1727 // -- esp[0] : return address |
| 1739 // -- esp[4] : thisArgument | 1728 // -- esp[4] : thisArgument |
| 1740 // ----------------------------------- | 1729 // ----------------------------------- |
| 1741 | 1730 |
| 1742 // 2. Make sure the target is actually callable. | 1731 // 2. We don't need to check explicitly for callable target here, |
| 1743 Label target_not_callable; | 1732 // since that's the first thing the Call/CallWithArrayLike builtins |
| 1744 __ JumpIfSmi(edi, &target_not_callable, Label::kNear); | 1733 // will do. |
| 1745 __ mov(ecx, FieldOperand(edi, HeapObject::kMapOffset)); | |
| 1746 __ test_b(FieldOperand(ecx, Map::kBitFieldOffset), | |
| 1747 Immediate(1 << Map::kIsCallable)); | |
| 1748 __ j(zero, &target_not_callable, Label::kNear); | |
| 1749 | 1734 |
| 1750 // 3a. Apply the target to the given argumentsList. | 1735 // 3. Apply the target to the given argumentsList. |
| 1751 __ Jump(masm->isolate()->builtins()->CallWithArrayLike(), | 1736 __ Jump(masm->isolate()->builtins()->CallWithArrayLike(), |
| 1752 RelocInfo::CODE_TARGET); | 1737 RelocInfo::CODE_TARGET); |
| 1753 | |
| 1754 // 3b. The target is not callable, throw an appropriate TypeError. | |
| 1755 __ bind(&target_not_callable); | |
| 1756 { | |
| 1757 __ mov(Operand(esp, kPointerSize), edi); | |
| 1758 __ TailCallRuntime(Runtime::kThrowApplyNonFunction); | |
| 1759 } | |
| 1760 } | 1738 } |
| 1761 | 1739 |
| 1762 void Builtins::Generate_ReflectConstruct(MacroAssembler* masm) { | 1740 void Builtins::Generate_ReflectConstruct(MacroAssembler* masm) { |
| 1763 // ----------- S t a t e ------------- | 1741 // ----------- S t a t e ------------- |
| 1764 // -- eax : argc | 1742 // -- eax : argc |
| 1765 // -- esp[0] : return address | 1743 // -- esp[0] : return address |
| 1766 // -- esp[4] : new.target (optional) | 1744 // -- esp[4] : new.target (optional) |
| 1767 // -- esp[8] : argumentsList | 1745 // -- esp[8] : argumentsList |
| 1768 // -- esp[12] : target | 1746 // -- esp[12] : target |
| 1769 // -- esp[16] : receiver | 1747 // -- esp[16] : receiver |
| (...skipping 1533 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3303 } | 3281 } |
| 3304 // Now jump to the instructions of the returned code object. | 3282 // Now jump to the instructions of the returned code object. |
| 3305 __ jmp(edi); | 3283 __ jmp(edi); |
| 3306 } | 3284 } |
| 3307 | 3285 |
| 3308 #undef __ | 3286 #undef __ |
| 3309 } // namespace internal | 3287 } // namespace internal |
| 3310 } // namespace v8 | 3288 } // namespace v8 |
| 3311 | 3289 |
| 3312 #endif // V8_TARGET_ARCH_IA32 | 3290 #endif // V8_TARGET_ARCH_IA32 |
| OLD | NEW |