3    Copyright 2006 Free Software Foundation, Inc.
 
   5    This file is part of GDB, GAS, and the GNU binutils.
 
   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.
 
  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.
 
  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.  */
 
  21 #include <linux/kernel.h>
 
  24 /* This file holds the Spu opcode table */
 
  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 
 
  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"
 
  44 const int spu_num_opcodes = ARRAY_SIZE(spu_opcodes);