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 |