Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 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_X64 | 5 #if V8_TARGET_ARCH_X64 |
| 6 | 6 |
| 7 #include "src/api-arguments.h" | 7 #include "src/api-arguments.h" |
| 8 #include "src/bootstrapper.h" | 8 #include "src/bootstrapper.h" |
| 9 #include "src/code-stubs.h" | 9 #include "src/code-stubs.h" |
| 10 #include "src/codegen.h" | 10 #include "src/codegen.h" |
| (...skipping 2737 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2748 __ PushRoot(Heap::kUndefinedValueRootIndex); | 2748 __ PushRoot(Heap::kUndefinedValueRootIndex); |
| 2749 // return value default | 2749 // return value default |
| 2750 __ PushRoot(Heap::kUndefinedValueRootIndex); | 2750 __ PushRoot(Heap::kUndefinedValueRootIndex); |
| 2751 // isolate | 2751 // isolate |
| 2752 Register scratch = call_data; | 2752 Register scratch = call_data; |
| 2753 __ Move(scratch, ExternalReference::isolate_address(masm->isolate())); | 2753 __ Move(scratch, ExternalReference::isolate_address(masm->isolate())); |
| 2754 __ Push(scratch); | 2754 __ Push(scratch); |
| 2755 // holder | 2755 // holder |
| 2756 __ Push(holder); | 2756 __ Push(holder); |
| 2757 | 2757 |
| 2758 if (this->is_lazy()) { | |
|
jochen (gone - plz use gerrit)
2017/06/14 09:26:01
maybe we can just enter the correct context before
Yuki
2017/06/14 13:34:52
I gave it a shot in PS8, but I failed so far. Cou
| |
| 2759 // load context from holder | |
| 2760 __ movp(scratch, FieldOperand(holder, HeapObject::kMapOffset)); | |
| 2761 __ GetMapConstructor(scratch, scratch, context); | |
| 2762 __ movp(context, FieldOperand(scratch, JSFunction::kContextOffset)); | |
| 2763 } else { | |
| 2764 // load context from callee | |
| 2765 __ movp(context, FieldOperand(callee, JSFunction::kContextOffset)); | |
| 2766 } | |
| 2767 | |
| 2758 __ movp(scratch, rsp); | 2768 __ movp(scratch, rsp); |
| 2759 // Push return address back on stack. | 2769 // Push return address back on stack. |
| 2760 __ PushReturnAddressFrom(return_address); | 2770 __ PushReturnAddressFrom(return_address); |
| 2761 | 2771 |
| 2762 if (!this->is_lazy()) { | |
| 2763 // load context from callee | |
| 2764 __ movp(context, FieldOperand(callee, JSFunction::kContextOffset)); | |
| 2765 } | |
| 2766 | |
| 2767 // Allocate the v8::Arguments structure in the arguments' space since | 2772 // Allocate the v8::Arguments structure in the arguments' space since |
| 2768 // it's not controlled by GC. | 2773 // it's not controlled by GC. |
| 2769 const int kApiStackSpace = 3; | 2774 const int kApiStackSpace = 3; |
| 2770 | 2775 |
| 2771 PrepareCallApiFunction(masm, kApiStackSpace); | 2776 PrepareCallApiFunction(masm, kApiStackSpace); |
| 2772 | 2777 |
| 2773 // FunctionCallbackInfo::implicit_args_. | 2778 // FunctionCallbackInfo::implicit_args_. |
| 2774 int argc = this->argc(); | 2779 int argc = this->argc(); |
| 2775 __ movp(StackSpaceOperand(0), scratch); | 2780 __ movp(StackSpaceOperand(0), scratch); |
| 2776 __ addp(scratch, Immediate((argc + FCA::kArgsLength - 1) * kPointerSize)); | 2781 __ addp(scratch, Immediate((argc + FCA::kArgsLength - 1) * kPointerSize)); |
| (...skipping 117 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2894 kStackUnwindSpace, nullptr, return_value_operand, | 2899 kStackUnwindSpace, nullptr, return_value_operand, |
| 2895 NULL); | 2900 NULL); |
| 2896 } | 2901 } |
| 2897 | 2902 |
| 2898 #undef __ | 2903 #undef __ |
| 2899 | 2904 |
| 2900 } // namespace internal | 2905 } // namespace internal |
| 2901 } // namespace v8 | 2906 } // namespace v8 |
| 2902 | 2907 |
| 2903 #endif // V8_TARGET_ARCH_X64 | 2908 #endif // V8_TARGET_ARCH_X64 |
| OLD | NEW |