2011-07-24 Chao-ying Fu Maciej W. Rozycki * micromips-opc.c: New file. * mips-dis.c (micromips_to_32_reg_b_map): New array. (micromips_to_32_reg_c_map, micromips_to_32_reg_d_map): Likewise. (micromips_to_32_reg_e_map, micromips_to_32_reg_f_map): Likewise. (micromips_to_32_reg_g_map, micromips_to_32_reg_l_map): Likewise. (micromips_to_32_reg_q_map): Likewise. (micromips_imm_b_map, micromips_imm_c_map): Likewise. (micromips_ase): New variable. (is_micromips): New function. (set_default_mips_dis_options): Handle microMIPS ASE. (print_insn_micromips): New function. (is_compressed_mode_p): Likewise. (_print_insn_mips): Handle microMIPS instructions. * Makefile.am (CFILES): Add micromips-opc.c. * configure.in (bfd_mips_arch): Add micromips-opc.lo. * Makefile.in: Regenerate. * configure: Regenerate. * mips-dis.c (micromips_to_32_reg_h_map): New variable. (micromips_to_32_reg_i_map): Likewise. (micromips_to_32_reg_m_map): Likewise. (micromips_to_32_reg_n_map): New macro. 2011-07-24 Maciej W. Rozycki * mips-opc.c (NODS): New macro. (TRAP): Adjust for the rename of INSN_TRAP to INSN_NO_DELAY_SLOT. (DSP_VOLA): Likewise. (mips_builtin_opcodes): Add NODS annotation to "deret" and "eret". Replace INSN_SYNC with NODS throughout. Use NODS in place of TRAP for "wait", "waiti" and "yield". * mips16-opc.c (NODS): New macro. (TRAP): Adjust for the rename of INSN_TRAP to INSN_NO_DELAY_SLOT. (mips16_opcodes): Use NODS in place of TRAP for "jalrc", "jrc", "restore" and "save". 2011-07-22 H.J. Lu * configure.in: Handle bfd_k1om_arch. * configure: Regenerated. * disassemble.c (disassembler): Handle bfd_k1om_arch. * i386-dis.c (print_insn): Handle bfd_mach_k1om and bfd_mach_k1om_intel_syntax. * i386-gen.c (cpu_flag_init): Set CPU_UNKNOWN_FLAGS to ~(CpuL1OM|CpuK1OM). Add CPU_K1OM_FLAGS. (cpu_flags): Add CpuK1OM. * i386-opc.h (CpuK1OM): New. (i386_cpu_flags): Add cpuk1om. * i386-init.h: Regenerated. * i386-tbl.h: Likewise. 2011-07-12 Nick Clifton * arm-dis.c (print_insn_arm): Revert previous, undocumented, accidental change. 2011-07-01 Nick Clifton PR binutils/12329 * avr-dis.c (avr_operand): Fix disassembly of ELPM, LPM and SPM insns using post-increment addressing. 2011-06-30 H.J. Lu * i386-dis.c (vex_len_table): Update rorxS. 2011-06-30 H.J. Lu AVX Programming Reference (June, 2011) * i386-dis.c (vex_len_table): Correct rorxS. * i386-opc.tbl: Correct rorx. * i386-tbl.h: Regenerated. 2011-06-29 H.J. Lu * tilegx-opc.c (find_opcode): Replace "index" with "i". * tilepro-opc.c (find_opcode): Likewise. 2011-06-29 Richard Sandiford * mips16-opc.c (jalrc, jrc): Move earlier in file. 2011-06-21 H.J. Lu * i386-dis.c (prefix_table): Re-indent PREFIX_VEX_0F388C and PREFIX_VEX_0F388E. 2011-06-17 Andreas Schwab * Makefile.am (MAINTAINERCLEANFILES): Move s390-opc.tab ... (MOSTLYCLEANFILES): ... here. * Makefile.in: Regenerate. 2011-06-14 Alan Modra * Makefile.in: Regenerate. 2011-06-13 Walter Lee * Makefile.am (TARGET_LIBOPCODES_CFILES): Add tilegx-dis.c, tilegx-opc.c, tilepro-dis.c, and tilepro-opc.c. * Makefile.in: Regenerate. * configure.in: Handle bfd_tilegx_arch and bfd_tilepro_arch. * configure: Regenerate. * disassemble.c (disassembler): Add ARCH_tilegx and ARCH_tilepro. * po/POTFILES.in: Regenerate. * tilegx-dis.c: New file. * tilegx-opc.c: New file. * tilepro-dis.c: New file. * tilepro-opc.c: New file. 2011-06-10 H.J. Lu AVX Programming Reference (June, 2011) * i386-dis.c (XMGatherQ): New. * i386-dis.c (EXxmm_mb): New. (EXxmm_mb): Likewise. (EXxmm_mw): Likewise. (EXxmm_md): Likewise. (EXxmm_mq): Likewise. (EXxmmdw): Likewise. (EXxmmqd): Likewise. (VexGatherQ): Likewise. (MVexVSIBDWpX): Likewise. (MVexVSIBQWpX): Likewise. (xmm_mb_mode): Likewise. (xmm_mw_mode): Likewise. (xmm_md_mode): Likewise. (xmm_mq_mode): Likewise. (xmmdw_mode): Likewise. (xmmqd_mode): Likewise. (ymmxmm_mode): Likewise. (vex_vsib_d_w_dq_mode): Likewise. (vex_vsib_q_w_dq_mode): Likewise. (MOD_VEX_0F385A_PREFIX_2): Likewise. (MOD_VEX_0F388C_PREFIX_2): Likewise. (MOD_VEX_0F388E_PREFIX_2): Likewise. (PREFIX_0F3882): Likewise. (PREFIX_VEX_0F3816): Likewise. (PREFIX_VEX_0F3836): Likewise. (PREFIX_VEX_0F3845): Likewise. (PREFIX_VEX_0F3846): Likewise. (PREFIX_VEX_0F3847): Likewise. (PREFIX_VEX_0F3858): Likewise. (PREFIX_VEX_0F3859): Likewise. (PREFIX_VEX_0F385A): Likewise. (PREFIX_VEX_0F3878): Likewise. (PREFIX_VEX_0F3879): Likewise. (PREFIX_VEX_0F388C): Likewise. (PREFIX_VEX_0F388E): Likewise. (PREFIX_VEX_0F3890..PREFIX_VEX_0F3893): Likewise. (PREFIX_VEX_0F38F5): Likewise. (PREFIX_VEX_0F38F6): Likewise. (PREFIX_VEX_0F3A00): Likewise. (PREFIX_VEX_0F3A01): Likewise. (PREFIX_VEX_0F3A02): Likewise. (PREFIX_VEX_0F3A38): Likewise. (PREFIX_VEX_0F3A39): Likewise. (PREFIX_VEX_0F3A46): Likewise. (PREFIX_VEX_0F3AF0): Likewise. (VEX_LEN_0F3816_P_2): Likewise. (VEX_LEN_0F3819_P_2): Likewise. (VEX_LEN_0F3836_P_2): Likewise. (VEX_LEN_0F385A_P_2_M_0): Likewise. (VEX_LEN_0F38F5_P_0): Likewise. (VEX_LEN_0F38F5_P_1): Likewise. (VEX_LEN_0F38F5_P_3): Likewise. (VEX_LEN_0F38F6_P_3): Likewise. (VEX_LEN_0F38F7_P_1): Likewise. (VEX_LEN_0F38F7_P_2): Likewise. (VEX_LEN_0F38F7_P_3): Likewise. (VEX_LEN_0F3A00_P_2): Likewise. (VEX_LEN_0F3A01_P_2): Likewise. (VEX_LEN_0F3A38_P_2): Likewise. (VEX_LEN_0F3A39_P_2): Likewise. (VEX_LEN_0F3A46_P_2): Likewise. (VEX_LEN_0F3AF0_P_3): Likewise. (VEX_W_0F3816_P_2): Likewise. (VEX_W_0F3818_P_2): Likewise. (VEX_W_0F3819_P_2): Likewise. (VEX_W_0F3836_P_2): Likewise. (VEX_W_0F3846_P_2): Likewise. (VEX_W_0F3858_P_2): Likewise. (VEX_W_0F3859_P_2): Likewise. (VEX_W_0F385A_P_2_M_0): Likewise. (VEX_W_0F3878_P_2): Likewise. (VEX_W_0F3879_P_2): Likewise. (VEX_W_0F3A00_P_2): Likewise. (VEX_W_0F3A01_P_2): Likewise. (VEX_W_0F3A02_P_2): Likewise. (VEX_W_0F3A38_P_2): Likewise. (VEX_W_0F3A39_P_2): Likewise. (VEX_W_0F3A46_P_2): Likewise. (MOD_VEX_0F3818_PREFIX_2): Removed. (MOD_VEX_0F3819_PREFIX_2): Likewise. (VEX_LEN_0F60_P_2..VEX_LEN_0F6D_P_2): Likewise. (VEX_LEN_0F70_P_1..VEX_LEN_0F76_P_2): Likewise. (VEX_LEN_0FD1_P_2..VEX_LEN_0FD5_P_2): Likewise. (VEX_LEN_0FD7_P_2_M_1..VEX_LEN_0F3819_P_2_M_0): Likewise. (VEX_LEN_0F381C_P_2..VEX_LEN_0F3840_P_2): Likewise. (VEX_LEN_0F3A0E_P_2): Likewise. (VEX_LEN_0F3A0F_P_2): Likewise. (VEX_LEN_0F3A42_P_2): Likewise. (VEX_LEN_0F3A4C_P_2): Likewise. (VEX_W_0F3818_P_2_M_0): Likewise. (VEX_W_0F3819_P_2_M_0): Likewise. (prefix_table): Updated. (three_byte_table): Likewise. (vex_table): Likewise. (vex_len_table): Likewise. (vex_w_table): Likewise. (mod_table): Likewise. (putop): Handle "LW". (intel_operand_size): Handle xmm_mb_mode, xmm_mw_mode, xmm_md_mode, xmm_mq_mode, xmmdw_mode, xmmqd_mode, ymmxmm_mode, vex_vsib_d_w_dq_mode, vex_vsib_q_w_dq_mode. (OP_EX): Likewise. (OP_E_memory): Handle vex_vsib_d_w_dq_mode and vex_vsib_q_w_dq_mode. (OP_XMM): Handle vex_vsib_q_w_dq_mode. (OP_VEX): Likewise. * i386-gen.c (cpu_flag_init): Add CpuAVX2 to CPU_ANY_SSE_FLAGS and CPU_ANY_AVX_FLAGS. Add CPU_BMI2_FLAGS, CPU_LZCNT_FLAGS, CPU_INVPCID_FLAGS and CPU_AVX2_FLAGS. (cpu_flags): Add CpuAVX2, CpuBMI2, CpuLZCNT and CpuINVPCID. (opcode_modifiers): Add VecSIB. * i386-opc.h (CpuAVX2): New. (CpuBMI2): Likewise. (CpuLZCNT): Likewise. (CpuINVPCID): Likewise. (VecSIB128): Likewise. (VecSIB256): Likewise. (VecSIB): Likewise. (i386_cpu_flags): Add cpuavx2, cpubmi2, cpulzcnt and cpuinvpcid. (i386_opcode_modifier): Add vecsib. * i386-opc.tbl: Add invpcid, AVX2 and BMI2 instructions. * i386-init.h: Regenerated. * i386-tbl.h: Likewise. 2011-06-03 Quentin Neill * i386-gen.c (cpu_flag_init): Add CpuF16C to CPU_BDVER2_FLAGS. * i386-init.h: Regenerated. 2011-06-03 Nick Clifton PR binutils/12752 * arm-dis.c (print_insn_coprocessor): Use bfd_vma type for computing address offsets. (print_arm_address): Likewise. (print_insn_arm): Likewise. (print_insn_thumb16): Likewise. (print_insn_thumb32): Likewise. 2011-06-02 Jie Zhang Nathan Sidwell Maciej Rozycki * arm-dis.c (print_insn_coprocessor): Explicitly print #-0 as address offset. (print_arm_address): Likewise. Elide positive #0 appropriately. (print_insn_arm): Likewise. 2011-06-02 Nick Clifton PR gas/12752 * arm-dis.c (print_insn_thumb32): Do not sign extend addresses passed to print_address_func. 2011-06-02 Nick Clifton * arm-dis.c: Fix spelling mistakes. * op/opcodes.pot: Regenerate. 2011-05-24 Andreas Krebbel * s390-opc.c: Replace S390_OPERAND_REG_EVEN with S390_OPERAND_REG_PAIR. Fix INSTR_RRF_0UFEF instruction type. * s390-opc.txt: Fix cxr instruction type. 2011-05-24 Andreas Krebbel * s390-opc.c: Add new instruction types marking register pair operands. * s390-opc.txt: Match instructions having register pair operands to the new instruction types. 2011-05-19 Nick Clifton * v850-opc.c (cmpf.[sd]): Reverse the order of the reg1 and reg2 operands. 2011-05-10 Quentin Neill * i386-gen.c (cpu_flag_init): Add new CPU_BDVER2_FLAGS. * i386-init.h: Regenerated. 2011-04-27 Nick Clifton * po/da.po: Updated Danish translation. 2011-04-26 Anton Blanchard * ppc-opc.c: (powerpc_opcodes): Enable icswx for POWER7. 2011-04-21 DJ Delorie * rx-decode.opc (rx_decode_opcode): Set the syntax for multi-byte NOPs. * rx-decode.c: Regenerate. 2011-04-20 H.J. Lu * i386-init.h: Regenerated. 2011-04-19 Quentin Neill * i386-gen.c (cpu_flag_init): Remove 3dnow and 3dnowa bits from bdver1 flags. 2011-04-13 Nick Clifton * v850-dis.c (disassemble): Always print a closing square brace if an opening square brace was printed. 2011-04-12 Nick Clifton PR binutils/12534 * arm-dis.c (thumb32_opcodes): Add %L suffix to LDRD and STRD insn patterns. (print_insn_thumb32): Handle %L. 2011-04-11 Julian Brown * arm-dis.c (psr_name): Fix typo for BASEPRI_MAX. (print_insn_thumb32): Add APSR bitmask support. 2011-04-07 Paul Carroll * arm-dis.c (print_insn): init vars moved into private_data structure. 2011-03-24 Mike Frysinger * bfin-dis.c (decode_dsp32mac_0): Move MM zeroing down to MAC0 logic. 2011-03-22 Eric B. Weddington * avr-dis.c (avr_operand): Add opcode_str parameter. Check for post-increment to support LPM Z+ instruction. Add support for 'E' constraint for DES instruction. (print_insn_avr): Adjust calls to avr_operand. Rename variable. 2011-03-14 Richard Sandiford * arm-dis.c (get_sym_code_type): Treat STT_GNU_IFUNCs as code. 2011-03-14 Richard Sandiford * arm-dis.c (get_sym_code_type): Don't check for STT_ARM_TFUNC. Use branch types instead. (print_insn): Likewise. 2011-02-28 Maciej W. Rozycki * mips-opc.c (mips_builtin_opcodes): Correct register use annotation of "alnv.ps". 2011-02-28 Maciej W. Rozycki * mips-opc.c (mips_builtin_opcodes): Add "pref" macro. 2011-02-22 Mike Frysinger * bfin-dis.c (OUTS): Remove p NULL check and txt NUL check. 2011-02-22 Mike Frysinger * bfin-dis.c (print_insn_bfin): Change outf->fprintf_func to OUTS. 2011-02-19 Mike Frysinger * bfin-dis.c (saved_state): Mark static. Change a[01]x to ax[] and a[01]w to aw[]. Delete ac0, ac0_copy, ac1, an, aq, av0, av0s, av1, av1s, az, cc, v, v_copy, vs, rnd_mod, v_internal, pc, ticks, insts, exception, end_of_registers, msize, memory, bfd_mach. (CCREG, PCREG, A0XREG, A0WREG, A1XREG, A1WREG, LC0REG, LT0REG, LB0REG, LC1REG, LT1REG, LB1REG): Delete (AXREG, AWREG, LCREG, LTREG, LBREG): Define. (get_allreg): Change to new defines. Fallback to abort(). 2011-02-14 Mike Frysinger * bfin-dis.c: Add whitespace/parenthesis where needed. 2011-02-14 Mike Frysinger * bfin-dis.c (decode_LoopSetup_0): Return when reg is greater than 7. 2011-02-13 Ralf Wildenhues * configure: Regenerate. 2011-02-13 Mike Frysinger * bfin-dis.c (decode_dsp32alu_0): Fix typo with A1 reg. 2011-02-13 Mike Frysinger * bfin-dis.c (decode_dsp32mult_0): Add 1 to dst for mac1. Output dregs only when P is set, and dregs_lo otherwise. 2011-02-13 Mike Frysinger * bfin-dis.c (decode_dsp32alu_0): Delete BYTEOP2M code. 2011-02-12 Mike Frysinger * bfin-dis.c (decode_pseudoDEBUG_0): Add space after PRNT. 2011-02-12 Mike Frysinger * bfin-dis.c (machine_registers): Delete REG_GP. (reg_names): Delete "GP". (decode_allregs): Change REG_GP to REG_LASTREG. 2011-02-12 Mike Frysinger * bfin-dis.c (M_S2RND, M_T, M_W32, M_FU, M_TFU, M_IS, M_ISS2, M_IH, M_IU): Delete. 2011-02-11 Mike Frysinger * bfin-dis.c (reg_names): Add const. (decode_dregs_lo, decode_dregs_hi, decode_dregs, decode_dregs_byte, decode_pregs, decode_iregs, decode_mregs, decode_dpregs, decode_gregs, decode_regs, decode_regs_lo, decode_regs_hi, decode_statbits, decode_counters, decode_allregs): Likewise. 2011-02-09 Michael Snyder * i386-dis.c (OP_J): Parenthesize expression to prevent truncated addresses. (print_insn): Fix indentation off-by-one. 2011-02-01 Nick Clifton * po/da.po: Updated Danish translation. 2011-01-21 Dave Murphy * ppc-opc.c (NON32, NO371): Remove PPC_OPCODE_PPCPS. 2011-01-18 H.J. Lu * i386-dis.c (sIbT): New. (b_T_mode): Likewise. (dis386): Replace sIb with sIbT on "pushT". (x86_64_table): Replace sIb with Ib on "aam" and "aad". (OP_sI): Handle b_T_mode. Properly sign-extend byte. 2011-01-18 Jan Kratochvil * i386-init.h: Regenerated. * i386-tbl.h: Regenerated 2011-01-17 Quentin Neill * i386-dis.c (REG_XOP_TBM_01): New. (REG_XOP_TBM_02): New. (reg_table): Add REG_XOP_TBM_01 and REG_XOP_TBM_02 tables. (xop_table): Redirect to REG_XOP_TBM_01 and REG_XOP_TBM_02 entries, and add bextr instruction. * i386-gen.c (cpu_flag_init): Add CPU_TBM_FLAGS, CpuTBM. (cpu_flags): Add CpuTBM. * i386-opc.h (CpuTBM) New. (i386_cpu_flags): Add bit cputbm. * i386-opc.tbl: Add bextr, blcfill, blci, blcic, blcmsk, blcs, blsfill, blsic, t1mskc, and tzmsk. 2011-01-12 DJ Delorie * rx-dis.c (print_insn_rx): Support RX_Operand_TwoReg. 2011-01-11 Mingjie Xing * mips-dis.c (print_insn_args): Adjust the value to print the real offset for "+c" argument. 2011-01-10 Nick Clifton * po/da.po: Updated Danish translation. 2011-01-05 Nathan Sidwell * arm-dis.c (thumb32_opcodes): BLX must have bit zero clear. 2011-01-04 H.J. Lu * i386-dis.c (REG_VEX_38F3): New. (PREFIX_0FBC): Likewise. (PREFIX_VEX_38F2): Likewise. (PREFIX_VEX_38F3_REG_1): Likewise. (PREFIX_VEX_38F3_REG_2): Likewise. (PREFIX_VEX_38F3_REG_3): Likewise. (PREFIX_VEX_38F7): Likewise. (VEX_LEN_38F2_P_0): Likewise. (VEX_LEN_38F3_R_1_P_0): Likewise. (VEX_LEN_38F3_R_2_P_0): Likewise. (VEX_LEN_38F3_R_3_P_0): Likewise. (VEX_LEN_38F7_P_0): Likewise. (dis386_twobyte): Use PREFIX_0FBC. (reg_table): Add REG_VEX_38F3. (prefix_table): Add PREFIX_0FBC, PREFIX_VEX_38F2, PREFIX_VEX_38F3_REG_1, PREFIX_VEX_38F3_REG_2, PREFIX_VEX_38F3_REG_3 and PREFIX_VEX_38F7. (vex_table): Use PREFIX_VEX_38F2, REG_VEX_38F3 and PREFIX_VEX_38F7. (vex_len_table): Add VEX_LEN_38F2_P_0, VEX_LEN_38F3_R_1_P_0, VEX_LEN_38F3_R_2_P_0, VEX_LEN_38F3_R_3_P_0 and VEX_LEN_38F7_P_0. * i386-gen.c (cpu_flag_init): Add CPU_BMI_FLAGS. (cpu_flags): Add CpuBMI. * i386-opc.h (CpuBMI): New. (i386_cpu_flags): Add cpubmi. * i386-opc.tbl: Add andn, bextr, blsi, blsmsk, blsr and tzcnt. * i386-init.h: Regenerated. * i386-tbl.h: Likewise. 2011-01-04 H.J. Lu * i386-dis.c (VexGdq): New. (OP_VEX): Handle dq_mode. 2011-01-01 H.J. Lu * i386-gen.c (process_copyright): Update copyright to 2011. For older changes see ChangeLog-2010 Local Variables: mode: change-log left-margin: 8 fill-column: 74 version-control: never End: