| 
									
										
										
										
											2011-06-28 00:29:20 +00:00
										 |  |  | #ifdef SUPERMODEL_DEBUGGER
 | 
					
						
							|  |  |  | #ifndef INCLUDED_PPCDEBUG_H
 | 
					
						
							|  |  |  | #define INCLUDED_PPCDEBUG_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "Debugger/CPUDebug.h"
 | 
					
						
							| 
									
										
										
										
											2011-07-20 21:39:11 +00:00
										 |  |  | #include "CPU/Bus.h"
 | 
					
						
							| 
									
										
										
										
											2011-06-28 00:29:20 +00:00
										 |  |  | #include "Types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PPCSPECIAL_LR 0
 | 
					
						
							|  |  |  | #define PPCSPECIAL_FPSCR 1
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Debugger | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	static UINT32 GetSpecialReg(CCPUDebug *cpu, unsigned id); | 
					
						
							|  |  |  | 	static bool SetSpecialReg(CCPUDebug *cpu, unsigned id, UINT32 data); | 
					
						
							|  |  |  | 	static UINT32 GetSPR(CCPUDebug *cpu, unsigned id); | 
					
						
							|  |  |  | 	static bool SetSPR(CCPUDebug *cpu, unsigned id, UINT32 data); | 
					
						
							|  |  |  | 	static UINT32 GetGPR(CCPUDebug *cpu, unsigned id); | 
					
						
							|  |  |  | 	static bool SetGPR(CCPUDebug *cpu, unsigned id, UINT32 data); | 
					
						
							|  |  |  | 	static double GetFPR(CCPUDebug *cpu, unsigned id); | 
					
						
							|  |  |  | 	static bool SetFRP(CCPUDebug *cpu, unsigned id, double data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * CCPUDebug implementation for the PowerPC PPC603 emulator. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	class CPPCDebug : public CCPUDebug, public ::CBus | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	private: | 
					
						
							|  |  |  | 		char m_crNames[32][5]; | 
					
						
							|  |  |  | 		char m_gprNames[32][4]; | 
					
						
							|  |  |  | 		char m_fprNames[32][4]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		::CBus *m_bus; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		UINT8 m_irqState; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	public: | 
					
						
							|  |  |  | 		CPPCDebug(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		virtual ~CPPCDebug(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// CCPUDebug methods
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		void AttachToCPU(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		::CBus *AttachBus(::CBus *bus); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		void DetachFromCPU(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		::CBus *DetachBus(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		void CheckException(UINT16 exCode); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		UINT32 GetResetAddr(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bool UpdatePC(UINT32 pc); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bool ForceException(CException *ex); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bool ForceInterrupt(CInterrupt *in); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		UINT64 ReadMem(UINT32 addr, unsigned dataSize); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bool WriteMem(UINT32 addr, unsigned dataSize, UINT64 data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		int Disassemble(UINT32 addr, char *mnemonic, char *operands); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		EOpFlags GetOpFlags(UINT32 addr, UINT32 opcode); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bool GetJumpAddr(UINT32 addr, UINT32 opcode, UINT32 &jumpAddr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bool GetJumpRetAddr(UINT32 addr, UINT32 opcode, UINT32 &retAddr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bool GetReturnAddr(UINT32 addr, UINT32 opcode, UINT32 &retAddr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bool GetHandlerAddr(CException *ex, UINT32 &handlerAddr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bool GetHandlerAddr(CInterrupt *in, UINT32 &handlerAddr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// CBus methods
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		UINT8 Read8(UINT32 addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		UINT16 Read16(UINT32 addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		UINT32 Read32(UINT32 addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		UINT64 Read64(UINT32 addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		void Write8(UINT32 addr, UINT8 data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		void Write16(UINT32 addr, UINT16 data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		void Write32(UINT32 addr, UINT32 data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		void Write64(UINT32 addr, UINT64 data); | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif	// INCLUDED_PPCDEBUG_H
 | 
					
						
							|  |  |  | #endif  // SUPERMODEL_DEBUGGER
 |