2011-06-29 Tristan Gingold <gingold@adacore.com>
[binutils.git] / opcodes / ChangeLog
blob158d456309bad1272dc2375ca627e43f7b4ff5bc
1 2011-06-21  H.J. Lu  <hongjiu.lu@intel.com>
3         * i386-dis.c (prefix_table): Re-indent PREFIX_VEX_0F388C and
4         PREFIX_VEX_0F388E.
6 2011-06-17  Andreas Schwab  <schwab@redhat.com>
8         * Makefile.am (MAINTAINERCLEANFILES): Move s390-opc.tab ...
9         (MOSTLYCLEANFILES): ... here.
10         * Makefile.in: Regenerate.
12 2011-06-14  Alan Modra  <amodra@gmail.com>
14         * Makefile.in: Regenerate.
16 2011-06-13  Walter Lee  <walt@tilera.com>
18         * Makefile.am (TARGET_LIBOPCODES_CFILES): Add tilegx-dis.c,
19         tilegx-opc.c, tilepro-dis.c, and tilepro-opc.c.
20         * Makefile.in: Regenerate.
21         * configure.in: Handle bfd_tilegx_arch and bfd_tilepro_arch.
22         * configure: Regenerate.
23         * disassemble.c (disassembler): Add ARCH_tilegx and ARCH_tilepro.
24         * po/POTFILES.in: Regenerate.
25         * tilegx-dis.c: New file.
26         * tilegx-opc.c: New file.
27         * tilepro-dis.c: New file.
28         * tilepro-opc.c: New file.
30 2011-06-10  H.J. Lu  <hongjiu.lu@intel.com>
32         AVX Programming Reference (June, 2011)
33         * i386-dis.c (XMGatherQ): New.
34         * i386-dis.c (EXxmm_mb): New.
35         (EXxmm_mb): Likewise.
36         (EXxmm_mw): Likewise.
37         (EXxmm_md): Likewise.
38         (EXxmm_mq): Likewise.
39         (EXxmmdw): Likewise.
40         (EXxmmqd): Likewise.
41         (VexGatherQ): Likewise.
42         (MVexVSIBDWpX): Likewise.
43         (MVexVSIBQWpX): Likewise.
44         (xmm_mb_mode): Likewise.
45         (xmm_mw_mode): Likewise.
46         (xmm_md_mode): Likewise.
47         (xmm_mq_mode): Likewise.
48         (xmmdw_mode): Likewise.
49         (xmmqd_mode): Likewise.
50         (ymmxmm_mode): Likewise.
51         (vex_vsib_d_w_dq_mode): Likewise.
52         (vex_vsib_q_w_dq_mode): Likewise.
53         (MOD_VEX_0F385A_PREFIX_2): Likewise.
54         (MOD_VEX_0F388C_PREFIX_2): Likewise.
55         (MOD_VEX_0F388E_PREFIX_2): Likewise.
56         (PREFIX_0F3882): Likewise.
57         (PREFIX_VEX_0F3816): Likewise.
58         (PREFIX_VEX_0F3836): Likewise.
59         (PREFIX_VEX_0F3845): Likewise.
60         (PREFIX_VEX_0F3846): Likewise.
61         (PREFIX_VEX_0F3847): Likewise.
62         (PREFIX_VEX_0F3858): Likewise.
63         (PREFIX_VEX_0F3859): Likewise.
64         (PREFIX_VEX_0F385A): Likewise.
65         (PREFIX_VEX_0F3878): Likewise.
66         (PREFIX_VEX_0F3879): Likewise.
67         (PREFIX_VEX_0F388C): Likewise.
68         (PREFIX_VEX_0F388E): Likewise.
69         (PREFIX_VEX_0F3890..PREFIX_VEX_0F3893): Likewise.
70         (PREFIX_VEX_0F38F5): Likewise.
71         (PREFIX_VEX_0F38F6): Likewise.
72         (PREFIX_VEX_0F3A00): Likewise.
73         (PREFIX_VEX_0F3A01): Likewise.
74         (PREFIX_VEX_0F3A02): Likewise.
75         (PREFIX_VEX_0F3A38): Likewise.
76         (PREFIX_VEX_0F3A39): Likewise.
77         (PREFIX_VEX_0F3A46): Likewise.
78         (PREFIX_VEX_0F3AF0): Likewise.
79         (VEX_LEN_0F3816_P_2): Likewise.
80         (VEX_LEN_0F3819_P_2): Likewise.
81         (VEX_LEN_0F3836_P_2): Likewise.
82         (VEX_LEN_0F385A_P_2_M_0): Likewise.
83         (VEX_LEN_0F38F5_P_0): Likewise.
84         (VEX_LEN_0F38F5_P_1): Likewise.
85         (VEX_LEN_0F38F5_P_3): Likewise.
86         (VEX_LEN_0F38F6_P_3): Likewise.
87         (VEX_LEN_0F38F7_P_1): Likewise.
88         (VEX_LEN_0F38F7_P_2): Likewise.
89         (VEX_LEN_0F38F7_P_3): Likewise.
90         (VEX_LEN_0F3A00_P_2): Likewise.
91         (VEX_LEN_0F3A01_P_2): Likewise.
92         (VEX_LEN_0F3A38_P_2): Likewise.
93         (VEX_LEN_0F3A39_P_2): Likewise.
94         (VEX_LEN_0F3A46_P_2): Likewise.
95         (VEX_LEN_0F3AF0_P_3): Likewise.
96         (VEX_W_0F3816_P_2): Likewise.
97         (VEX_W_0F3818_P_2): Likewise.
98         (VEX_W_0F3819_P_2): Likewise.
99         (VEX_W_0F3836_P_2): Likewise.
100         (VEX_W_0F3846_P_2): Likewise.
101         (VEX_W_0F3858_P_2): Likewise.
102         (VEX_W_0F3859_P_2): Likewise.
103         (VEX_W_0F385A_P_2_M_0): Likewise.
104         (VEX_W_0F3878_P_2): Likewise.
105         (VEX_W_0F3879_P_2): Likewise.
106         (VEX_W_0F3A00_P_2): Likewise.
107         (VEX_W_0F3A01_P_2): Likewise.
108         (VEX_W_0F3A02_P_2): Likewise.
109         (VEX_W_0F3A38_P_2): Likewise.
110         (VEX_W_0F3A39_P_2): Likewise.
111         (VEX_W_0F3A46_P_2): Likewise.
112         (MOD_VEX_0F3818_PREFIX_2): Removed.
113         (MOD_VEX_0F3819_PREFIX_2): Likewise.
114         (VEX_LEN_0F60_P_2..VEX_LEN_0F6D_P_2): Likewise.
115         (VEX_LEN_0F70_P_1..VEX_LEN_0F76_P_2): Likewise.
116         (VEX_LEN_0FD1_P_2..VEX_LEN_0FD5_P_2): Likewise.
117         (VEX_LEN_0FD7_P_2_M_1..VEX_LEN_0F3819_P_2_M_0): Likewise.
118         (VEX_LEN_0F381C_P_2..VEX_LEN_0F3840_P_2): Likewise.
119         (VEX_LEN_0F3A0E_P_2): Likewise.
120         (VEX_LEN_0F3A0F_P_2): Likewise.
121         (VEX_LEN_0F3A42_P_2): Likewise.
122         (VEX_LEN_0F3A4C_P_2): Likewise.
123         (VEX_W_0F3818_P_2_M_0): Likewise.
124         (VEX_W_0F3819_P_2_M_0): Likewise.
125         (prefix_table): Updated.
126         (three_byte_table): Likewise.
127         (vex_table): Likewise.
128         (vex_len_table): Likewise.
129         (vex_w_table): Likewise.
130         (mod_table): Likewise.
131         (putop): Handle "LW".
132         (intel_operand_size): Handle xmm_mb_mode, xmm_mw_mode,
133         xmm_md_mode, xmm_mq_mode, xmmdw_mode, xmmqd_mode, ymmxmm_mode,
134         vex_vsib_d_w_dq_mode, vex_vsib_q_w_dq_mode.
135         (OP_EX): Likewise.
136         (OP_E_memory): Handle vex_vsib_d_w_dq_mode and
137         vex_vsib_q_w_dq_mode.
138         (OP_XMM): Handle vex_vsib_q_w_dq_mode.
139         (OP_VEX): Likewise.
141         * i386-gen.c (cpu_flag_init): Add CpuAVX2 to CPU_ANY_SSE_FLAGS
142         and CPU_ANY_AVX_FLAGS.  Add CPU_BMI2_FLAGS, CPU_LZCNT_FLAGS,
143         CPU_INVPCID_FLAGS and CPU_AVX2_FLAGS.
144         (cpu_flags): Add CpuAVX2, CpuBMI2, CpuLZCNT and CpuINVPCID.
145         (opcode_modifiers): Add VecSIB.
147         * i386-opc.h (CpuAVX2): New.
148         (CpuBMI2): Likewise.
149         (CpuLZCNT): Likewise.
150         (CpuINVPCID): Likewise.
151         (VecSIB128): Likewise.
152         (VecSIB256): Likewise.
153         (VecSIB): Likewise.
154         (i386_cpu_flags): Add cpuavx2, cpubmi2, cpulzcnt and cpuinvpcid.
155         (i386_opcode_modifier): Add vecsib.
157         * i386-opc.tbl: Add invpcid, AVX2 and BMI2 instructions.
158         * i386-init.h: Regenerated.
159         * i386-tbl.h: Likewise.
161 2011-06-03  Quentin Neill  <quentin.neill@amd.com>
163         * i386-gen.c (cpu_flag_init): Add CpuF16C to CPU_BDVER2_FLAGS.
164         * i386-init.h: Regenerated.
166 2011-06-03  Nick Clifton  <nickc@redhat.com>
168         PR binutils/12752
169         * arm-dis.c (print_insn_coprocessor): Use bfd_vma type for
170         computing address offsets.
171         (print_arm_address): Likewise.
172         (print_insn_arm): Likewise.
173         (print_insn_thumb16): Likewise.
174         (print_insn_thumb32): Likewise.
176 2011-06-02  Jie Zhang <jie@codesourcery.com>
177             Nathan Sidwell <nathan@codesourcery.com>
178             Maciej Rozycki <macro@codesourcery.com>
180         * arm-dis.c (print_insn_coprocessor): Explicitly print #-0
181         as address offset.
182         (print_arm_address): Likewise. Elide positive #0 appropriately.
183         (print_insn_arm): Likewise.
185 2011-06-02  Nick Clifton  <nickc@redhat.com>
187         PR gas/12752
188         * arm-dis.c (print_insn_thumb32): Do not sign extend  addresses
189         passed to print_address_func.
191 2011-06-02  Nick Clifton  <nickc@redhat.com>
193         * arm-dis.c: Fix spelling mistakes.
194         * op/opcodes.pot: Regenerate.
196 2011-05-24  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
198         * s390-opc.c: Replace S390_OPERAND_REG_EVEN with
199         S390_OPERAND_REG_PAIR.  Fix INSTR_RRF_0UFEF instruction type.
200         * s390-opc.txt: Fix cxr instruction type.
202 2011-05-24  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
204         * s390-opc.c: Add new instruction types marking register pair
205         operands.
206         * s390-opc.txt: Match instructions having register pair operands
207         to the new instruction types.
209 2011-05-19  Nick Clifton  <nickc@redhat.com>
211         * v850-opc.c (cmpf.[sd]): Reverse the order of the reg1 and reg2
212         operands.
214 2011-05-10  Quentin Neill  <quentin.neill@amd.com>
216         * i386-gen.c (cpu_flag_init): Add new CPU_BDVER2_FLAGS.
217         * i386-init.h: Regenerated.
219 2011-04-27  Nick Clifton  <nickc@redhat.com>
221         * po/da.po: Updated Danish translation.
223 2011-04-26  Anton Blanchard  <anton@samba.org>
225         * ppc-opc.c: (powerpc_opcodes): Enable icswx for POWER7.
227 2011-04-21  DJ Delorie  <dj@redhat.com>
229         * rx-decode.opc (rx_decode_opcode): Set the syntax for multi-byte NOPs.
230         * rx-decode.c: Regenerate.
232 2011-04-20  H.J. Lu  <hongjiu.lu@intel.com>
234         * i386-init.h: Regenerated.
236 2011-04-19  Quentin Neill  <quentin.neill@amd.com>
238         * i386-gen.c (cpu_flag_init): Remove 3dnow and 3dnowa bits
239         from bdver1 flags.
241 2011-04-13  Nick Clifton  <nickc@redhat.com>
243         * v850-dis.c (disassemble): Always print a closing square brace if
244         an opening square brace was printed.
246 2011-04-12  Nick Clifton  <nickc@redhat.com>
248         PR binutils/12534
249         * arm-dis.c (thumb32_opcodes): Add %L suffix to LDRD and STRD insn
250         patterns.
251         (print_insn_thumb32): Handle %L.
253 2011-04-11  Julian Brown  <julian@codesourcery.com>
255         * arm-dis.c (psr_name): Fix typo for BASEPRI_MAX.
256         (print_insn_thumb32): Add APSR bitmask support.
258 2011-04-07  Paul Carroll<pcarroll@codesourcery.com>
260         * arm-dis.c (print_insn): init vars moved into private_data structure.
262 2011-03-24  Mike Frysinger  <vapier@gentoo.org>
264         * bfin-dis.c (decode_dsp32mac_0): Move MM zeroing down to MAC0 logic.
266 2011-03-22  Eric B. Weddington  <eric.weddington@atmel.com>
268         * avr-dis.c (avr_operand): Add opcode_str parameter. Check for
269         post-increment to support LPM Z+ instruction. Add support for 'E'
270         constraint for DES instruction.
271         (print_insn_avr): Adjust calls to avr_operand. Rename variable.
273 2011-03-14  Richard Sandiford  <richard.sandiford@linaro.org>
275         * arm-dis.c (get_sym_code_type): Treat STT_GNU_IFUNCs as code.
277 2011-03-14  Richard Sandiford  <richard.sandiford@linaro.org>
279         * arm-dis.c (get_sym_code_type): Don't check for STT_ARM_TFUNC.
280         Use branch types instead.
281         (print_insn): Likewise.
283 2011-02-28  Maciej W. Rozycki  <macro@codesourcery.com>
285         * mips-opc.c (mips_builtin_opcodes): Correct register use
286         annotation of "alnv.ps".
288 2011-02-28  Maciej W. Rozycki  <macro@codesourcery.com>
290         * mips-opc.c (mips_builtin_opcodes): Add "pref" macro.
292 2011-02-22  Mike Frysinger  <vapier@gentoo.org>
294         * bfin-dis.c (OUTS): Remove p NULL check and txt NUL check.
296 2011-02-22  Mike Frysinger  <vapier@gentoo.org>
298         * bfin-dis.c (print_insn_bfin): Change outf->fprintf_func to OUTS.
300 2011-02-19  Mike Frysinger  <vapier@gentoo.org>
302         * bfin-dis.c (saved_state): Mark static.  Change a[01]x to ax[] and
303         a[01]w to aw[].  Delete ac0, ac0_copy, ac1, an, aq, av0, av0s, av1,
304         av1s, az, cc, v, v_copy, vs, rnd_mod, v_internal, pc, ticks, insts,
305         exception, end_of_registers, msize, memory, bfd_mach.
306         (CCREG, PCREG, A0XREG, A0WREG, A1XREG, A1WREG, LC0REG, LT0REG,
307         LB0REG, LC1REG, LT1REG, LB1REG): Delete
308         (AXREG, AWREG, LCREG, LTREG, LBREG): Define.
309         (get_allreg): Change to new defines.  Fallback to abort().
311 2011-02-14  Mike Frysinger  <vapier@gentoo.org>
313         * bfin-dis.c: Add whitespace/parenthesis where needed.
315 2011-02-14  Mike Frysinger  <vapier@gentoo.org>
317         * bfin-dis.c (decode_LoopSetup_0): Return when reg is greater
318         than 7.
320 2011-02-13  Ralf Wildenhues  <Ralf.Wildenhues@gmx.de>
322         * configure: Regenerate.
324 2011-02-13  Mike Frysinger  <vapier@gentoo.org>
326         * bfin-dis.c (decode_dsp32alu_0): Fix typo with A1 reg.
328 2011-02-13  Mike Frysinger  <vapier@gentoo.org>
330         * bfin-dis.c (decode_dsp32mult_0): Add 1 to dst for mac1.  Output
331         dregs only when P is set, and dregs_lo otherwise.
333 2011-02-13  Mike Frysinger  <vapier@gentoo.org>
335         * bfin-dis.c (decode_dsp32alu_0): Delete BYTEOP2M code.
337 2011-02-12  Mike Frysinger  <vapier@gentoo.org>
339         * bfin-dis.c (decode_pseudoDEBUG_0): Add space after PRNT.
341 2011-02-12  Mike Frysinger  <vapier@gentoo.org>
343         * bfin-dis.c (machine_registers): Delete REG_GP.
344         (reg_names): Delete "GP".
345         (decode_allregs): Change REG_GP to REG_LASTREG.
347 2011-02-12  Mike Frysinger  <vapier@gentoo.org>
349         * bfin-dis.c (M_S2RND, M_T, M_W32, M_FU, M_TFU, M_IS, M_ISS2,
350         M_IH, M_IU): Delete.
352 2011-02-11  Mike Frysinger  <vapier@gentoo.org>
354         * bfin-dis.c (reg_names): Add const.
355         (decode_dregs_lo, decode_dregs_hi, decode_dregs, decode_dregs_byte,
356         decode_pregs, decode_iregs, decode_mregs, decode_dpregs, decode_gregs,
357         decode_regs, decode_regs_lo, decode_regs_hi, decode_statbits,
358         decode_counters, decode_allregs): Likewise.
360 2011-02-09  Michael Snyder  <msnyder@vmware.com>
362         * i386-dis.c (OP_J): Parenthesize expression to prevent
363         truncated addresses.
364         (print_insn): Fix indentation off-by-one.
366 2011-02-01  Nick Clifton  <nickc@redhat.com>
368         * po/da.po: Updated Danish translation.
370 2011-01-21  Dave Murphy  <davem@devkitpro.org>
372         * ppc-opc.c (NON32, NO371): Remove PPC_OPCODE_PPCPS.
374 2011-01-18  H.J. Lu  <hongjiu.lu@intel.com>
376         * i386-dis.c (sIbT): New.
377         (b_T_mode): Likewise.
378         (dis386): Replace sIb with sIbT on "pushT".
379         (x86_64_table): Replace sIb with Ib on "aam" and "aad".
380         (OP_sI): Handle b_T_mode.  Properly sign-extend byte.
382 2011-01-18  Jan Kratochvil  <jan.kratochvil@redhat.com>
384         * i386-init.h: Regenerated.
385         * i386-tbl.h: Regenerated
387 2011-01-17  Quentin Neill  <quentin.neill@amd.com>
389         * i386-dis.c (REG_XOP_TBM_01): New.
390         (REG_XOP_TBM_02): New.
391         (reg_table): Add REG_XOP_TBM_01 and REG_XOP_TBM_02 tables.
392         (xop_table): Redirect to REG_XOP_TBM_01 and REG_XOP_TBM_02
393         entries, and add bextr instruction.
395         * i386-gen.c (cpu_flag_init): Add CPU_TBM_FLAGS, CpuTBM.
396         (cpu_flags): Add CpuTBM.
398         * i386-opc.h (CpuTBM) New.
399         (i386_cpu_flags): Add bit cputbm.
401         * i386-opc.tbl: Add bextr, blcfill, blci, blcic, blcmsk,
402         blcs, blsfill, blsic, t1mskc, and tzmsk.
404 2011-01-12  DJ Delorie  <dj@redhat.com>
406         * rx-dis.c (print_insn_rx): Support RX_Operand_TwoReg.
408 2011-01-11  Mingjie Xing  <mingjie.xing@gmail.com>
410         * mips-dis.c (print_insn_args): Adjust the value to print the real
411         offset for "+c" argument.
413 2011-01-10  Nick Clifton  <nickc@redhat.com>
415         * po/da.po: Updated Danish translation.
417 2011-01-05  Nathan Sidwell  <nathan@codesourcery.com>
419         * arm-dis.c (thumb32_opcodes): BLX must have bit zero clear.
421 2011-01-04  H.J. Lu  <hongjiu.lu@intel.com>
423         * i386-dis.c (REG_VEX_38F3): New.
424         (PREFIX_0FBC): Likewise.
425         (PREFIX_VEX_38F2): Likewise.
426         (PREFIX_VEX_38F3_REG_1): Likewise.
427         (PREFIX_VEX_38F3_REG_2): Likewise.
428         (PREFIX_VEX_38F3_REG_3): Likewise.
429         (PREFIX_VEX_38F7): Likewise.
430         (VEX_LEN_38F2_P_0): Likewise.
431         (VEX_LEN_38F3_R_1_P_0): Likewise.
432         (VEX_LEN_38F3_R_2_P_0): Likewise.
433         (VEX_LEN_38F3_R_3_P_0): Likewise.
434         (VEX_LEN_38F7_P_0): Likewise.
435         (dis386_twobyte): Use PREFIX_0FBC.
436         (reg_table): Add REG_VEX_38F3.
437         (prefix_table): Add PREFIX_0FBC, PREFIX_VEX_38F2,
438         PREFIX_VEX_38F3_REG_1, PREFIX_VEX_38F3_REG_2,
439         PREFIX_VEX_38F3_REG_3 and PREFIX_VEX_38F7.
440         (vex_table): Use PREFIX_VEX_38F2, REG_VEX_38F3 and
441         PREFIX_VEX_38F7.
442         (vex_len_table): Add VEX_LEN_38F2_P_0, VEX_LEN_38F3_R_1_P_0,
443         VEX_LEN_38F3_R_2_P_0, VEX_LEN_38F3_R_3_P_0 and
444         VEX_LEN_38F7_P_0.
446         * i386-gen.c (cpu_flag_init): Add CPU_BMI_FLAGS.
447         (cpu_flags): Add CpuBMI.
449         * i386-opc.h (CpuBMI): New.
450         (i386_cpu_flags): Add cpubmi.
452         * i386-opc.tbl: Add andn, bextr, blsi, blsmsk, blsr and tzcnt.
453         * i386-init.h: Regenerated.
454         * i386-tbl.h: Likewise.
456 2011-01-04  H.J. Lu  <hongjiu.lu@intel.com>
458         * i386-dis.c (VexGdq): New.
459         (OP_VEX): Handle dq_mode.
461 2011-01-01  H.J. Lu  <hongjiu.lu@intel.com>
463         * i386-gen.c (process_copyright): Update copyright to 2011.
465 For older changes see ChangeLog-2010
467 Local Variables:
468 mode: change-log
469 left-margin: 8
470 fill-column: 74
471 version-control: never
472 End: