mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-02-05 12:53:16 +08:00
Introduces instructions for the Advanced SIMD lut extension for AArch64. They are documented in the following links: * luti2: https://developer.arm.com/documentation/ddi0602/2024-03/SIMD-FP-Instructions/LUTI2--Lookup-table-read-with-2-bit-indices-?lang=en * luti4: https://developer.arm.com/documentation/ddi0602/2024-03/SIMD-FP-Instructions/LUTI4--Lookup-table-read-with-4-bit-indices-?lang=en These instructions needed definition of some new operands. We will first discuss operands for the third operand of the instructions and then discuss a vector register list operand needed for the second operand. The third operands are vectors with bit indices and without type qualifiers. They are called Em_INDEX1_14, Em_INDEX2_13, and Em_INDEX3_12 and they have 1 bit, 2 bit, and 3 bit indices respectively. For these new operands, we defined new parsing case branch. The lsb and width of these operands are the same as many existing but the convention is to give different names to fields that serve different purpose so we introduced new fields in aarch64-opc.c and aarch64-opc.h for these new operands. For the second operand of these instructions, we introduced a new operand called LVn_LUT. This represents a vector register list with stride 1. We defined new inserter and extractor for this new operand and it is encoded in FLD_Rn. We are enforcing the number of registers in the reglist using opcode flag rather than operand flag as this is what other SIMD vector register list operands are doing. The disassembly also uses opcode flag to print the correct number of registers.
152 lines
6.3 KiB
C
152 lines
6.3 KiB
C
/* aarch64-dis.h -- Header file for aarch64-dis.c and aarch64-dis-2.c.
|
|
Copyright (C) 2012-2024 Free Software Foundation, Inc.
|
|
Contributed by ARM Ltd.
|
|
|
|
This file is part of the GNU opcodes library.
|
|
|
|
This library 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 3, or (at your option)
|
|
any later version.
|
|
|
|
It 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; see the file COPYING3. If not,
|
|
see <http://www.gnu.org/licenses/>. */
|
|
|
|
#ifndef OPCODES_AARCH64_DIS_H
|
|
#define OPCODES_AARCH64_DIS_H
|
|
#include <stdint.h>
|
|
#include "aarch64-opc.h"
|
|
|
|
/* Lookup opcode WORD in the opcode table.
|
|
|
|
In the case of multiple aarch64_opcode candidates, one of them will be
|
|
returned; for other candidate(s), call aarch64_find_next_opcode to
|
|
obtain. Note that aarch64_find_next_opcode finds the next
|
|
aarch64_opcode candidate in a way as if all related aarch64_opcode
|
|
entries were in a single-link list.
|
|
|
|
N.B. all alias opcodes are ignored here. */
|
|
|
|
const aarch64_opcode* aarch64_opcode_lookup (uint32_t);
|
|
const aarch64_opcode* aarch64_find_next_opcode (const aarch64_opcode *);
|
|
|
|
/* Given OPCODE, return its alias, e.g. given UBFM, return LSL.
|
|
|
|
In the case of multiple alias candidates, the one of the highest priority
|
|
(or one of several aliases of the same highest priority) will be
|
|
returned; for the other candidate(s), call aarch64_find_next_alias_opcode
|
|
to obtain. Note that aarch64_find_next_alias_opcode finds the next
|
|
alias candidate in a way as if all related aliases were in a single-link
|
|
list with priority from the highest to the least. */
|
|
|
|
const aarch64_opcode* aarch64_find_alias_opcode (const aarch64_opcode *);
|
|
const aarch64_opcode* aarch64_find_next_alias_opcode (const aarch64_opcode *);
|
|
|
|
/* Switch-table-based high-level operand extractor. */
|
|
|
|
bool
|
|
aarch64_extract_operand (const aarch64_operand *, aarch64_opnd_info *,
|
|
const aarch64_insn, const aarch64_inst *,
|
|
aarch64_operand_error *);
|
|
|
|
/* Operand extractors. */
|
|
|
|
#define AARCH64_DECL_OPD_EXTRACTOR(x) \
|
|
bool aarch64_##x (const aarch64_operand *, aarch64_opnd_info *, \
|
|
const aarch64_insn, const aarch64_inst *, \
|
|
aarch64_operand_error *)
|
|
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_none);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_regno);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_regno_pair);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_regrt_sysins);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_reglane);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_reglist);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_ldst_reglist);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_ldst_reglist_r);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_lut_reglist);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_ldst_elemlist);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_advsimd_imm_shift);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_shll_imm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_imm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_imm_half);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_advsimd_imm_modified);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_fpimm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_fbits);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_aimm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_limm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_inv_limm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_ft);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_addr_simple);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_addr_offset);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_addr_regoff);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_addr_simm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_addr_simm10);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_addr_uimm12);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_simd_addr_post);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_cond);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sysreg);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_pstatefield);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sysins_op);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_barrier);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_barrier_dsb_nxs);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_hint);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_prfop);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_reg_extended);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_reg_shifted);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_reg_lsl_shifted);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_ri_s4);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_ri_s4xvl);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_ri_s6xvl);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_ri_s9xvl);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_ri_u6);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_rr_lsl);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_rz_xtw);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_zi_u5);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_zz_lsl);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_zz_sxtw);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_zz_uxtw);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_aimm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_aligned_reglist);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_asimm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_float_half_one);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_float_half_two);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_float_zero_one);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_index);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_index_imm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_limm_mov);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_quad_index);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_reglist);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_strided_reglist);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_scale);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_shlimm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_shrimm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sme_za_vrs1);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sme_za_vrs2);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sme_za_hv_tiles);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sme_za_hv_tiles_range);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sme_za_list);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sme_za_array);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sme_addr_ri_u4xvl);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sme_sm_za);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sme_pred_reg_with_index);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_imm_rotate1);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_imm_rotate2);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_x0_to_x30);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_simple_index);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_plain_shrimm);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_sve_reglist_zt);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_rcpc3_addr_opt_offset);
|
|
AARCH64_DECL_OPD_EXTRACTOR (ext_rcpc3_addr_offset);
|
|
|
|
|
|
#undef AARCH64_DECL_OPD_EXTRACTOR
|
|
|
|
#endif /* OPCODES_AARCH64_DIS_H */
|