162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 262306a36Sopenharmony_ci/* SPU opcode list 362306a36Sopenharmony_ci 462306a36Sopenharmony_ci Copyright 2006 Free Software Foundation, Inc. 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci This file is part of GDB, GAS, and the GNU binutils. 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci */ 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include <linux/kernel.h> 1162306a36Sopenharmony_ci#include <linux/bug.h> 1262306a36Sopenharmony_ci#include "spu.h" 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci/* This file holds the Spu opcode table */ 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci/* 1862306a36Sopenharmony_ci Example contents of spu-insn.h 1962306a36Sopenharmony_ci id_tag mode mode type opcode mnemonic asmtype dependency FPU L/S? branch? instruction 2062306a36Sopenharmony_ci QUAD WORD (0,RC,RB,RA,RT) latency 2162306a36Sopenharmony_ci APUOP(M_LQD, 1, 0, RI9, 0x1f8, "lqd", ASM_RI9IDX, 00012, FXU, 1, 0) Load Quadword d-form 2262306a36Sopenharmony_ci */ 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ciconst struct spu_opcode spu_opcodes[] = { 2562306a36Sopenharmony_ci#define APUOP(TAG,MACFORMAT,OPCODE,MNEMONIC,ASMFORMAT,DEP,PIPE) \ 2662306a36Sopenharmony_ci { MACFORMAT, OPCODE, MNEMONIC, ASMFORMAT }, 2762306a36Sopenharmony_ci#define APUOPFB(TAG,MACFORMAT,OPCODE,FB,MNEMONIC,ASMFORMAT,DEP,PIPE) \ 2862306a36Sopenharmony_ci { MACFORMAT, OPCODE, MNEMONIC, ASMFORMAT }, 2962306a36Sopenharmony_ci#include "spu-insns.h" 3062306a36Sopenharmony_ci#undef APUOP 3162306a36Sopenharmony_ci#undef APUOPFB 3262306a36Sopenharmony_ci}; 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_ciconst int spu_num_opcodes = ARRAY_SIZE(spu_opcodes); 35