| 
									
										
										
										
											2014-04-08 19:15:46 -04:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							| 
									
										
										
										
											2014-12-16 21:38:14 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							| 
									
										
										
										
											2014-04-08 19:15:46 -04:00
										 |  |  | // Refer to the license.txt file included.
 | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-08 19:15:46 -04:00
										 |  |  | #pragma once
 | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-29 18:03:08 -05:00
										 |  |  | #include <memory>
 | 
					
						
							| 
									
										
										
										
											2014-12-22 04:30:09 -02:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ARM_Interface; | 
					
						
							| 
									
										
										
										
											2014-04-03 21:22:13 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | ////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Core { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-22 04:30:09 -02:00
										 |  |  | struct ThreadContext { | 
					
						
							|  |  |  |     u32 cpu_registers[13]; | 
					
						
							|  |  |  |     u32 sp; | 
					
						
							|  |  |  |     u32 lr; | 
					
						
							|  |  |  |     u32 pc; | 
					
						
							|  |  |  |     u32 cpsr; | 
					
						
							| 
									
										
										
										
											2015-11-29 13:06:45 -05:00
										 |  |  |     u32 fpu_registers[64]; | 
					
						
							| 
									
										
										
										
											2014-12-22 04:30:09 -02:00
										 |  |  |     u32 fpscr; | 
					
						
							|  |  |  |     u32 fpexc; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-29 18:03:08 -05:00
										 |  |  | extern std::unique_ptr<ARM_Interface> g_app_core; ///< ARM11 application core
 | 
					
						
							|  |  |  | extern std::unique_ptr<ARM_Interface> g_sys_core; ///< ARM11 system (OS) core
 | 
					
						
							| 
									
										
										
										
											2014-04-04 22:26:06 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | /// Start the core
 | 
					
						
							|  |  |  | void Start(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-29 23:24:32 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Run the core CPU loop | 
					
						
							| 
									
										
										
										
											2014-11-09 16:56:57 -05:00
										 |  |  |  * This function runs the core for the specified number of CPU instructions before trying to update | 
					
						
							|  |  |  |  * hardware. This is much faster than SingleStep (and should be equivalent), as the CPU is not | 
					
						
							|  |  |  |  * required to do a full dispatch with each instruction. NOTE: the number of instructions requested | 
					
						
							|  |  |  |  * is not guaranteed to run, as this will be interrupted preemptively if a hardware update is | 
					
						
							|  |  |  |  * requested (e.g. on a thread switch). | 
					
						
							| 
									
										
										
										
											2014-08-29 23:24:32 -04:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-11-09 16:56:57 -05:00
										 |  |  | void RunLoop(int tight_loop=1000); | 
					
						
							| 
									
										
										
										
											2013-09-26 22:01:09 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | /// Step the CPU one instruction
 | 
					
						
							|  |  |  | void SingleStep(); | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-26 22:01:09 -04:00
										 |  |  | /// Halt the core
 | 
					
						
							| 
									
										
										
										
											2013-10-01 19:07:33 -04:00
										 |  |  | void Halt(const char *msg); | 
					
						
							| 
									
										
										
										
											2013-09-26 22:01:09 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | /// Kill the core
 | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | void Stop(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// Initialize the core
 | 
					
						
							| 
									
										
										
										
											2016-01-07 20:33:54 +01:00
										 |  |  | void Init(); | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-05 00:01:07 -04:00
										 |  |  | /// Shutdown the core
 | 
					
						
							|  |  |  | void Shutdown(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | } // namespace
 |