| 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 | 5 |
| 6 | 6 |
| 7 #include "src/v8.h" | 7 #include "src/v8.h" |
| 8 | 8 |
| 9 #if V8_TARGET_ARCH_MIPS | 9 #if V8_TARGET_ARCH_MIPS |
| 10 | 10 |
| (...skipping 623 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 634 // a2 is an AllocationSite. We are creating a memento from it, so we | 634 // a2 is an AllocationSite. We are creating a memento from it, so we |
| 635 // need to increment the memento create count. | 635 // need to increment the memento create count. |
| 636 __ lw(a3, FieldMemOperand(a2, | 636 __ lw(a3, FieldMemOperand(a2, |
| 637 AllocationSite::kPretenureCreateCountOffset)); | 637 AllocationSite::kPretenureCreateCountOffset)); |
| 638 __ Addu(a3, a3, Operand(Smi::FromInt(1))); | 638 __ Addu(a3, a3, Operand(Smi::FromInt(1))); |
| 639 __ sw(a3, FieldMemOperand(a2, | 639 __ sw(a3, FieldMemOperand(a2, |
| 640 AllocationSite::kPretenureCreateCountOffset)); | 640 AllocationSite::kPretenureCreateCountOffset)); |
| 641 __ bind(&count_incremented); | 641 __ bind(&count_incremented); |
| 642 } | 642 } |
| 643 | 643 |
| 644 __ Pop(a1); |
| 645 |
| 644 __ Push(t4, t4); | 646 __ Push(t4, t4); |
| 645 | 647 |
| 646 // Reload the number of arguments from the stack. | 648 // Reload the number of arguments from the stack. |
| 647 // sp[0]: receiver | 649 // sp[0]: receiver |
| 648 // sp[1]: receiver | 650 // sp[1]: receiver |
| 649 // sp[2]: constructor function | 651 // sp[2]: number of arguments (smi-tagged) |
| 650 // sp[3]: number of arguments (smi-tagged) | 652 __ lw(a3, MemOperand(sp, 2 * kPointerSize)); |
| 651 __ lw(a1, MemOperand(sp, 2 * kPointerSize)); | |
| 652 __ lw(a3, MemOperand(sp, 3 * kPointerSize)); | |
| 653 | 653 |
| 654 // Set up pointer to last argument. | 654 // Set up pointer to last argument. |
| 655 __ Addu(a2, fp, Operand(StandardFrameConstants::kCallerSPOffset)); | 655 __ Addu(a2, fp, Operand(StandardFrameConstants::kCallerSPOffset)); |
| 656 | 656 |
| 657 // Set up number of arguments for function call below. | 657 // Set up number of arguments for function call below. |
| 658 __ srl(a0, a3, kSmiTagSize); | 658 __ srl(a0, a3, kSmiTagSize); |
| 659 | 659 |
| 660 // Copy arguments and receiver to the expression stack. | 660 // Copy arguments and receiver to the expression stack. |
| 661 // a0: number of arguments | 661 // a0: number of arguments |
| 662 // a1: constructor function | 662 // a1: constructor function |
| 663 // a2: address of last argument (caller sp) | 663 // a2: address of last argument (caller sp) |
| 664 // a3: number of arguments (smi-tagged) | 664 // a3: number of arguments (smi-tagged) |
| 665 // sp[0]: receiver | 665 // sp[0]: receiver |
| 666 // sp[1]: receiver | 666 // sp[1]: receiver |
| 667 // sp[2]: constructor function | 667 // sp[2]: number of arguments (smi-tagged) |
| 668 // sp[3]: number of arguments (smi-tagged) | |
| 669 Label loop, entry; | 668 Label loop, entry; |
| 670 __ jmp(&entry); | 669 __ jmp(&entry); |
| 671 __ bind(&loop); | 670 __ bind(&loop); |
| 672 __ sll(t0, a3, kPointerSizeLog2 - kSmiTagSize); | 671 __ sll(t0, a3, kPointerSizeLog2 - kSmiTagSize); |
| 673 __ Addu(t0, a2, Operand(t0)); | 672 __ Addu(t0, a2, Operand(t0)); |
| 674 __ lw(t1, MemOperand(t0)); | 673 __ lw(t1, MemOperand(t0)); |
| 675 __ push(t1); | 674 __ push(t1); |
| 676 __ bind(&entry); | 675 __ bind(&entry); |
| 677 __ Addu(a3, a3, Operand(-2)); | 676 __ Addu(a3, a3, Operand(-2)); |
| 678 __ Branch(&loop, greater_equal, a3, Operand(zero_reg)); | 677 __ Branch(&loop, greater_equal, a3, Operand(zero_reg)); |
| (...skipping 20 matching lines...) Expand all Loading... |
| 699 __ lw(cp, MemOperand(fp, StandardFrameConstants::kContextOffset)); | 698 __ lw(cp, MemOperand(fp, StandardFrameConstants::kContextOffset)); |
| 700 | 699 |
| 701 // If the result is an object (in the ECMA sense), we should get rid | 700 // If the result is an object (in the ECMA sense), we should get rid |
| 702 // of the receiver and use the result; see ECMA-262 section 13.2.2-7 | 701 // of the receiver and use the result; see ECMA-262 section 13.2.2-7 |
| 703 // on page 74. | 702 // on page 74. |
| 704 Label use_receiver, exit; | 703 Label use_receiver, exit; |
| 705 | 704 |
| 706 // If the result is a smi, it is *not* an object in the ECMA sense. | 705 // If the result is a smi, it is *not* an object in the ECMA sense. |
| 707 // v0: result | 706 // v0: result |
| 708 // sp[0]: receiver (newly allocated object) | 707 // sp[0]: receiver (newly allocated object) |
| 709 // sp[1]: constructor function | 708 // sp[1]: number of arguments (smi-tagged) |
| 710 // sp[2]: number of arguments (smi-tagged) | |
| 711 __ JumpIfSmi(v0, &use_receiver); | 709 __ JumpIfSmi(v0, &use_receiver); |
| 712 | 710 |
| 713 // If the type of the result (stored in its map) is less than | 711 // If the type of the result (stored in its map) is less than |
| 714 // FIRST_SPEC_OBJECT_TYPE, it is not an object in the ECMA sense. | 712 // FIRST_SPEC_OBJECT_TYPE, it is not an object in the ECMA sense. |
| 715 __ GetObjectType(v0, a1, a3); | 713 __ GetObjectType(v0, a1, a3); |
| 716 __ Branch(&exit, greater_equal, a3, Operand(FIRST_SPEC_OBJECT_TYPE)); | 714 __ Branch(&exit, greater_equal, a3, Operand(FIRST_SPEC_OBJECT_TYPE)); |
| 717 | 715 |
| 718 // Throw away the result of the constructor invocation and use the | 716 // Throw away the result of the constructor invocation and use the |
| 719 // on-stack receiver as the result. | 717 // on-stack receiver as the result. |
| 720 __ bind(&use_receiver); | 718 __ bind(&use_receiver); |
| 721 __ lw(v0, MemOperand(sp)); | 719 __ lw(v0, MemOperand(sp)); |
| 722 | 720 |
| 723 // Remove receiver from the stack, remove caller arguments, and | 721 // Remove receiver from the stack, remove caller arguments, and |
| 724 // return. | 722 // return. |
| 725 __ bind(&exit); | 723 __ bind(&exit); |
| 726 // v0: result | 724 // v0: result |
| 727 // sp[0]: receiver (newly allocated object) | 725 // sp[0]: receiver (newly allocated object) |
| 728 // sp[1]: constructor function | 726 // sp[1]: number of arguments (smi-tagged) |
| 729 // sp[2]: number of arguments (smi-tagged) | 727 __ lw(a1, MemOperand(sp, kPointerSize)); |
| 730 __ lw(a1, MemOperand(sp, 2 * kPointerSize)); | |
| 731 | 728 |
| 732 // Leave construct frame. | 729 // Leave construct frame. |
| 733 } | 730 } |
| 734 | 731 |
| 735 __ sll(t0, a1, kPointerSizeLog2 - 1); | 732 __ sll(t0, a1, kPointerSizeLog2 - 1); |
| 736 __ Addu(sp, sp, t0); | 733 __ Addu(sp, sp, t0); |
| 737 __ Addu(sp, sp, kPointerSize); | 734 __ Addu(sp, sp, kPointerSize); |
| 738 __ IncrementCounter(isolate->counters()->constructed_objects(), 1, a1, a2); | 735 __ IncrementCounter(isolate->counters()->constructed_objects(), 1, a1, a2); |
| 739 __ Ret(); | 736 __ Ret(); |
| 740 } | 737 } |
| (...skipping 1096 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1837 } | 1834 } |
| 1838 } | 1835 } |
| 1839 | 1836 |
| 1840 | 1837 |
| 1841 #undef __ | 1838 #undef __ |
| 1842 | 1839 |
| 1843 } // namespace internal | 1840 } // namespace internal |
| 1844 } // namespace v8 | 1841 } // namespace v8 |
| 1845 | 1842 |
| 1846 #endif // V8_TARGET_ARCH_MIPS | 1843 #endif // V8_TARGET_ARCH_MIPS |
| OLD | NEW |