9ed608f98b
The Statistical Profile Extension adds the instruction PSB CSYNC as an alias for the HINT #17 instruction. This patch adds support for aliases of HINT which take an operand, adding a table to store operand names and their matching hint number as well as encoding and decoding functions for such operands. Parsing and printing the operands are deferred to any support added for aliases with such operands. include/opcode/ 2015-12-11 Matthew Wahab <matthew.wahab@arm.com> * aarch64.h (aarch64_hint_options): Declare. (aarch64_opnd_info): Add field hint_option. opcodes/ 2015-12-11 Matthew Wahab <matthew.wahab@arm.com> * aarch64-asm.c (aarch64_ins_hint): New. * aarch64-asm.h (aarch64_ins_hint): Declare. * aarch64-dis.c (aarch64_ext_hint): New. * aarch64-dis.h (aarch64_ext_hint): Declare. * aarch64-opc-2.c: Regenerate. * aarch64-opc.c (aarch64_hint_options): New. * aarch64-tbl.h (AARCH64_OPERANDS): Fix typos. Change-Id: I2205038fc1c47d3025d1f0bc2fbf405b5575b287
74 lines
2.7 KiB
C
74 lines
2.7 KiB
C
/* aarch64-asm.h -- Header file for aarch64-asm.c and aarch64-asm-2.c.
|
|
Copyright (C) 2012-2015 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_ASM_H
|
|
#define OPCODES_AARCH64_ASM_H
|
|
|
|
#include "aarch64-opc.h"
|
|
|
|
/* Given OPCODE, return the opcode entry that OPCODE aliases to, e.g.
|
|
given LSL, return UBFM. */
|
|
|
|
const aarch64_opcode* aarch64_find_real_opcode (const aarch64_opcode *);
|
|
|
|
/* Switch-table-based high-level operand inserter. */
|
|
|
|
const char* aarch64_insert_operand (const aarch64_operand *,
|
|
const aarch64_opnd_info *, aarch64_insn *,
|
|
const aarch64_inst *);
|
|
|
|
/* Operand inserters. */
|
|
|
|
#define AARCH64_DECL_OPD_INSERTER(x) \
|
|
const char* aarch64_##x (const aarch64_operand *, const aarch64_opnd_info *, \
|
|
aarch64_insn *, const aarch64_inst *)
|
|
|
|
AARCH64_DECL_OPD_INSERTER (ins_regno);
|
|
AARCH64_DECL_OPD_INSERTER (ins_reglane);
|
|
AARCH64_DECL_OPD_INSERTER (ins_reglist);
|
|
AARCH64_DECL_OPD_INSERTER (ins_ldst_reglist);
|
|
AARCH64_DECL_OPD_INSERTER (ins_ldst_reglist_r);
|
|
AARCH64_DECL_OPD_INSERTER (ins_ldst_elemlist);
|
|
AARCH64_DECL_OPD_INSERTER (ins_advsimd_imm_shift);
|
|
AARCH64_DECL_OPD_INSERTER (ins_imm);
|
|
AARCH64_DECL_OPD_INSERTER (ins_imm_half);
|
|
AARCH64_DECL_OPD_INSERTER (ins_advsimd_imm_modified);
|
|
AARCH64_DECL_OPD_INSERTER (ins_fbits);
|
|
AARCH64_DECL_OPD_INSERTER (ins_aimm);
|
|
AARCH64_DECL_OPD_INSERTER (ins_limm);
|
|
AARCH64_DECL_OPD_INSERTER (ins_ft);
|
|
AARCH64_DECL_OPD_INSERTER (ins_addr_simple);
|
|
AARCH64_DECL_OPD_INSERTER (ins_addr_regoff);
|
|
AARCH64_DECL_OPD_INSERTER (ins_addr_simm);
|
|
AARCH64_DECL_OPD_INSERTER (ins_addr_uimm12);
|
|
AARCH64_DECL_OPD_INSERTER (ins_simd_addr_post);
|
|
AARCH64_DECL_OPD_INSERTER (ins_cond);
|
|
AARCH64_DECL_OPD_INSERTER (ins_sysreg);
|
|
AARCH64_DECL_OPD_INSERTER (ins_pstatefield);
|
|
AARCH64_DECL_OPD_INSERTER (ins_sysins_op);
|
|
AARCH64_DECL_OPD_INSERTER (ins_barrier);
|
|
AARCH64_DECL_OPD_INSERTER (ins_hint);
|
|
AARCH64_DECL_OPD_INSERTER (ins_prfop);
|
|
AARCH64_DECL_OPD_INSERTER (ins_reg_extended);
|
|
AARCH64_DECL_OPD_INSERTER (ins_reg_shifted);
|
|
|
|
#undef AARCH64_DECL_OPD_INSERTER
|
|
|
|
#endif /* OPCODES_AARCH64_ASM_H */
|