| 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 // Declares a Simulator for MIPS instructions if we are not generating a native | 5 // Declares a Simulator for MIPS instructions if we are not generating a native |
| 6 // MIPS binary. This Simulator allows us to run and debug MIPS code generation | 6 // MIPS binary. This Simulator allows us to run and debug MIPS code generation |
| 7 // on regular desktop machines. | 7 // on regular desktop machines. |
| 8 // Dart calls into generated code by "calling" the InvokeDartCode stub, | 8 // Dart calls into generated code by "calling" the InvokeDartCode stub, |
| 9 // which will start execution in the Simulator or forwards to the real entry | 9 // which will start execution in the Simulator or forwards to the real entry |
| 10 // on a MIPS HW platform. | 10 // on a MIPS HW platform. |
| (...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 119 kNativeCall | 119 kNativeCall |
| 120 }; | 120 }; |
| 121 static uword RedirectExternalReference(uword function, | 121 static uword RedirectExternalReference(uword function, |
| 122 CallKind call_kind, | 122 CallKind call_kind, |
| 123 int argument_count); | 123 int argument_count); |
| 124 | 124 |
| 125 void Longjmp(uword pc, | 125 void Longjmp(uword pc, |
| 126 uword sp, | 126 uword sp, |
| 127 uword fp, | 127 uword fp, |
| 128 RawObject* raw_exception, | 128 RawObject* raw_exception, |
| 129 RawObject* raw_stacktrace); | 129 RawObject* raw_stacktrace, |
| 130 Isolate* isolate); |
| 130 | 131 |
| 131 private: | 132 private: |
| 132 // A pc value used to signal the simulator to stop execution. Generally | 133 // A pc value used to signal the simulator to stop execution. Generally |
| 133 // the ra is set to this value on transition from native C code to | 134 // the ra is set to this value on transition from native C code to |
| 134 // simulated execution, so that the simulator can "return" to the native | 135 // simulated execution, so that the simulator can "return" to the native |
| 135 // C code. | 136 // C code. |
| 136 static const uword kEndSimulatingPC = -1; | 137 static const uword kEndSimulatingPC = -1; |
| 137 | 138 |
| 138 // Special registers for the results of div, divu. | 139 // Special registers for the results of div, divu. |
| 139 int32_t hi_reg_; | 140 int32_t hi_reg_; |
| (...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 210 } | 211 } |
| 211 | 212 |
| 212 friend class SimulatorDebugger; | 213 friend class SimulatorDebugger; |
| 213 friend class SimulatorSetjmpBuffer; | 214 friend class SimulatorSetjmpBuffer; |
| 214 DISALLOW_COPY_AND_ASSIGN(Simulator); | 215 DISALLOW_COPY_AND_ASSIGN(Simulator); |
| 215 }; | 216 }; |
| 216 | 217 |
| 217 } // namespace dart | 218 } // namespace dart |
| 218 | 219 |
| 219 #endif // VM_SIMULATOR_MIPS_H_ | 220 #endif // VM_SIMULATOR_MIPS_H_ |
| OLD | NEW |