xref: /openbmc/linux/arch/powerpc/xmon/spu-opc.c (revision f15cbe6f1a4b4d9df59142fc8e4abb973302cf44)
1 /* SPU opcode list
2 
3    Copyright 2006 Free Software Foundation, Inc.
4 
5    This file is part of GDB, GAS, and the GNU binutils.
6 
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 2 of the License, or
10    (at your option) any later version.
11 
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16 
17    You should have received a copy of the GNU General Public License along
18    with this program; if not, write to the Free Software Foundation, Inc.,
19    51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.  */
20 
21 #include <linux/kernel.h>
22 #include "spu.h"
23 
24 /* This file holds the Spu opcode table */
25 
26 
27 /*
28    Example contents of spu-insn.h
29       id_tag	mode	mode	type	opcode	mnemonic	asmtype	    dependency		FPU	L/S?	branch?	instruction
30                 QUAD	WORD                                               (0,RC,RB,RA,RT)    latency
31    APUOP(M_LQD,	1,	0,	RI9,	0x1f8,	"lqd",		ASM_RI9IDX,	00012,		FXU,	1,	0)	Load Quadword d-form
32  */
33 
34 const struct spu_opcode spu_opcodes[] = {
35 #define APUOP(TAG,MACFORMAT,OPCODE,MNEMONIC,ASMFORMAT,DEP,PIPE) \
36 	{ MACFORMAT, OPCODE, MNEMONIC, ASMFORMAT },
37 #define APUOPFB(TAG,MACFORMAT,OPCODE,FB,MNEMONIC,ASMFORMAT,DEP,PIPE) \
38 	{ MACFORMAT, OPCODE, MNEMONIC, ASMFORMAT },
39 #include "spu-insns.h"
40 #undef APUOP
41 #undef APUOPFB
42 };
43 
44 const int spu_num_opcodes = ARRAY_SIZE(spu_opcodes);
45