| 
									
										
										
										
											2008-12-08 04:46:09 +00:00
										 |  |  | // Copyright (C) 2003-2008 Dolphin Project.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // 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/
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _OPCODE_DECODING_H
 | 
					
						
							|  |  |  | #define _OPCODE_DECODING_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GX_NOP                      0x00
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GX_LOAD_BP_REG              0x61
 | 
					
						
							|  |  |  | #define GX_LOAD_CP_REG              0x08
 | 
					
						
							|  |  |  | #define GX_LOAD_XF_REG              0x10
 | 
					
						
							|  |  |  | #define GX_LOAD_INDX_A              0x20
 | 
					
						
							|  |  |  | #define GX_LOAD_INDX_B              0x28
 | 
					
						
							|  |  |  | #define GX_LOAD_INDX_C              0x30
 | 
					
						
							|  |  |  | #define GX_LOAD_INDX_D              0x38
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GX_CMD_CALL_DL              0x40
 | 
					
						
							|  |  |  | #define GX_CMD_INVL_VC              0x48
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GX_PRIMITIVE_MASK           0x78
 | 
					
						
							|  |  |  | #define GX_PRIMITIVE_SHIFT          3
 | 
					
						
							|  |  |  | #define GX_VAT_MASK                 0x07
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //these are defined 1/8th of their real values and without their top bit
 | 
					
						
							|  |  |  | #define GX_DRAW_QUADS               0x0   //0x80
 | 
					
						
							|  |  |  | #define GX_DRAW_TRIANGLES           0x2   //0x90
 | 
					
						
							|  |  |  | #define GX_DRAW_TRIANGLE_STRIP      0x3   //0x98
 | 
					
						
							|  |  |  | #define GX_DRAW_TRIANGLE_FAN        0x4   //0xA0
 | 
					
						
							|  |  |  | #define GX_DRAW_LINES               0x5   //0xA8
 | 
					
						
							|  |  |  | #define GX_DRAW_LINE_STRIP          0x6   //0xB0
 | 
					
						
							|  |  |  | #define GX_DRAW_POINTS              0x7   //0xB8
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void OpcodeDecoder_Init(); | 
					
						
							|  |  |  | void OpcodeDecoder_Shutdown(); | 
					
						
							|  |  |  | void OpcodeDecoder_Run(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |