| 
									
										
										
										
											2009-03-23 09:10:32 +00:00
										 |  |  | /*====================================================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    filename:     opcodes.h | 
					
						
							|  |  |  |    project:      GameCube DSP Tool (gcdsp) | 
					
						
							|  |  |  |    created:      2005.03.04 | 
					
						
							|  |  |  |    mail:		  duddie@walla.com | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Copyright (c) 2005 Duddie | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    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; either version 2 | 
					
						
							|  |  |  |    of the License, or (at your option) any later version. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    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 for more details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |    along with this program; if not, write to the Free Software | 
					
						
							|  |  |  |    Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    ====================================================================*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-12 10:21:40 +00:00
										 |  |  | #ifndef _GDSP_EXT_OP_H
 | 
					
						
							|  |  |  | #define _GDSP_EXT_OP_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "DSPTables.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Extended opcode support.
 | 
					
						
							| 
									
										
										
										
											2010-03-22 13:46:00 +00:00
										 |  |  | // Many opcode have the lower 0xFF (some only 0x7f) free - there, an opcode extension
 | 
					
						
							|  |  |  | // can be stored. 
 | 
					
						
							| 
									
										
										
										
											2009-04-12 10:21:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-14 11:43:44 +00:00
										 |  |  | namespace DSPInterpreter | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | namespace Ext | 
					
						
							|  |  |  | {  | 
					
						
							| 
									
										
										
										
											2010-03-24 05:05:25 +00:00
										 |  |  | void l(const UDSPInstruction opc); | 
					
						
							|  |  |  | void ln(const UDSPInstruction opc); | 
					
						
							|  |  |  | void ls(const UDSPInstruction opc); | 
					
						
							|  |  |  | void lsn(const UDSPInstruction opc); | 
					
						
							|  |  |  | void lsm(const UDSPInstruction opc); | 
					
						
							|  |  |  | void lsnm(const UDSPInstruction opc); | 
					
						
							|  |  |  | void sl(const UDSPInstruction opc); | 
					
						
							|  |  |  | void sln(const UDSPInstruction opc); | 
					
						
							|  |  |  | void slm(const UDSPInstruction opc); | 
					
						
							|  |  |  | void slnm(const UDSPInstruction opc); | 
					
						
							|  |  |  | void s(const UDSPInstruction opc); | 
					
						
							|  |  |  | void sn(const UDSPInstruction opc); | 
					
						
							|  |  |  | void ld(const UDSPInstruction opc); | 
					
						
							|  |  |  | void ldn(const UDSPInstruction opc); | 
					
						
							|  |  |  | void ldm(const UDSPInstruction opc); | 
					
						
							|  |  |  | void ldnm(const UDSPInstruction opc); | 
					
						
							|  |  |  | void mv(const UDSPInstruction opc); | 
					
						
							|  |  |  | void dr(const UDSPInstruction opc); | 
					
						
							|  |  |  | void ir(const UDSPInstruction opc); | 
					
						
							|  |  |  | void nr(const UDSPInstruction opc); | 
					
						
							|  |  |  | void nop(const UDSPInstruction opc); | 
					
						
							| 
									
										
										
										
											2009-04-14 11:43:44 +00:00
										 |  |  |   | 
					
						
							|  |  |  | } // end namespace Ext
 | 
					
						
							|  |  |  | } // end namespace DSPinterpeter
 | 
					
						
							| 
									
										
										
										
											2009-04-12 10:21:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 21:38:39 +00:00
										 |  |  | // Needs comments.
 | 
					
						
							| 
									
										
										
										
											2009-08-19 21:37:24 +00:00
										 |  |  | inline void writeToBackLog(int i, int idx, u16 value) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	writeBackLog[i] = value; | 
					
						
							|  |  |  | 	writeBackLogIdx[i] = idx; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-12 10:21:40 +00:00
										 |  |  | #endif
 |