diff options
author | Tamar Christina <tamar.christina@arm.com> | 2017-11-09 15:22:30 +0000 |
---|---|---|
committer | Tamar Christina <tamar.christina@arm.com> | 2017-11-09 16:29:04 +0000 |
commit | f42f1a1d6ca0cc84e43d7f2b85044a2565ca00f2 (patch) | |
tree | 09df61653ce091a7efc3741d8a59748e3e55a876 /opcodes/aarch64-asm-2.c | |
parent | e793c052f9d9548442a46817998a46cbca4ccb70 (diff) | |
download | binutils-f42f1a1d6ca0cc84e43d7f2b85044a2565ca00f2.zip binutils-f42f1a1d6ca0cc84e43d7f2b85044a2565ca00f2.tar.gz binutils-f42f1a1d6ca0cc84e43d7f2b85044a2565ca00f2.tar.bz2 |
Adds the new Fields and Operand types for the new instructions in Armv8.4-a.
gas/
* config/tc-aarch64.c (process_omitted_operand):
Add AARCH64_OPND_Va, AARCH64_OPND_SM3_IMM2
and AARCH64_OPND_IMM_2.
(parse_operands): Add AARCH64_OPND_Va, AARCH64_OPND_SM3_IMM2,
AARCH64_OPND_IMM_2, AARCH64_OPND_MASK
and AARCH64_OPND_ADDR_OFFSET.
include/
* opcode/aarch64.h:
(aarch64_opnd): Add AARCH64_OPND_Va, AARCH64_OPND_MASK,
AARCH64_OPND_IMM_2, AARCH64_OPND_ADDR_OFFSET
and AARCH64_OPND_SM3_IMM2.
(aarch64_insn_class): Add cryptosm3 and cryptosm4.
(arch64_feature_set): Make uint64_t.
opcodes/
* aarch64-asm.h (ins_addr_offset): New.
* aarch64-asm.c (aarch64_ins_reglane): Add cryptosm3.
(aarch64_ins_addr_offset): New.
* aarch64-asm-2.c: Regenerate.
* aarch64-dis.h (ext_addr_offset): New.
* aarch64-dis.c (aarch64_ext_reglane): Add cryptosm3.
(aarch64_ext_addr_offset): New.
* aarch64-dis-2.c: Regenerate.
* aarch64-opc.h (aarch64_field_kind): Add FLD_imm6_2,
FLD_imm4_2 and FLD_SM3_imm2.
* aarch64-opc.c (fields): Add FLD_imm6_2,
FLD_imm4_2 and FLD_SM3_imm2.
(operand_general_constraint_met_p): Add AARCH64_OPND_ADDR_OFFSET.
(aarch64_print_operand): Add AARCH64_OPND_Va, AARCH64_OPND_SM3_IMM2,
AARCH64_OPND_MASK, AARCH64_OPND_IMM_2 and AARCH64_OPND_ADDR_OFFSET.
* aarch64-opc-2.c (Va, MASK, IMM_2, ADDR_OFFSET, SM3_IMM2): New.
* aarch64-tbl.h
(aarch64_opcode_table): Add Va, MASK, IMM_2, ADDR_OFFSET, SM3_IMM2.
Diffstat (limited to 'opcodes/aarch64-asm-2.c')
-rw-r--r-- | opcodes/aarch64-asm-2.c | 182 |
1 files changed, 94 insertions, 88 deletions
diff --git a/opcodes/aarch64-asm-2.c b/opcodes/aarch64-asm-2.c index c5d9e6f..ba7fbfb 100644 --- a/opcodes/aarch64-asm-2.c +++ b/opcodes/aarch64-asm-2.c @@ -611,27 +611,28 @@ aarch64_insert_operand (const aarch64_operand *self, case 26: case 27: case 28: - case 147: - case 148: - case 149: - case 150: + case 29: case 151: case 152: case 153: case 154: case 155: case 156: - case 169: - case 170: - case 171: - case 172: + case 157: + case 158: + case 159: + case 160: case 173: case 174: case 175: case 176: case 177: + case 178: + case 179: + case 180: case 181: - case 184: + case 185: + case 188: return aarch64_ins_regno (self, info, code, inst); case 13: return aarch64_ins_reg_extended (self, info, code, inst); @@ -639,23 +640,23 @@ aarch64_insert_operand (const aarch64_operand *self, return aarch64_ins_reg_shifted (self, info, code, inst); case 19: return aarch64_ins_ft (self, info, code, inst); - case 29: case 30: case 31: - return aarch64_ins_reglane (self, info, code, inst); case 32: - return aarch64_ins_reglist (self, info, code, inst); + case 190: + return aarch64_ins_reglane (self, info, code, inst); case 33: - return aarch64_ins_ldst_reglist (self, info, code, inst); + return aarch64_ins_reglist (self, info, code, inst); case 34: - return aarch64_ins_ldst_reglist_r (self, info, code, inst); + return aarch64_ins_ldst_reglist (self, info, code, inst); case 35: - return aarch64_ins_ldst_elemlist (self, info, code, inst); + return aarch64_ins_ldst_reglist_r (self, info, code, inst); case 36: + return aarch64_ins_ldst_elemlist (self, info, code, inst); case 37: case 38: - case 48: - case 49: + case 39: + case 40: case 50: case 51: case 52: @@ -667,101 +668,102 @@ aarch64_insert_operand (const aarch64_operand *self, case 58: case 59: case 60: - case 72: - case 73: - case 74: + case 61: + case 62: + case 63: case 75: - case 144: - case 146: - case 161: - case 162: - case 163: - case 164: + case 76: + case 77: + case 78: + case 148: + case 150: case 165: case 166: case 167: case 168: + case 169: + case 170: + case 171: + case 172: return aarch64_ins_imm (self, info, code, inst); - case 39: - case 40: - return aarch64_ins_advsimd_imm_shift (self, info, code, inst); case 41: case 42: + return aarch64_ins_advsimd_imm_shift (self, info, code, inst); case 43: + case 44: + case 45: return aarch64_ins_advsimd_imm_modified (self, info, code, inst); - case 47: - case 135: + case 49: + case 139: return aarch64_ins_fpimm (self, info, code, inst); - case 61: - case 142: + case 64: + case 146: return aarch64_ins_limm (self, info, code, inst); - case 62: + case 65: return aarch64_ins_aimm (self, info, code, inst); - case 63: - return aarch64_ins_imm_half (self, info, code, inst); - case 64: - return aarch64_ins_fbits (self, info, code, inst); case 66: + return aarch64_ins_imm_half (self, info, code, inst); case 67: - case 140: - return aarch64_ins_imm_rotate2 (self, info, code, inst); - case 68: - case 139: - return aarch64_ins_imm_rotate1 (self, info, code, inst); + return aarch64_ins_fbits (self, info, code, inst); case 69: case 70: + case 144: + return aarch64_ins_imm_rotate2 (self, info, code, inst); + case 71: + case 143: + return aarch64_ins_imm_rotate1 (self, info, code, inst); + case 72: + case 73: return aarch64_ins_cond (self, info, code, inst); - case 76: - case 83: - return aarch64_ins_addr_simple (self, info, code, inst); - case 77: - return aarch64_ins_addr_regoff (self, info, code, inst); - case 78: case 79: + case 86: + return aarch64_ins_addr_simple (self, info, code, inst); case 80: - return aarch64_ins_addr_simm (self, info, code, inst); + return aarch64_ins_addr_regoff (self, info, code, inst); case 81: - return aarch64_ins_addr_simm10 (self, info, code, inst); case 82: - return aarch64_ins_addr_uimm12 (self, info, code, inst); + case 83: + return aarch64_ins_addr_simm (self, info, code, inst); case 84: - return aarch64_ins_simd_addr_post (self, info, code, inst); + return aarch64_ins_addr_simm10 (self, info, code, inst); case 85: - return aarch64_ins_sysreg (self, info, code, inst); - case 86: - return aarch64_ins_pstatefield (self, info, code, inst); + return aarch64_ins_addr_uimm12 (self, info, code, inst); case 87: + return aarch64_ins_addr_offset (self, info, code, inst); case 88: + return aarch64_ins_simd_addr_post (self, info, code, inst); case 89: + return aarch64_ins_sysreg (self, info, code, inst); case 90: - return aarch64_ins_sysins_op (self, info, code, inst); + return aarch64_ins_pstatefield (self, info, code, inst); case 91: case 92: - return aarch64_ins_barrier (self, info, code, inst); case 93: - return aarch64_ins_prfop (self, info, code, inst); case 94: - return aarch64_ins_hint (self, info, code, inst); + return aarch64_ins_sysins_op (self, info, code, inst); case 95: - return aarch64_ins_sve_addr_ri_s4 (self, info, code, inst); case 96: + return aarch64_ins_barrier (self, info, code, inst); case 97: + return aarch64_ins_prfop (self, info, code, inst); case 98: + return aarch64_ins_hint (self, info, code, inst); case 99: - return aarch64_ins_sve_addr_ri_s4xvl (self, info, code, inst); + return aarch64_ins_sve_addr_ri_s4 (self, info, code, inst); case 100: - return aarch64_ins_sve_addr_ri_s6xvl (self, info, code, inst); case 101: - return aarch64_ins_sve_addr_ri_s9xvl (self, info, code, inst); case 102: case 103: + return aarch64_ins_sve_addr_ri_s4xvl (self, info, code, inst); case 104: + return aarch64_ins_sve_addr_ri_s6xvl (self, info, code, inst); case 105: - return aarch64_ins_sve_addr_ri_u6 (self, info, code, inst); + return aarch64_ins_sve_addr_ri_s9xvl (self, info, code, inst); case 106: case 107: case 108: case 109: + return aarch64_ins_sve_addr_ri_u6 (self, info, code, inst); case 110: case 111: case 112: @@ -770,57 +772,61 @@ aarch64_insert_operand (const aarch64_operand *self, case 115: case 116: case 117: - return aarch64_ins_sve_addr_rr_lsl (self, info, code, inst); case 118: case 119: case 120: case 121: + return aarch64_ins_sve_addr_rr_lsl (self, info, code, inst); case 122: case 123: case 124: case 125: - return aarch64_ins_sve_addr_rz_xtw (self, info, code, inst); case 126: case 127: case 128: case 129: - return aarch64_ins_sve_addr_zi_u5 (self, info, code, inst); + return aarch64_ins_sve_addr_rz_xtw (self, info, code, inst); case 130: - return aarch64_ins_sve_addr_zz_lsl (self, info, code, inst); case 131: - return aarch64_ins_sve_addr_zz_sxtw (self, info, code, inst); case 132: - return aarch64_ins_sve_addr_zz_uxtw (self, info, code, inst); case 133: - return aarch64_ins_sve_aimm (self, info, code, inst); + return aarch64_ins_sve_addr_zi_u5 (self, info, code, inst); case 134: - return aarch64_ins_sve_asimm (self, info, code, inst); + return aarch64_ins_sve_addr_zz_lsl (self, info, code, inst); + case 135: + return aarch64_ins_sve_addr_zz_sxtw (self, info, code, inst); case 136: - return aarch64_ins_sve_float_half_one (self, info, code, inst); + return aarch64_ins_sve_addr_zz_uxtw (self, info, code, inst); case 137: - return aarch64_ins_sve_float_half_two (self, info, code, inst); + return aarch64_ins_sve_aimm (self, info, code, inst); case 138: - return aarch64_ins_sve_float_zero_one (self, info, code, inst); + return aarch64_ins_sve_asimm (self, info, code, inst); + case 140: + return aarch64_ins_sve_float_half_one (self, info, code, inst); case 141: + return aarch64_ins_sve_float_half_two (self, info, code, inst); + case 142: + return aarch64_ins_sve_float_zero_one (self, info, code, inst); + case 145: return aarch64_ins_inv_limm (self, info, code, inst); - case 143: + case 147: return aarch64_ins_sve_limm_mov (self, info, code, inst); - case 145: + case 149: return aarch64_ins_sve_scale (self, info, code, inst); - case 157: - case 158: + case 161: + case 162: return aarch64_ins_sve_shlimm (self, info, code, inst); - case 159: - case 160: + case 163: + case 164: return aarch64_ins_sve_shrimm (self, info, code, inst); - case 178: - case 179: - case 180: - return aarch64_ins_sve_quad_index (self, info, code, inst); case 182: - return aarch64_ins_sve_index (self, info, code, inst); case 183: - case 185: + case 184: + return aarch64_ins_sve_quad_index (self, info, code, inst); + case 186: + return aarch64_ins_sve_index (self, info, code, inst); + case 187: + case 189: return aarch64_ins_sve_reglist (self, info, code, inst); default: assert (0); abort (); } |