Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(27)

Side by Side Diff: src/builtins/ia32/builtins-ia32.cc

Issue 2950773002: [turbofan] Introduce new JSCallWithArrayLike operator. (Closed)
Patch Set: Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698