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_MIPS64 | 5 #if V8_TARGET_ARCH_MIPS64 |
6 | 6 |
7 #include "src/codegen.h" | 7 #include "src/codegen.h" |
8 #include "src/debug/debug.h" | 8 #include "src/debug/debug.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 949 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
960 // frames.h for its layout. | 960 // frames.h for its layout. |
961 void Builtins::Generate_InterpreterEntryTrampoline(MacroAssembler* masm) { | 961 void Builtins::Generate_InterpreterEntryTrampoline(MacroAssembler* masm) { |
962 // Open a frame scope to indicate that there is a frame on the stack. The | 962 // Open a frame scope to indicate that there is a frame on the stack. The |
963 // MANUAL indicates that the scope shouldn't actually generate code to set up | 963 // MANUAL indicates that the scope shouldn't actually generate code to set up |
964 // the frame (that is done below). | 964 // the frame (that is done below). |
965 FrameScope frame_scope(masm, StackFrame::MANUAL); | 965 FrameScope frame_scope(masm, StackFrame::MANUAL); |
966 | 966 |
967 __ Push(ra, fp, cp, a1); | 967 __ Push(ra, fp, cp, a1); |
968 __ Daddu(fp, sp, Operand(StandardFrameConstants::kFixedFrameSizeFromFp)); | 968 __ Daddu(fp, sp, Operand(StandardFrameConstants::kFixedFrameSizeFromFp)); |
969 | 969 |
970 // Push new.target, dispatch table pointer and zero for bytecode array offset. | |
971 __ li(a0, Operand(ExternalReference::interpreter_dispatch_table_address( | |
972 masm->isolate()))); | |
973 __ Push(a3, a0, zero_reg); | |
974 | |
975 // Get the bytecode array from the function object and load the pointer to the | 970 // Get the bytecode array from the function object and load the pointer to the |
976 // first entry into kInterpreterBytecodeRegister. | 971 // first entry into kInterpreterBytecodeRegister. |
977 __ ld(a0, FieldMemOperand(a1, JSFunction::kSharedFunctionInfoOffset)); | 972 __ ld(a0, FieldMemOperand(a1, JSFunction::kSharedFunctionInfoOffset)); |
978 __ ld(kInterpreterBytecodeArrayRegister, | 973 __ ld(kInterpreterBytecodeArrayRegister, |
979 FieldMemOperand(a0, SharedFunctionInfo::kFunctionDataOffset)); | 974 FieldMemOperand(a0, SharedFunctionInfo::kFunctionDataOffset)); |
980 | 975 |
981 if (FLAG_debug_code) { | 976 if (FLAG_debug_code) { |
982 // Check function data field is actually a BytecodeArray object. | 977 // Check function data field is actually a BytecodeArray object. |
983 __ SmiTst(kInterpreterBytecodeArrayRegister, a4); | 978 __ SmiTst(kInterpreterBytecodeArrayRegister, a4); |
984 __ Assert(ne, kFunctionDataShouldBeBytecodeArrayOnInterpreterEntry, a4, | 979 __ Assert(ne, kFunctionDataShouldBeBytecodeArrayOnInterpreterEntry, a4, |
985 Operand(zero_reg)); | 980 Operand(zero_reg)); |
986 __ GetObjectType(kInterpreterBytecodeArrayRegister, a4, a4); | 981 __ GetObjectType(kInterpreterBytecodeArrayRegister, a4, a4); |
987 __ Assert(eq, kFunctionDataShouldBeBytecodeArrayOnInterpreterEntry, a4, | 982 __ Assert(eq, kFunctionDataShouldBeBytecodeArrayOnInterpreterEntry, a4, |
988 Operand(BYTECODE_ARRAY_TYPE)); | 983 Operand(BYTECODE_ARRAY_TYPE)); |
989 } | 984 } |
990 | 985 |
| 986 // Push new.target, bytecode array and zero for bytecode array offset. |
| 987 __ Push(a3, kInterpreterBytecodeArrayRegister, zero_reg); |
| 988 |
991 // Allocate the local and temporary register file on the stack. | 989 // Allocate the local and temporary register file on the stack. |
992 { | 990 { |
993 // Load frame size (word) from the BytecodeArray object. | 991 // Load frame size (word) from the BytecodeArray object. |
994 __ lw(a4, FieldMemOperand(kInterpreterBytecodeArrayRegister, | 992 __ lw(a4, FieldMemOperand(kInterpreterBytecodeArrayRegister, |
995 BytecodeArray::kFrameSizeOffset)); | 993 BytecodeArray::kFrameSizeOffset)); |
996 | 994 |
997 // Do a stack check to ensure we don't go over the limit. | 995 // Do a stack check to ensure we don't go over the limit. |
998 Label ok; | 996 Label ok; |
999 __ Dsubu(a5, sp, Operand(a4)); | 997 __ Dsubu(a5, sp, Operand(a4)); |
1000 __ LoadRoot(a2, Heap::kRealStackLimitRootIndex); | 998 __ LoadRoot(a2, Heap::kRealStackLimitRootIndex); |
(...skipping 20 matching lines...) Expand all Loading... |
1021 // - Support profiler (specifically profiling_counter). | 1019 // - Support profiler (specifically profiling_counter). |
1022 // - Call ProfileEntryHookStub when isolate has a function_entry_hook. | 1020 // - Call ProfileEntryHookStub when isolate has a function_entry_hook. |
1023 // - Code aging of the BytecodeArray object. | 1021 // - Code aging of the BytecodeArray object. |
1024 | 1022 |
1025 // Load bytecode offset and dispatch table into registers. | 1023 // Load bytecode offset and dispatch table into registers. |
1026 __ LoadRoot(kInterpreterAccumulatorRegister, Heap::kUndefinedValueRootIndex); | 1024 __ LoadRoot(kInterpreterAccumulatorRegister, Heap::kUndefinedValueRootIndex); |
1027 __ Daddu(kInterpreterRegisterFileRegister, fp, | 1025 __ Daddu(kInterpreterRegisterFileRegister, fp, |
1028 Operand(InterpreterFrameConstants::kRegisterFilePointerFromFp)); | 1026 Operand(InterpreterFrameConstants::kRegisterFilePointerFromFp)); |
1029 __ li(kInterpreterBytecodeOffsetRegister, | 1027 __ li(kInterpreterBytecodeOffsetRegister, |
1030 Operand(BytecodeArray::kHeaderSize - kHeapObjectTag)); | 1028 Operand(BytecodeArray::kHeaderSize - kHeapObjectTag)); |
1031 __ lw(kInterpreterDispatchTableRegister, | 1029 __ li(kInterpreterDispatchTableRegister, |
1032 MemOperand(fp, InterpreterFrameConstants::kDispatchTableFromFp)); | 1030 Operand(ExternalReference::interpreter_dispatch_table_address( |
| 1031 masm->isolate()))); |
1033 | 1032 |
1034 // Dispatch to the first bytecode handler for the function. | 1033 // Dispatch to the first bytecode handler for the function. |
1035 __ Daddu(a0, kInterpreterBytecodeArrayRegister, | 1034 __ Daddu(a0, kInterpreterBytecodeArrayRegister, |
1036 kInterpreterBytecodeOffsetRegister); | 1035 kInterpreterBytecodeOffsetRegister); |
1037 __ lbu(a0, MemOperand(a0)); | 1036 __ lbu(a0, MemOperand(a0)); |
1038 __ Dlsa(at, kInterpreterDispatchTableRegister, a0, kPointerSizeLog2); | 1037 __ Dlsa(at, kInterpreterDispatchTableRegister, a0, kPointerSizeLog2); |
1039 __ ld(at, MemOperand(at)); | 1038 __ ld(at, MemOperand(at)); |
1040 // TODO(rmcilroy): Make dispatch table point to code entrys to avoid untagging | 1039 // TODO(rmcilroy): Make dispatch table point to code entrys to avoid untagging |
1041 // and header removal. | 1040 // and header removal. |
1042 __ Daddu(at, at, Operand(Code::kHeaderSize - kHeapObjectTag)); | 1041 __ Daddu(at, at, Operand(Code::kHeaderSize - kHeapObjectTag)); |
(...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1135 __ li(kInterpreterDispatchTableRegister, | 1134 __ li(kInterpreterDispatchTableRegister, |
1136 Operand(ExternalReference::interpreter_dispatch_table_address( | 1135 Operand(ExternalReference::interpreter_dispatch_table_address( |
1137 masm->isolate()))); | 1136 masm->isolate()))); |
1138 | 1137 |
1139 // Get the context from the frame. | 1138 // Get the context from the frame. |
1140 __ ld(kContextRegister, | 1139 __ ld(kContextRegister, |
1141 MemOperand(kInterpreterRegisterFileRegister, | 1140 MemOperand(kInterpreterRegisterFileRegister, |
1142 InterpreterFrameConstants::kContextFromRegisterPointer)); | 1141 InterpreterFrameConstants::kContextFromRegisterPointer)); |
1143 | 1142 |
1144 // Get the bytecode array pointer from the frame. | 1143 // Get the bytecode array pointer from the frame. |
1145 __ ld(a1, | 1144 __ ld( |
1146 MemOperand(kInterpreterRegisterFileRegister, | 1145 kInterpreterBytecodeArrayRegister, |
1147 InterpreterFrameConstants::kFunctionFromRegisterPointer)); | 1146 MemOperand(kInterpreterRegisterFileRegister, |
1148 __ ld(a1, FieldMemOperand(a1, JSFunction::kSharedFunctionInfoOffset)); | 1147 InterpreterFrameConstants::kBytecodeArrayFromRegisterPointer)); |
1149 __ ld(kInterpreterBytecodeArrayRegister, | |
1150 FieldMemOperand(a1, SharedFunctionInfo::kFunctionDataOffset)); | |
1151 | 1148 |
1152 if (FLAG_debug_code) { | 1149 if (FLAG_debug_code) { |
1153 // Check function data field is actually a BytecodeArray object. | 1150 // Check function data field is actually a BytecodeArray object. |
1154 __ SmiTst(kInterpreterBytecodeArrayRegister, at); | 1151 __ SmiTst(kInterpreterBytecodeArrayRegister, at); |
1155 __ Assert(ne, kFunctionDataShouldBeBytecodeArrayOnInterpreterEntry, at, | 1152 __ Assert(ne, kFunctionDataShouldBeBytecodeArrayOnInterpreterEntry, at, |
1156 Operand(zero_reg)); | 1153 Operand(zero_reg)); |
1157 __ GetObjectType(kInterpreterBytecodeArrayRegister, a1, a1); | 1154 __ GetObjectType(kInterpreterBytecodeArrayRegister, a1, a1); |
1158 __ Assert(eq, kFunctionDataShouldBeBytecodeArrayOnInterpreterEntry, a1, | 1155 __ Assert(eq, kFunctionDataShouldBeBytecodeArrayOnInterpreterEntry, a1, |
1159 Operand(BYTECODE_ARRAY_TYPE)); | 1156 Operand(BYTECODE_ARRAY_TYPE)); |
1160 } | 1157 } |
(...skipping 1589 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2750 } | 2747 } |
2751 } | 2748 } |
2752 | 2749 |
2753 | 2750 |
2754 #undef __ | 2751 #undef __ |
2755 | 2752 |
2756 } // namespace internal | 2753 } // namespace internal |
2757 } // namespace v8 | 2754 } // namespace v8 |
2758 | 2755 |
2759 #endif // V8_TARGET_ARCH_MIPS64 | 2756 #endif // V8_TARGET_ARCH_MIPS64 |
OLD | NEW |