| 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_MIPS | 5 #if V8_TARGET_ARCH_MIPS |
| 6 | 6 |
| 7 #include "src/base/bits.h" | 7 #include "src/base/bits.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 1048 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1059 } | 1059 } |
| 1060 | 1060 |
| 1061 | 1061 |
| 1062 void CEntryStub::Generate(MacroAssembler* masm) { | 1062 void CEntryStub::Generate(MacroAssembler* masm) { |
| 1063 // Called from JavaScript; parameters are on stack as if calling JS function | 1063 // Called from JavaScript; parameters are on stack as if calling JS function |
| 1064 // a0: number of arguments including receiver | 1064 // a0: number of arguments including receiver |
| 1065 // a1: pointer to builtin function | 1065 // a1: pointer to builtin function |
| 1066 // fp: frame pointer (restored after C call) | 1066 // fp: frame pointer (restored after C call) |
| 1067 // sp: stack pointer (restored as callee's sp after C call) | 1067 // sp: stack pointer (restored as callee's sp after C call) |
| 1068 // cp: current context (C callee-saved) | 1068 // cp: current context (C callee-saved) |
| 1069 // | |
| 1070 // If argv_in_register(): | |
| 1071 // a2: pointer to the first argument | |
| 1072 | 1069 |
| 1073 ProfileEntryHookStub::MaybeCallEntryHook(masm); | 1070 ProfileEntryHookStub::MaybeCallEntryHook(masm); |
| 1074 | 1071 |
| 1075 if (!argv_in_register()) { | 1072 // Compute the argv pointer in a callee-saved register. |
| 1076 // Compute the argv pointer in a callee-saved register. | 1073 __ sll(s1, a0, kPointerSizeLog2); |
| 1077 __ sll(s1, a0, kPointerSizeLog2); | 1074 __ Addu(s1, sp, s1); |
| 1078 __ Addu(s1, sp, s1); | 1075 __ Subu(s1, s1, kPointerSize); |
| 1079 __ Subu(s1, s1, kPointerSize); | |
| 1080 } else { | |
| 1081 __ mov(s1, a2); | |
| 1082 } | |
| 1083 | 1076 |
| 1084 // Enter the exit frame that transitions from JavaScript to C++. | 1077 // Enter the exit frame that transitions from JavaScript to C++. |
| 1085 FrameScope scope(masm, StackFrame::MANUAL); | 1078 FrameScope scope(masm, StackFrame::MANUAL); |
| 1086 __ EnterExitFrame(save_doubles()); | 1079 __ EnterExitFrame(save_doubles()); |
| 1087 | 1080 |
| 1088 // s0: number of arguments including receiver (C callee-saved) | 1081 // s0: number of arguments including receiver (C callee-saved) |
| 1089 // s1: pointer to first argument (C callee-saved) | 1082 // s1: pointer to first argument (C callee-saved) |
| 1090 // s2: pointer to builtin function (C callee-saved) | 1083 // s2: pointer to builtin function (C callee-saved) |
| 1091 | 1084 |
| 1092 // Prepare arguments for C routine. | 1085 // Prepare arguments for C routine. |
| (...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1153 // Cannot use check here as it attempts to generate call into runtime. | 1146 // Cannot use check here as it attempts to generate call into runtime. |
| 1154 __ Branch(&okay, eq, t0, Operand(a2)); | 1147 __ Branch(&okay, eq, t0, Operand(a2)); |
| 1155 __ stop("Unexpected pending exception"); | 1148 __ stop("Unexpected pending exception"); |
| 1156 __ bind(&okay); | 1149 __ bind(&okay); |
| 1157 } | 1150 } |
| 1158 | 1151 |
| 1159 // Exit C frame and return. | 1152 // Exit C frame and return. |
| 1160 // v0:v1: result | 1153 // v0:v1: result |
| 1161 // sp: stack pointer | 1154 // sp: stack pointer |
| 1162 // fp: frame pointer | 1155 // fp: frame pointer |
| 1163 Register argc; | 1156 // s0: still holds argc (callee-saved). |
| 1164 if (!argv_in_register()) { | 1157 __ LeaveExitFrame(save_doubles(), s0, true, EMIT_RETURN); |
| 1165 // s0: still holds argc (callee-saved). | |
| 1166 argc = s0; | |
| 1167 } | |
| 1168 __ LeaveExitFrame(save_doubles(), argc, true, EMIT_RETURN); | |
| 1169 | 1158 |
| 1170 // Handling of exception. | 1159 // Handling of exception. |
| 1171 __ bind(&exception_returned); | 1160 __ bind(&exception_returned); |
| 1172 | 1161 |
| 1173 ExternalReference pending_handler_context_address( | 1162 ExternalReference pending_handler_context_address( |
| 1174 Isolate::kPendingHandlerContextAddress, isolate()); | 1163 Isolate::kPendingHandlerContextAddress, isolate()); |
| 1175 ExternalReference pending_handler_code_address( | 1164 ExternalReference pending_handler_code_address( |
| 1176 Isolate::kPendingHandlerCodeAddress, isolate()); | 1165 Isolate::kPendingHandlerCodeAddress, isolate()); |
| 1177 ExternalReference pending_handler_offset_address( | 1166 ExternalReference pending_handler_offset_address( |
| 1178 Isolate::kPendingHandlerOffsetAddress, isolate()); | 1167 Isolate::kPendingHandlerOffsetAddress, isolate()); |
| (...skipping 4559 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 5738 MemOperand(fp, 6 * kPointerSize), NULL); | 5727 MemOperand(fp, 6 * kPointerSize), NULL); |
| 5739 } | 5728 } |
| 5740 | 5729 |
| 5741 | 5730 |
| 5742 #undef __ | 5731 #undef __ |
| 5743 | 5732 |
| 5744 } // namespace internal | 5733 } // namespace internal |
| 5745 } // namespace v8 | 5734 } // namespace v8 |
| 5746 | 5735 |
| 5747 #endif // V8_TARGET_ARCH_MIPS | 5736 #endif // V8_TARGET_ARCH_MIPS |
| OLD | NEW |