Add startswith function and use it instead of CONST_STRNEQ.
[deliverable/binutils-gdb.git] / opcodes / ChangeLog
index 6d46709533f39f9ec6024a5d38c4002dd0b3f182..bd8cfef1b9490e707e646592b970340d0029f536 100644 (file)
@@ -1,3 +1,352 @@
+2021-03-22  Martin Liska  <mliska@suse.cz>
+
+       * aarch64-dis.c (parse_aarch64_dis_option): Replace usage of CONST_STRNEQ with startswith.
+       * arc-dis.c (parse_option): Likewise.
+       * arm-dis.c (parse_arm_disassembler_options): Likewise.
+       * cris-dis.c (print_with_operands): Likewise.
+       * h8300-dis.c (bfd_h8_disassemble): Likewise.
+       * i386-dis.c (print_insn): Likewise.
+       * ia64-gen.c (fetch_insn_class): Likewise.
+       (parse_resource_users): Likewise.
+       (in_iclass): Likewise.
+       (lookup_specifier): Likewise.
+       (insert_opcode_dependencies): Likewise.
+       * mips-dis.c (parse_mips_ase_option): Likewise.
+       (parse_mips_dis_option): Likewise.
+       * s390-dis.c (disassemble_init_s390): Likewise.
+       * wasm32-dis.c (parse_wasm32_disassembler_options): Likewise.
+
+2021-03-16  Kuan-Lin Chen  <kuanlinchentw@gmail.com>
+
+       * riscv-opc.c (riscv_opcodes): Add zba, zbb and zbc instructions.
+
+2021-03-12  Przemyslaw Wirkus  <przemyslaw.wirkus@arm.com>
+
+       * aarch64-opc.c: Add lorc_el1, lorea_el1, lorn_el1, lorsa_el1,
+       icc_ctlr_el3, icc_sre_elx, ich_vtr_el2 system registers.
+
+2021-03-12  Alan Modra  <amodra@gmail.com>
+
+       * i386-dis.c (print_insn <PREFIX_IGNORED>): Correct typo.
+
+2021-03-11  Jan Beulich  <jbeulich@suse.com>
+
+       * i386-dis.c (OP_XMM): Re-order checks.
+
+2021-03-11  Jan Beulich  <jbeulich@suse.com>
+
+       * i386-dis.c (putop): Drop need_vex check when also checking
+       vex.evex.
+       (intel_operand_size, OP_E_memory): Drop vex.evex check when also
+       checking vex.b.
+
+2021-03-11  Jan Beulich  <jbeulich@suse.com>
+
+       * i386-dis.c (OP_E_memory): Drop xmmq_mode from broadcast
+       checks. Move case label past broadcast check.
+
+2021-03-10  Jan Beulich  <jbeulich@suse.com>
+
+       * opcodes/i386-dis.c (MVexVSIBDQWpX, MVexVSIBQDWpX,
+       vex_vsib_d_w_d_mode, vex_vsib_q_w_d_mode,
+       REG_EVEX_0F38C7_M_0_L_2_W_0, REG_EVEX_0F38C7_M_0_L_2_W_1,
+       EVEX_W_0F3891, EVEX_W_0F3893, EVEX_W_0F38A1, EVEX_W_0F38A3,
+       EVEX_W_0F38C7_M_0_L_2): Delete.
+       (REG_EVEX_0F38C7_M_0_L_2): New.
+       (intel_operand_size): Handle VEX and EVEX the same for
+       vex_vsib_d_w_dq_mode and vex_vsib_q_w_dq_mode. Drop
+       vex_vsib_d_w_d_mode and vex_vsib_q_w_d_mode cases.
+       (OP_E_memory, OP_XMM, OP_VEX): Drop vex_vsib_d_w_d_mode and
+       vex_vsib_q_w_d_mode uses.
+       * i386-dis-evex.h (evex_table): Adjust opcode 0F3891, 0F3893,
+       0F38A1, and 0F38A3 entries.
+       * i386-dis-evex-len.h (evex_len_table): Adjust opcode 0F38C7
+       entry.
+       * i386-dis-evex-reg.h: Fold opcode 0F38C7 entries.
+       * i386-dis-evex-w.h: Delete opcode 0F3891, 0F3893, 0F38A1, and
+       0F38A3 entries.
+
+2021-03-10  Jan Beulich  <jbeulich@suse.com>
+
+       * opcodes/i386-dis.c (REG_0FXOP_09_01_L_0, REG_0FXOP_09_02_L_0,
+       REG_0FXOP_09_12_M_1_L_0, REG_0FXOP_0A_12_L_0,
+       MOD_VEX_0FXOP_09_12): Rename to ...
+       (REG_XOP_09_01_L_0, REG_XOP_09_02_L_0, REG_XOP_09_12_M_1_L_0,
+       REG_XOP_0A_12_L_0, MOD_XOP_09_12): ... these.
+       (MOD_62_32BIT, MOD_8D, MOD_C4_32BIT, MOD_C5_32BIT,
+       RM_0F3A0F_P_1_MOD_3_REG_0, X86_64_0F24, X86_64_0F26,
+       X86_64_VEX_0F3849, X86_64_VEX_0F384B, X86_64_VEX_0F385C,
+       X86_64_VEX_0F385E, X86_64_0FC7_REG_6_MOD_3_PREFIX_1): Move.
+       (reg_table): Adjust comments.
+       (x86_64_table): Move X86_64_0F24, X86_64_0F26,
+       X86_64_VEX_0F3849, X86_64_VEX_0F384B, X86_64_VEX_0F385C,
+       X86_64_VEX_0F385E, and X86_64_0FC7_REG_6_MOD_3_PREFIX_1 entries.
+       (xop_table): Adjust opcode 09_01, 09_02, and 09_12 entries.
+       (vex_len_table): Adjust opcode 0A_12 entry.
+       (mod_table): Move MOD_62_32BIT, MOD_8D, MOD_C4_32BIT,
+       MOD_C5_32BIT, and MOD_XOP_09_12 entries.
+       (rm_table): Move hreset entry.
+
+2021-03-10  Jan Beulich  <jbeulich@suse.com>
+
+       * opcodes/i386-dis.c (EVEX_LEN_0F6E, EVEX_LEN_0F7E_P_1,
+       EVEX_LEN_0F7E_P_2, EVEX_LEN_0FC4, EVEX_LEN_0FC5, EVEX_LEN_0FD6,
+       EVEX_LEN_0F3816, EVEX_LEN_0F3A14, EVEX_LEN_0F3A15,
+       EVEX_LEN_0F3A16, EVEX_LEN_0F3A17, EVEX_LEN_0F3A20,
+       EVEX_LEN_0F3A21_W_0, EVEX_LEN_0F3A22, EVEX_W_0FD6_L_0): Delete.
+       (EVEX_LEN_0F3816, EVEX_W_0FD6): New.
+       (get_valid_dis386): Also handle 512-bit vector length when
+       vectoring into vex_len_table[].
+       * i386-dis-evex.h (evex_table): Adjust opcode 0F6E, 0FC4, 0FC5,
+       0FD6, 0F3A14, 0F3A15, 0F3A16, 0F3A17, 0F3A20, and 0F3A22
+       entries.
+       * i386-dis-evex-len.h: Delete opcode 0F6E, 0FC4, 0FC5, 0FD6,
+       0F3A14, 0F3A15, 0F3A16, 0F3A17, 0F3A20, and 0F3A22 entries.
+       * i386-dis-evex-prefix.h: Adjust 0F7E entry.
+       * i386-dis-evex-w.h: Adjust 0F7E, 0F7F, 0FD6, and 0F3A21
+       entries.
+
+2021-03-10  Jan Beulich  <jbeulich@suse.com>
+
+       * opcodes/i386-dis.c (EVEX_LEN_0F3A00_W_1, EVEX_LEN_0F3A01_W_1):
+       Rename to EVEX_LEN_0F3A00 and EVEX_LEN_0F3A01 respectively.
+       EVEX_W_0F3A00, EVEX_W_0F3A01): Delete.
+       * i386-dis-evex.h (evex_table): Adjust opcode 0F3A00 and 0F3A01
+       entries.
+       * i386-dis-evex-len.h (evex_len_table): Likewise.
+       * i386-dis-evex-w.h: Remove opcode 0F3A00 and 0F3A01 entries.
+
+2021-03-10  Jan Beulich  <jbeulich@suse.com>
+
+       * opcodes/i386-dis.c (REG_EVEX_0F38C6, REG_EVEX_0F38C7,
+       MOD_EVEX_0F381A_W_0, MOD_EVEX_0F381A_W_1, MOD_EVEX_0F381B_W_0,
+       MOD_EVEX_0F381B_W_1, MOD_EVEX_0F385A_W_0, MOD_EVEX_0F385A_W_1,
+       MOD_EVEX_0F385B_W_0, MOD_EVEX_0F385B_W_1,
+       MOD_EVEX_0F38C6_REG_1, MOD_EVEX_0F38C6_REG_2,
+       MOD_EVEX_0F38C6_REG_5, MOD_EVEX_0F38C6_REG_6,
+       MOD_EVEX_0F38C7_REG_1, MOD_EVEX_0F38C7_REG_2,
+       MOD_EVEX_0F38C7_REG_5, MOD_EVEX_0F38C7_REG_6
+       EVEX_LEN_0F3819_W_0, EVEX_LEN_0F3819_W_1,
+       EVEX_LEN_0F381A_W_0_M_0, EVEX_LEN_0F381A_W_1_M_0,
+       EVEX_LEN_0F381B_W_0_M_0, EVEX_LEN_0F381B_W_1_M_0,
+       EVEX_LEN_0F385A_W_0_M_0, EVEX_LEN_0F385A_W_1_M_0,
+       EVEX_LEN_0F385B_W_0_M_0, EVEX_LEN_0F385B_W_1_M_0,
+       EVEX_LEN_0F38C6_R_1_M_0, EVEX_LEN_0F38C6_R_2_M_0,
+       EVEX_LEN_0F38C6_R_5_M_0, EVEX_LEN_0F38C6_R_6_M_0,
+       EVEX_LEN_0F38C7_R_1_M_0_W_0, EVEX_LEN_0F38C7_R_1_M_0_W_1,
+       EVEX_LEN_0F38C7_R_2_M_0_W_0, EVEX_LEN_0F38C7_R_2_M_0_W_1,
+       EVEX_LEN_0F38C7_R_5_M_0_W_0, EVEX_LEN_0F38C7_R_5_M_0_W_1,
+       EVEX_LEN_0F38C7_R_6_M_0_W_0, EVEX_LEN_0F38C7_R_6_M_0_W_1,
+       EVEX_LEN_0F3A18_W_0, EVEX_LEN_0F3A18_W_1, EVEX_LEN_0F3A19_W_0,
+       EVEX_LEN_0F3A19_W_1, EVEX_LEN_0F3A1A_W_0, EVEX_LEN_0F3A1A_W_1,
+       EVEX_LEN_0F3A1B_W_0, EVEX_LEN_0F3A1B_W_1, EVEX_LEN_0F3A23_W_0,
+       EVEX_LEN_0F3A23_W_1, EVEX_LEN_0F3A38_W_0, EVEX_LEN_0F3A38_W_1,
+       EVEX_LEN_0F3A39_W_0, EVEX_LEN_0F3A39_W_1, EVEX_LEN_0F3A3A_W_0,
+       EVEX_LEN_0F3A3A_W_1, EVEX_LEN_0F3A3B_W_0, EVEX_LEN_0F3A3B_W_1,
+       EVEX_LEN_0F3A43_W_0, EVEX_LEN_0F3A43_W_1 EVEX_W_0F3819,
+       EVEX_W_0F381A, EVEX_W_0F381B, EVEX_W_0F385A, EVEX_W_0F385B,
+       EVEX_W_0F38C7_R_1_M_0, EVEX_W_0F38C7_R_2_M_0,
+       EVEX_W_0F38C7_R_5_M_0, EVEX_W_0F38C7_R_6_M_0,
+       EVEX_W_0F3A18, EVEX_W_0F3A19, EVEX_W_0F3A1A, EVEX_W_0F3A1B,
+       EVEX_W_0F3A23, EVEX_W_0F3A38, EVEX_W_0F3A39, EVEX_W_0F3A3A,
+       EVEX_W_0F3A3B, EVEX_W_0F3A43): Delete.
+       REG_EVEX_0F38C6_M_0_L_2, REG_EVEX_0F38C7_M_0_L_2_W_0,
+       REG_EVEX_0F38C7_M_0_L_2_W_1, MOD_EVEX_0F381A,
+       MOD_EVEX_0F381B, MOD_EVEX_0F385A, MOD_EVEX_0F385B,
+       MOD_EVEX_0F38C6, MOD_EVEX_0F38C7 EVEX_LEN_0F3819,
+       EVEX_LEN_0F381A_M_0, EVEX_LEN_0F381B_M_0,
+       EVEX_LEN_0F385A_M_0, EVEX_LEN_0F385B_M_0,
+       EVEX_LEN_0F38C6_M_0, EVEX_LEN_0F38C7_M_0,
+       EVEX_LEN_0F3A18, EVEX_LEN_0F3A19, EVEX_LEN_0F3A1A,
+       EVEX_LEN_0F3A1B, EVEX_LEN_0F3A23, EVEX_LEN_0F3A38,
+       EVEX_LEN_0F3A39, EVEX_LEN_0F3A3A, EVEX_LEN_0F3A3B,
+       EVEX_LEN_0F3A43, EVEX_W_0F3819_L_n, EVEX_W_0F381A_M_0_L_n,
+       EVEX_W_0F381B_M_0_L_2, EVEX_W_0F385A_M_0_L_n,
+       EVEX_W_0F385B_M_0_L_2, EVEX_W_0F38C7_M_0_L_2,
+       EVEX_W_0F3A18_L_n, EVEX_W_0F3A19_L_n, EVEX_W_0F3A1A_L_2,
+       EVEX_W_0F3A1B_L_2, EVEX_W_0F3A23_L_n, EVEX_W_0F3A38_L_n,
+       EVEX_W_0F3A39_L_n, EVEX_W_0F3A3A_L_2, EVEX_W_0F3A3B_L_2,
+       EVEX_W_0F3A43_L_n): New.
+       * i386-dis-evex.h (evex_table): Adjust opcode 0F3819, 0F381A,
+       0F381B, 0F385A, 0F385B, 0F38C7, 0F3A18, 0F3A19, 0F3A1A, 0F3A1B,
+       0F3A23, 0F3A38, 0F3A39, 0F3A3A, 0F3A3B, and 0F3A43 entries.
+       * i386-dis-evex-len.h (evex_len_table): Link to vex_w_table[]
+       for opcodes 0F3819, 0F381A, 0F381B, 0F385A, 0F385B, 0F38C7,
+       0F3A18, 0F3A19, 0F3A1A, 0F3A1B, 0F3A23, 0F3A38, 0F3A39, 0F3A3A,
+       0F3A3B, and 0F3A43. Link to reg_table[] for opcodes 0F38C6.
+       * i386-dis-evex-mod.h: Adjust opcode 0F381A, 0F381B, 0F385A,
+       0F385B, 0F38C6, and 0F38C7 entries.
+       * i386-dis-evex-reg.h: No longer link to mod_table[] for opcodes
+       0F38C6 and 0F38C7.
+       * i386-dis-evex-w.h: No longer link to evex_len_table[] for
+       opcodes 0F3819, 0F38C7, 0F3A18, 0F3A19, 0F3A1A, 0F3A1B, 0F3A23,
+       0F3A38, 0F3A39, 0F3A3A, 0F3A3B, and 0F3A43. No longer link to
+       evex_len_table[] for opcodes 0F381A, 0F381B, 0F385A, and 0F385B.
+
+2021-03-10  Jan Beulich  <jbeulich@suse.com>
+
+       * opcodes/i386-dis.c (MOD_VEX_W_0_0F41_P_0_LEN_1,
+       MOD_VEX_W_1_0F41_P_0_LEN_1, MOD_VEX_W_0_0F41_P_2_LEN_1,
+       MOD_VEX_W_1_0F41_P_2_LEN_1, MOD_VEX_W_0_0F42_P_0_LEN_1,
+       MOD_VEX_W_1_0F42_P_0_LEN_1, MOD_VEX_W_0_0F42_P_2_LEN_1,
+       MOD_VEX_W_1_0F42_P_2_LEN_1, MOD_VEX_W_0_0F44_P_0_LEN_1,
+       MOD_VEX_W_1_0F44_P_0_LEN_1, MOD_VEX_W_0_0F44_P_2_LEN_1,
+       MOD_VEX_W_1_0F44_P_2_LEN_1, MOD_VEX_W_0_0F45_P_0_LEN_1,
+       MOD_VEX_W_1_0F45_P_0_LEN_1, MOD_VEX_W_0_0F45_P_2_LEN_1,
+       MOD_VEX_W_1_0F45_P_2_LEN_1, MOD_VEX_W_0_0F46_P_0_LEN_1,
+       MOD_VEX_W_1_0F46_P_0_LEN_1, MOD_VEX_W_0_0F46_P_2_LEN_1,
+       MOD_VEX_W_1_0F46_P_2_LEN_1, MOD_VEX_W_0_0F47_P_0_LEN_1,
+       MOD_VEX_W_1_0F47_P_0_LEN_1, MOD_VEX_W_0_0F47_P_2_LEN_1,
+       MOD_VEX_W_1_0F47_P_2_LEN_1, MOD_VEX_W_0_0F4A_P_0_LEN_1,
+       MOD_VEX_W_1_0F4A_P_0_LEN_1, MOD_VEX_W_0_0F4A_P_2_LEN_1,
+       MOD_VEX_W_1_0F4A_P_2_LEN_1, MOD_VEX_W_0_0F4B_P_0_LEN_1,
+       MOD_VEX_W_1_0F4B_P_0_LEN_1, MOD_VEX_W_0_0F4B_P_2_LEN_1,
+       MOD_VEX_W_0_0F91_P_0_LEN_0, MOD_VEX_W_1_0F91_P_0_LEN_0,
+       MOD_VEX_W_0_0F91_P_2_LEN_0, MOD_VEX_W_1_0F91_P_2_LEN_0,
+       MOD_VEX_W_0_0F92_P_0_LEN_0, MOD_VEX_W_0_0F92_P_2_LEN_0,
+       MOD_VEX_0F92_P_3_LEN_0, MOD_VEX_W_0_0F93_P_0_LEN_0,
+       MOD_VEX_W_0_0F93_P_2_LEN_0, MOD_VEX_0F93_P_3_LEN_0,
+       MOD_VEX_W_0_0F98_P_0_LEN_0, MOD_VEX_W_1_0F98_P_0_LEN_0,
+       MOD_VEX_W_0_0F98_P_2_LEN_0, MOD_VEX_W_1_0F98_P_2_LEN_0,
+       MOD_VEX_W_0_0F99_P_0_LEN_0, MOD_VEX_W_1_0F99_P_0_LEN_0,
+       MOD_VEX_W_0_0F99_P_2_LEN_0, MOD_VEX_W_1_0F99_P_2_LEN_0,
+       PREFIX_VEX_0F41, PREFIX_VEX_0F42, PREFIX_VEX_0F44,
+       PREFIX_VEX_0F45, PREFIX_VEX_0F46, PREFIX_VEX_0F47,
+       PREFIX_VEX_0F4A, PREFIX_VEX_0F4B, PREFIX_VEX_0F90,
+       PREFIX_VEX_0F91, PREFIX_VEX_0F92, PREFIX_VEX_0F93,
+       PREFIX_VEX_0F98, PREFIX_VEX_0F99, VEX_LEN_0F41_P_0,
+       VEX_LEN_0F41_P_2, VEX_LEN_0F42_P_0, VEX_LEN_0F42_P_2,
+       VEX_LEN_0F44_P_0, VEX_LEN_0F44_P_2, VEX_LEN_0F45_P_0,
+       VEX_LEN_0F45_P_2, VEX_LEN_0F46_P_0, VEX_LEN_0F46_P_2,
+       VEX_LEN_0F47_P_0, VEX_LEN_0F47_P_2, VEX_LEN_0F4A_P_0,
+       VEX_LEN_0F4A_P_2, VEX_LEN_0F4B_P_0, VEX_LEN_0F4B_P_2,
+       VEX_LEN_0F90_P_0, VEX_LEN_0F90_P_2, VEX_LEN_0F91_P_0,
+       VEX_LEN_0F91_P_2, VEX_LEN_0F92_P_0, VEX_LEN_0F92_P_2,
+       VEX_LEN_0F92_P_3, VEX_LEN_0F93_P_0, VEX_LEN_0F93_P_2,
+       VEX_LEN_0F93_P_3, VEX_LEN_0F98_P_0, VEX_LEN_0F98_P_2,
+       VEX_LEN_0F99_P_0, VEX_LEN_0F99_P_2, VEX_W_0F41_P_0_LEN_1,
+       VEX_W_0F41_P_2_LEN_1, VEX_W_0F42_P_0_LEN_1,
+       VEX_W_0F42_P_2_LEN_1, VEX_W_0F44_P_0_LEN_0,
+       VEX_W_0F44_P_2_LEN_0, VEX_W_0F45_P_0_LEN_1,
+       VEX_W_0F45_P_2_LEN_1, VEX_W_0F46_P_0_LEN_1,
+       VEX_W_0F46_P_2_LEN_1, VEX_W_0F47_P_0_LEN_1,
+       VEX_W_0F47_P_2_LEN_1, VEX_W_0F4A_P_0_LEN_1,
+       VEX_W_0F4A_P_2_LEN_1, VEX_W_0F4B_P_0_LEN_1,
+       VEX_W_0F4B_P_2_LEN_1, VEX_W_0F90_P_0_LEN_0,
+       VEX_W_0F90_P_2_LEN_0, VEX_W_0F91_P_0_LEN_0,
+       VEX_W_0F91_P_2_LEN_0, VEX_W_0F92_P_0_LEN_0,
+       VEX_W_0F92_P_2_LEN_0, VEX_W_0F93_P_0_LEN_0,
+       VEX_W_0F93_P_2_LEN_0, VEX_W_0F98_P_0_LEN_0,
+       VEX_W_0F98_P_2_LEN_0, VEX_W_0F99_P_0_LEN_0,
+       VEX_W_0F99_P_2_LEN_0): Delete.
+       MOD_VEX_0F41_L_1, MOD_VEX_0F42_L_1, MOD_VEX_0F44_L_0,
+       MOD_VEX_0F45_L_1, MOD_VEX_0F46_L_1, MOD_VEX_0F47_L_1,
+       MOD_VEX_0F4A_L_1, MOD_VEX_0F4B_L_1, MOD_VEX_0F91_L_0,
+       MOD_VEX_0F92_L_0, MOD_VEX_0F93_L_0, MOD_VEX_0F98_L_0,
+       MOD_VEX_0F99_L_0, PREFIX_VEX_0F41_L_1_M_1_W_0,
+       PREFIX_VEX_0F41_L_1_M_1_W_1, PREFIX_VEX_0F42_L_1_M_1_W_0,
+       PREFIX_VEX_0F42_L_1_M_1_W_1, PREFIX_VEX_0F44_L_0_M_1_W_0,
+       PREFIX_VEX_0F44_L_0_M_1_W_1, PREFIX_VEX_0F45_L_1_M_1_W_0,
+       PREFIX_VEX_0F45_L_1_M_1_W_1, PREFIX_VEX_0F46_L_1_M_1_W_0,
+       PREFIX_VEX_0F46_L_1_M_1_W_1, PREFIX_VEX_0F47_L_1_M_1_W_0,
+       PREFIX_VEX_0F47_L_1_M_1_W_1, PREFIX_VEX_0F4A_L_1_M_1_W_0,
+       PREFIX_VEX_0F4A_L_1_M_1_W_1, PREFIX_VEX_0F4B_L_1_M_1_W_0,
+       PREFIX_VEX_0F4B_L_1_M_1_W_1, PREFIX_VEX_0F90_L_0_W_0,
+       PREFIX_VEX_0F90_L_0_W_1, PREFIX_VEX_0F91_L_0_M_0_W_0,
+       PREFIX_VEX_0F91_L_0_M_0_W_1, PREFIX_VEX_0F92_L_0_M_1_W_0,
+       PREFIX_VEX_0F92_L_0_M_1_W_1, PREFIX_VEX_0F93_L_0_M_1_W_0,
+       PREFIX_VEX_0F93_L_0_M_1_W_1, PREFIX_VEX_0F98_L_0_M_1_W_0,
+       PREFIX_VEX_0F98_L_0_M_1_W_1, PREFIX_VEX_0F99_L_0_M_1_W_0,
+       PREFIX_VEX_0F99_L_0_M_1_W_1, VEX_LEN_0F41, VEX_LEN_0F42,
+       VEX_LEN_0F44, VEX_LEN_0F45, VEX_LEN_0F46, VEX_LEN_0F47,
+       VEX_LEN_0F4A, VEX_LEN_0F4B, VEX_LEN_0F90, VEX_LEN_0F91,
+       VEX_LEN_0F92, VEX_LEN_0F93, VEX_LEN_0F98, VEX_LEN_0F99,
+       VEX_W_0F41_L_1_M_1, VEX_W_0F42_L_1_M_1, VEX_W_0F44_L_0_M_1,
+       VEX_W_0F45_L_1_M_1, VEX_W_0F46_L_1_M_1, VEX_W_0F47_L_1_M_1,
+       VEX_W_0F4A_L_1_M_1, VEX_W_0F4B_L_1_M_1, VEX_W_0F90_L_0,
+       VEX_W_0F91_L_0_M_0, VEX_W_0F92_L_0_M_1, VEX_W_0F93_L_0_M_1,
+       VEX_W_0F98_L_0_M_1, VEX_W_0F99_L_0_M_1): New.
+       (prefix_table): No longer link to vex_len_table[] for opcodes
+       0F41, 0F42, 0F44, 0F45, 0F46, 0F47, 0F4A, 0F4B, 0F90, 0F91,
+       0F92, 0F93, 0F98, and 0F99.
+       (vex_table): Link to vex_len_table[] for opcodes 0F41, 0F42,
+       0F44, 0F45, 0F46, 0F47, 0F4A, 0F4B, 0F90, 0F91, 0F92, 0F93,
+       0F98, and 0F99.
+       (vex_len_table): Link to mod_table[] for opcodes 0F41, 0F42,
+       0F44, 0F45, 0F46, 0F47, 0F4A, 0F4B, 0F90, 0F91, 0F92, 0F93,
+       0F98, and 0F99.
+       (vex_w_table): Link to prefix_table[] for opcodes 0F41, 0F42,
+       0F44, 0F45, 0F46, 0F47, 0F4A, 0F4B, 0F90, 0F91, 0F92, 0F93,
+       0F98, and 0F99.
+       (mod_table): Link to vex_w_table[] for opcodes 0F41, 0F42,
+       0F44, 0F45, 0F46, 0F47, 0F4A, 0F4B, 0F90, 0F91, 0F92, 0F93,
+       0F98, and 0F99.
+
+2021-03-10  Jan Beulich  <jbeulich@suse.com>
+
+       * opcodes/i386-dis.c (VEX_REG_0F71, VEX_REG_0F72, VEX_REG_0F73):
+       Rename to REG_VEX_0F71_M_0, REG_VEX_0F72_M_0, and
+       REG_VEX_0F73_M_0 respectively.
+       (MOD_VEX_0F71_REG_2, MOD_VEX_0F71_REG_4, MOD_VEX_0F71_REG_6,
+       MOD_VEX_0F72_REG_2, MOD_VEX_0F72_REG_4, MOD_VEX_0F72_REG_6,
+       MOD_VEX_0F73_REG_2, MOD_VEX_0F73_REG_3, MOD_VEX_0F73_REG_6,
+       MOD_VEX_0F73_REG_7): Delete.
+       (MOD_VEX_0F71, MOD_VEX_0F72, MOD_VEX_0F73): New.
+       (PREFIX_VEX_0F38F5, PREFIX_VEX_0F38F6, PREFIX_VEX_0F38F7,
+       PREFIX_VEX_0F3AF0): Rename to PREFIX_VEX_0F38F5_L_0,
+       PREFIX_VEX_0F38F6_L_0, PREFIX_VEX_0F38F7_L_0,
+       PREFIX_VEX_0F3AF0_L_0 respectively.
+       (VEX_LEN_0F38F3_R_1, VEX_LEN_0F38F3_R_2, VEX_LEN_0F38F3_R_3,
+       VEX_LEN_0F38F5_P_0, VEX_LEN_0F38F5_P_1, VEX_LEN_0F38F5_P_3,
+       VEX_LEN_0F38F6_P_3, VEX_LEN_0F38F7_P_0, VEX_LEN_0F38F7_P_1,
+       VEX_LEN_0F38F7_P_2, VEX_LEN_0F38F7_P_3): Delete.
+       (VEX_LEN_0F38F3, VEX_LEN_0F38F5, VEX_LEN_0F38F6,
+       VEX_LEN_0F38F7): New.
+       (VEX_LEN_0F3AF0_P_3): Rename to VEX_LEN_0F3AF0.
+       (reg_table): No longer link to mod_table[] for VEX opcodes 0F71,
+       0F72, and 0F73. No longer link to vex_len_table[] for opcode
+       0F38F3.
+       (prefix_table): No longer link to vex_len_table[] for opcodes
+       0F38F5, 0F38F6, 0F38F7, and 0F3AF0.
+       (vex_table): Link to mod_table[] for opcodes 0F71, 0F72, and
+       0F73. Link to vex_len_table[] for opcodes 0F38F3, 0F38F5,
+       0F38F6, 0F38F7, and 0F3AF0.
+       (vex_len_table): Link to reg_table[] for opcode 0F38F3. Link to
+       prefix_table[] for opcodes 0F38F5, 0F38F6, 0F38F7, and 0F3AF0.
+       (mod_table): Link to reg_table[] for VEX opcodes 0F71, 0F72, and
+       0F73.
+
+2021-03-10  Jan Beulich  <jbeulich@suse.com>
+
+       * opcodes/i386-dis.c (REG_0F71, REG_0F72, REG_0F73): Rename to
+       REG_0F71_MOD_0, REG_0F72_MOD_0, and REG_0F73_MOD_0 respectively.
+       (MOD_0F71_REG_2, MOD_0F71_REG_4, MOD_0F71_REG_6, MOD_0F72_REG_2,
+       MOD_0F72_REG_4, MOD_0F72_REG_6, MOD_0F73_REG_2, MOD_0F73_REG_3,
+       MOD_0F73_REG_6, MOD_0F73_REG_7): Delete.
+       (MOD_0F71, MOD_0F72, MOD_0F73): New.
+       (dis386_twobyte): Link to mod_table[] for opcodes 71, 72, and
+       73.
+       (reg_table): No longer link to mod_table[] for opcodes 0F71,
+       0F72, and 0F73.
+       (mod_table): Link to reg_table[] for opcodes 0F71, 0F72, and
+       0F73.
+
+2021-03-10  Jan Beulich  <jbeulich@suse.com>
+
+       * opcodes/i386-dis.c (MOD_0F18_REG_4, MOD_0F18_REG_5,
+       MOD_0F18_REG_6, MOD_0F18_REG_7): Delete.
+       (reg_table): Don't link to mod_table[] where not needed. Add
+       PREFIX_IGNORED to nop entries.
+       (prefix_table): Replace PREFIX_OPCODE in nop entries.
+       (mod_table): Add nop entries next to prefetch ones. Drop
+       MOD_0F18_REG_4, MOD_0F18_REG_5, MOD_0F18_REG_6, and
+       MOD_0F18_REG_7 entries. Add PREFIX_IGNORED to nop entries.
+       (rm_table): Add PREFIX_IGNORED to nop entries. Drop
+       PREFIX_OPCODE from endbr* entries.
+       (get_valid_dis386): Also consider entry's name when zapping
+       vindex.
+       (print_insn): Handle PREFIX_IGNORED.
+
 2021-03-09  Jan Beulich  <jbeulich@suse.com>
 
        * opcodes/i386-gen.c (opcode_modifiers): Delete NoTrackPrefixOk,
This page took 0.026437 seconds and 4 git commands to generate.