blob: d023b5233e1c56fa47206c391cfbb575d4a35e85 [file] [log] [blame]
/* 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 <xtensa-isa.h>
#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);
const 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];
}
const 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 }
};