OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #include "vm/globals.h" | 5 #include "vm/globals.h" |
6 #if defined(TARGET_ARCH_MIPS) | 6 #if defined(TARGET_ARCH_MIPS) |
7 | 7 |
8 #include "vm/assembler.h" | 8 #include "vm/assembler.h" |
9 #include "vm/code_generator.h" | 9 #include "vm/code_generator.h" |
10 #include "vm/compiler.h" | 10 #include "vm/compiler.h" |
(...skipping 1967 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1978 __ Ret(); | 1978 __ Ret(); |
1979 __ delay_slot()->mov(V0, SP); | 1979 __ delay_slot()->mov(V0, SP); |
1980 } | 1980 } |
1981 | 1981 |
1982 | 1982 |
1983 // Jump to the exception or error handler. | 1983 // Jump to the exception or error handler. |
1984 // RA: return address. | 1984 // RA: return address. |
1985 // A0: program_counter. | 1985 // A0: program_counter. |
1986 // A1: stack_pointer. | 1986 // A1: stack_pointer. |
1987 // A2: frame_pointer. | 1987 // A2: frame_pointer. |
1988 // A3: error object. | 1988 // A3: thread. |
1989 // SP + 4*kWordSize: address of stacktrace object. | |
1990 // SP + 5*kWordSize: address of thread. | |
1991 // Does not return. | 1989 // Does not return. |
1992 void StubCode::GenerateJumpToExceptionHandlerStub(Assembler* assembler) { | 1990 void StubCode::GenerateJumpToFrameStub(Assembler* assembler) { |
1993 ASSERT(kExceptionObjectReg == V0); | 1991 ASSERT(kExceptionObjectReg == V0); |
1994 ASSERT(kStackTraceObjectReg == V1); | 1992 ASSERT(kStackTraceObjectReg == V1); |
1995 __ mov(V0, A3); // Exception object. | 1993 __ mov(FP, A2); // Frame_pointer. |
1996 // MIPS ABI reserves stack space for all arguments. The StackTrace object is | 1994 __ mov(THR, A3); // Thread. |
1997 // the last of five arguments, so it is first pushed on the stack. | |
1998 __ lw(V1, Address(SP, 4 * kWordSize)); // StackTrace object. | |
1999 __ mov(FP, A2); // Frame_pointer. | |
2000 __ lw(THR, Address(SP, 5 * kWordSize)); // Thread. | |
2001 // Set tag. | 1995 // Set tag. |
2002 __ LoadImmediate(A2, VMTag::kDartTagId); | 1996 __ LoadImmediate(A2, VMTag::kDartTagId); |
2003 __ sw(A2, Assembler::VMTagAddress()); | 1997 __ sw(A2, Assembler::VMTagAddress()); |
2004 // Clear top exit frame. | 1998 // Clear top exit frame. |
2005 __ sw(ZR, Address(THR, Thread::top_exit_frame_info_offset())); | 1999 __ sw(ZR, Address(THR, Thread::top_exit_frame_info_offset())); |
2006 // Restore pool pointer. | 2000 // Restore pool pointer. |
2007 __ RestoreCodePointer(); | 2001 __ RestoreCodePointer(); |
2008 __ LoadPoolPointer(); | 2002 __ LoadPoolPointer(); |
2009 __ jr(A0); // Jump to the exception handler code. | 2003 __ jr(A0); // Jump to the program counter. |
2010 __ delay_slot()->mov(SP, A1); // Stack pointer. | 2004 __ delay_slot()->mov(SP, A1); // Stack pointer. |
2011 } | 2005 } |
2012 | 2006 |
2013 | 2007 |
| 2008 // Run an exception handler. Execution comes from JumpToFrame |
| 2009 // stub or from the simulator. |
| 2010 // |
| 2011 // The arguments are stored in the Thread object. |
| 2012 // Does not return. |
| 2013 void StubCode::GenerateRunExceptionHandlerStub(Assembler* assembler) { |
| 2014 __ lw(A0, Address(THR, Thread::resume_pc_offset())); |
| 2015 __ LoadImmediate(A2, 0); |
| 2016 |
| 2017 // Load the exception from the current thread. |
| 2018 Address exception_addr(THR, Thread::active_exception_offset()); |
| 2019 __ lw(V0, exception_addr); |
| 2020 __ sw(A2, exception_addr); |
| 2021 |
| 2022 // Load the stacktrace from the current thread. |
| 2023 Address stacktrace_addr(THR, Thread::active_stacktrace_offset()); |
| 2024 __ lw(V1, stacktrace_addr); |
| 2025 |
| 2026 __ jr(A0); // Jump to continuation point. |
| 2027 __ delay_slot()->sw(A2, stacktrace_addr); |
| 2028 } |
| 2029 |
| 2030 |
2014 // Calls to the runtime to optimize the given function. | 2031 // Calls to the runtime to optimize the given function. |
2015 // T0: function to be reoptimized. | 2032 // T0: function to be reoptimized. |
2016 // S4: argument descriptor (preserved). | 2033 // S4: argument descriptor (preserved). |
2017 void StubCode::GenerateOptimizeFunctionStub(Assembler* assembler) { | 2034 void StubCode::GenerateOptimizeFunctionStub(Assembler* assembler) { |
2018 __ Comment("OptimizeFunctionStub"); | 2035 __ Comment("OptimizeFunctionStub"); |
2019 __ EnterStubFrame(); | 2036 __ EnterStubFrame(); |
2020 __ addiu(SP, SP, Immediate(-3 * kWordSize)); | 2037 __ addiu(SP, SP, Immediate(-3 * kWordSize)); |
2021 __ sw(S4, Address(SP, 2 * kWordSize)); | 2038 __ sw(S4, Address(SP, 2 * kWordSize)); |
2022 // Setup space on stack for return value. | 2039 // Setup space on stack for return value. |
2023 __ sw(ZR, Address(SP, 1 * kWordSize)); | 2040 __ sw(ZR, Address(SP, 1 * kWordSize)); |
(...skipping 357 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2381 } | 2398 } |
2382 | 2399 |
2383 | 2400 |
2384 void StubCode::GenerateFrameAwaitingMaterializationStub(Assembler* assembler) { | 2401 void StubCode::GenerateFrameAwaitingMaterializationStub(Assembler* assembler) { |
2385 __ break_(0); | 2402 __ break_(0); |
2386 } | 2403 } |
2387 | 2404 |
2388 } // namespace dart | 2405 } // namespace dart |
2389 | 2406 |
2390 #endif // defined TARGET_ARCH_MIPS | 2407 #endif // defined TARGET_ARCH_MIPS |
OLD | NEW |