/* Xtensa configuration-specific ISA information. Copyright 2003 Free Software Foundation, Inc. This file is part of BFD, the Binary File Descriptor library. 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. */ #include #include "xtensa-isa-internal.h" #include "ansidecl.h" #define BPW 32 #define WINDEX(_n) ((_n) / BPW) #define BINDEX(_n) ((_n) %% BPW) static uint32 tie_do_reloc_l (uint32, uint32) ATTRIBUTE_UNUSED; static uint32 tie_undo_reloc_l (uint32, uint32) ATTRIBUTE_UNUSED; static uint32 tie_do_reloc_l (uint32 addr, uint32 pc) { return (addr - pc); } static uint32 tie_undo_reloc_l (uint32 offset, uint32 pc) { return (pc + offset); } xtensa_opcode_internal** get_opcodes (void); int get_num_opcodes (void); int decode_insn (const xtensa_insnbuf); int interface_version (void); uint32 get_bbi_field (const xtensa_insnbuf); void set_bbi_field (xtensa_insnbuf, uint32); uint32 get_bbi4_field (const xtensa_insnbuf); void set_bbi4_field (xtensa_insnbuf, uint32); uint32 get_i_field (const xtensa_insnbuf); void set_i_field (xtensa_insnbuf, uint32); uint32 get_imm12_field (const xtensa_insnbuf); void set_imm12_field (xtensa_insnbuf, uint32); uint32 get_imm12b_field (const xtensa_insnbuf); void set_imm12b_field (xtensa_insnbuf, uint32); uint32 get_imm16_field (const xtensa_insnbuf); void set_imm16_field (xtensa_insnbuf, uint32); uint32 get_imm4_field (const xtensa_insnbuf); void set_imm4_field (xtensa_insnbuf, uint32); uint32 get_imm6_field (const xtensa_insnbuf); void set_imm6_field (xtensa_insnbuf, uint32); uint32 get_imm6hi_field (const xtensa_insnbuf); void set_imm6hi_field (xtensa_insnbuf, uint32); uint32 get_imm6lo_field (const xtensa_insnbuf); void set_imm6lo_field (xtensa_insnbuf, uint32); uint32 get_imm7_field (const xtensa_insnbuf); void set_imm7_field (xtensa_insnbuf, uint32); uint32 get_imm7hi_field (const xtensa_insnbuf); void set_imm7hi_field (xtensa_insnbuf, uint32); uint32 get_imm7lo_field (const xtensa_insnbuf); void set_imm7lo_field (xtensa_insnbuf, uint32); uint32 get_imm8_field (const xtensa_insnbuf); void set_imm8_field (xtensa_insnbuf, uint32); uint32 get_m_field (const xtensa_insnbuf); void set_m_field (xtensa_insnbuf, uint32); uint32 get_mn_field (const xtensa_insnbuf); void set_mn_field (xtensa_insnbuf, uint32); uint32 get_n_field (const xtensa_insnbuf); void set_n_field (xtensa_insnbuf, uint32); uint32 get_none_field (const xtensa_insnbuf); void set_none_field (xtensa_insnbuf, uint32); uint32 get_offset_field (const xtensa_insnbuf); void set_offset_field (xtensa_insnbuf, uint32); uint32 get_op0_field (const xtensa_insnbuf); void set_op0_field (xtensa_insnbuf, uint32); uint32 get_op1_field (const xtensa_insnbuf); void set_op1_field (xtensa_insnbuf, uint32); uint32 get_op2_field (const xtensa_insnbuf); void set_op2_field (xtensa_insnbuf, uint32); uint32 get_r_field (const xtensa_insnbuf); void set_r_field (xtensa_insnbuf, uint32); uint32 get_s_field (const xtensa_insnbuf); void set_s_field (xtensa_insnbuf, uint32); uint32 get_sa4_field (const xtensa_insnbuf); void set_sa4_field (xtensa_insnbuf, uint32); uint32 get_sae_field (const xtensa_insnbuf); void set_sae_field (xtensa_insnbuf, uint32); uint32 get_sae4_field (const xtensa_insnbuf); void set_sae4_field (xtensa_insnbuf, uint32); uint32 get_sal_field (const xtensa_insnbuf); void set_sal_field (xtensa_insnbuf, uint32); uint32 get_sar_field (const xtensa_insnbuf); void set_sar_field (xtensa_insnbuf, uint32); uint32 get_sas_field (const xtensa_insnbuf); void set_sas_field (xtensa_insnbuf, uint32); uint32 get_sas4_field (const xtensa_insnbuf); void set_sas4_field (xtensa_insnbuf, uint32); uint32 get_sr_field (const xtensa_insnbuf); void set_sr_field (xtensa_insnbuf, uint32); uint32 get_t_field (const xtensa_insnbuf); void set_t_field (xtensa_insnbuf, uint32); uint32 get_thi3_field (const xtensa_insnbuf); void set_thi3_field (xtensa_insnbuf, uint32); uint32 get_z_field (const xtensa_insnbuf); void set_z_field (xtensa_insnbuf, uint32); uint32 get_bbi_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf0000) >> 16) | ((insn[0] & 0x100) >> 4); } void set_bbi_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfff0ffff) | ((val << 16) & 0xf0000); insn[0] = (insn[0] & 0xfffffeff) | ((val << 4) & 0x100); } uint32 get_bbi4_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x100) >> 8); } void set_bbi4_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffffeff) | ((val << 8) & 0x100); } uint32 get_i_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x80000) >> 19); } void set_i_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfff7ffff) | ((val << 19) & 0x80000); } uint32 get_imm12_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xfff)); } void set_imm12_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffff000) | (val & 0xfff); } uint32 get_imm12b_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xff)) | ((insn[0] & 0xf000) >> 4); } void set_imm12b_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xffffff00) | (val & 0xff); insn[0] = (insn[0] & 0xffff0fff) | ((val << 4) & 0xf000); } uint32 get_imm16_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xffff)); } void set_imm16_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xffff0000) | (val & 0xffff); } uint32 get_imm4_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf00) >> 8); } void set_imm4_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffff0ff) | ((val << 8) & 0xf00); } uint32 get_imm6_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf00) >> 8) | ((insn[0] & 0x30000) >> 12); } void set_imm6_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffff0ff) | ((val << 8) & 0xf00); insn[0] = (insn[0] & 0xfffcffff) | ((val << 12) & 0x30000); } uint32 get_imm6hi_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x30000) >> 16); } void set_imm6hi_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffcffff) | ((val << 16) & 0x30000); } uint32 get_imm6lo_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf00) >> 8); } void set_imm6lo_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffff0ff) | ((val << 8) & 0xf00); } uint32 get_imm7_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf00) >> 8) | ((insn[0] & 0x70000) >> 12); } void set_imm7_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffff0ff) | ((val << 8) & 0xf00); insn[0] = (insn[0] & 0xfff8ffff) | ((val << 12) & 0x70000); } uint32 get_imm7hi_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x70000) >> 16); } void set_imm7hi_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfff8ffff) | ((val << 16) & 0x70000); } uint32 get_imm7lo_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf00) >> 8); } void set_imm7lo_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffff0ff) | ((val << 8) & 0xf00); } uint32 get_imm8_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xff)); } void set_imm8_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xffffff00) | (val & 0xff); } uint32 get_m_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x30000) >> 16); } void set_m_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffcffff) | ((val << 16) & 0x30000); } uint32 get_mn_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x30000) >> 16) | ((insn[0] & 0xc0000) >> 16); } void set_mn_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffcffff) | ((val << 16) & 0x30000); insn[0] = (insn[0] & 0xfff3ffff) | ((val << 16) & 0xc0000); } uint32 get_n_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xc0000) >> 18); } void set_n_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfff3ffff) | ((val << 18) & 0xc0000); } uint32 get_none_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x0)); } void set_none_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xffffffff) | (val & 0x0); } uint32 get_offset_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x3ffff)); } void set_offset_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffc0000) | (val & 0x3ffff); } uint32 get_op0_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf00000) >> 20); } void set_op0_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xff0fffff) | ((val << 20) & 0xf00000); } uint32 get_op1_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf0) >> 4); } void set_op1_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xffffff0f) | ((val << 4) & 0xf0); } uint32 get_op2_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf)); } void set_op2_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffffff0) | (val & 0xf); } uint32 get_r_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf00) >> 8); } void set_r_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffff0ff) | ((val << 8) & 0xf00); } uint32 get_s_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf000) >> 12); } void set_s_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xffff0fff) | ((val << 12) & 0xf000); } uint32 get_sa4_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x1)); } void set_sa4_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffffffe) | (val & 0x1); } uint32 get_sae_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf000) >> 12) | ((insn[0] & 0x10)); } void set_sae_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xffff0fff) | ((val << 12) & 0xf000); insn[0] = (insn[0] & 0xffffffef) | (val & 0x10); } uint32 get_sae4_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x10) >> 4); } void set_sae4_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xffffffef) | ((val << 4) & 0x10); } uint32 get_sal_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf0000) >> 16) | ((insn[0] & 0x1) << 4); } void set_sal_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfff0ffff) | ((val << 16) & 0xf0000); insn[0] = (insn[0] & 0xfffffffe) | ((val >> 4) & 0x1); } uint32 get_sar_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf000) >> 12) | ((insn[0] & 0x1) << 4); } void set_sar_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xffff0fff) | ((val << 12) & 0xf000); insn[0] = (insn[0] & 0xfffffffe) | ((val >> 4) & 0x1); } uint32 get_sas_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf000) >> 12) | ((insn[0] & 0x10000) >> 12); } void set_sas_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xffff0fff) | ((val << 12) & 0xf000); insn[0] = (insn[0] & 0xfffeffff) | ((val << 12) & 0x10000); } uint32 get_sas4_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x10000) >> 16); } void set_sas4_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffeffff) | ((val << 16) & 0x10000); } uint32 get_sr_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf00) >> 8) | ((insn[0] & 0xf000) >> 8); } void set_sr_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffff0ff) | ((val << 8) & 0xf00); insn[0] = (insn[0] & 0xffff0fff) | ((val << 8) & 0xf000); } uint32 get_t_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xf0000) >> 16); } void set_t_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfff0ffff) | ((val << 16) & 0xf0000); } uint32 get_thi3_field (const xtensa_insnbuf insn) { return ((insn[0] & 0xe0000) >> 17); } void set_thi3_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfff1ffff) | ((val << 17) & 0xe0000); } uint32 get_z_field (const xtensa_insnbuf insn) { return ((insn[0] & 0x40000) >> 18); } void set_z_field (xtensa_insnbuf insn, uint32 val) { insn[0] = (insn[0] & 0xfffbffff) | ((val << 18) & 0x40000); } uint32 decode_b4constu (uint32); xtensa_encode_result encode_b4constu (uint32 *); uint32 decode_simm8x256 (uint32); xtensa_encode_result encode_simm8x256 (uint32 *); uint32 decode_soffset (uint32); xtensa_encode_result encode_soffset (uint32 *); uint32 decode_imm4 (uint32); xtensa_encode_result encode_imm4 (uint32 *); uint32 decode_op0 (uint32); xtensa_encode_result encode_op0 (uint32 *); uint32 decode_op1 (uint32); xtensa_encode_result encode_op1 (uint32 *); uint32 decode_imm6 (uint32); xtensa_encode_result encode_imm6 (uint32 *); uint32 decode_op2 (uint32); xtensa_encode_result encode_op2 (uint32 *); uint32 decode_imm7 (uint32); xtensa_encode_result encode_imm7 (uint32 *); uint32 decode_simm4 (uint32); xtensa_encode_result encode_simm4 (uint32 *); uint32 decode_ai4const (uint32); xtensa_encode_result encode_ai4const (uint32 *); uint32 decode_imm8 (uint32); xtensa_encode_result encode_imm8 (uint32 *); uint32 decode_sae (uint32); xtensa_encode_result encode_sae (uint32 *); uint32 decode_imm7lo (uint32); xtensa_encode_result encode_imm7lo (uint32 *); uint32 decode_simm7 (uint32); xtensa_encode_result encode_simm7 (uint32 *); uint32 decode_simm8 (uint32); xtensa_encode_result encode_simm8 (uint32 *); uint32 decode_uimm12x8 (uint32); xtensa_encode_result encode_uimm12x8 (uint32 *); uint32 decode_sal (uint32); xtensa_encode_result encode_sal (uint32 *); uint32 decode_uimm6 (uint32); xtensa_encode_result encode_uimm6 (uint32 *); uint32 decode_sas4 (uint32); xtensa_encode_result encode_sas4 (uint32 *); uint32 decode_uimm8 (uint32); xtensa_encode_result encode_uimm8 (uint32 *); uint32 decode_uimm16x4 (uint32); xtensa_encode_result encode_uimm16x4 (uint32 *); uint32 decode_sar (uint32); xtensa_encode_result encode_sar (uint32 *); uint32 decode_sa4 (uint32); xtensa_encode_result encode_sa4 (uint32 *); uint32 decode_sas (uint32); xtensa_encode_result encode_sas (uint32 *); uint32 decode_imm6hi (uint32); xtensa_encode_result encode_imm6hi (uint32 *); uint32 decode_bbi (uint32); xtensa_encode_result encode_bbi (uint32 *); uint32 decode_uimm8x2 (uint32); xtensa_encode_result encode_uimm8x2 (uint32 *); uint32 decode_uimm8x4 (uint32); xtensa_encode_result encode_uimm8x4 (uint32 *); uint32 decode_msalp32 (uint32); xtensa_encode_result encode_msalp32 (uint32 *); uint32 decode_bbi4 (uint32); xtensa_encode_result encode_bbi4 (uint32 *); uint32 decode_op2p1 (uint32); xtensa_encode_result encode_op2p1 (uint32 *); uint32 decode_soffsetx4 (uint32); xtensa_encode_result encode_soffsetx4 (uint32 *); uint32 decode_imm6lo (uint32); xtensa_encode_result encode_imm6lo (uint32 *); uint32 decode_imm12 (uint32); xtensa_encode_result encode_imm12 (uint32 *); uint32 decode_b4const (uint32); xtensa_encode_result encode_b4const (uint32 *); uint32 decode_i (uint32); xtensa_encode_result encode_i (uint32 *); uint32 decode_imm16 (uint32); xtensa_encode_result encode_imm16 (uint32 *); uint32 decode_mn (uint32); xtensa_encode_result encode_mn (uint32 *); uint32 decode_m (uint32); xtensa_encode_result encode_m (uint32 *); uint32 decode_n (uint32); xtensa_encode_result encode_n (uint32 *); uint32 decode_none (uint32); xtensa_encode_result encode_none (uint32 *); uint32 decode_imm12b (uint32); xtensa_encode_result encode_imm12b (uint32 *); uint32 decode_r (uint32); xtensa_encode_result encode_r (uint32 *); uint32 decode_s (uint32); xtensa_encode_result encode_s (uint32 *); uint32 decode_t (uint32); xtensa_encode_result encode_t (uint32 *); uint32 decode_thi3 (uint32); xtensa_encode_result encode_thi3 (uint32 *); uint32 decode_sae4 (uint32); xtensa_encode_result encode_sae4 (uint32 *); uint32 decode_offset (uint32); xtensa_encode_result encode_offset (uint32 *); uint32 decode_imm7hi (uint32); xtensa_encode_result encode_imm7hi (uint32 *); uint32 decode_uimm4x16 (uint32); xtensa_encode_result encode_uimm4x16 (uint32 *); uint32 decode_simm12b (uint32); xtensa_encode_result encode_simm12b (uint32 *); uint32 decode_lsi4x4 (uint32); xtensa_encode_result encode_lsi4x4 (uint32 *); uint32 decode_z (uint32); xtensa_encode_result encode_z (uint32 *); uint32 decode_simm12 (uint32); xtensa_encode_result encode_simm12 (uint32 *); uint32 decode_sr (uint32); xtensa_encode_result encode_sr (uint32 *); uint32 decode_nimm4x2 (uint32); xtensa_encode_result encode_nimm4x2 (uint32 *); static const uint32 b4constu_table[] = { 32768, 65536, 2, 3, 4, 5, 6, 7, 8, 10, 12, 16, 32, 64, 128, 256 }; uint32 decode_b4constu (uint32 val) { val = b4constu_table[val]; return val; } xtensa_encode_result encode_b4constu (uint32 *valp) { uint32 val = *valp; unsigned i; for (i = 0; i < (1 << 4); i += 1) if (b4constu_table[i] == val) goto found; return xtensa_encode_result_not_in_table; found: val = i; *valp = val; return xtensa_encode_result_ok; } uint32 decode_simm8x256 (uint32 val) { val = (val ^ 0x80) - 0x80; val <<= 8; return val; } xtensa_encode_result encode_simm8x256 (uint32 *valp) { uint32 val = *valp; if ((val & ((1 << 8) - 1)) != 0) return xtensa_encode_result_align; val = (signed int) val >> 8; if (((val + (1 << 7)) >> 8) != 0) { if ((signed int) val > 0) return xtensa_encode_result_too_high; else return xtensa_encode_result_too_low; } *valp = val; return xtensa_encode_result_ok; } uint32 decode_soffset (uint32 val) { val = (val ^ 0x20000) - 0x20000; return val; } xtensa_encode_result encode_soffset (uint32 *valp) { uint32 val = *valp; if (((val + (1 << 17)) >> 18) != 0) { if ((signed int) val > 0) return xtensa_encode_result_too_high; else return xtensa_encode_result_too_low; } *valp = val; return xtensa_encode_result_ok; } uint32 decode_imm4 (uint32 val) { return val; } xtensa_encode_result encode_imm4 (uint32 *valp) { uint32 val = *valp; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_op0 (uint32 val) { return val; } xtensa_encode_result encode_op0 (uint32 *valp) { uint32 val = *valp; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_op1 (uint32 val) { return val; } xtensa_encode_result encode_op1 (uint32 *valp) { uint32 val = *valp; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_imm6 (uint32 val) { return val; } xtensa_encode_result encode_imm6 (uint32 *valp) { uint32 val = *valp; if ((val >> 6) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_op2 (uint32 val) { return val; } xtensa_encode_result encode_op2 (uint32 *valp) { uint32 val = *valp; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_imm7 (uint32 val) { return val; } xtensa_encode_result encode_imm7 (uint32 *valp) { uint32 val = *valp; if ((val >> 7) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_simm4 (uint32 val) { val = (val ^ 0x8) - 0x8; return val; } xtensa_encode_result encode_simm4 (uint32 *valp) { uint32 val = *valp; if (((val + (1 << 3)) >> 4) != 0) { if ((signed int) val > 0) return xtensa_encode_result_too_high; else return xtensa_encode_result_too_low; } *valp = val; return xtensa_encode_result_ok; } static const uint32 ai4const_table[] = { -1, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 }; uint32 decode_ai4const (uint32 val) { val = ai4const_table[val]; return val; } xtensa_encode_result encode_ai4const (uint32 *valp) { uint32 val = *valp; unsigned i; for (i = 0; i < (1 << 4); i += 1) if (ai4const_table[i] == val) goto found; return xtensa_encode_result_not_in_table; found: val = i; *valp = val; return xtensa_encode_result_ok; } uint32 decode_imm8 (uint32 val) { return val; } xtensa_encode_result encode_imm8 (uint32 *valp) { uint32 val = *valp; if ((val >> 8) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_sae (uint32 val) { return val; } xtensa_encode_result encode_sae (uint32 *valp) { uint32 val = *valp; if ((val >> 5) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_imm7lo (uint32 val) { return val; } xtensa_encode_result encode_imm7lo (uint32 *valp) { uint32 val = *valp; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_simm7 (uint32 val) { if (val > 95) val |= -32; return val; } xtensa_encode_result encode_simm7 (uint32 *valp) { uint32 val = *valp; if ((signed int) val < -32) return xtensa_encode_result_too_low; if ((signed int) val > 95) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_simm8 (uint32 val) { val = (val ^ 0x80) - 0x80; return val; } xtensa_encode_result encode_simm8 (uint32 *valp) { uint32 val = *valp; if (((val + (1 << 7)) >> 8) != 0) { if ((signed int) val > 0) return xtensa_encode_result_too_high; else return xtensa_encode_result_too_low; } *valp = val; return xtensa_encode_result_ok; } uint32 decode_uimm12x8 (uint32 val) { val <<= 3; return val; } xtensa_encode_result encode_uimm12x8 (uint32 *valp) { uint32 val = *valp; if ((val & ((1 << 3) - 1)) != 0) return xtensa_encode_result_align; val = (signed int) val >> 3; if ((val >> 12) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_sal (uint32 val) { return val; } xtensa_encode_result encode_sal (uint32 *valp) { uint32 val = *valp; if ((val >> 5) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_uimm6 (uint32 val) { return val; } xtensa_encode_result encode_uimm6 (uint32 *valp) { uint32 val = *valp; if ((val >> 6) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_sas4 (uint32 val) { return val; } xtensa_encode_result encode_sas4 (uint32 *valp) { uint32 val = *valp; if ((val >> 1) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_uimm8 (uint32 val) { return val; } xtensa_encode_result encode_uimm8 (uint32 *valp) { uint32 val = *valp; if ((val >> 8) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_uimm16x4 (uint32 val) { val |= -1 << 16; val <<= 2; return val; } xtensa_encode_result encode_uimm16x4 (uint32 *valp) { uint32 val = *valp; if ((val & ((1 << 2) - 1)) != 0) return xtensa_encode_result_align; val = (signed int) val >> 2; if ((signed int) val >> 16 != -1) { if ((signed int) val >= 0) return xtensa_encode_result_too_high; else return xtensa_encode_result_too_low; } *valp = val; return xtensa_encode_result_ok; } uint32 decode_sar (uint32 val) { return val; } xtensa_encode_result encode_sar (uint32 *valp) { uint32 val = *valp; if ((val >> 5) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_sa4 (uint32 val) { return val; } xtensa_encode_result encode_sa4 (uint32 *valp) { uint32 val = *valp; if ((val >> 1) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_sas (uint32 val) { return val; } xtensa_encode_result encode_sas (uint32 *valp) { uint32 val = *valp; if ((val >> 5) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_imm6hi (uint32 val) { return val; } xtensa_encode_result encode_imm6hi (uint32 *valp) { uint32 val = *valp; if ((val >> 2) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_bbi (uint32 val) { return val; } xtensa_encode_result encode_bbi (uint32 *valp) { uint32 val = *valp; if ((val >> 5) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_uimm8x2 (uint32 val) { val <<= 1; return val; } xtensa_encode_result encode_uimm8x2 (uint32 *valp) { uint32 val = *valp; if ((val & ((1 << 1) - 1)) != 0) return xtensa_encode_result_align; val = (signed int) val >> 1; if ((val >> 8) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_uimm8x4 (uint32 val) { val <<= 2; return val; } xtensa_encode_result encode_uimm8x4 (uint32 *valp) { uint32 val = *valp; if ((val & ((1 << 2) - 1)) != 0) return xtensa_encode_result_align; val = (signed int) val >> 2; if ((val >> 8) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } static const uint32 mip32const_table[] = { 32, 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1 }; uint32 decode_msalp32 (uint32 val) { val = mip32const_table[val]; return val; } xtensa_encode_result encode_msalp32 (uint32 *valp) { uint32 val = *valp; unsigned i; for (i = 0; i < (1 << 5); i += 1) if (mip32const_table[i] == val) goto found; return xtensa_encode_result_not_in_table; found: val = i; *valp = val; return xtensa_encode_result_ok; } uint32 decode_bbi4 (uint32 val) { return val; } xtensa_encode_result encode_bbi4 (uint32 *valp) { uint32 val = *valp; if ((val >> 1) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } static const uint32 i4p1const_table[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 }; uint32 decode_op2p1 (uint32 val) { val = i4p1const_table[val]; return val; } xtensa_encode_result encode_op2p1 (uint32 *valp) { uint32 val = *valp; unsigned i; for (i = 0; i < (1 << 4); i += 1) if (i4p1const_table[i] == val) goto found; return xtensa_encode_result_not_in_table; found: val = i; *valp = val; return xtensa_encode_result_ok; } uint32 decode_soffsetx4 (uint32 val) { val = (val ^ 0x20000) - 0x20000; val <<= 2; return val; } xtensa_encode_result encode_soffsetx4 (uint32 *valp) { uint32 val = *valp; if ((val & ((1 << 2) - 1)) != 0) return xtensa_encode_result_align; val = (signed int) val >> 2; if (((val + (1 << 17)) >> 18) != 0) { if ((signed int) val > 0) return xtensa_encode_result_too_high; else return xtensa_encode_result_too_low; } *valp = val; return xtensa_encode_result_ok; } uint32 decode_imm6lo (uint32 val) { return val; } xtensa_encode_result encode_imm6lo (uint32 *valp) { uint32 val = *valp; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_imm12 (uint32 val) { return val; } xtensa_encode_result encode_imm12 (uint32 *valp) { uint32 val = *valp; if ((val >> 12) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } static const uint32 b4const_table[] = { -1, 1, 2, 3, 4, 5, 6, 7, 8, 10, 12, 16, 32, 64, 128, 256 }; uint32 decode_b4const (uint32 val) { val = b4const_table[val]; return val; } xtensa_encode_result encode_b4const (uint32 *valp) { uint32 val = *valp; unsigned i; for (i = 0; i < (1 << 4); i += 1) if (b4const_table[i] == val) goto found; return xtensa_encode_result_not_in_table; found: val = i; *valp = val; return xtensa_encode_result_ok; } uint32 decode_i (uint32 val) { return val; } xtensa_encode_result encode_i (uint32 *valp) { uint32 val = *valp; if ((val >> 1) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_imm16 (uint32 val) { return val; } xtensa_encode_result encode_imm16 (uint32 *valp) { uint32 val = *valp; if ((val >> 16) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_mn (uint32 val) { return val; } xtensa_encode_result encode_mn (uint32 *valp) { uint32 val = *valp; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_m (uint32 val) { return val; } xtensa_encode_result encode_m (uint32 *valp) { uint32 val = *valp; if ((val >> 2) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_n (uint32 val) { return val; } xtensa_encode_result encode_n (uint32 *valp) { uint32 val = *valp; if ((val >> 2) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_none (uint32 val) { return val; } xtensa_encode_result encode_none (uint32 *valp) { uint32 val = *valp; if ((val >> 0) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_imm12b (uint32 val) { return val; } xtensa_encode_result encode_imm12b (uint32 *valp) { uint32 val = *valp; if ((val >> 12) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_r (uint32 val) { return val; } xtensa_encode_result encode_r (uint32 *valp) { uint32 val = *valp; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_s (uint32 val) { return val; } xtensa_encode_result encode_s (uint32 *valp) { uint32 val = *valp; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_t (uint32 val) { return val; } xtensa_encode_result encode_t (uint32 *valp) { uint32 val = *valp; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_thi3 (uint32 val) { return val; } xtensa_encode_result encode_thi3 (uint32 *valp) { uint32 val = *valp; if ((val >> 3) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_sae4 (uint32 val) { return val; } xtensa_encode_result encode_sae4 (uint32 *valp) { uint32 val = *valp; if ((val >> 1) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_offset (uint32 val) { return val; } xtensa_encode_result encode_offset (uint32 *valp) { uint32 val = *valp; if ((val >> 18) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_imm7hi (uint32 val) { return val; } xtensa_encode_result encode_imm7hi (uint32 *valp) { uint32 val = *valp; if ((val >> 3) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_uimm4x16 (uint32 val) { val <<= 4; return val; } xtensa_encode_result encode_uimm4x16 (uint32 *valp) { uint32 val = *valp; if ((val & ((1 << 4) - 1)) != 0) return xtensa_encode_result_align; val = (signed int) val >> 4; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_simm12b (uint32 val) { val = (val ^ 0x800) - 0x800; return val; } xtensa_encode_result encode_simm12b (uint32 *valp) { uint32 val = *valp; if (((val + (1 << 11)) >> 12) != 0) { if ((signed int) val > 0) return xtensa_encode_result_too_high; else return xtensa_encode_result_too_low; } *valp = val; return xtensa_encode_result_ok; } uint32 decode_lsi4x4 (uint32 val) { val <<= 2; return val; } xtensa_encode_result encode_lsi4x4 (uint32 *valp) { uint32 val = *valp; if ((val & ((1 << 2) - 1)) != 0) return xtensa_encode_result_align; val = (signed int) val >> 2; if ((val >> 4) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_z (uint32 val) { return val; } xtensa_encode_result encode_z (uint32 *valp) { uint32 val = *valp; if ((val >> 1) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_simm12 (uint32 val) { val = (val ^ 0x800) - 0x800; return val; } xtensa_encode_result encode_simm12 (uint32 *valp) { uint32 val = *valp; if (((val + (1 << 11)) >> 12) != 0) { if ((signed int) val > 0) return xtensa_encode_result_too_high; else return xtensa_encode_result_too_low; } *valp = val; return xtensa_encode_result_ok; } uint32 decode_sr (uint32 val) { return val; } xtensa_encode_result encode_sr (uint32 *valp) { uint32 val = *valp; if ((val >> 8) != 0) return xtensa_encode_result_too_high; *valp = val; return xtensa_encode_result_ok; } uint32 decode_nimm4x2 (uint32 val) { val |= -1 << 4; val <<= 2; return val; } xtensa_encode_result encode_nimm4x2 (uint32 *valp) { uint32 val = *valp; if ((val & ((1 << 2) - 1)) != 0) return xtensa_encode_result_align; val = (signed int) val >> 2; if ((signed int) val >> 4 != -1) { if ((signed int) val >= 0) return xtensa_encode_result_too_high; else return xtensa_encode_result_too_low; } *valp = val; return xtensa_encode_result_ok; } uint32 do_reloc_l (uint32, uint32); uint32 undo_reloc_l (uint32, uint32); uint32 do_reloc_L (uint32, uint32); uint32 undo_reloc_L (uint32, uint32); uint32 do_reloc_r (uint32, uint32); uint32 undo_reloc_r (uint32, uint32); uint32 do_reloc_l (uint32 addr, uint32 pc) { return addr - pc - 4; } uint32 undo_reloc_l (uint32 offset, uint32 pc) { return pc + offset + 4; } uint32 do_reloc_L (uint32 addr, uint32 pc) { return addr - (pc & -4) - 4; } uint32 undo_reloc_L (uint32 offset, uint32 pc) { return (pc & -4) + offset + 4; } uint32 do_reloc_r (uint32 addr, uint32 pc) { return addr - ((pc+3) & -4); } uint32 undo_reloc_r (uint32 offset, uint32 pc) { return ((pc+3) & -4) + offset; } static xtensa_operand_internal iib4const_operand = { "i", '<', 0, get_r_field, set_r_field, encode_b4const, decode_b4const, 0, 0 }; static xtensa_operand_internal iiuimm8_operand = { "i", '<', 0, get_imm8_field, set_imm8_field, encode_uimm8, decode_uimm8, 0, 0 }; static xtensa_operand_internal lisoffsetx4_operand = { "L", '<', 1, get_offset_field, set_offset_field, encode_soffsetx4, decode_soffsetx4, do_reloc_L, undo_reloc_L, }; static xtensa_operand_internal iisimm8x256_operand = { "i", '<', 0, get_imm8_field, set_imm8_field, encode_simm8x256, decode_simm8x256, 0, 0 }; static xtensa_operand_internal lisimm12_operand = { "l", '<', 1, get_imm12_field, set_imm12_field, encode_simm12, decode_simm12, do_reloc_l, undo_reloc_l, }; static xtensa_operand_internal iiop2p1_operand = { "i", '<', 0, get_op2_field, set_op2_field, encode_op2p1, decode_op2p1, 0, 0 }; static xtensa_operand_internal iisae_operand = { "i", '<', 0, get_sae_field, set_sae_field, encode_sae, decode_sae, 0, 0 }; static xtensa_operand_internal iis_operand = { "i", '<', 0, get_s_field, set_s_field, encode_s, decode_s, 0, 0 }; static xtensa_operand_internal iit_operand = { "i", '<', 0, get_t_field, set_t_field, encode_t, decode_t, 0, 0 }; static xtensa_operand_internal iisimm12b_operand = { "i", '<', 0, get_imm12b_field, set_imm12b_field, encode_simm12b, decode_simm12b, 0, 0 }; static xtensa_operand_internal iinimm4x2_operand = { "i", '<', 0, get_imm4_field, set_imm4_field, encode_nimm4x2, decode_nimm4x2, 0, 0 }; static xtensa_operand_internal iiuimm4x16_operand = { "i", '<', 0, get_op2_field, set_op2_field, encode_uimm4x16, decode_uimm4x16, 0, 0 }; static xtensa_operand_internal abs_operand = { "a", '=', 0, get_s_field, set_s_field, encode_s, decode_s, 0, 0 }; static xtensa_operand_internal iisar_operand = { "i", '<', 0, get_sar_field, set_sar_field, encode_sar, decode_sar, 0, 0 }; static xtensa_operand_internal abt_operand = { "a", '=', 0, get_t_field, set_t_field, encode_t, decode_t, 0, 0 }; static xtensa_operand_internal iisas_operand = { "i", '<', 0, get_sas_field, set_sas_field, encode_sas, decode_sas, 0, 0 }; static xtensa_operand_internal amr_operand = { "a", '=', 0, get_r_field, set_r_field, encode_r, decode_r, 0, 0 }; static xtensa_operand_internal iib4constu_operand = { "i", '<', 0, get_r_field, set_r_field, encode_b4constu, decode_b4constu, 0, 0 }; static xtensa_operand_internal iisr_operand = { "i", '<', 0, get_sr_field, set_sr_field, encode_sr, decode_sr, 0, 0 }; static xtensa_operand_internal iibbi_operand = { "i", '<', 0, get_bbi_field, set_bbi_field, encode_bbi, decode_bbi, 0, 0 }; static xtensa_operand_internal iiai4const_operand = { "i", '<', 0, get_t_field, set_t_field, encode_ai4const, decode_ai4const, 0, 0 }; static xtensa_operand_internal iiuimm12x8_operand = { "i", '<', 0, get_imm12_field, set_imm12_field, encode_uimm12x8, decode_uimm12x8, 0, 0 }; static xtensa_operand_internal riuimm16x4_operand = { "r", '<', 1, get_imm16_field, set_imm16_field, encode_uimm16x4, decode_uimm16x4, do_reloc_r, undo_reloc_r, }; static xtensa_operand_internal lisimm8_operand = { "l", '<', 1, get_imm8_field, set_imm8_field, encode_simm8, decode_simm8, do_reloc_l, undo_reloc_l, }; static xtensa_operand_internal iilsi4x4_operand = { "i", '<', 0, get_r_field, set_r_field, encode_lsi4x4, decode_lsi4x4, 0, 0 }; static xtensa_operand_internal iiuimm8x2_operand = { "i", '<', 0, get_imm8_field, set_imm8_field, encode_uimm8x2, decode_uimm8x2, 0, 0 }; static xtensa_operand_internal iisimm4_operand = { "i", '<', 0, get_mn_field, set_mn_field, encode_simm4, decode_simm4, 0, 0 }; static xtensa_operand_internal iimsalp32_operand = { "i", '<', 0, get_sal_field, set_sal_field, encode_msalp32, decode_msalp32, 0, 0 }; static xtensa_operand_internal liuimm6_operand = { "l", '<', 1, get_imm6_field, set_imm6_field, encode_uimm6, decode_uimm6, do_reloc_l, undo_reloc_l, }; static xtensa_operand_internal iiuimm8x4_operand = { "i", '<', 0, get_imm8_field, set_imm8_field, encode_uimm8x4, decode_uimm8x4, 0, 0 }; static xtensa_operand_internal lisoffset_operand = { "l", '<', 1, get_offset_field, set_offset_field, encode_soffset, decode_soffset, do_reloc_l, undo_reloc_l, }; static xtensa_operand_internal iisimm7_operand = { "i", '<', 0, get_imm7_field, set_imm7_field, encode_simm7, decode_simm7, 0, 0 }; static xtensa_operand_internal ais_operand = { "a", '<', 0, get_s_field, set_s_field, encode_s, decode_s, 0, 0 }; static xtensa_operand_internal liuimm8_operand = { "l", '<', 1, get_imm8_field, set_imm8_field, encode_uimm8, decode_uimm8, do_reloc_l, undo_reloc_l, }; static xtensa_operand_internal ait_operand = { "a", '<', 0, get_t_field, set_t_field, encode_t, decode_t, 0, 0 }; static xtensa_operand_internal iisimm8_operand = { "i", '<', 0, get_imm8_field, set_imm8_field, encode_simm8, decode_simm8, 0, 0 }; static xtensa_operand_internal aor_operand = { "a", '>', 0, get_r_field, set_r_field, encode_r, decode_r, 0, 0 }; static xtensa_operand_internal aos_operand = { "a", '>', 0, get_s_field, set_s_field, encode_s, decode_s, 0, 0 }; static xtensa_operand_internal aot_operand = { "a", '>', 0, get_t_field, set_t_field, encode_t, decode_t, 0, 0 }; static xtensa_iclass_internal nopn_iclass = { 0, 0 }; static xtensa_operand_internal *movi_operand_list[] = { &aot_operand, &iisimm12b_operand }; static xtensa_iclass_internal movi_iclass = { 2, &movi_operand_list[0] }; static xtensa_operand_internal *bsi8u_operand_list[] = { &ais_operand, &iib4constu_operand, &lisimm8_operand }; static xtensa_iclass_internal bsi8u_iclass = { 3, &bsi8u_operand_list[0] }; static xtensa_operand_internal *itlb_operand_list[] = { &ais_operand }; static xtensa_iclass_internal itlb_iclass = { 1, &itlb_operand_list[0] }; static xtensa_operand_internal *shiftst_operand_list[] = { &aor_operand, &ais_operand, &ait_operand }; static xtensa_iclass_internal shiftst_iclass = { 3, &shiftst_operand_list[0] }; static xtensa_operand_internal *l32r_operand_list[] = { &aot_operand, &riuimm16x4_operand }; static xtensa_iclass_internal l32r_iclass = { 2, &l32r_operand_list[0] }; static xtensa_iclass_internal rfe_iclass = { 0, 0 }; static xtensa_operand_internal *wait_operand_list[] = { &iis_operand }; static xtensa_iclass_internal wait_iclass = { 1, &wait_operand_list[0] }; static xtensa_operand_internal *rfi_operand_list[] = { &iis_operand }; static xtensa_iclass_internal rfi_iclass = { 1, &rfi_operand_list[0] }; static xtensa_operand_internal *movz_operand_list[] = { &amr_operand, &ais_operand, &ait_operand }; static xtensa_iclass_internal movz_iclass = { 3, &movz_operand_list[0] }; static xtensa_operand_internal *callx_operand_list[] = { &ais_operand }; static xtensa_iclass_internal callx_iclass = { 1, &callx_operand_list[0] }; static xtensa_operand_internal *mov_n_operand_list[] = { &aot_operand, &ais_operand }; static xtensa_iclass_internal mov_n_iclass = { 2, &mov_n_operand_list[0] }; static xtensa_operand_internal *loadi4_operand_list[] = { &aot_operand, &ais_operand, &iilsi4x4_operand }; static xtensa_iclass_internal loadi4_iclass = { 3, &loadi4_operand_list[0] }; static xtensa_operand_internal *exti_operand_list[] = { &aor_operand, &ait_operand, &iisae_operand, &iiop2p1_operand }; static xtensa_iclass_internal exti_iclass = { 4, &exti_operand_list[0] }; static xtensa_operand_internal *break_operand_list[] = { &iis_operand, &iit_operand }; static xtensa_iclass_internal break_iclass = { 2, &break_operand_list[0] }; static xtensa_operand_internal *slli_operand_list[] = { &aor_operand, &ais_operand, &iimsalp32_operand }; static xtensa_iclass_internal slli_iclass = { 3, &slli_operand_list[0] }; static xtensa_operand_internal *s16i_operand_list[] = { &ait_operand, &ais_operand, &iiuimm8x2_operand }; static xtensa_iclass_internal s16i_iclass = { 3, &s16i_operand_list[0] }; static xtensa_operand_internal *call_operand_list[] = { &lisoffsetx4_operand }; static xtensa_iclass_internal call_iclass = { 1, &call_operand_list[0] }; static xtensa_operand_internal *shifts_operand_list[] = { &aor_operand, &ais_operand }; static xtensa_iclass_internal shifts_iclass = { 2, &shifts_operand_list[0] }; static xtensa_operand_internal *shiftt_operand_list[] = { &aor_operand, &ait_operand }; static xtensa_iclass_internal shiftt_iclass = { 2, &shiftt_operand_list[0] }; static xtensa_operand_internal *rotw_operand_list[] = { &iisimm4_operand }; static xtensa_iclass_internal rotw_iclass = { 1, &rotw_operand_list[0] }; static xtensa_operand_internal *addsub_operand_list[] = { &aor_operand, &ais_operand, &ait_operand }; static xtensa_iclass_internal addsub_iclass = { 3, &addsub_operand_list[0] }; static xtensa_operand_internal *l8i_operand_list[] = { &aot_operand, &ais_operand, &iiuimm8_operand }; static xtensa_iclass_internal l8i_iclass = { 3, &l8i_operand_list[0] }; static xtensa_operand_internal *sari_operand_list[] = { &iisas_operand }; static xtensa_iclass_internal sari_iclass = { 1, &sari_operand_list[0] }; static xtensa_operand_internal *xsr_operand_list[] = { &abt_operand, &iisr_operand }; static xtensa_iclass_internal xsr_iclass = { 2, &xsr_operand_list[0] }; static xtensa_operand_internal *rsil_operand_list[] = { &aot_operand, &iis_operand }; static xtensa_iclass_internal rsil_iclass = { 2, &rsil_operand_list[0] }; static xtensa_operand_internal *bst8_operand_list[] = { &ais_operand, &ait_operand, &lisimm8_operand }; static xtensa_iclass_internal bst8_iclass = { 3, &bst8_operand_list[0] }; static xtensa_operand_internal *addi_operand_list[] = { &aot_operand, &ais_operand, &iisimm8_operand }; static xtensa_iclass_internal addi_iclass = { 3, &addi_operand_list[0] }; static xtensa_operand_internal *callx12_operand_list[] = { &ais_operand }; static xtensa_iclass_internal callx12_iclass = { 1, &callx12_operand_list[0] }; static xtensa_operand_internal *bsi8_operand_list[] = { &ais_operand, &iib4const_operand, &lisimm8_operand }; static xtensa_iclass_internal bsi8_iclass = { 3, &bsi8_operand_list[0] }; static xtensa_operand_internal *jumpx_operand_list[] = { &ais_operand }; static xtensa_iclass_internal jumpx_iclass = { 1, &jumpx_operand_list[0] }; static xtensa_iclass_internal retn_iclass = { 0, 0 }; static xtensa_operand_internal *nsa_operand_list[] = { &aot_operand, &ais_operand }; static xtensa_iclass_internal nsa_iclass = { 2, &nsa_operand_list[0] }; static xtensa_operand_internal *storei4_operand_list[] = { &ait_operand, &ais_operand, &iilsi4x4_operand }; static xtensa_iclass_internal storei4_iclass = { 3, &storei4_operand_list[0] }; static xtensa_operand_internal *wtlb_operand_list[] = { &ait_operand, &ais_operand }; static xtensa_iclass_internal wtlb_iclass = { 2, &wtlb_operand_list[0] }; static xtensa_operand_internal *dce_operand_list[] = { &ais_operand, &iiuimm4x16_operand }; static xtensa_iclass_internal dce_iclass = { 2, &dce_operand_list[0] }; static xtensa_operand_internal *l16i_operand_list[] = { &aot_operand, &ais_operand, &iiuimm8x2_operand }; static xtensa_iclass_internal l16i_iclass = { 3, &l16i_operand_list[0] }; static xtensa_operand_internal *callx4_operand_list[] = { &ais_operand }; static xtensa_iclass_internal callx4_iclass = { 1, &callx4_operand_list[0] }; static xtensa_operand_internal *callx8_operand_list[] = { &ais_operand }; static xtensa_iclass_internal callx8_iclass = { 1, &callx8_operand_list[0] }; static xtensa_operand_internal *movsp_operand_list[] = { &aot_operand, &ais_operand }; static xtensa_iclass_internal movsp_iclass = { 2, &movsp_operand_list[0] }; static xtensa_operand_internal *wsr_operand_list[] = { &ait_operand, &iisr_operand }; static xtensa_iclass_internal wsr_iclass = { 2, &wsr_operand_list[0] }; static xtensa_operand_internal *call12_operand_list[] = { &lisoffsetx4_operand }; static xtensa_iclass_internal call12_iclass = { 1, &call12_operand_list[0] }; static xtensa_operand_internal *call4_operand_list[] = { &lisoffsetx4_operand }; static xtensa_iclass_internal call4_iclass = { 1, &call4_operand_list[0] }; static xtensa_operand_internal *addmi_operand_list[] = { &aot_operand, &ais_operand, &iisimm8x256_operand }; static xtensa_iclass_internal addmi_iclass = { 3, &addmi_operand_list[0] }; static xtensa_operand_internal *bit_operand_list[] = { &aor_operand, &ais_operand, &ait_operand }; static xtensa_iclass_internal bit_iclass = { 3, &bit_operand_list[0] }; static xtensa_operand_internal *call8_operand_list[] = { &lisoffsetx4_operand }; static xtensa_iclass_internal call8_iclass = { 1, &call8_operand_list[0] }; static xtensa_iclass_internal itlba_iclass = { 0, 0 }; static xtensa_operand_internal *break_n_operand_list[] = { &iis_operand }; static xtensa_iclass_internal break_n_iclass = { 1, &break_n_operand_list[0] }; static xtensa_operand_internal *sar_operand_list[] = { &ais_operand }; static xtensa_iclass_internal sar_iclass = { 1, &sar_operand_list[0] }; static xtensa_operand_internal *s32e_operand_list[] = { &ait_operand, &ais_operand, &iinimm4x2_operand }; static xtensa_iclass_internal s32e_iclass = { 3, &s32e_operand_list[0] }; static xtensa_operand_internal *bz6_operand_list[] = { &ais_operand, &liuimm6_operand }; static xtensa_iclass_internal bz6_iclass = { 2, &bz6_operand_list[0] }; static xtensa_operand_internal *loop_operand_list[] = { &ais_operand, &liuimm8_operand }; static xtensa_iclass_internal loop_iclass = { 2, &loop_operand_list[0] }; static xtensa_operand_internal *rsr_operand_list[] = { &aot_operand, &iisr_operand }; static xtensa_iclass_internal rsr_iclass = { 2, &rsr_operand_list[0] }; static xtensa_operand_internal *icache_operand_list[] = { &ais_operand, &iiuimm8x4_operand }; static xtensa_iclass_internal icache_iclass = { 2, &icache_operand_list[0] }; static xtensa_operand_internal *s8i_operand_list[] = { &ait_operand, &ais_operand, &iiuimm8_operand }; static xtensa_iclass_internal s8i_iclass = { 3, &s8i_operand_list[0] }; static xtensa_iclass_internal return_iclass = { 0, 0 }; static xtensa_operand_internal *dcache_operand_list[] = { &ais_operand, &iiuimm8x4_operand }; static xtensa_iclass_internal dcache_iclass = { 2, &dcache_operand_list[0] }; static xtensa_operand_internal *s32i_operand_list[] = { &ait_operand, &ais_operand, &iiuimm8x4_operand }; static xtensa_iclass_internal s32i_iclass = { 3, &s32i_operand_list[0] }; static xtensa_operand_internal *jump_operand_list[] = { &lisoffset_operand }; static xtensa_iclass_internal jump_iclass = { 1, &jump_operand_list[0] }; static xtensa_operand_internal *addi_n_operand_list[] = { &aor_operand, &ais_operand, &iiai4const_operand }; static xtensa_iclass_internal addi_n_iclass = { 3, &addi_n_operand_list[0] }; static xtensa_iclass_internal sync_iclass = { 0, 0 }; static xtensa_operand_internal *neg_operand_list[] = { &aor_operand, &ait_operand }; static xtensa_iclass_internal neg_iclass = { 2, &neg_operand_list[0] }; static xtensa_iclass_internal syscall_iclass = { 0, 0 }; static xtensa_operand_internal *bsz12_operand_list[] = { &ais_operand, &lisimm12_operand }; static xtensa_iclass_internal bsz12_iclass = { 2, &bsz12_operand_list[0] }; static xtensa_iclass_internal excw_iclass = { 0, 0 }; static xtensa_operand_internal *movi_n_operand_list[] = { &aos_operand, &iisimm7_operand }; static xtensa_iclass_internal movi_n_iclass = { 2, &movi_n_operand_list[0] }; static xtensa_operand_internal *rtlb_operand_list[] = { &aot_operand, &ais_operand }; static xtensa_iclass_internal rtlb_iclass = { 2, &rtlb_operand_list[0] }; static xtensa_operand_internal *actl_operand_list[] = { &aot_operand, &ais_operand }; static xtensa_iclass_internal actl_iclass = { 2, &actl_operand_list[0] }; static xtensa_operand_internal *srli_operand_list[] = { &aor_operand, &ait_operand, &iis_operand }; static xtensa_iclass_internal srli_iclass = { 3, &srli_operand_list[0] }; static xtensa_operand_internal *bsi8b_operand_list[] = { &ais_operand, &iibbi_operand, &lisimm8_operand }; static xtensa_iclass_internal bsi8b_iclass = { 3, &bsi8b_operand_list[0] }; static xtensa_operand_internal *acts_operand_list[] = { &ait_operand, &ais_operand }; static xtensa_iclass_internal acts_iclass = { 2, &acts_operand_list[0] }; static xtensa_operand_internal *add_n_operand_list[] = { &aor_operand, &ais_operand, &ait_operand }; static xtensa_iclass_internal add_n_iclass = { 3, &add_n_operand_list[0] }; static xtensa_operand_internal *srai_operand_list[] = { &aor_operand, &ait_operand, &iisar_operand }; static xtensa_iclass_internal srai_iclass = { 3, &srai_operand_list[0] }; static xtensa_operand_internal *entry_operand_list[] = { &abs_operand, &iiuimm12x8_operand }; static xtensa_iclass_internal entry_iclass = { 2, &entry_operand_list[0] }; static xtensa_operand_internal *l32e_operand_list[] = { &aot_operand, &ais_operand, &iinimm4x2_operand }; static xtensa_iclass_internal l32e_iclass = { 3, &l32e_operand_list[0] }; static xtensa_operand_internal *dpf_operand_list[] = { &ais_operand, &iiuimm8x4_operand }; static xtensa_iclass_internal dpf_iclass = { 2, &dpf_operand_list[0] }; static xtensa_operand_internal *l32i_operand_list[] = { &aot_operand, &ais_operand, &iiuimm8x4_operand }; static xtensa_iclass_internal l32i_iclass = { 3, &l32i_operand_list[0] }; static xtensa_insnbuf abs_template (void); static xtensa_insnbuf add_template (void); static xtensa_insnbuf add_n_template (void); static xtensa_insnbuf addi_template (void); static xtensa_insnbuf addi_n_template (void); static xtensa_insnbuf addmi_template (void); static xtensa_insnbuf addx2_template (void); static xtensa_insnbuf addx4_template (void); static xtensa_insnbuf addx8_template (void); static xtensa_insnbuf and_template (void); static xtensa_insnbuf ball_template (void); static xtensa_insnbuf bany_template (void); static xtensa_insnbuf bbc_template (void); static xtensa_insnbuf bbci_template (void); static xtensa_insnbuf bbs_template (void); static xtensa_insnbuf bbsi_template (void); static xtensa_insnbuf beq_template (void); static xtensa_insnbuf beqi_template (void); static xtensa_insnbuf beqz_template (void); static xtensa_insnbuf beqz_n_template (void); static xtensa_insnbuf bge_template (void); static xtensa_insnbuf bgei_template (void); static xtensa_insnbuf bgeu_template (void); static xtensa_insnbuf bgeui_template (void); static xtensa_insnbuf bgez_template (void); static xtensa_insnbuf blt_template (void); static xtensa_insnbuf blti_template (void); static xtensa_insnbuf bltu_template (void); static xtensa_insnbuf bltui_template (void); static xtensa_insnbuf bltz_template (void); static xtensa_insnbuf bnall_template (void); static xtensa_insnbuf bne_template (void); static xtensa_insnbuf bnei_template (void); static xtensa_insnbuf bnez_template (void); static xtensa_insnbuf bnez_n_template (void); static xtensa_insnbuf bnone_template (void); static xtensa_insnbuf break_template (void); static xtensa_insnbuf break_n_template (void); static xtensa_insnbuf call0_template (void); static xtensa_insnbuf call12_template (void); static xtensa_insnbuf call4_template (void); static xtensa_insnbuf call8_template (void); static xtensa_insnbuf callx0_template (void); static xtensa_insnbuf callx12_template (void); static xtensa_insnbuf callx4_template (void); static xtensa_insnbuf callx8_template (void); static xtensa_insnbuf dhi_template (void); static xtensa_insnbuf dhwb_template (void); static xtensa_insnbuf dhwbi_template (void); static xtensa_insnbuf dii_template (void); static xtensa_insnbuf diwb_template (void); static xtensa_insnbuf diwbi_template (void); static xtensa_insnbuf dpfr_template (void); static xtensa_insnbuf dpfro_template (void); static xtensa_insnbuf dpfw_template (void); static xtensa_insnbuf dpfwo_template (void); static xtensa_insnbuf dsync_template (void); static xtensa_insnbuf entry_template (void); static xtensa_insnbuf esync_template (void); static xtensa_insnbuf excw_template (void); static xtensa_insnbuf extui_template (void); static xtensa_insnbuf idtlb_template (void); static xtensa_insnbuf idtlba_template (void); static xtensa_insnbuf ihi_template (void); static xtensa_insnbuf iii_template (void); static xtensa_insnbuf iitlb_template (void); static xtensa_insnbuf iitlba_template (void); static xtensa_insnbuf ipf_template (void); static xtensa_insnbuf isync_template (void); static xtensa_insnbuf j_template (void); static xtensa_insnbuf jx_template (void); static xtensa_insnbuf l16si_template (void); static xtensa_insnbuf l16ui_template (void); static xtensa_insnbuf l32e_template (void); static xtensa_insnbuf l32i_template (void); static xtensa_insnbuf l32i_n_template (void); static xtensa_insnbuf l32r_template (void); static xtensa_insnbuf l8ui_template (void); static xtensa_insnbuf ldct_template (void); static xtensa_insnbuf lict_template (void); static xtensa_insnbuf licw_template (void); static xtensa_insnbuf loop_template (void); static xtensa_insnbuf loopgtz_template (void); static xtensa_insnbuf loopnez_template (void); static xtensa_insnbuf memw_template (void); static xtensa_insnbuf mov_n_template (void); static xtensa_insnbuf moveqz_template (void); static xtensa_insnbuf movgez_template (void); static xtensa_insnbuf movi_template (void); static xtensa_insnbuf movi_n_template (void); static xtensa_insnbuf movltz_template (void); static xtensa_insnbuf movnez_template (void); static xtensa_insnbuf movsp_template (void); static xtensa_insnbuf neg_template (void); static xtensa_insnbuf nop_n_template (void); static xtensa_insnbuf nsa_template (void); static xtensa_insnbuf nsau_template (void); static xtensa_insnbuf or_template (void); static xtensa_insnbuf pdtlb_template (void); static xtensa_insnbuf pitlb_template (void); static xtensa_insnbuf rdtlb0_template (void); static xtensa_insnbuf rdtlb1_template (void); static xtensa_insnbuf ret_template (void); static xtensa_insnbuf ret_n_template (void); static xtensa_insnbuf retw_template (void); static xtensa_insnbuf retw_n_template (void); static xtensa_insnbuf rfde_template (void); static xtensa_insnbuf rfe_template (void); static xtensa_insnbuf rfi_template (void); static xtensa_insnbuf rfwo_template (void); static xtensa_insnbuf rfwu_template (void); static xtensa_insnbuf ritlb0_template (void); static xtensa_insnbuf ritlb1_template (void); static xtensa_insnbuf rotw_template (void); static xtensa_insnbuf rsil_template (void); static xtensa_insnbuf rsr_template (void); static xtensa_insnbuf rsync_template (void); static xtensa_insnbuf s16i_template (void); static xtensa_insnbuf s32e_template (void); static xtensa_insnbuf s32i_template (void); static xtensa_insnbuf s32i_n_template (void); static xtensa_insnbuf s8i_template (void); static xtensa_insnbuf sdct_template (void); static xtensa_insnbuf sict_template (void); static xtensa_insnbuf sicw_template (void); static xtensa_insnbuf simcall_template (void); static xtensa_insnbuf sll_template (void); static xtensa_insnbuf slli_template (void); static xtensa_insnbuf sra_template (void); static xtensa_insnbuf srai_template (void); static xtensa_insnbuf src_template (void); static xtensa_insnbuf srl_template (void); static xtensa_insnbuf srli_template (void); static xtensa_insnbuf ssa8b_template (void); static xtensa_insnbuf ssa8l_template (void); static xtensa_insnbuf ssai_template (void); static xtensa_insnbuf ssl_template (void); static xtensa_insnbuf ssr_template (void); static xtensa_insnbuf sub_template (void); static xtensa_insnbuf subx2_template (void); static xtensa_insnbuf subx4_template (void); static xtensa_insnbuf subx8_template (void); static xtensa_insnbuf syscall_template (void); static xtensa_insnbuf waiti_template (void); static xtensa_insnbuf wdtlb_template (void); static xtensa_insnbuf witlb_template (void); static xtensa_insnbuf wsr_template (void); static xtensa_insnbuf xor_template (void); static xtensa_insnbuf xsr_template (void); static xtensa_insnbuf abs_template (void) { static xtensa_insnbuf_word template[] = { 0x00001006 }; return &template[0]; } static xtensa_insnbuf add_template (void) { static xtensa_insnbuf_word template[] = { 0x00000008 }; return &template[0]; } static xtensa_insnbuf add_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00a00000 }; return &template[0]; } static xtensa_insnbuf addi_template (void) { static xtensa_insnbuf_word template[] = { 0x00200c00 }; return &template[0]; } static xtensa_insnbuf addi_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00b00000 }; return &template[0]; } static xtensa_insnbuf addmi_template (void) { static xtensa_insnbuf_word template[] = { 0x00200d00 }; return &template[0]; } static xtensa_insnbuf addx2_template (void) { static xtensa_insnbuf_word template[] = { 0x00000009 }; return &template[0]; } static xtensa_insnbuf addx4_template (void) { static xtensa_insnbuf_word template[] = { 0x0000000a }; return &template[0]; } static xtensa_insnbuf addx8_template (void) { static xtensa_insnbuf_word template[] = { 0x0000000b }; return &template[0]; } static xtensa_insnbuf and_template (void) { static xtensa_insnbuf_word template[] = { 0x00000001 }; return &template[0]; } static xtensa_insnbuf ball_template (void) { static xtensa_insnbuf_word template[] = { 0x00700400 }; return &template[0]; } static xtensa_insnbuf bany_template (void) { static xtensa_insnbuf_word template[] = { 0x00700800 }; return &template[0]; } static xtensa_insnbuf bbc_template (void) { static xtensa_insnbuf_word template[] = { 0x00700500 }; return &template[0]; } static xtensa_insnbuf bbci_template (void) { static xtensa_insnbuf_word template[] = { 0x00700600 }; return &template[0]; } static xtensa_insnbuf bbs_template (void) { static xtensa_insnbuf_word template[] = { 0x00700d00 }; return &template[0]; } static xtensa_insnbuf bbsi_template (void) { static xtensa_insnbuf_word template[] = { 0x00700e00 }; return &template[0]; } static xtensa_insnbuf beq_template (void) { static xtensa_insnbuf_word template[] = { 0x00700100 }; return &template[0]; } static xtensa_insnbuf beqi_template (void) { static xtensa_insnbuf_word template[] = { 0x00680000 }; return &template[0]; } static xtensa_insnbuf beqz_template (void) { static xtensa_insnbuf_word template[] = { 0x00640000 }; return &template[0]; } static xtensa_insnbuf beqz_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00c80000 }; return &template[0]; } static xtensa_insnbuf bge_template (void) { static xtensa_insnbuf_word template[] = { 0x00700a00 }; return &template[0]; } static xtensa_insnbuf bgei_template (void) { static xtensa_insnbuf_word template[] = { 0x006b0000 }; return &template[0]; } static xtensa_insnbuf bgeu_template (void) { static xtensa_insnbuf_word template[] = { 0x00700b00 }; return &template[0]; } static xtensa_insnbuf bgeui_template (void) { static xtensa_insnbuf_word template[] = { 0x006f0000 }; return &template[0]; } static xtensa_insnbuf bgez_template (void) { static xtensa_insnbuf_word template[] = { 0x00670000 }; return &template[0]; } static xtensa_insnbuf blt_template (void) { static xtensa_insnbuf_word template[] = { 0x00700200 }; return &template[0]; } static xtensa_insnbuf blti_template (void) { static xtensa_insnbuf_word template[] = { 0x006a0000 }; return &template[0]; } static xtensa_insnbuf bltu_template (void) { static xtensa_insnbuf_word template[] = { 0x00700300 }; return &template[0]; } static xtensa_insnbuf bltui_template (void) { static xtensa_insnbuf_word template[] = { 0x006e0000 }; return &template[0]; } static xtensa_insnbuf bltz_template (void) { static xtensa_insnbuf_word template[] = { 0x00660000 }; return &template[0]; } static xtensa_insnbuf bnall_template (void) { static xtensa_insnbuf_word template[] = { 0x00700c00 }; return &template[0]; } static xtensa_insnbuf bne_template (void) { static xtensa_insnbuf_word template[] = { 0x00700900 }; return &template[0]; } static xtensa_insnbuf bnei_template (void) { static xtensa_insnbuf_word template[] = { 0x00690000 }; return &template[0]; } static xtensa_insnbuf bnez_template (void) { static xtensa_insnbuf_word template[] = { 0x00650000 }; return &template[0]; } static xtensa_insnbuf bnez_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00cc0000 }; return &template[0]; } static xtensa_insnbuf bnone_template (void) { static xtensa_insnbuf_word template[] = { 0x00700000 }; return &template[0]; } static xtensa_insnbuf break_template (void) { static xtensa_insnbuf_word template[] = { 0x00000400 }; return &template[0]; } static xtensa_insnbuf break_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00d20f00 }; return &template[0]; } static xtensa_insnbuf call0_template (void) { static xtensa_insnbuf_word template[] = { 0x00500000 }; return &template[0]; } static xtensa_insnbuf call12_template (void) { static xtensa_insnbuf_word template[] = { 0x005c0000 }; return &template[0]; } static xtensa_insnbuf call4_template (void) { static xtensa_insnbuf_word template[] = { 0x00540000 }; return &template[0]; } static xtensa_insnbuf call8_template (void) { static xtensa_insnbuf_word template[] = { 0x00580000 }; return &template[0]; } static xtensa_insnbuf callx0_template (void) { static xtensa_insnbuf_word template[] = { 0x00030000 }; return &template[0]; } static xtensa_insnbuf callx12_template (void) { static xtensa_insnbuf_word template[] = { 0x000f0000 }; return &template[0]; } static xtensa_insnbuf callx4_template (void) { static xtensa_insnbuf_word template[] = { 0x00070000 }; return &template[0]; } static xtensa_insnbuf callx8_template (void) { static xtensa_insnbuf_word template[] = { 0x000b0000 }; return &template[0]; } static xtensa_insnbuf dhi_template (void) { static xtensa_insnbuf_word template[] = { 0x00260700 }; return &template[0]; } static xtensa_insnbuf dhwb_template (void) { static xtensa_insnbuf_word template[] = { 0x00240700 }; return &template[0]; } static xtensa_insnbuf dhwbi_template (void) { static xtensa_insnbuf_word template[] = { 0x00250700 }; return &template[0]; } static xtensa_insnbuf dii_template (void) { static xtensa_insnbuf_word template[] = { 0x00270700 }; return &template[0]; } static xtensa_insnbuf diwb_template (void) { static xtensa_insnbuf_word template[] = { 0x00280740 }; return &template[0]; } static xtensa_insnbuf diwbi_template (void) { static xtensa_insnbuf_word template[] = { 0x00280750 }; return &template[0]; } static xtensa_insnbuf dpfr_template (void) { static xtensa_insnbuf_word template[] = { 0x00200700 }; return &template[0]; } static xtensa_insnbuf dpfro_template (void) { static xtensa_insnbuf_word template[] = { 0x00220700 }; return &template[0]; } static xtensa_insnbuf dpfw_template (void) { static xtensa_insnbuf_word template[] = { 0x00210700 }; return &template[0]; } static xtensa_insnbuf dpfwo_template (void) { static xtensa_insnbuf_word template[] = { 0x00230700 }; return &template[0]; } static xtensa_insnbuf dsync_template (void) { static xtensa_insnbuf_word template[] = { 0x00030200 }; return &template[0]; } static xtensa_insnbuf entry_template (void) { static xtensa_insnbuf_word template[] = { 0x006c0000 }; return &template[0]; } static xtensa_insnbuf esync_template (void) { static xtensa_insnbuf_word template[] = { 0x00020200 }; return &template[0]; } static xtensa_insnbuf excw_template (void) { static xtensa_insnbuf_word template[] = { 0x00080200 }; return &template[0]; } static xtensa_insnbuf extui_template (void) { static xtensa_insnbuf_word template[] = { 0x00000040 }; return &template[0]; } static xtensa_insnbuf idtlb_template (void) { static xtensa_insnbuf_word template[] = { 0x00000c05 }; return &template[0]; } static xtensa_insnbuf idtlba_template (void) { static xtensa_insnbuf_word template[] = { 0x00000805 }; return &template[0]; } static xtensa_insnbuf ihi_template (void) { static xtensa_insnbuf_word template[] = { 0x002e0700 }; return &template[0]; } static xtensa_insnbuf iii_template (void) { static xtensa_insnbuf_word template[] = { 0x002f0700 }; return &template[0]; } static xtensa_insnbuf iitlb_template (void) { static xtensa_insnbuf_word template[] = { 0x00000405 }; return &template[0]; } static xtensa_insnbuf iitlba_template (void) { static xtensa_insnbuf_word template[] = { 0x00000005 }; return &template[0]; } static xtensa_insnbuf ipf_template (void) { static xtensa_insnbuf_word template[] = { 0x002c0700 }; return &template[0]; } static xtensa_insnbuf isync_template (void) { static xtensa_insnbuf_word template[] = { 0x00000200 }; return &template[0]; } static xtensa_insnbuf j_template (void) { static xtensa_insnbuf_word template[] = { 0x00600000 }; return &template[0]; } static xtensa_insnbuf jx_template (void) { static xtensa_insnbuf_word template[] = { 0x000a0000 }; return &template[0]; } static xtensa_insnbuf l16si_template (void) { static xtensa_insnbuf_word template[] = { 0x00200900 }; return &template[0]; } static xtensa_insnbuf l16ui_template (void) { static xtensa_insnbuf_word template[] = { 0x00200100 }; return &template[0]; } static xtensa_insnbuf l32e_template (void) { static xtensa_insnbuf_word template[] = { 0x00000090 }; return &template[0]; } static xtensa_insnbuf l32i_template (void) { static xtensa_insnbuf_word template[] = { 0x00200200 }; return &template[0]; } static xtensa_insnbuf l32i_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00800000 }; return &template[0]; } static xtensa_insnbuf l32r_template (void) { static xtensa_insnbuf_word template[] = { 0x00100000 }; return &template[0]; } static xtensa_insnbuf l8ui_template (void) { static xtensa_insnbuf_word template[] = { 0x00200000 }; return &template[0]; } static xtensa_insnbuf ldct_template (void) { static xtensa_insnbuf_word template[] = { 0x0000081f }; return &template[0]; } static xtensa_insnbuf lict_template (void) { static xtensa_insnbuf_word template[] = { 0x0000001f }; return &template[0]; } static xtensa_insnbuf licw_template (void) { static xtensa_insnbuf_word template[] = { 0x0000021f }; return &template[0]; } static xtensa_insnbuf loop_template (void) { static xtensa_insnbuf_word template[] = { 0x006d0800 }; return &template[0]; } static xtensa_insnbuf loopgtz_template (void) { static xtensa_insnbuf_word template[] = { 0x006d0a00 }; return &template[0]; } static xtensa_insnbuf loopnez_template (void) { static xtensa_insnbuf_word template[] = { 0x006d0900 }; return &template[0]; } static xtensa_insnbuf memw_template (void) { static xtensa_insnbuf_word template[] = { 0x000c0200 }; return &template[0]; } static xtensa_insnbuf mov_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00d00000 }; return &template[0]; } static xtensa_insnbuf moveqz_template (void) { static xtensa_insnbuf_word template[] = { 0x00000038 }; return &template[0]; } static xtensa_insnbuf movgez_template (void) { static xtensa_insnbuf_word template[] = { 0x0000003b }; return &template[0]; } static xtensa_insnbuf movi_template (void) { static xtensa_insnbuf_word template[] = { 0x00200a00 }; return &template[0]; } static xtensa_insnbuf movi_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00c00000 }; return &template[0]; } static xtensa_insnbuf movltz_template (void) { static xtensa_insnbuf_word template[] = { 0x0000003a }; return &template[0]; } static xtensa_insnbuf movnez_template (void) { static xtensa_insnbuf_word template[] = { 0x00000039 }; return &template[0]; } static xtensa_insnbuf movsp_template (void) { static xtensa_insnbuf_word template[] = { 0x00000100 }; return &template[0]; } static xtensa_insnbuf neg_template (void) { static xtensa_insnbuf_word template[] = { 0x00000006 }; return &template[0]; } static xtensa_insnbuf nop_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00d30f00 }; return &template[0]; } static xtensa_insnbuf nsa_template (void) { static xtensa_insnbuf_word template[] = { 0x00000e04 }; return &template[0]; } static xtensa_insnbuf nsau_template (void) { static xtensa_insnbuf_word template[] = { 0x00000f04 }; return &template[0]; } static xtensa_insnbuf or_template (void) { static xtensa_insnbuf_word template[] = { 0x00000002 }; return &template[0]; } static xtensa_insnbuf pdtlb_template (void) { static xtensa_insnbuf_word template[] = { 0x00000d05 }; return &template[0]; } static xtensa_insnbuf pitlb_template (void) { static xtensa_insnbuf_word template[] = { 0x00000505 }; return &template[0]; } static xtensa_insnbuf rdtlb0_template (void) { static xtensa_insnbuf_word template[] = { 0x00000b05 }; return &template[0]; } static xtensa_insnbuf rdtlb1_template (void) { static xtensa_insnbuf_word template[] = { 0x00000f05 }; return &template[0]; } static xtensa_insnbuf ret_template (void) { static xtensa_insnbuf_word template[] = { 0x00020000 }; return &template[0]; } static xtensa_insnbuf ret_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00d00f00 }; return &template[0]; } static xtensa_insnbuf retw_template (void) { static xtensa_insnbuf_word template[] = { 0x00060000 }; return &template[0]; } static xtensa_insnbuf retw_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00d10f00 }; return &template[0]; } static xtensa_insnbuf rfde_template (void) { static xtensa_insnbuf_word template[] = { 0x00002300 }; return &template[0]; } static xtensa_insnbuf rfe_template (void) { static xtensa_insnbuf_word template[] = { 0x00000300 }; return &template[0]; } static xtensa_insnbuf rfi_template (void) { static xtensa_insnbuf_word template[] = { 0x00010300 }; return &template[0]; } static xtensa_insnbuf rfwo_template (void) { static xtensa_insnbuf_word template[] = { 0x00004300 }; return &template[0]; } static xtensa_insnbuf rfwu_template (void) { static xtensa_insnbuf_word template[] = { 0x00005300 }; return &template[0]; } static xtensa_insnbuf ritlb0_template (void) { static xtensa_insnbuf_word template[] = { 0x00000305 }; return &template[0]; } static xtensa_insnbuf ritlb1_template (void) { static xtensa_insnbuf_word template[] = { 0x00000705 }; return &template[0]; } static xtensa_insnbuf rotw_template (void) { static xtensa_insnbuf_word template[] = { 0x00000804 }; return &template[0]; } static xtensa_insnbuf rsil_template (void) { static xtensa_insnbuf_word template[] = { 0x00000600 }; return &template[0]; } static xtensa_insnbuf rsr_template (void) { static xtensa_insnbuf_word template[] = { 0x00000030 }; return &template[0]; } static xtensa_insnbuf rsync_template (void) { static xtensa_insnbuf_word template[] = { 0x00010200 }; return &template[0]; } static xtensa_insnbuf s16i_template (void) { static xtensa_insnbuf_word template[] = { 0x00200500 }; return &template[0]; } static xtensa_insnbuf s32e_template (void) { static xtensa_insnbuf_word template[] = { 0x00000094 }; return &template[0]; } static xtensa_insnbuf s32i_template (void) { static xtensa_insnbuf_word template[] = { 0x00200600 }; return &template[0]; } static xtensa_insnbuf s32i_n_template (void) { static xtensa_insnbuf_word template[] = { 0x00900000 }; return &template[0]; } static xtensa_insnbuf s8i_template (void) { static xtensa_insnbuf_word template[] = { 0x00200400 }; return &template[0]; } static xtensa_insnbuf sdct_template (void) { static xtensa_insnbuf_word template[] = { 0x0000091f }; return &template[0]; } static xtensa_insnbuf sict_template (void) { static xtensa_insnbuf_word template[] = { 0x0000011f }; return &template[0]; } static xtensa_insnbuf sicw_template (void) { static xtensa_insnbuf_word template[] = { 0x0000031f }; return &template[0]; } static xtensa_insnbuf simcall_template (void) { static xtensa_insnbuf_word template[] = { 0x00001500 }; return &template[0]; } static xtensa_insnbuf sll_template (void) { static xtensa_insnbuf_word template[] = { 0x0000001a }; return &template[0]; } static xtensa_insnbuf slli_template (void) { static xtensa_insnbuf_word template[] = { 0x00000010 }; return &template[0]; } static xtensa_insnbuf sra_template (void) { static xtensa_insnbuf_word template[] = { 0x0000001b }; return &template[0]; } static xtensa_insnbuf srai_template (void) { static xtensa_insnbuf_word template[] = { 0x00000012 }; return &template[0]; } static xtensa_insnbuf src_template (void) { static xtensa_insnbuf_word template[] = { 0x00000018 }; return &template[0]; } static xtensa_insnbuf srl_template (void) { static xtensa_insnbuf_word template[] = { 0x00000019 }; return &template[0]; } static xtensa_insnbuf srli_template (void) { static xtensa_insnbuf_word template[] = { 0x00000014 }; return &template[0]; } static xtensa_insnbuf ssa8b_template (void) { static xtensa_insnbuf_word template[] = { 0x00000304 }; return &template[0]; } static xtensa_insnbuf ssa8l_template (void) { static xtensa_insnbuf_word template[] = { 0x00000204 }; return &template[0]; } static xtensa_insnbuf ssai_template (void) { static xtensa_insnbuf_word template[] = { 0x00000404 }; return &template[0]; } static xtensa_insnbuf ssl_template (void) { static xtensa_insnbuf_word template[] = { 0x00000104 }; return &template[0]; } static xtensa_insnbuf ssr_template (void) { static xtensa_insnbuf_word template[] = { 0x00000004 }; return &template[0]; } static xtensa_insnbuf sub_template (void) { static xtensa_insnbuf_word template[] = { 0x0000000c }; return &template[0]; } static xtensa_insnbuf subx2_template (void) { static xtensa_insnbuf_word template[] = { 0x0000000d }; return &template[0]; } static xtensa_insnbuf subx4_template (void) { static xtensa_insnbuf_word template[] = { 0x0000000e }; return &template[0]; } static xtensa_insnbuf subx8_template (void) { static xtensa_insnbuf_word template[] = { 0x0000000f }; return &template[0]; } static xtensa_insnbuf syscall_template (void) { static xtensa_insnbuf_word template[] = { 0x00000500 }; return &template[0]; } static xtensa_insnbuf waiti_template (void) { static xtensa_insnbuf_word template[] = { 0x00000700 }; return &template[0]; } static xtensa_insnbuf wdtlb_template (void) { static xtensa_insnbuf_word template[] = { 0x00000e05 }; return &template[0]; } static xtensa_insnbuf witlb_template (void) { static xtensa_insnbuf_word template[] = { 0x00000605 }; return &template[0]; } static xtensa_insnbuf wsr_template (void) { static xtensa_insnbuf_word template[] = { 0x00000031 }; return &template[0]; } static xtensa_insnbuf xor_template (void) { static xtensa_insnbuf_word template[] = { 0x00000003 }; return &template[0]; } static xtensa_insnbuf xsr_template (void) { static xtensa_insnbuf_word template[] = { 0x00000016 }; return &template[0]; } static xtensa_opcode_internal abs_opcode = { "abs", 3, abs_template, &neg_iclass }; static xtensa_opcode_internal add_opcode = { "add", 3, add_template, &addsub_iclass }; static xtensa_opcode_internal add_n_opcode = { "add.n", 2, add_n_template, &add_n_iclass }; static xtensa_opcode_internal addi_opcode = { "addi", 3, addi_template, &addi_iclass }; static xtensa_opcode_internal addi_n_opcode = { "addi.n", 2, addi_n_template, &addi_n_iclass }; static xtensa_opcode_internal addmi_opcode = { "addmi", 3, addmi_template, &addmi_iclass }; static xtensa_opcode_internal addx2_opcode = { "addx2", 3, addx2_template, &addsub_iclass }; static xtensa_opcode_internal addx4_opcode = { "addx4", 3, addx4_template, &addsub_iclass }; static xtensa_opcode_internal addx8_opcode = { "addx8", 3, addx8_template, &addsub_iclass }; static xtensa_opcode_internal and_opcode = { "and", 3, and_template, &bit_iclass }; static xtensa_opcode_internal ball_opcode = { "ball", 3, ball_template, &bst8_iclass }; static xtensa_opcode_internal bany_opcode = { "bany", 3, bany_template, &bst8_iclass }; static xtensa_opcode_internal bbc_opcode = { "bbc", 3, bbc_template, &bst8_iclass }; static xtensa_opcode_internal bbci_opcode = { "bbci", 3, bbci_template, &bsi8b_iclass }; static xtensa_opcode_internal bbs_opcode = { "bbs", 3, bbs_template, &bst8_iclass }; static xtensa_opcode_internal bbsi_opcode = { "bbsi", 3, bbsi_template, &bsi8b_iclass }; static xtensa_opcode_internal beq_opcode = { "beq", 3, beq_template, &bst8_iclass }; static xtensa_opcode_internal beqi_opcode = { "beqi", 3, beqi_template, &bsi8_iclass }; static xtensa_opcode_internal beqz_opcode = { "beqz", 3, beqz_template, &bsz12_iclass }; static xtensa_opcode_internal beqz_n_opcode = { "beqz.n", 2, beqz_n_template, &bz6_iclass }; static xtensa_opcode_internal bge_opcode = { "bge", 3, bge_template, &bst8_iclass }; static xtensa_opcode_internal bgei_opcode = { "bgei", 3, bgei_template, &bsi8_iclass }; static xtensa_opcode_internal bgeu_opcode = { "bgeu", 3, bgeu_template, &bst8_iclass }; static xtensa_opcode_internal bgeui_opcode = { "bgeui", 3, bgeui_template, &bsi8u_iclass }; static xtensa_opcode_internal bgez_opcode = { "bgez", 3, bgez_template, &bsz12_iclass }; static xtensa_opcode_internal blt_opcode = { "blt", 3, blt_template, &bst8_iclass }; static xtensa_opcode_internal blti_opcode = { "blti", 3, blti_template, &bsi8_iclass }; static xtensa_opcode_internal bltu_opcode = { "bltu", 3, bltu_template, &bst8_iclass }; static xtensa_opcode_internal bltui_opcode = { "bltui", 3, bltui_template, &bsi8u_iclass }; static xtensa_opcode_internal bltz_opcode = { "bltz", 3, bltz_template, &bsz12_iclass }; static xtensa_opcode_internal bnall_opcode = { "bnall", 3, bnall_template, &bst8_iclass }; static xtensa_opcode_internal bne_opcode = { "bne", 3, bne_template, &bst8_iclass }; static xtensa_opcode_internal bnei_opcode = { "bnei", 3, bnei_template, &bsi8_iclass }; static xtensa_opcode_internal bnez_opcode = { "bnez", 3, bnez_template, &bsz12_iclass }; static xtensa_opcode_internal bnez_n_opcode = { "bnez.n", 2, bnez_n_template, &bz6_iclass }; static xtensa_opcode_internal bnone_opcode = { "bnone", 3, bnone_template, &bst8_iclass }; static xtensa_opcode_internal break_opcode = { "break", 3, break_template, &break_iclass }; static xtensa_opcode_internal break_n_opcode = { "break.n", 2, break_n_template, &break_n_iclass }; static xtensa_opcode_internal call0_opcode = { "call0", 3, call0_template, &call_iclass }; static xtensa_opcode_internal call12_opcode = { "call12", 3, call12_template, &call12_iclass }; static xtensa_opcode_internal call4_opcode = { "call4", 3, call4_template, &call4_iclass }; static xtensa_opcode_internal call8_opcode = { "call8", 3, call8_template, &call8_iclass }; static xtensa_opcode_internal callx0_opcode = { "callx0", 3, callx0_template, &callx_iclass }; static xtensa_opcode_internal callx12_opcode = { "callx12", 3, callx12_template, &callx12_iclass }; static xtensa_opcode_internal callx4_opcode = { "callx4", 3, callx4_template, &callx4_iclass }; static xtensa_opcode_internal callx8_opcode = { "callx8", 3, callx8_template, &callx8_iclass }; static xtensa_opcode_internal dhi_opcode = { "dhi", 3, dhi_template, &dcache_iclass }; static xtensa_opcode_internal dhwb_opcode = { "dhwb", 3, dhwb_template, &dcache_iclass }; static xtensa_opcode_internal dhwbi_opcode = { "dhwbi", 3, dhwbi_template, &dcache_iclass }; static xtensa_opcode_internal dii_opcode = { "dii", 3, dii_template, &dcache_iclass }; static xtensa_opcode_internal diwb_opcode = { "diwb", 3, diwb_template, &dce_iclass }; static xtensa_opcode_internal diwbi_opcode = { "diwbi", 3, diwbi_template, &dce_iclass }; static xtensa_opcode_internal dpfr_opcode = { "dpfr", 3, dpfr_template, &dpf_iclass }; static xtensa_opcode_internal dpfro_opcode = { "dpfro", 3, dpfro_template, &dpf_iclass }; static xtensa_opcode_internal dpfw_opcode = { "dpfw", 3, dpfw_template, &dpf_iclass }; static xtensa_opcode_internal dpfwo_opcode = { "dpfwo", 3, dpfwo_template, &dpf_iclass }; static xtensa_opcode_internal dsync_opcode = { "dsync", 3, dsync_template, &sync_iclass }; static xtensa_opcode_internal entry_opcode = { "entry", 3, entry_template, &entry_iclass }; static xtensa_opcode_internal esync_opcode = { "esync", 3, esync_template, &sync_iclass }; static xtensa_opcode_internal excw_opcode = { "excw", 3, excw_template, &excw_iclass }; static xtensa_opcode_internal extui_opcode = { "extui", 3, extui_template, &exti_iclass }; static xtensa_opcode_internal idtlb_opcode = { "idtlb", 3, idtlb_template, &itlb_iclass }; static xtensa_opcode_internal idtlba_opcode = { "idtlba", 3, idtlba_template, &itlba_iclass }; static xtensa_opcode_internal ihi_opcode = { "ihi", 3, ihi_template, &icache_iclass }; static xtensa_opcode_internal iii_opcode = { "iii", 3, iii_template, &icache_iclass }; static xtensa_opcode_internal iitlb_opcode = { "iitlb", 3, iitlb_template, &itlb_iclass }; static xtensa_opcode_internal iitlba_opcode = { "iitlba", 3, iitlba_template, &itlba_iclass }; static xtensa_opcode_internal ipf_opcode = { "ipf", 3, ipf_template, &icache_iclass }; static xtensa_opcode_internal isync_opcode = { "isync", 3, isync_template, &sync_iclass }; static xtensa_opcode_internal j_opcode = { "j", 3, j_template, &jump_iclass }; static xtensa_opcode_internal jx_opcode = { "jx", 3, jx_template, &jumpx_iclass }; static xtensa_opcode_internal l16si_opcode = { "l16si", 3, l16si_template, &l16i_iclass }; static xtensa_opcode_internal l16ui_opcode = { "l16ui", 3, l16ui_template, &l16i_iclass }; static xtensa_opcode_internal l32e_opcode = { "l32e", 3, l32e_template, &l32e_iclass }; static xtensa_opcode_internal l32i_opcode = { "l32i", 3, l32i_template, &l32i_iclass }; static xtensa_opcode_internal l32i_n_opcode = { "l32i.n", 2, l32i_n_template, &loadi4_iclass }; static xtensa_opcode_internal l32r_opcode = { "l32r", 3, l32r_template, &l32r_iclass }; static xtensa_opcode_internal l8ui_opcode = { "l8ui", 3, l8ui_template, &l8i_iclass }; static xtensa_opcode_internal ldct_opcode = { "ldct", 3, ldct_template, &actl_iclass }; static xtensa_opcode_internal lict_opcode = { "lict", 3, lict_template, &actl_iclass }; static xtensa_opcode_internal licw_opcode = { "licw", 3, licw_template, &actl_iclass }; static xtensa_opcode_internal loop_opcode = { "loop", 3, loop_template, &loop_iclass }; static xtensa_opcode_internal loopgtz_opcode = { "loopgtz", 3, loopgtz_template, &loop_iclass }; static xtensa_opcode_internal loopnez_opcode = { "loopnez", 3, loopnez_template, &loop_iclass }; static xtensa_opcode_internal memw_opcode = { "memw", 3, memw_template, &sync_iclass }; static xtensa_opcode_internal mov_n_opcode = { "mov.n", 2, mov_n_template, &mov_n_iclass }; static xtensa_opcode_internal moveqz_opcode = { "moveqz", 3, moveqz_template, &movz_iclass }; static xtensa_opcode_internal movgez_opcode = { "movgez", 3, movgez_template, &movz_iclass }; static xtensa_opcode_internal movi_opcode = { "movi", 3, movi_template, &movi_iclass }; static xtensa_opcode_internal movi_n_opcode = { "movi.n", 2, movi_n_template, &movi_n_iclass }; static xtensa_opcode_internal movltz_opcode = { "movltz", 3, movltz_template, &movz_iclass }; static xtensa_opcode_internal movnez_opcode = { "movnez", 3, movnez_template, &movz_iclass }; static xtensa_opcode_internal movsp_opcode = { "movsp", 3, movsp_template, &movsp_iclass }; static xtensa_opcode_internal neg_opcode = { "neg", 3, neg_template, &neg_iclass }; static xtensa_opcode_internal nop_n_opcode = { "nop.n", 2, nop_n_template, &nopn_iclass }; static xtensa_opcode_internal nsa_opcode = { "nsa", 3, nsa_template, &nsa_iclass }; static xtensa_opcode_internal nsau_opcode = { "nsau", 3, nsau_template, &nsa_iclass }; static xtensa_opcode_internal or_opcode = { "or", 3, or_template, &bit_iclass }; static xtensa_opcode_internal pdtlb_opcode = { "pdtlb", 3, pdtlb_template, &rtlb_iclass }; static xtensa_opcode_internal pitlb_opcode = { "pitlb", 3, pitlb_template, &rtlb_iclass }; static xtensa_opcode_internal rdtlb0_opcode = { "rdtlb0", 3, rdtlb0_template, &rtlb_iclass }; static xtensa_opcode_internal rdtlb1_opcode = { "rdtlb1", 3, rdtlb1_template, &rtlb_iclass }; static xtensa_opcode_internal ret_opcode = { "ret", 3, ret_template, &return_iclass }; static xtensa_opcode_internal ret_n_opcode = { "ret.n", 2, ret_n_template, &retn_iclass }; static xtensa_opcode_internal retw_opcode = { "retw", 3, retw_template, &return_iclass }; static xtensa_opcode_internal retw_n_opcode = { "retw.n", 2, retw_n_template, &retn_iclass }; static xtensa_opcode_internal rfde_opcode = { "rfde", 3, rfde_template, &rfe_iclass }; static xtensa_opcode_internal rfe_opcode = { "rfe", 3, rfe_template, &rfe_iclass }; static xtensa_opcode_internal rfi_opcode = { "rfi", 3, rfi_template, &rfi_iclass }; static xtensa_opcode_internal rfwo_opcode = { "rfwo", 3, rfwo_template, &rfe_iclass }; static xtensa_opcode_internal rfwu_opcode = { "rfwu", 3, rfwu_template, &rfe_iclass }; static xtensa_opcode_internal ritlb0_opcode = { "ritlb0", 3, ritlb0_template, &rtlb_iclass }; static xtensa_opcode_internal ritlb1_opcode = { "ritlb1", 3, ritlb1_template, &rtlb_iclass }; static xtensa_opcode_internal rotw_opcode = { "rotw", 3, rotw_template, &rotw_iclass }; static xtensa_opcode_internal rsil_opcode = { "rsil", 3, rsil_template, &rsil_iclass }; static xtensa_opcode_internal rsr_opcode = { "rsr", 3, rsr_template, &rsr_iclass }; static xtensa_opcode_internal rsync_opcode = { "rsync", 3, rsync_template, &sync_iclass }; static xtensa_opcode_internal s16i_opcode = { "s16i", 3, s16i_template, &s16i_iclass }; static xtensa_opcode_internal s32e_opcode = { "s32e", 3, s32e_template, &s32e_iclass }; static xtensa_opcode_internal s32i_opcode = { "s32i", 3, s32i_template, &s32i_iclass }; static xtensa_opcode_internal s32i_n_opcode = { "s32i.n", 2, s32i_n_template, &storei4_iclass }; static xtensa_opcode_internal s8i_opcode = { "s8i", 3, s8i_template, &s8i_iclass }; static xtensa_opcode_internal sdct_opcode = { "sdct", 3, sdct_template, &acts_iclass }; static xtensa_opcode_internal sict_opcode = { "sict", 3, sict_template, &acts_iclass }; static xtensa_opcode_internal sicw_opcode = { "sicw", 3, sicw_template, &acts_iclass }; static xtensa_opcode_internal simcall_opcode = { "simcall", 3, simcall_template, &syscall_iclass }; static xtensa_opcode_internal sll_opcode = { "sll", 3, sll_template, &shifts_iclass }; static xtensa_opcode_internal slli_opcode = { "slli", 3, slli_template, &slli_iclass }; static xtensa_opcode_internal sra_opcode = { "sra", 3, sra_template, &shiftt_iclass }; static xtensa_opcode_internal srai_opcode = { "srai", 3, srai_template, &srai_iclass }; static xtensa_opcode_internal src_opcode = { "src", 3, src_template, &shiftst_iclass }; static xtensa_opcode_internal srl_opcode = { "srl", 3, srl_template, &shiftt_iclass }; static xtensa_opcode_internal srli_opcode = { "srli", 3, srli_template, &srli_iclass }; static xtensa_opcode_internal ssa8b_opcode = { "ssa8b", 3, ssa8b_template, &sar_iclass }; static xtensa_opcode_internal ssa8l_opcode = { "ssa8l", 3, ssa8l_template, &sar_iclass }; static xtensa_opcode_internal ssai_opcode = { "ssai", 3, ssai_template, &sari_iclass }; static xtensa_opcode_internal ssl_opcode = { "ssl", 3, ssl_template, &sar_iclass }; static xtensa_opcode_internal ssr_opcode = { "ssr", 3, ssr_template, &sar_iclass }; static xtensa_opcode_internal sub_opcode = { "sub", 3, sub_template, &addsub_iclass }; static xtensa_opcode_internal subx2_opcode = { "subx2", 3, subx2_template, &addsub_iclass }; static xtensa_opcode_internal subx4_opcode = { "subx4", 3, subx4_template, &addsub_iclass }; static xtensa_opcode_internal subx8_opcode = { "subx8", 3, subx8_template, &addsub_iclass }; static xtensa_opcode_internal syscall_opcode = { "syscall", 3, syscall_template, &syscall_iclass }; static xtensa_opcode_internal waiti_opcode = { "waiti", 3, waiti_template, &wait_iclass }; static xtensa_opcode_internal wdtlb_opcode = { "wdtlb", 3, wdtlb_template, &wtlb_iclass }; static xtensa_opcode_internal witlb_opcode = { "witlb", 3, witlb_template, &wtlb_iclass }; static xtensa_opcode_internal wsr_opcode = { "wsr", 3, wsr_template, &wsr_iclass }; static xtensa_opcode_internal xor_opcode = { "xor", 3, xor_template, &bit_iclass }; static xtensa_opcode_internal xsr_opcode = { "xsr", 3, xsr_template, &xsr_iclass }; static xtensa_opcode_internal * opcodes[149] = { &abs_opcode, &add_opcode, &add_n_opcode, &addi_opcode, &addi_n_opcode, &addmi_opcode, &addx2_opcode, &addx4_opcode, &addx8_opcode, &and_opcode, &ball_opcode, &bany_opcode, &bbc_opcode, &bbci_opcode, &bbs_opcode, &bbsi_opcode, &beq_opcode, &beqi_opcode, &beqz_opcode, &beqz_n_opcode, &bge_opcode, &bgei_opcode, &bgeu_opcode, &bgeui_opcode, &bgez_opcode, &blt_opcode, &blti_opcode, &bltu_opcode, &bltui_opcode, &bltz_opcode, &bnall_opcode, &bne_opcode, &bnei_opcode, &bnez_opcode, &bnez_n_opcode, &bnone_opcode, &break_opcode, &break_n_opcode, &call0_opcode, &call12_opcode, &call4_opcode, &call8_opcode, &callx0_opcode, &callx12_opcode, &callx4_opcode, &callx8_opcode, &dhi_opcode, &dhwb_opcode, &dhwbi_opcode, &dii_opcode, &diwb_opcode, &diwbi_opcode, &dpfr_opcode, &dpfro_opcode, &dpfw_opcode, &dpfwo_opcode, &dsync_opcode, &entry_opcode, &esync_opcode, &excw_opcode, &extui_opcode, &idtlb_opcode, &idtlba_opcode, &ihi_opcode, &iii_opcode, &iitlb_opcode, &iitlba_opcode, &ipf_opcode, &isync_opcode, &j_opcode, &jx_opcode, &l16si_opcode, &l16ui_opcode, &l32e_opcode, &l32i_opcode, &l32i_n_opcode, &l32r_opcode, &l8ui_opcode, &ldct_opcode, &lict_opcode, &licw_opcode, &loop_opcode, &loopgtz_opcode, &loopnez_opcode, &memw_opcode, &mov_n_opcode, &moveqz_opcode, &movgez_opcode, &movi_opcode, &movi_n_opcode, &movltz_opcode, &movnez_opcode, &movsp_opcode, &neg_opcode, &nop_n_opcode, &nsa_opcode, &nsau_opcode, &or_opcode, &pdtlb_opcode, &pitlb_opcode, &rdtlb0_opcode, &rdtlb1_opcode, &ret_opcode, &ret_n_opcode, &retw_opcode, &retw_n_opcode, &rfde_opcode, &rfe_opcode, &rfi_opcode, &rfwo_opcode, &rfwu_opcode, &ritlb0_opcode, &ritlb1_opcode, &rotw_opcode, &rsil_opcode, &rsr_opcode, &rsync_opcode, &s16i_opcode, &s32e_opcode, &s32i_opcode, &s32i_n_opcode, &s8i_opcode, &sdct_opcode, &sict_opcode, &sicw_opcode, &simcall_opcode, &sll_opcode, &slli_opcode, &sra_opcode, &srai_opcode, &src_opcode, &srl_opcode, &srli_opcode, &ssa8b_opcode, &ssa8l_opcode, &ssai_opcode, &ssl_opcode, &ssr_opcode, &sub_opcode, &subx2_opcode, &subx4_opcode, &subx8_opcode, &syscall_opcode, &waiti_opcode, &wdtlb_opcode, &witlb_opcode, &wsr_opcode, &xor_opcode, &xsr_opcode }; xtensa_opcode_internal ** get_opcodes (void) { return &opcodes[0]; } int get_num_opcodes (void) { return 149; } #define xtensa_abs_op 0 #define xtensa_add_op 1 #define xtensa_add_n_op 2 #define xtensa_addi_op 3 #define xtensa_addi_n_op 4 #define xtensa_addmi_op 5 #define xtensa_addx2_op 6 #define xtensa_addx4_op 7 #define xtensa_addx8_op 8 #define xtensa_and_op 9 #define xtensa_ball_op 10 #define xtensa_bany_op 11 #define xtensa_bbc_op 12 #define xtensa_bbci_op 13 #define xtensa_bbs_op 14 #define xtensa_bbsi_op 15 #define xtensa_beq_op 16 #define xtensa_beqi_op 17 #define xtensa_beqz_op 18 #define xtensa_beqz_n_op 19 #define xtensa_bge_op 20 #define xtensa_bgei_op 21 #define xtensa_bgeu_op 22 #define xtensa_bgeui_op 23 #define xtensa_bgez_op 24 #define xtensa_blt_op 25 #define xtensa_blti_op 26 #define xtensa_bltu_op 27 #define xtensa_bltui_op 28 #define xtensa_bltz_op 29 #define xtensa_bnall_op 30 #define xtensa_bne_op 31 #define xtensa_bnei_op 32 #define xtensa_bnez_op 33 #define xtensa_bnez_n_op 34 #define xtensa_bnone_op 35 #define xtensa_break_op 36 #define xtensa_break_n_op 37 #define xtensa_call0_op 38 #define xtensa_call12_op 39 #define xtensa_call4_op 40 #define xtensa_call8_op 41 #define xtensa_callx0_op 42 #define xtensa_callx12_op 43 #define xtensa_callx4_op 44 #define xtensa_callx8_op 45 #define xtensa_dhi_op 46 #define xtensa_dhwb_op 47 #define xtensa_dhwbi_op 48 #define xtensa_dii_op 49 #define xtensa_diwb_op 50 #define xtensa_diwbi_op 51 #define xtensa_dpfr_op 52 #define xtensa_dpfro_op 53 #define xtensa_dpfw_op 54 #define xtensa_dpfwo_op 55 #define xtensa_dsync_op 56 #define xtensa_entry_op 57 #define xtensa_esync_op 58 #define xtensa_excw_op 59 #define xtensa_extui_op 60 #define xtensa_idtlb_op 61 #define xtensa_idtlba_op 62 #define xtensa_ihi_op 63 #define xtensa_iii_op 64 #define xtensa_iitlb_op 65 #define xtensa_iitlba_op 66 #define xtensa_ipf_op 67 #define xtensa_isync_op 68 #define xtensa_j_op 69 #define xtensa_jx_op 70 #define xtensa_l16si_op 71 #define xtensa_l16ui_op 72 #define xtensa_l32e_op 73 #define xtensa_l32i_op 74 #define xtensa_l32i_n_op 75 #define xtensa_l32r_op 76 #define xtensa_l8ui_op 77 #define xtensa_ldct_op 78 #define xtensa_lict_op 79 #define xtensa_licw_op 80 #define xtensa_loop_op 81 #define xtensa_loopgtz_op 82 #define xtensa_loopnez_op 83 #define xtensa_memw_op 84 #define xtensa_mov_n_op 85 #define xtensa_moveqz_op 86 #define xtensa_movgez_op 87 #define xtensa_movi_op 88 #define xtensa_movi_n_op 89 #define xtensa_movltz_op 90 #define xtensa_movnez_op 91 #define xtensa_movsp_op 92 #define xtensa_neg_op 93 #define xtensa_nop_n_op 94 #define xtensa_nsa_op 95 #define xtensa_nsau_op 96 #define xtensa_or_op 97 #define xtensa_pdtlb_op 98 #define xtensa_pitlb_op 99 #define xtensa_rdtlb0_op 100 #define xtensa_rdtlb1_op 101 #define xtensa_ret_op 102 #define xtensa_ret_n_op 103 #define xtensa_retw_op 104 #define xtensa_retw_n_op 105 #define xtensa_rfde_op 106 #define xtensa_rfe_op 107 #define xtensa_rfi_op 108 #define xtensa_rfwo_op 109 #define xtensa_rfwu_op 110 #define xtensa_ritlb0_op 111 #define xtensa_ritlb1_op 112 #define xtensa_rotw_op 113 #define xtensa_rsil_op 114 #define xtensa_rsr_op 115 #define xtensa_rsync_op 116 #define xtensa_s16i_op 117 #define xtensa_s32e_op 118 #define xtensa_s32i_op 119 #define xtensa_s32i_n_op 120 #define xtensa_s8i_op 121 #define xtensa_sdct_op 122 #define xtensa_sict_op 123 #define xtensa_sicw_op 124 #define xtensa_simcall_op 125 #define xtensa_sll_op 126 #define xtensa_slli_op 127 #define xtensa_sra_op 128 #define xtensa_srai_op 129 #define xtensa_src_op 130 #define xtensa_srl_op 131 #define xtensa_srli_op 132 #define xtensa_ssa8b_op 133 #define xtensa_ssa8l_op 134 #define xtensa_ssai_op 135 #define xtensa_ssl_op 136 #define xtensa_ssr_op 137 #define xtensa_sub_op 138 #define xtensa_subx2_op 139 #define xtensa_subx4_op 140 #define xtensa_subx8_op 141 #define xtensa_syscall_op 142 #define xtensa_waiti_op 143 #define xtensa_wdtlb_op 144 #define xtensa_witlb_op 145 #define xtensa_wsr_op 146 #define xtensa_xor_op 147 #define xtensa_xsr_op 148 int decode_insn (const xtensa_insnbuf insn) { switch (get_op0_field (insn)) { case 0: /* QRST: op0=0000 */ switch (get_op1_field (insn)) { case 3: /* RST3: op1=0011 */ switch (get_op2_field (insn)) { case 8: /* MOVEQZ: op2=1000 */ return xtensa_moveqz_op; case 9: /* MOVNEZ: op2=1001 */ return xtensa_movnez_op; case 10: /* MOVLTZ: op2=1010 */ return xtensa_movltz_op; case 11: /* MOVGEZ: op2=1011 */ return xtensa_movgez_op; case 0: /* RSR: op2=0000 */ return xtensa_rsr_op; case 1: /* WSR: op2=0001 */ return xtensa_wsr_op; } break; case 9: /* LSI4: op1=1001 */ switch (get_op2_field (insn)) { case 4: /* S32E: op2=0100 */ return xtensa_s32e_op; case 0: /* L32E: op2=0000 */ return xtensa_l32e_op; } break; case 4: /* EXTUI: op1=010x */ case 5: /* EXTUI: op1=010x */ return xtensa_extui_op; case 0: /* RST0: op1=0000 */ switch (get_op2_field (insn)) { case 15: /* SUBX8: op2=1111 */ return xtensa_subx8_op; case 0: /* ST0: op2=0000 */ switch (get_r_field (insn)) { case 0: /* SNM0: r=0000 */ switch (get_m_field (insn)) { case 2: /* JR: m=10 */ switch (get_n_field (insn)) { case 0: /* RET: n=00 */ return xtensa_ret_op; case 1: /* RETW: n=01 */ return xtensa_retw_op; case 2: /* JX: n=10 */ return xtensa_jx_op; } break; case 3: /* CALLX: m=11 */ switch (get_n_field (insn)) { case 0: /* CALLX0: n=00 */ return xtensa_callx0_op; case 1: /* CALLX4: n=01 */ return xtensa_callx4_op; case 2: /* CALLX8: n=10 */ return xtensa_callx8_op; case 3: /* CALLX12: n=11 */ return xtensa_callx12_op; } break; } break; case 1: /* MOVSP: r=0001 */ return xtensa_movsp_op; case 2: /* SYNC: r=0010 */ switch (get_s_field (insn)) { case 0: /* SYNCT: s=0000 */ switch (get_t_field (insn)) { case 2: /* ESYNC: t=0010 */ return xtensa_esync_op; case 3: /* DSYNC: t=0011 */ return xtensa_dsync_op; case 8: /* EXCW: t=1000 */ return xtensa_excw_op; case 12: /* MEMW: t=1100 */ return xtensa_memw_op; case 0: /* ISYNC: t=0000 */ return xtensa_isync_op; case 1: /* RSYNC: t=0001 */ return xtensa_rsync_op; } break; } break; case 4: /* BREAK: r=0100 */ return xtensa_break_op; case 3: /* RFEI: r=0011 */ switch (get_t_field (insn)) { case 0: /* RFET: t=0000 */ switch (get_s_field (insn)) { case 2: /* RFDE: s=0010 */ return xtensa_rfde_op; case 4: /* RFWO: s=0100 */ return xtensa_rfwo_op; case 5: /* RFWU: s=0101 */ return xtensa_rfwu_op; case 0: /* RFE: s=0000 */ return xtensa_rfe_op; } break; case 1: /* RFI: t=0001 */ return xtensa_rfi_op; } break; case 5: /* SCALL: r=0101 */ switch (get_s_field (insn)) { case 0: /* SYSCALL: s=0000 */ return xtensa_syscall_op; case 1: /* SIMCALL: s=0001 */ return xtensa_simcall_op; } break; case 6: /* RSIL: r=0110 */ return xtensa_rsil_op; case 7: /* WAITI: r=0111 */ return xtensa_waiti_op; } break; case 1: /* AND: op2=0001 */ return xtensa_and_op; case 2: /* OR: op2=0010 */ return xtensa_or_op; case 3: /* XOR: op2=0011 */ return xtensa_xor_op; case 4: /* ST1: op2=0100 */ switch (get_r_field (insn)) { case 15: /* NSAU: r=1111 */ return xtensa_nsau_op; case 0: /* SSR: r=0000 */ return xtensa_ssr_op; case 1: /* SSL: r=0001 */ return xtensa_ssl_op; case 2: /* SSA8L: r=0010 */ return xtensa_ssa8l_op; case 3: /* SSA8B: r=0011 */ return xtensa_ssa8b_op; case 4: /* SSAI: r=0100 */ return xtensa_ssai_op; case 8: /* ROTW: r=1000 */ return xtensa_rotw_op; case 14: /* NSA: r=1110 */ return xtensa_nsa_op; } break; case 8: /* ADD: op2=1000 */ return xtensa_add_op; case 5: /* ST4: op2=0101 */ switch (get_r_field (insn)) { case 15: /* RDTLB1: r=1111 */ return xtensa_rdtlb1_op; case 0: /* IITLBA: r=0000 */ return xtensa_iitlba_op; case 3: /* RITLB0: r=0011 */ return xtensa_ritlb0_op; case 4: /* IITLB: r=0100 */ return xtensa_iitlb_op; case 8: /* IDTLBA: r=1000 */ return xtensa_idtlba_op; case 5: /* PITLB: r=0101 */ return xtensa_pitlb_op; case 6: /* WITLB: r=0110 */ return xtensa_witlb_op; case 7: /* RITLB1: r=0111 */ return xtensa_ritlb1_op; case 11: /* RDTLB0: r=1011 */ return xtensa_rdtlb0_op; case 12: /* IDTLB: r=1100 */ return xtensa_idtlb_op; case 13: /* PDTLB: r=1101 */ return xtensa_pdtlb_op; case 14: /* WDTLB: r=1110 */ return xtensa_wdtlb_op; } break; case 6: /* RT0: op2=0110 */ switch (get_s_field (insn)) { case 0: /* NEG: s=0000 */ return xtensa_neg_op; case 1: /* ABS: s=0001 */ return xtensa_abs_op; } break; case 9: /* ADDX2: op2=1001 */ return xtensa_addx2_op; case 10: /* ADDX4: op2=1010 */ return xtensa_addx4_op; case 11: /* ADDX8: op2=1011 */ return xtensa_addx8_op; case 12: /* SUB: op2=1100 */ return xtensa_sub_op; case 13: /* SUBX2: op2=1101 */ return xtensa_subx2_op; case 14: /* SUBX4: op2=1110 */ return xtensa_subx4_op; } break; case 1: /* RST1: op1=0001 */ switch (get_op2_field (insn)) { case 15: /* IMP: op2=1111 */ switch (get_r_field (insn)) { case 0: /* LICT: r=0000 */ return xtensa_lict_op; case 1: /* SICT: r=0001 */ return xtensa_sict_op; case 2: /* LICW: r=0010 */ return xtensa_licw_op; case 3: /* SICW: r=0011 */ return xtensa_sicw_op; case 8: /* LDCT: r=1000 */ return xtensa_ldct_op; case 9: /* SDCT: r=1001 */ return xtensa_sdct_op; } break; case 0: /* SLLI: op2=000x */ case 1: /* SLLI: op2=000x */ return xtensa_slli_op; case 2: /* SRAI: op2=001x */ case 3: /* SRAI: op2=001x */ return xtensa_srai_op; case 4: /* SRLI: op2=0100 */ return xtensa_srli_op; case 8: /* SRC: op2=1000 */ return xtensa_src_op; case 9: /* SRL: op2=1001 */ return xtensa_srl_op; case 6: /* XSR: op2=0110 */ return xtensa_xsr_op; case 10: /* SLL: op2=1010 */ return xtensa_sll_op; case 11: /* SRA: op2=1011 */ return xtensa_sra_op; } break; } break; case 1: /* L32R: op0=0001 */ return xtensa_l32r_op; case 2: /* LSAI: op0=0010 */ switch (get_r_field (insn)) { case 0: /* L8UI: r=0000 */ return xtensa_l8ui_op; case 1: /* L16UI: r=0001 */ return xtensa_l16ui_op; case 2: /* L32I: r=0010 */ return xtensa_l32i_op; case 4: /* S8I: r=0100 */ return xtensa_s8i_op; case 5: /* S16I: r=0101 */ return xtensa_s16i_op; case 9: /* L16SI: r=1001 */ return xtensa_l16si_op; case 6: /* S32I: r=0110 */ return xtensa_s32i_op; case 7: /* CACHE: r=0111 */ switch (get_t_field (insn)) { case 15: /* III: t=1111 */ return xtensa_iii_op; case 0: /* DPFR: t=0000 */ return xtensa_dpfr_op; case 1: /* DPFW: t=0001 */ return xtensa_dpfw_op; case 2: /* DPFRO: t=0010 */ return xtensa_dpfro_op; case 4: /* DHWB: t=0100 */ return xtensa_dhwb_op; case 3: /* DPFWO: t=0011 */ return xtensa_dpfwo_op; case 8: /* DCE: t=1000 */ switch (get_op1_field (insn)) { case 4: /* DIWB: op1=0100 */ return xtensa_diwb_op; case 5: /* DIWBI: op1=0101 */ return xtensa_diwbi_op; } break; case 5: /* DHWBI: t=0101 */ return xtensa_dhwbi_op; case 6: /* DHI: t=0110 */ return xtensa_dhi_op; case 7: /* DII: t=0111 */ return xtensa_dii_op; case 12: /* IPF: t=1100 */ return xtensa_ipf_op; case 14: /* IHI: t=1110 */ return xtensa_ihi_op; } break; case 10: /* MOVI: r=1010 */ return xtensa_movi_op; case 12: /* ADDI: r=1100 */ return xtensa_addi_op; case 13: /* ADDMI: r=1101 */ return xtensa_addmi_op; } break; case 8: /* L32I.N: op0=1000 */ return xtensa_l32i_n_op; case 5: /* CALL: op0=0101 */ switch (get_n_field (insn)) { case 0: /* CALL0: n=00 */ return xtensa_call0_op; case 1: /* CALL4: n=01 */ return xtensa_call4_op; case 2: /* CALL8: n=10 */ return xtensa_call8_op; case 3: /* CALL12: n=11 */ return xtensa_call12_op; } break; case 6: /* SI: op0=0110 */ switch (get_n_field (insn)) { case 0: /* J: n=00 */ return xtensa_j_op; case 1: /* BZ: n=01 */ switch (get_m_field (insn)) { case 0: /* BEQZ: m=00 */ return xtensa_beqz_op; case 1: /* BNEZ: m=01 */ return xtensa_bnez_op; case 2: /* BLTZ: m=10 */ return xtensa_bltz_op; case 3: /* BGEZ: m=11 */ return xtensa_bgez_op; } break; case 2: /* BI0: n=10 */ switch (get_m_field (insn)) { case 0: /* BEQI: m=00 */ return xtensa_beqi_op; case 1: /* BNEI: m=01 */ return xtensa_bnei_op; case 2: /* BLTI: m=10 */ return xtensa_blti_op; case 3: /* BGEI: m=11 */ return xtensa_bgei_op; } break; case 3: /* BI1: n=11 */ switch (get_m_field (insn)) { case 0: /* ENTRY: m=00 */ return xtensa_entry_op; case 1: /* B1: m=01 */ switch (get_r_field (insn)) { case 8: /* LOOP: r=1000 */ return xtensa_loop_op; case 9: /* LOOPNEZ: r=1001 */ return xtensa_loopnez_op; case 10: /* LOOPGTZ: r=1010 */ return xtensa_loopgtz_op; } break; case 2: /* BLTUI: m=10 */ return xtensa_bltui_op; case 3: /* BGEUI: m=11 */ return xtensa_bgeui_op; } break; } break; case 9: /* S32I.N: op0=1001 */ return xtensa_s32i_n_op; case 10: /* ADD.N: op0=1010 */ return xtensa_add_n_op; case 7: /* B: op0=0111 */ switch (get_r_field (insn)) { case 6: /* BBCI: r=011x */ case 7: /* BBCI: r=011x */ return xtensa_bbci_op; case 0: /* BNONE: r=0000 */ return xtensa_bnone_op; case 1: /* BEQ: r=0001 */ return xtensa_beq_op; case 2: /* BLT: r=0010 */ return xtensa_blt_op; case 4: /* BALL: r=0100 */ return xtensa_ball_op; case 14: /* BBSI: r=111x */ case 15: /* BBSI: r=111x */ return xtensa_bbsi_op; case 3: /* BLTU: r=0011 */ return xtensa_bltu_op; case 5: /* BBC: r=0101 */ return xtensa_bbc_op; case 8: /* BANY: r=1000 */ return xtensa_bany_op; case 9: /* BNE: r=1001 */ return xtensa_bne_op; case 10: /* BGE: r=1010 */ return xtensa_bge_op; case 11: /* BGEU: r=1011 */ return xtensa_bgeu_op; case 12: /* BNALL: r=1100 */ return xtensa_bnall_op; case 13: /* BBS: r=1101 */ return xtensa_bbs_op; } break; case 11: /* ADDI.N: op0=1011 */ return xtensa_addi_n_op; case 12: /* ST2: op0=1100 */ switch (get_i_field (insn)) { case 0: /* MOVI.N: i=0 */ return xtensa_movi_n_op; case 1: /* BZ6: i=1 */ switch (get_z_field (insn)) { case 0: /* BEQZ.N: z=0 */ return xtensa_beqz_n_op; case 1: /* BNEZ.N: z=1 */ return xtensa_bnez_n_op; } break; } break; case 13: /* ST3: op0=1101 */ switch (get_r_field (insn)) { case 15: /* S3: r=1111 */ switch (get_t_field (insn)) { case 0: /* RET.N: t=0000 */ return xtensa_ret_n_op; case 1: /* RETW.N: t=0001 */ return xtensa_retw_n_op; case 2: /* BREAK.N: t=0010 */ return xtensa_break_n_op; case 3: /* NOP.N: t=0011 */ return xtensa_nop_n_op; } break; case 0: /* MOV.N: r=0000 */ return xtensa_mov_n_op; } break; } return XTENSA_UNDEFINED; } int interface_version (void) { return 3; } static struct config_struct config_table[] = { {"IsaMemoryOrder", "BigEndian"}, {"PIFReadDataBits", "128"}, {"PIFWriteDataBits", "128"}, {"IsaCoprocessorCount", "0"}, {"IsaUseBooleans", "0"}, {"IsaUseDensityInstruction", "1"}, {0, 0} }; struct config_struct * get_config_table (void); struct config_struct * get_config_table (void) { return config_table; } xtensa_isa_module xtensa_isa_modules[] = { { get_num_opcodes, get_opcodes, decode_insn, get_config_table }, { 0, 0, 0, 0 } };