| 
									
										
										
										
											2014-04-08 19:19:26 -04:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							| 
									
										
										
										
											2014-12-16 21:38:14 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							| 
									
										
										
										
											2014-11-19 08:49:13 +00:00
										 |  |  | // Refer to the license.txt file included.
 | 
					
						
							| 
									
										
										
										
											2014-04-04 22:26:06 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-08 20:15:08 -04:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2015-04-06 12:57:49 -04:00
										 |  |  | #include "core/arm/skyeye_common/arm_regformat.h"
 | 
					
						
							| 
									
										
										
										
											2016-05-14 15:45:04 +02:00
										 |  |  | #include "core/arm/skyeye_common/vfp/asm_vfp.h"
 | 
					
						
							| 
									
										
										
										
											2014-04-04 22:26:06 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | /// Generic ARM11 CPU interface
 | 
					
						
							| 
									
										
										
										
											2014-04-27 18:29:51 -04:00
										 |  |  | class ARM_Interface : NonCopyable { | 
					
						
							| 
									
										
										
										
											2014-04-04 22:26:06 -04:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2016-09-18 18:01:46 -07:00
										 |  |  |     virtual ~ARM_Interface() {} | 
					
						
							| 
									
										
										
										
											2014-04-04 22:26:06 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-22 00:08:09 -05:00
										 |  |  |     struct ThreadContext { | 
					
						
							| 
									
										
										
										
											2017-08-28 21:09:42 -04:00
										 |  |  |         u64 cpu_registers[30]; | 
					
						
							|  |  |  |         u64 lr; | 
					
						
							|  |  |  |         u64 sp; | 
					
						
							|  |  |  |         u64 pc; | 
					
						
							|  |  |  |         u64 cpsr; | 
					
						
							|  |  |  |         u64 fpu_registers[64]; | 
					
						
							|  |  |  |         u64 fpscr; | 
					
						
							|  |  |  |         u64 fpexc; | 
					
						
							| 
									
										
										
										
											2017-09-30 14:16:39 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // TODO(bunnei): Fix once we have proper support for tpidrro_el0, etc. in the JIT
 | 
					
						
							|  |  |  |         VAddr tls_address; | 
					
						
							| 
									
										
										
										
											2016-12-22 00:08:09 -05:00
										 |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-17 11:59:18 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Runs the CPU for the given number of instructions | 
					
						
							|  |  |  |      * @param num_instructions Number of instructions to run | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void Run(int num_instructions) { | 
					
						
							|  |  |  |         ExecuteInstructions(num_instructions); | 
					
						
							| 
									
										
										
										
											2014-06-01 21:08:26 +02:00
										 |  |  |         this->num_instructions += num_instructions; | 
					
						
							| 
									
										
										
										
											2014-05-17 11:59:18 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-05 15:23:59 -04:00
										 |  |  |     /// Step CPU by one instruction
 | 
					
						
							| 
									
										
										
										
											2014-04-05 01:23:28 -04:00
										 |  |  |     void Step() { | 
					
						
							| 
									
										
										
										
											2014-05-17 11:59:18 -04:00
										 |  |  |         Run(1); | 
					
						
							| 
									
										
										
										
											2014-04-05 01:23:28 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-05-17 11:59:18 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-27 21:38:49 +03:00
										 |  |  |     /// Clear all instruction cache
 | 
					
						
							|  |  |  |     virtual void ClearInstructionCache() = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-05 15:23:59 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Set the Program Counter to an address | 
					
						
							|  |  |  |      * @param addr Address to set PC to | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-08-28 21:09:42 -04:00
										 |  |  |     virtual void SetPC(u64 addr) = 0; | 
					
						
							| 
									
										
										
										
											2014-04-05 15:23:59 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /*
 | 
					
						
							|  |  |  |      * Get the current Program Counter | 
					
						
							|  |  |  |      * @return Returns current PC | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-08-28 21:09:42 -04:00
										 |  |  |     virtual u64 GetPC() const = 0; | 
					
						
							| 
									
										
										
										
											2014-04-05 15:23:59 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get an ARM register | 
					
						
							| 
									
										
										
										
											2017-08-28 21:09:42 -04:00
										 |  |  |      * @param index Register index | 
					
						
							| 
									
										
										
										
											2014-04-05 15:23:59 -04:00
										 |  |  |      * @return Returns the value in the register | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-08-28 21:09:42 -04:00
										 |  |  |     virtual u64 GetReg(int index) const = 0; | 
					
						
							| 
									
										
										
										
											2014-04-05 15:23:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-10 19:57:56 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Set an ARM register | 
					
						
							| 
									
										
										
										
											2017-08-28 21:09:42 -04:00
										 |  |  |      * @param index Register index | 
					
						
							| 
									
										
										
										
											2014-04-10 19:57:56 -04:00
										 |  |  |      * @param value Value to set register to | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-08-28 21:09:42 -04:00
										 |  |  |     virtual void SetReg(int index, u64 value) = 0; | 
					
						
							| 
									
										
										
										
											2014-04-10 19:57:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-06 21:24:25 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Gets the value of a VFP register | 
					
						
							|  |  |  |      * @param index Register index (0-31) | 
					
						
							|  |  |  |      * @return Returns the value in the register | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual u32 GetVFPReg(int index) const = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Sets a VFP register to the given value | 
					
						
							|  |  |  |      * @param index Register index (0-31) | 
					
						
							|  |  |  |      * @param value Value to set register to | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void SetVFPReg(int index, u32 value) = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Gets the current value within a given VFP system register | 
					
						
							|  |  |  |      * @param reg The VFP system register | 
					
						
							|  |  |  |      * @return The value within the VFP system register | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual u32 GetVFPSystemReg(VFPSystemRegister reg) const = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Sets the VFP system register to the given value | 
					
						
							|  |  |  |      * @param reg   The VFP system register | 
					
						
							|  |  |  |      * @param value Value to set the VFP system register to | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void SetVFPSystemReg(VFPSystemRegister reg, u32 value) = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-05 15:23:59 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the current CPSR register | 
					
						
							|  |  |  |      * @return Returns the value of the CPSR register | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-11-19 08:49:13 +00:00
										 |  |  |     virtual u32 GetCPSR() const = 0; | 
					
						
							| 
									
										
										
										
											2014-04-05 01:23:28 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-11 22:14:13 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Set the current CPSR register | 
					
						
							|  |  |  |      * @param cpsr Value to set CPSR to | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void SetCPSR(u32 cpsr) = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 12:57:49 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Gets the value stored in a CP15 register. | 
					
						
							|  |  |  |      * @param reg The CP15 register to retrieve the value from. | 
					
						
							|  |  |  |      * @return the value stored in the given CP15 register. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual u32 GetCP15Register(CP15Register reg) = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Stores the given value into the indicated CP15 register. | 
					
						
							|  |  |  |      * @param reg   The CP15 register to store the value into. | 
					
						
							|  |  |  |      * @param value The value to store into the CP15 register. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void SetCP15Register(CP15Register reg, u32 value) = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-30 14:16:39 -04:00
										 |  |  |     virtual VAddr GetTlsAddress() const = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     virtual void SetTlsAddress(VAddr address) = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-23 22:45:52 -05:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Advance the CPU core by the specified number of ticks (e.g. to simulate CPU execution time) | 
					
						
							|  |  |  |      * @param ticks Number of ticks to advance the CPU core | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void AddTicks(u64 ticks) = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-20 18:50:16 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Saves the current CPU context | 
					
						
							|  |  |  |      * @param ctx Thread context to save | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-22 00:08:09 -05:00
										 |  |  |     virtual void SaveContext(ThreadContext& ctx) = 0; | 
					
						
							| 
									
										
										
										
											2014-05-20 18:50:16 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Loads a CPU context | 
					
						
							|  |  |  |      * @param ctx Thread context to load | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-22 00:08:09 -05:00
										 |  |  |     virtual void LoadContext(const ThreadContext& ctx) = 0; | 
					
						
							| 
									
										
										
										
											2014-05-20 18:50:16 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-01 21:40:10 -04:00
										 |  |  |     /// Prepare core for thread reschedule (if needed to correctly handle state)
 | 
					
						
							|  |  |  |     virtual void PrepareReschedule() = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-20 18:52:54 -04:00
										 |  |  |     /// Getter for num_instructions
 | 
					
						
							| 
									
										
										
										
											2015-12-06 15:07:59 -05:00
										 |  |  |     u64 GetNumInstructions() const { | 
					
						
							| 
									
										
										
										
											2014-05-20 18:52:54 -04:00
										 |  |  |         return num_instructions; | 
					
						
							| 
									
										
										
										
											2014-04-08 20:38:33 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-04-05 01:23:28 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     s64 down_count = 0; ///< A decreasing counter of remaining cycles before the next event,
 | 
					
						
							|  |  |  |                         /// decreased by the cpu run loop
 | 
					
						
							| 
									
										
										
										
											2015-01-05 20:17:49 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-10 19:57:56 -04:00
										 |  |  | protected: | 
					
						
							| 
									
										
										
										
											2014-05-17 11:59:18 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Executes the given number of instructions | 
					
						
							|  |  |  |      * @param num_instructions Number of instructions to executes | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void ExecuteInstructions(int num_instructions) = 0; | 
					
						
							| 
									
										
										
										
											2014-04-04 22:26:06 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-10 19:57:56 -04:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2015-12-06 15:07:00 -05:00
										 |  |  |     u64 num_instructions = 0; ///< Number of instructions executed
 | 
					
						
							| 
									
										
										
										
											2014-04-04 22:26:06 -04:00
										 |  |  | }; |