| 
									
										
										
										
											2009-07-28 21:32:10 +00:00
										 |  |  | // Copyright (C) 2003 Dolphin Project.
 | 
					
						
							| 
									
										
										
										
											2008-12-08 04:46:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | // This program is free software: you can redistribute it and/or modify
 | 
					
						
							|  |  |  | // it under the terms of the GNU General Public License as published by
 | 
					
						
							|  |  |  | // the Free Software Foundation, version 2.0.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // This program is distributed in the hope that it will be useful,
 | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
					
						
							|  |  |  | // GNU General Public License 2.0 for more details.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // A copy of the GPL 2.0 should have been included with the program.
 | 
					
						
							|  |  |  | // If not, see http://www.gnu.org/licenses/
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Official SVN repository and contact information can be found at
 | 
					
						
							|  |  |  | // http://code.google.com/p/dolphin-emu/
 | 
					
						
							| 
									
										
										
										
											2009-03-28 08:57:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifndef _X64ANALYZER_H_
 | 
					
						
							|  |  |  | #define _X64ANALYZER_H_
 | 
					
						
							| 
									
										
										
										
											2008-12-08 04:46:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "Common.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct InstructionInfo | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int operandSize; //8, 16, 32, 64
 | 
					
						
							|  |  |  | 	int instructionSize; | 
					
						
							|  |  |  | 	int regOperandReg; | 
					
						
							|  |  |  | 	int otherReg; | 
					
						
							|  |  |  | 	int scaledReg; | 
					
						
							|  |  |  | 	bool zeroExtend; | 
					
						
							|  |  |  | 	bool signExtend; | 
					
						
							|  |  |  | 	bool hasImmediate; | 
					
						
							|  |  |  | 	bool isMemoryWrite; | 
					
						
							|  |  |  | 	u64 immediate; | 
					
						
							|  |  |  | 	s32 displacement; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct ModRM | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int mod, reg, rm; | 
					
						
							|  |  |  | 	ModRM(u8 modRM, u8 rex) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		mod = modRM >> 6; | 
					
						
							|  |  |  | 		reg = ((modRM >> 3) & 7) | ((rex & 4)?8:0); | 
					
						
							|  |  |  | 		rm = modRM & 7; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-06 21:32:42 +00:00
										 |  |  | enum{ | 
					
						
							|  |  |  | 	MOVZX_BYTE      = 0xB6, //movzx on byte
 | 
					
						
							|  |  |  | 	MOVZX_SHORT     = 0xB7, //movzx on short
 | 
					
						
							|  |  |  | 	MOVSX_BYTE      = 0xBE, //movsx on byte
 | 
					
						
							|  |  |  | 	MOVSX_SHORT     = 0xBF, //movsx on short
 | 
					
						
							|  |  |  | 	MOVE_8BIT	    = 0xC6, //move 8-bit immediate
 | 
					
						
							|  |  |  | 	MOVE_16_32BIT   = 0xC7, //move 16 or 32-bit immediate
 | 
					
						
							|  |  |  | 	MOVE_REG_TO_MEM = 0x89, //move reg to memory
 | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2008-12-08 04:46:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | enum AccessType{ | 
					
						
							|  |  |  | 	OP_ACCESS_READ = 0, | 
					
						
							|  |  |  | 	OP_ACCESS_WRITE = 1 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool DisassembleMov(const unsigned char *codePtr, InstructionInfo &info, int accessType); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-28 08:57:34 +00:00
										 |  |  | #endif // _X64ANALYZER_H_
 |