1 2018-09-13 Jan Beulich <jbeulich@suse.com>
3 * i386-opc.tbl: Drop IgnoreSize from SSE2 insns where meaningless.
4 * i386-tbl.h: Re-generate.
6 2018-09-13 Jan Beulich <jbeulich@suse.com>
8 * i386-opc.tbl: Drop IgnoreSize from SSE insns where meaningless.
9 * i386-tbl.h: Re-generate.
11 2018-09-13 Jan Beulich <jbeulich@suse.com>
13 * i386-opc.tbl (crc32, incsspq, rdsspq): Drop Rex64.
14 (vpbroadcastw, rdpid): Drop NoRex64.
15 * i386-tbl.h: Re-generate.
17 2018-09-13 Jan Beulich <jbeulich@suse.com>
19 * i386-opc.tbl (vmovsd, vmovss): Fold register form load and
20 store templates, adding D.
21 * i386-tbl.h: Re-generate.
23 2018-09-13 Jan Beulich <jbeulich@suse.com>
25 * i386-opc.tbl (bndmov, kmovb, kmovd, kmovq, kmovw, movapd,
26 movaps, movd, movdqa, movdqu, movhpd, movhps, movlpd, movlps,
27 movq, movsd, movss, movupd, movups, vmovapd, vmovaps, vmovd,
28 vmovdqa, vmovdqa32, vmovdqa64, vmovdqu, vmovdqu16, vmovdqu32,
29 vmovdqu64, vmovdqu8, vmovq, vmovsd, vmovss, vmovupd, vmovups):
30 Fold load and store templates where possible, adding D. Drop
31 IgnoreSize where it was pointlessly present. Drop redundant
33 * i386-tbl.h: Re-generate.
35 2018-09-13 Jan Beulich <jbeulich@suse.com>
37 * i386-dis.c (Mv_bnd, v_bndmk_mode): New.
38 (mod_table): Use Mv_bnd for bndldx, bndstx, and bndmk.
39 (intel_operand_size): Handle v_bndmk_mode.
40 (OP_E_memory): Likewise. Produce (bad) when also riprel.
42 2018-09-08 John Darrington <john@darrington.wattle.id.au>
44 * disassemble.c (ARCH_s12z): Define if ARCH_all.
46 2018-08-31 Kito Cheng <kito@andestech.com>
48 * riscv-opc.c (riscv_opcodes): Fix incorrect subset info for
49 compressed floating point instructions.
51 2018-08-30 Kito Cheng <kito@andestech.com>
53 * riscv-dis.c (riscv_disassemble_insn): Check XLEN by
54 riscv_opcode.xlen_requirement.
55 * riscv-opc.c (riscv_opcodes): Update for struct change.
57 2018-08-29 Martin Aberg <maberg@gaisler.com>
59 * sparc-opc.c (sparc_opcodes): Add Leon specific partial write
60 psr (PWRPSR) instruction.
62 2018-08-29 Chenghua Xu <paul.hua.gm@gmail.com>
64 * mips-dis.c (mips_arch_choices): Add gs264e descriptors.
66 2018-08-29 Chenghua Xu <paul.hua.gm@gmail.com>
68 * mips-dis.c (mips_arch_choices): Add gs464e descriptors.
70 2018-08-29 Chenghua Xu <paul.hua.gm@gmail.com>
72 * mips-dis.c (mips_arch_choices): Add gs464 descriptors, Keep
73 loongson3a as an alias of gs464 for compatibility.
74 * mips-opc.c (mips_opcodes): Change Comments.
76 2018-08-29 Chenghua Xu <paul.hua.gm@gmail.com>
78 * mips-dis.c (parse_mips_ase_option): Handle -M loongson-ext
80 (print_mips_disassembler_options): Document -M loongson-ext.
81 * mips-opc.c (LEXT2): New macro.
82 (mips_opcodes): Add cto, ctz, dcto, dctz instructions.
84 2018-08-29 Chenghua Xu <paul.hua.gm@gmail.com>
86 * mips-dis.c (mips_arch_choices): Add EXT to loongson3a
88 (parse_mips_ase_option): Handle -M loongson-ext option.
89 (print_mips_disassembler_options): Document -M loongson-ext.
90 * mips-opc.c (IL3A): Delete.
91 * mips-opc.c (LEXT): New macro.
92 (mips_opcodes): Replace IL2F|IL3A marking with LEXT for EXT
95 2018-08-29 Chenghua Xu <paul.hua.gm@gmail.com>
97 * mips-dis.c (mips_arch_choices): Add CAM to loongson3a
99 (parse_mips_ase_option): Handle -M loongson-cam option.
100 (print_mips_disassembler_options): Document -M loongson-cam.
101 * mips-opc.c (LCAM): New macro.
102 (mips_opcodes): Replace IL2F|IL3A marking with LCAM for CAM
105 2018-08-21 Alan Modra <amodra@gmail.com>
107 * ppc-dis.c (operand_value_powerpc): Init "invalid".
108 (skip_optional_operands): Count optional operands, and update
109 ppc_optional_operand_value call.
110 * ppc-opc.c (extract_dxdn): Remove ATTRIBUTE_UNUSED from used arg.
111 (extract_vlensi): Likewise.
112 (extract_fxm): Return default value for missing optional operand.
113 (extract_ls, extract_raq, extract_tbr): Likewise.
114 (insert_sxl, extract_sxl): New functions.
115 (insert_esync, extract_esync): Remove Power9 handling and simplify.
116 (powerpc_operands <FXM4, TBR>): Delete PPC_OPERAND_OPTIONAL_VALUE
117 flag and extra entry.
118 (powerpc_operands <SXL>): Likewise, and use insert_sxl and
121 2018-08-20 Alan Modra <amodra@gmail.com>
123 * sh-opc.h (MASK): Simplify.
125 2018-08-18 John Darrington <john@darrington.wattle.id.au>
127 * s12z-dis.c (bm_decode): Deal with cases where the mode is
128 BM_RESERVED0 or BM_RESERVED1
129 (bm_rel_decode, bm_n_bytes): Ditto.
131 2018-08-18 John Darrington <john@darrington.wattle.id.au>
135 2018-08-14 H.J. Lu <hongjiu.lu@intel.com>
137 * i386-dis.c (OP_E_memory): In 64-bit mode, display eiz for
138 address with the addr32 prefix and without base nor index
141 2018-08-11 H.J. Lu <hongjiu.lu@intel.com>
143 * i386-gen.c (cpu_flag_init): Add CpuCMOV and CpuFXSR to
144 CPU_I686_FLAGS. Add CPU_CMOV_FLAGS, CPU_FXSR_FLAGS,
145 CPU_ANY_CMOV_FLAGS and CPU_ANY_FXSR_FLAGS.
146 (cpu_flags): Add CpuCMOV and CpuFXSR.
147 * i386-opc.tbl: Replace Cpu686 with CpuFXSR on fxsave, fxsave64,
148 fxrstor and fxrstor64. Replace Cpu686 with CpuCMOV on cmovCC.
149 * i386-init.h: Regenerated.
150 * i386-tbl.h: Likewise.
152 2018-08-06 Claudiu Zissulescu <claziss@synopsys.com>
154 * arc-regs.h: Update auxiliary registers.
156 2018-08-06 Jan Beulich <jbeulich@suse.com>
158 * i386-opc.h (RegRip, RegEip, RegEiz, RegRiz): Drop defines.
159 (RegIP, RegIZ): Define.
160 * i386-reg.tbl: Adjust comments.
161 (rip): Use Qword instead of BaseIndex. Use RegIP.
162 (eip): Use Dword instead of BaseIndex. Use RegIP.
163 (riz): Add Qword. Use RegIZ.
164 (eiz): Add Dword. Use RegIZ.
165 * i386-tbl.h: Re-generate.
167 2018-08-03 Jan Beulich <jbeulich@suse.com>
169 * i386-opc.tbl (pmovsxbw, pmovsxdq, pmovsxwd, pmovzxbw,
170 pmovzxdq, pmovzxwd, vpmovsxbw, vpmovsxdq, vpmovsxwd, vpmovzxbw,
171 vpmovzxdq, vpmovzxwd): Remove NoRex64.
172 * i386-tbl.h: Re-generate.
174 2018-08-03 Jan Beulich <jbeulich@suse.com>
176 * i386-gen.c (operand_types): Remove Mem field.
177 * i386-opc.h (union i386_operand_type): Remove mem field.
178 * i386-init.h, i386-tbl.h: Re-generate.
180 2018-08-01 Alan Modra <amodra@gmail.com>
182 * po/POTFILES.in: Regenerate.
184 2018-07-31 Nick Clifton <nickc@redhat.com>
186 * po/sv.po: Updated Swedish translation.
188 2018-07-31 Jan Beulich <jbeulich@suse.com>
190 * i386-opc.tbl (kandnd, kandnq, kxord, kxorq): Add Optimize.
191 * i386-init.h, i386-tbl.h: Re-generate.
193 2018-07-31 Jan Beulich <jbeulich@suse.com>
195 * i386-opc.h (ZEROING_MASKING) Rename to ...
196 (DYNAMIC_MASKING): ... this. Adjust comment.
197 * i386-opc.tbl (MaskingMorZ): Define.
198 (vcompresspd, vcompressps, vcvtps2ph, vextractf32x4,
199 vextractf32x8, vextractf64x2, vextractf64x4, vextracti32x4,
200 vextracti32x8, vextracti64x2, vextracti64x4, vmovapd, vmovaps,
201 vmovdqa32, vmovdqa64, vmovdqu8, vmovdqu16, vmovdqu32, vmovdqu64,
202 vmovupd, vmovups, vpcompressb, vpcompressw, vpcompressd,
203 vpcompressq, vpmovdb, vpmovdw, vpmovqb, vpmovqd, vpmovqw,
204 vpmovsdb, vpmovsdw, vpmovsqb, vpmovsqd, vpmovsqw, vpmovswb,
205 vpmovusdb, vpmovusdw, vpmovusqb, vpmovusqd, vpmovusqw,
206 vpmovuswb, vpmovwb): Fold AVX512 register and memory forms.
208 2018-07-31 Jan Beulich <jbeulich@suse.com>
210 * i386-opc.tbl: Use element rather than vector size for AVX512*
211 scatter/gather insns.
212 * i386-tbl.h: Re-generate.
214 2018-07-31 Jan Beulich <jbeulich@suse.com>
216 * i386-gen.c (cpu_flag_init): Drop CpuVREX uses.
217 (cpu_flags): Drop CpuVREX.
218 * i386-opc.h (CpuVREX): Delete.
219 (union i386_cpu_flags): Remove cpuvrex.
220 * i386-init.h, i386-tbl.h: Re-generate.
222 2018-07-30 Jim Wilson <jimw@sifive.com>
224 * riscv-dis.c (riscv_disassemble_insn): Set insn_type and data_size
226 * riscv-opc.c (riscv_opcodes): Use new INSN_* flags to annotate insns.
228 2018-07-30 Andrew Jenner <andrew@codesourcery.com>
230 * Makefile.am (TARGET_LIBOPCODES_CFILES): Add csky-dis.c.
231 * Makefile.in: Regenerated.
232 * configure.ac: Add C-SKY.
233 * configure: Regenerated.
234 * csky-dis.c: New file.
235 * csky-opc.h: New file.
236 * disassemble.c (ARCH_csky): Define.
237 (disassembler, disassemble_init_for_target): Add case for ARCH_csky.
238 * disassemble.h (print_insn_csky, csky_get_disassembler): Declare.
240 2018-07-27 Alan Modra <amodra@gmail.com>
242 * ppc-opc.c (insert_sprbat): Correct function parameter and
244 (extract_sprbat): Likewise, variable too.
246 2018-07-26 Alex Chadwick <Alex.Chadwick@cl.cam.ac.uk>
247 Alan Modra <amodra@gmail.com>
249 * ppc-dis.c (ppc_opts): Add -mgekko and -mbroadway.
250 (powerpc_init_dialect): Handle bfd_mach_ppc_750.
251 * ppc-opc.c (insert_sprbat, extract_sprbat): New functions to
252 support disjointed BAT.
253 (powerpc_operands): Allow extra bit in SPRBAT_MASK. Add SPRGQR.
254 (XSPRGQR_MASK, GEKKO, BROADWAY): Define.
255 (powerpc_opcodes): Add 750cl extended mnemonics for spr access.
257 2018-07-25 H.J. Lu <hongjiu.lu@intel.com>
258 Igor Tsimbalist <igor.v.tsimbalist@intel.com>
260 * i386-gen.c (adjust_broadcast_modifier): New function.
261 (process_i386_opcode_modifier): Add an argument for operands.
262 Adjust the Broadcast value based on operands.
263 (output_i386_opcode): Pass operand_types to
264 process_i386_opcode_modifier.
265 (process_i386_opcodes): Pass NULL as operands to
266 process_i386_opcode_modifier.
267 * i386-opc.h (BYTE_BROADCAST): New.
268 (WORD_BROADCAST): Likewise.
269 (DWORD_BROADCAST): Likewise.
270 (QWORD_BROADCAST): Likewise.
271 (i386_opcode_modifier): Expand broadcast to 3 bits.
272 * i386-tbl.h: Regenerated.
274 2018-07-24 Alan Modra <amodra@gmail.com>
277 * or1k-desc.h: Regenerate.
279 2018-07-24 Jan Beulich <jbeulich@suse.com>
281 * i386-dis-evex.h (evex_table): Add %LQ to vcvtsi2ss, vcvtsi2sd,
282 vcvtusi2ss, and vcvtusi2sd.
283 * i386-opc.tbl (vcvtsi2sd, vcvtusi2sd, vcvtsi2ss, vcvtusi2ss):
284 Convert AVX512F variants to distinct CpuNo64 and Cpu64 forms.
285 * i386-tbl.h: Re-generate.
287 2018-07-23 Claudiu Zissulescu <claziss@synopsys.com>
289 * arc-opc.c (extract_w6): Fix extending the sign.
291 2018-07-23 Claudiu Zissulescu <claziss@synopsys.com>
293 * arc-tbl.h (vewt): Allow it for ARC EM family.
295 2018-07-23 Alan Modra <amodra@gmail.com>
298 * ppc-opc.c (powerpc_opcodes): Add mtupmc/mfupmc/mfpmc extended
299 opcode variants for mtspr/mfspr encodings.
301 2018-07-20 Chenghua Xu <paul.hua.gm@gmail.com>
302 Maciej W. Rozycki <macro@mips.com>
304 * mips-dis.c (mips_arch_choices): Add MMI to loongson2f and
305 loongson3a descriptors.
306 (parse_mips_ase_option): Handle -M loongson-mmi option.
307 (print_mips_disassembler_options): Document -M loongson-mmi.
308 * mips-opc.c (LMMI): New macro.
309 (mips_opcodes): Replace IL2F|IL3A marking with LMMI for MMI
312 2018-07-19 Jan Beulich <jbeulich@suse.com>
314 * i386-opc.tbl (vcvtpd2dq, vcvtpd2ps, vcvttpd2dq, vcvtpd2udq,
315 vcvtqq2ps, vcvtuqq2ps): Fold 128- and 256-bit templates. Drop
316 IgnoreSize and [XYZ]MMword where applicable.
317 * i386-tbl.h: Re-generate.
319 2018-07-19 Jan Beulich <jbeulich@suse.com>
321 * i386-opc.tbl (vfpclasspd, vfpclassps): Fold.
322 (vfpclasspdz, vfpclasspsz): Drop IgnoreSize and ZmmWord.
323 (vfpclasspdx, vfpclasspsx): Drop IgnoreSize and XmmWord.
324 (vfpclasspdy, vfpclasspsy): Drop IgnoreSize and YmmWord.
325 * i386-tbl.h: Re-generate.
327 2018-07-19 Jan Beulich <jbeulich@suse.com>
329 * i386-opc.tbl: Fold AVX512IFMA, AVX512VBMI, AVX512_VPOPCNTDQ,
330 AVX512_VBMI2, AVX512_VNNI, AVX512_BITALG, GFNI, VAES, and
331 VPCLMULQDQ templates into their respective AVX512VL counterparts
332 where possible, using Disp8ShiftVL and CheckRegSize instead of
333 Evex= plus Disp8MemShift= (plus often IgnoreSize) as appropriate.
334 * i386-tbl.h: Re-generate.
336 2018-07-19 Jan Beulich <jbeulich@suse.com>
338 * i386-opc.tbl: Fold AVX512DQ templates into their respective
339 AVX512VL counterparts where possible, using Disp8ShiftVL and
340 CheckRegSize instead of Evex= plus Disp8MemShift= (plus often
341 IgnoreSize) as appropriate.
342 * i386-tbl.h: Re-generate.
344 2018-07-19 Jan Beulich <jbeulich@suse.com>
346 * i386-opc.tbl: Fold AVX512BW templates into their respective
347 AVX512VL counterparts where possible, using Disp8ShiftVL and
348 CheckRegSize instead of Evex= plus Disp8MemShift= (plus often
349 IgnoreSize) as appropriate.
350 * i386-tbl.h: Re-generate.
352 2018-07-19 Jan Beulich <jbeulich@suse.com>
354 * i386-opc.tbl: Fold AVX512CD templates into their respective
355 AVX512VL counterparts where possible, using Disp8ShiftVL and
356 CheckRegSize instead of Evex= plus Disp8MemShift= (plus often
357 IgnoreSize) as appropriate.
358 * i386-tbl.h: Re-generate.
360 2018-07-19 Jan Beulich <jbeulich@suse.com>
362 * i386-opc.h (DISP8_SHIFT_VL): New.
363 * i386-opc.tbl (Disp8ShiftVL): Define.
364 (various): Fold AVX512VL templates into their respective
365 AVX512F counterparts where possible, using Disp8ShiftVL and
366 CheckRegSize instead of Evex= plus Disp8MemShift= (plus often
367 IgnoreSize) as appropriate.
368 * i386-tbl.h: Re-generate.
370 2018-07-19 Jan Beulich <jbeulich@suse.com>
372 * Makefile.am: Change dependencies and rule for
373 $(srcdir)/i386-init.h.
374 * Makefile.in: Re-generate.
375 * i386-gen.c (process_i386_opcodes): New local variable
376 "marker". Drop opening of input file. Recognize marker and line
378 * i386-opc.tbl (OPCODE_I386_H): Define.
379 (i386-opc.h): Include it.
382 2018-07-18 H.J. Lu <hongjiu.lu@intel.com>
385 * i386-opc.h (Byte): Update comments.
394 * i386-opc.tbl: Split vcvtps2qq, vcvtps2uqq, vcvttps2qq and
396 * i386-tbl.h: Regenerated.
398 2018-07-12 Sudakshina Das <sudi.das@arm.com>
400 * aarch64-tbl.h (aarch64_opcode_table): Add entry for
401 ssbb and pssbb and update dsb flags to F_HAS_ALIAS.
402 * aarch64-asm-2.c: Regenerate.
403 * aarch64-dis-2.c: Regenerate.
404 * aarch64-opc-2.c: Regenerate.
406 2018-07-12 Tamar Christina <tamar.christina@arm.com>
409 * aarch64-tbl.h (sqdmlal, sqdmlal2, smlsl, smlsl2, sqdmlsl, sqdmlsl2,
410 mul, smull, smull2, sqdmull, sqdmull2, sqdmulh, sqrdmulh, mla, umlal,
411 umlal2, mls, umlsl, umlsl2, umull, umull2, sqdmlal, sqdmlsl, sqdmull,
412 sqdmulh, sqrdmulh): Use Em16.
414 2018-07-11 Sudakshina Das <sudi.das@arm.com>
416 * arm-dis.c (arm_opcodes): Add ssbb and pssbb and move
417 csdb together with them.
418 (thumb32_opcodes): Likewise.
420 2018-07-11 Jan Beulich <jbeulich@suse.com>
422 * i386-opc.tbl (monitor, monitorx): Add 64-bit template
423 requiring 32-bit registers as operands 2 and 3. Improve
425 (mwait, mwaitx): Fold templates. Improve comments.
426 OPERAND_TYPE_INOUTPORTREG.
427 * i386-tbl.h: Re-generate.
429 2018-07-11 Jan Beulich <jbeulich@suse.com>
431 * i386-gen.c (operand_type_init): Remove
432 OPERAND_TYPE_REG16_INOUTPORTREG entry and one instance of
433 OPERAND_TYPE_INOUTPORTREG.
434 * i386-init.h: Re-generate.
436 2018-07-11 Jan Beulich <jbeulich@suse.com>
438 * i386-opc.tbl (wrssd, wrussd): Add Dword.
439 (wrssq, wrussq): Add Qword.
440 * i386-tbl.h: Re-generate.
442 2018-07-11 Jan Beulich <jbeulich@suse.com>
444 * i386-opc.h: Rename OTMax to OTNum.
445 (OTNumOfUints): Adjust calculation.
446 (OTUnused): Directly alias to OTNum.
448 2018-07-09 Maciej W. Rozycki <macro@mips.com>
450 * s12z-dis.c (lea_reg_xys_opr): Rename `reg' local variable to
452 (lea_reg_xys): Likewise.
453 (print_insn_loop_primitive): Rename `reg' local variable to
456 2018-07-06 Tamar Christina <tamar.christina@arm.com>
459 * aarch64-tbl.h (ldarh): Fix disassembly mask.
461 2018-07-06 Tamar Christina <tamar.christina@arm.com>
464 * aarch64-opc.c (aarch64_sys_regs): Make read/write csselr_el1,
465 vsesr_el2, osdtrrx_el1, osdtrtx_el1, pmsidr_el1.
467 2018-07-02 Maciej W. Rozycki <macro@mips.com>
470 * mips-dis.c (mips_option_arg_t): New enumeration.
471 (mips_options): New variable.
472 (disassembler_options_mips): New function.
473 (print_mips_disassembler_options): Reimplement in terms of
474 `disassembler_options_mips'.
475 * arm-dis.c (disassembler_options_arm): Adapt to using the
476 `disasm_options_and_args_t' structure.
477 * ppc-dis.c (disassembler_options_powerpc): Likewise.
478 * s390-dis.c (disassembler_options_s390): Likewise.
480 2018-07-02 Thomas Preud'homme <thomas.preudhomme@arm.com>
482 * testsuite/ld-arm/tls-descrelax-be8.d: Add architecture version in
484 * testsuite/ld-arm/tls-descrelax-v7.d: Likewise.
485 * testsuite/ld-arm/tls-longplt-lib.d: Likewise.
486 * testsuite/ld-arm/tls-longplt.d: Likewise.
488 2018-06-29 Tamar Christina <tamar.christina@arm.com>
491 * aarch64-asm-2.c: Regenerate.
492 * aarch64-dis-2.c: Likewise.
493 * aarch64-opc-2.c: Likewise.
494 * aarch64-dis.c (aarch64_ext_reglane): Add AARCH64_OPND_Em16 constraint.
495 * aarch64-opc.c (operand_general_constraint_met_p,
496 aarch64_print_operand): Likewise.
497 * aarch64-tbl.h (aarch64_opcode_table): Change Em to Em16 for smlal,
498 smlal2, fmla, fmls, fmul, fmulx, sqrdmlah, sqrdlsh, fmlal, fmlsl,
500 (AARCH64_OPERANDS): Add Em2.
502 2018-06-26 Nick Clifton <nickc@redhat.com>
504 * po/uk.po: Updated Ukranian translation.
505 * po/de.po: Updated German translation.
506 * po/pt_BR.po: Updated Brazilian Portuguese translation.
508 2018-06-26 Nick Clifton <nickc@redhat.com>
510 * nfp-dis.c: Fix spelling mistake.
512 2018-06-24 Nick Clifton <nickc@redhat.com>
514 * configure: Regenerate.
515 * po/opcodes.pot: Regenerate.
517 2018-06-24 Nick Clifton <nickc@redhat.com>
521 2018-06-19 Tamar Christina <tamar.christina@arm.com>
523 * aarch64-tbl.h (aarch64_opcode_table): Fix alias flag for negs
524 * aarch64-asm-2.c: Regenerate.
525 * aarch64-dis-2.c: Likewise.
527 2018-06-21 Maciej W. Rozycki <macro@mips.com>
529 * mips-dis.c (print_mips_disassembler_options): Fix a typo in
530 `-M ginv' option description.
532 2018-06-20 Sebastian Huber <sebastian.huber@embedded-brains.de>
535 * riscv-opc.c (riscv_opcodes): Use new format specifier 'B' for
538 2018-06-19 Simon Marchi <simon.marchi@ericsson.com>
540 * Makefile.am (AUTOMAKE_OPTIONS): Remove 1.11.
541 * configure.ac: Remove AC_PREREQ.
542 * Makefile.in: Re-generate.
543 * aclocal.m4: Re-generate.
544 * configure: Re-generate.
546 2018-06-14 Faraz Shahbazker <Faraz.Shahbazker@mips.com>
548 * mips-dis.c (mips_arch_choices): Add GINV to mips32r6 and
549 mips64r6 descriptors.
550 (parse_mips_ase_option): Handle -Mginv option.
551 (print_mips_disassembler_options): Document -Mginv.
552 * mips-opc.c (decode_mips_operand) <+\>: New operand format.
554 (mips_opcodes): Define ginvi and ginvt.
556 2018-06-13 Scott Egerton <scott.egerton@imgtec.com>
557 Faraz Shahbazker <Faraz.Shahbazker@mips.com>
559 * mips-dis.c (mips_arch_choices): Add CRC and CRC64 ASEs.
560 * mips-opc.c (CRC, CRC64): New macros.
561 (mips_builtin_opcodes): Define crc32b, crc32h, crc32w,
562 crc32cb, crc32ch and crc32cw for CRC. Define crc32d and
565 2018-06-08 Egeyar Bagcioglu <egeyar.bagcioglu@oracle.com>
568 * aarch64-tbl.h: Introduce QL_INT2FP_FMOV and QL_FP2INT_FMOV.
569 (aarch64_opcode_table) : Use QL_INT2FP_FMOV and QL_FP2INT_FMOV.
571 2018-06-06 Alan Modra <amodra@gmail.com>
573 * xtensa-dis.c (print_insn_xtensa): Init fmt and valid_insn after
574 setjmp. Move init for some other vars later too.
576 2018-06-04 Max Filippov <jcmvbkbc@gmail.com>
578 * xtensa-dis.c (bfd.h, elf/xtensa.h): New includes.
579 (dis_private): Add new fields for property section tracking.
580 (xtensa_coalesce_insn_tables, xtensa_find_table_entry)
581 (xtensa_instruction_fits): New functions.
582 (fetch_data): Bump minimal fetch size to 4.
583 (print_insn_xtensa): Make struct dis_private static.
584 Load and prepare property table on section change.
585 Don't disassemble literals. Don't disassemble instructions that
586 cross property table boundaries.
588 2018-06-01 H.J. Lu <hongjiu.lu@intel.com>
590 * configure: Regenerated.
592 2018-06-01 Jan Beulich <jbeulich@suse.com>
594 * i386-opc.tbl (mov, movq): Fold to/from SReg* forms.
595 * i386-tbl.h: Re-generate.
597 2018-06-01 Jan Beulich <jbeulich@suse.com>
599 * i386-opc.tbl (sldt, str): Add NoRex64.
600 * i386-tbl.h: Re-generate.
602 2018-06-01 Jan Beulich <jbeulich@suse.com>
604 * i386-opc.tbl (invpcid): Add Oword.
605 * i386-tbl.h: Re-generate.
607 2018-06-01 Alan Modra <amodra@gmail.com>
609 * sysdep.h (_bfd_error_handler): Don't declare.
610 * msp430-decode.opc: Include bfd.h. Don't include ansidecl.h here.
611 * rl78-decode.opc: Likewise.
612 * msp430-decode.c: Regenerate.
613 * rl78-decode.c: Regenerate.
615 2018-05-30 Amit Pawar <Amit.Pawar@amd.com>
617 * i386-gen.c (cpu_flag_init): Add CPU_ZNVER2_FLAGS.
618 * i386-init.h : Regenerated.
620 2018-05-25 Alan Modra <amodra@gmail.com>
622 * Makefile.in: Regenerate.
623 * po/POTFILES.in: Regenerate.
625 2018-05-21 Peter Bergner <bergner@vnet.ibm.com.com>
627 * ppc-opc.c (insert_bat, extract_bat, insert_bba, extract_bba,
628 insert_rbs, extract_rbs, insert_xb6s, extract_xb6s): Delete functions.
629 (insert_bab, extract_bab, insert_btab, extract_btab,
630 insert_rsb, extract_rsb, insert_xab6, extract_xab6): New functions.
631 (BAT, BBA VBA RBS XB6S): Delete macros.
632 (BTAB, BAB, VAB, RAB, RSB, XAB6): New macros.
633 (BB, BD, RBX, XC6): Update for new macros.
634 (powerpc_opcodes) <evmr, evnot, vmr, vnot, crnot, crclr, crset,
635 crmove, not, not., mr, mr., xxspltd, xxswapd, xvmovsp, xvmovdp,
636 e_crnot, e_crclr, e_crset, e_crmove>: Likewise.
637 * ppc-dis.c (print_insn_powerpc): Delete handling of fake operands.
639 2018-05-18 John Darrington <john@darrington.wattle.id.au>
641 * Makefile.am: Add support for s12z architecture.
642 * configure.ac: Likewise.
643 * disassemble.c: Likewise.
644 * disassemble.h: Likewise.
645 * Makefile.in: Regenerate.
646 * configure: Regenerate.
647 * s12z-dis.c: New file.
650 2018-05-18 Alan Modra <amodra@gmail.com>
652 * nfp-dis.c: Don't #include libbfd.h.
653 (init_nfp3200_priv): Use bfd_get_section_contents.
654 (nit_nfp6000_mecsr_sec): Likewise.
656 2018-05-17 Nick Clifton <nickc@redhat.com>
658 * po/zh_CN.po: Updated simplified Chinese translation.
660 2018-05-16 Tamar Christina <tamar.christina@arm.com>
663 * aarch64-tbl.h (aarch64_opcode_table): Correct sdot and udot.
664 * aarch64-dis-2.c: Regenerate.
666 2018-05-15 Tamar Christina <tamar.christina@arm.com>
669 * aarch64-asm.c (opintl.h): Include.
670 (aarch64_ins_sysreg): Enforce read/write constraints.
671 * aarch64-dis.c (aarch64_ext_sysreg): Likewise.
672 * aarch64-opc.h (F_DEPRECATED, F_ARCHEXT, F_HASXT): Moved here.
673 (F_REG_READ, F_REG_WRITE): New.
674 * aarch64-opc.c (aarch64_print_operand): Generate notes for
676 (F_DEPRECATED, F_ARCHEXT, F_HASXT): Move to aarch64-opc.h.
677 (aarch64_sys_regs): Add constraints to currentel, midr_el1, ctr_el0,
678 mpidr_el1, revidr_el1, aidr_el1, dczid_el0, id_dfr0_el1, id_pfr0_el1,
679 id_pfr1_el1, id_afr0_el1, id_mmfr0_el1, id_mmfr1_el1, id_mmfr2_el1,
680 id_mmfr3_el1, id_mmfr4_el1, id_isar0_el1, id_isar1_el1, id_isar2_el1,
681 id_isar3_el1, id_isar4_el1, id_isar5_el1, mvfr0_el1, mvfr1_el1,
682 mvfr2_el1, ccsidr_el1, id_aa64pfr0_el1, id_aa64pfr1_el1,
683 id_aa64dfr0_el1, id_aa64dfr1_el1, id_aa64isar0_el1, id_aa64isar1_el1,
684 id_aa64mmfr0_el1, id_aa64mmfr1_el1, id_aa64mmfr2_el1, id_aa64afr0_el1,
685 id_aa64afr0_el1, id_aa64afr1_el1, id_aa64zfr0_el1, clidr_el1,
686 csselr_el1, vsesr_el2, erridr_el1, erxfr_el1, rvbar_el1, rvbar_el2,
687 rvbar_el3, isr_el1, tpidrro_el0, cntfrq_el0, cntpct_el0, cntvct_el0,
688 mdccsr_el0, dbgdtrrx_el0, dbgdtrtx_el0, osdtrrx_el1, osdtrtx_el1,
689 mdrar_el1, oslar_el1, oslsr_el1, dbgauthstatus_el1, pmbidr_el1,
690 pmsidr_el1, pmswinc_el0, pmceid0_el0, pmceid1_el0.
691 * aarch64-tbl.h (aarch64_opcode_table): Add constraints to
692 msr (F_SYS_WRITE), mrs (F_SYS_READ).
694 2018-05-15 Tamar Christina <tamar.christina@arm.com>
697 * aarch64-dis.c (no_notes: New.
698 (parse_aarch64_dis_option): Support notes.
699 (aarch64_decode_insn, print_operands): Likewise.
700 (print_aarch64_disassembler_options): Document notes.
701 * aarch64-opc.c (aarch64_print_operand): Support notes.
703 2018-05-15 Tamar Christina <tamar.christina@arm.com>
706 * aarch64-asm.h (aarch64_insert_operand, aarch64_##x): Return boolean
707 and take error struct.
708 * aarch64-asm.c (aarch64_ext_regno, aarch64_ins_reglane,
709 aarch64_ins_reglist, aarch64_ins_ldst_reglist,
710 aarch64_ins_ldst_reglist_r, aarch64_ins_ldst_elemlist,
711 aarch64_ins_advsimd_imm_shift, aarch64_ins_imm, aarch64_ins_imm_half,
712 aarch64_ins_advsimd_imm_modified, aarch64_ins_fpimm,
713 aarch64_ins_imm_rotate1, aarch64_ins_imm_rotate2, aarch64_ins_fbits,
714 aarch64_ins_aimm, aarch64_ins_limm_1, aarch64_ins_limm,
715 aarch64_ins_inv_limm, aarch64_ins_ft, aarch64_ins_addr_simple,
716 aarch64_ins_addr_regoff, aarch64_ins_addr_offset, aarch64_ins_addr_simm,
717 aarch64_ins_addr_simm10, aarch64_ins_addr_uimm12,
718 aarch64_ins_simd_addr_post, aarch64_ins_cond, aarch64_ins_sysreg,
719 aarch64_ins_pstatefield, aarch64_ins_sysins_op, aarch64_ins_barrier,
720 aarch64_ins_prfop, aarch64_ins_hint, aarch64_ins_reg_extended,
721 aarch64_ins_reg_shifted, aarch64_ins_sve_addr_ri_s4xvl,
722 aarch64_ins_sve_addr_ri_s6xvl, aarch64_ins_sve_addr_ri_s9xvl,
723 aarch64_ins_sve_addr_ri_s4, aarch64_ins_sve_addr_ri_u6,
724 aarch64_ins_sve_addr_rr_lsl, aarch64_ins_sve_addr_rz_xtw,
725 aarch64_ins_sve_addr_zi_u5, aarch64_ext_sve_addr_zz,
726 aarch64_ins_sve_addr_zz_lsl, aarch64_ins_sve_addr_zz_sxtw,
727 aarch64_ins_sve_addr_zz_uxtw, aarch64_ins_sve_aimm,
728 aarch64_ins_sve_asimm, aarch64_ins_sve_index, aarch64_ins_sve_limm_mov,
729 aarch64_ins_sve_quad_index, aarch64_ins_sve_reglist,
730 aarch64_ins_sve_scale, aarch64_ins_sve_shlimm, aarch64_ins_sve_shrimm,
731 aarch64_ins_sve_float_half_one, aarch64_ins_sve_float_half_two,
732 aarch64_ins_sve_float_zero_one, aarch64_opcode_encode): Likewise.
733 * aarch64-dis.h (aarch64_extract_operand, aarch64_##x): Likewise.
734 * aarch64-dis.c (aarch64_ext_regno, aarch64_ext_reglane,
735 aarch64_ext_reglist, aarch64_ext_ldst_reglist,
736 aarch64_ext_ldst_reglist_r, aarch64_ext_ldst_elemlist,
737 aarch64_ext_advsimd_imm_shift, aarch64_ext_imm, aarch64_ext_imm_half,
738 aarch64_ext_advsimd_imm_modified, aarch64_ext_fpimm,
739 aarch64_ext_imm_rotate1, aarch64_ext_imm_rotate2, aarch64_ext_fbits,
740 aarch64_ext_aimm, aarch64_ext_limm_1, aarch64_ext_limm, decode_limm,
741 aarch64_ext_inv_limm, aarch64_ext_ft, aarch64_ext_addr_simple,
742 aarch64_ext_addr_regoff, aarch64_ext_addr_offset, aarch64_ext_addr_simm,
743 aarch64_ext_addr_simm10, aarch64_ext_addr_uimm12,
744 aarch64_ext_simd_addr_post, aarch64_ext_cond, aarch64_ext_sysreg,
745 aarch64_ext_pstatefield, aarch64_ext_sysins_op, aarch64_ext_barrier,
746 aarch64_ext_prfop, aarch64_ext_hint, aarch64_ext_reg_extended,
747 aarch64_ext_reg_shifted, aarch64_ext_sve_addr_ri_s4xvl,
748 aarch64_ext_sve_addr_ri_s6xvl, aarch64_ext_sve_addr_ri_s9xvl,
749 aarch64_ext_sve_addr_ri_s4, aarch64_ext_sve_addr_ri_u6,
750 aarch64_ext_sve_addr_rr_lsl, aarch64_ext_sve_addr_rz_xtw,
751 aarch64_ext_sve_addr_zi_u5, aarch64_ext_sve_addr_zz,
752 aarch64_ext_sve_addr_zz_lsl, aarch64_ext_sve_addr_zz_sxtw,
753 aarch64_ext_sve_addr_zz_uxtw, aarch64_ext_sve_aimm,
754 aarch64_ext_sve_asimm, aarch64_ext_sve_index, aarch64_ext_sve_limm_mov,
755 aarch64_ext_sve_quad_index, aarch64_ext_sve_reglist,
756 aarch64_ext_sve_scale, aarch64_ext_sve_shlimm, aarch64_ext_sve_shrimm,
757 aarch64_ext_sve_float_half_one, aarch64_ext_sve_float_half_two,
758 aarch64_ext_sve_float_zero_one, aarch64_opcode_decode): Likewise.
759 (determine_disassembling_preference, aarch64_decode_insn,
760 print_insn_aarch64_word, print_insn_data): Take errors struct.
761 (print_insn_aarch64): Use errors.
762 * aarch64-asm-2.c: Regenerate.
763 * aarch64-dis-2.c: Regenerate.
764 * aarch64-gen.c (print_operand_inserter): Use errors and change type to
765 boolean in aarch64_insert_operan.
766 (print_operand_extractor): Likewise.
767 * aarch64-opc.c (aarch64_print_operand): Use sysreg struct.
769 2018-05-15 Francois H. Theron <francois.theron@netronome.com>
771 * nfp-dis.c: Use uint64_t for instruction variables, not bfd_vma.
773 2018-05-09 H.J. Lu <hongjiu.lu@intel.com>
775 * i386-opc.tbl: Remove Disp<N> from movidir{i,64b}.
777 2018-05-09 Sebastian Rasmussen <sebras@gmail.com>
779 * cr16-opc.c (cr16_instruction): Comment typo fix.
780 * hppa-dis.c (print_insn_hppa): Likewise.
782 2018-05-08 Jim Wilson <jimw@sifive.com>
784 * riscv-opc.c (match_c_slli, match_slli_as_c_slli): New.
785 (match_c_slli64, match_srxi_as_c_srxi): New.
786 (riscv_opcodes) <slli, sll>: Use match_slli_as_c_slli.
787 <srli, srl, srai, sra>: Use match_srxi_as_c_srxi.
788 <c.slli, c.srli, c.srai>: Use match_s_slli.
789 <c.slli64, c.srli64, c.srai64>: New.
791 2018-05-08 Alan Modra <amodra@gmail.com>
793 * ppc-dis.c (PPC_OPCD_SEGS): Define using PPC_OP.
794 (VLE_OPCD_SEGS, SPE2_OPCD_SEGS): Similarly, using macros used to
795 partition opcode space for index lookup.
797 2018-05-07 Peter Bergner <bergner@vnet.ibm.com.com>
799 * ppc-dis.c (print_insn_powerpc) <insn_is_short>: Replace this...
800 <insn_length>: ...with this. Update usage.
801 Remove duplicate call to *info->memory_error_func.
803 2018-05-07 Igor Tsimbalist <igor.v.tsimbalist@intel.com>
804 H.J. Lu <hongjiu.lu@intel.com>
806 * i386-dis.c (Gva): New.
807 (enum): Add PREFIX_0F38F8, PREFIX_0F38F9,
808 MOD_0F38F8_PREFIX_2, MOD_0F38F9_PREFIX_0.
809 (prefix_table): New instructions (see prefix above).
810 (mod_table): New instructions (see prefix above).
811 (OP_G): Handle va_mode.
812 * i386-gen.c (cpu_flag_init): Add CPU_MOVDIRI_FLAGS,
814 (cpu_flags): Add CpuMOVDIRI and CpuMOVDIR64B.
815 * i386-opc.h (enum): Add CpuMOVDIRI, CpuMOVDIR64B.
816 (i386_cpu_flags): Add cpumovdiri and cpumovdir64b.
817 * i386-opc.tbl: Add movidir{i,64b}.
818 * i386-init.h: Regenerated.
819 * i386-tbl.h: Likewise.
821 2018-05-07 H.J. Lu <hongjiu.lu@intel.com>
823 * i386-gen.c (opcode_modifiers): Replace AddrPrefixOp0 with
825 * i386-opc.h (AddrPrefixOp0): Renamed to ...
826 (AddrPrefixOpReg): This.
827 (i386_opcode_modifier): Rename addrprefixop0 to addrprefixopreg.
828 * i386-opc.tbl: Replace AddrPrefixOp0 with AddrPrefixOpReg.
830 2018-05-07 Peter Bergner <bergner@vnet.ibm.com.com>
832 * ppc-opc.c (powerpc_num_opcodes): Change type to unsigned.
833 (vle_num_opcodes): Likewise.
834 (spe2_num_opcodes): Likewise.
835 * ppc-dis.c (disassemble_init_powerpc) <powerpc_opcd_indices>: Rewrite
837 (disassemble_init_powerpc) <vle_opcd_indices>: Likewise.
838 (disassemble_init_powerpc) <spe2_opcd_indices>: Likewise. Initialize
841 2018-05-01 Tamar Christina <tamar.christina@arm.com>
843 * aarch64-dis.c (aarch64_opcode_decode): Moved memory clear code.
845 2018-04-30 Francois H. Theron <francois.theron@netronome.com>
847 Makefile.am: Added nfp-dis.c.
848 configure.ac: Added bfd_nfp_arch.
849 disassemble.h: Added print_insn_nfp prototype.
850 disassemble.c: Added ARCH_nfp and call to print_insn_nfp
851 nfp-dis.c: New, for NFP support.
852 po/POTFILES.in: Added nfp-dis.c to the list.
853 Makefile.in: Regenerate.
854 configure: Regenerate.
856 2018-04-26 Jan Beulich <jbeulich@suse.com>
858 * i386-opc.tbl: Fold various non-memory operand AVX512VL
859 templates into their base ones.
860 * i386-tlb.h: Re-generate.
862 2018-04-26 Jan Beulich <jbeulich@suse.com>
864 * i386-gen.c (cpu_flag_init): Use CPU_XOP_FLAGS for
865 CPU_BDVER1_FLAGS. Use CPU_AVX2_FLAGS for CPU_ZNVER1_FLAGS. Use
866 CPU_AVX_FLAGS for CPU_BTVER1_FLAGS. Add CPU_XSAVE_FLAGS to
867 CPU_LWP_FLAGS, CPU_AVX_FLAGS, CPU_MPX_FLAGS, and CPU_OSPKE_FLAGS.
868 * i386-init.h: Re-generate.
870 2018-04-26 Jan Beulich <jbeulich@suse.com>
872 * i386-gen.c (cpu_flag_init): Drop all uses of CpuRegMMX,
873 CpuRegXMM, CpuRegYMM, CpuRegZMM, and CpuRegMask. Use
874 CPU_AVX2_FLAGS for CPU_AVX512F_FLAGS and drop bogus comment.
875 Don't use CPU_AVX2_FLAGS for CPU_AVX512VL_FLAGS and drop bogus
877 (cpu_flags): Drop CpuRegMMX, CpuRegXMM, CpuRegYMM, CpuRegZMM,
879 * i386-opc.h: CpuRegMMX, CpuRegXMM, CpuRegYMM, CpuRegZMM,
881 (union i386_cpu_flags): Remove cpuregmmx, cpuregxmm, cpuregymm,
882 cpuregzmm, and cpuregmask.
883 * i386-init.h: Re-generate.
884 * i386-tbl.h: Re-generate.
886 2018-04-26 Jan Beulich <jbeulich@suse.com>
888 * i386-gen.c (cpu_flag_init): CPU_I586_FLAGS inherits Cpu387 only.
889 CPU_287_FLAGS is Cpu287 only. CPU_387_FLAGS is Cpu387 only.
890 * i386-init.h: Re-generate.
892 2018-04-26 Jan Beulich <jbeulich@suse.com>
894 * i386-gen.c (VexImmExt): Delete.
895 * i386-opc.h (VexImmExt, veximmext): Delete.
896 * i386-opc.tbl: Drop all VexImmExt uses.
897 * i386-tlb.h: Re-generate.
899 2018-04-25 Jan Beulich <jbeulich@suse.com>
901 * i386-opc.tbl (vpslld, vpsrad, vpsrld): Drop AVX512VL
903 * i386-tlb.h: Re-generate.
905 2018-04-25 Tamar Christina <tamar.christina@arm.com>
907 * aarch64-tbl.h (sqrdmlah, sqrdmlsh): Fix masks.
909 2018-04-17 Igor Tsimbalist <igor.v.tsimbalist@intel.com>
911 * i386-dis.c: Add REG_0F1C_MOD_0, MOD_0F1C_PREFIX_0,
913 * i386-gen.c (cpu_flag_init): Add CPU_CLDEMOTE_FLAGS,
914 (cpu_flags): Add CpuCLDEMOTE.
915 * i386-init.h: Regenerate.
916 * i386-opc.h (enum): Add CpuCLDEMOTE,
917 (i386_cpu_flags): Add cpucldemote.
918 * i386-opc.tbl: Add cldemote.
919 * i386-tbl.h: Regenerate.
921 2018-04-16 Alan Modra <amodra@gmail.com>
923 * Makefile.am: Remove sh5 and sh64 support.
924 * configure.ac: Likewise.
925 * disassemble.c: Likewise.
926 * disassemble.h: Likewise.
927 * sh-dis.c: Likewise.
928 * sh64-dis.c: Delete.
929 * sh64-opc.c: Delete.
930 * sh64-opc.h: Delete.
931 * Makefile.in: Regenerate.
932 * configure: Regenerate.
933 * po/POTFILES.in: Regenerate.
935 2018-04-16 Alan Modra <amodra@gmail.com>
937 * Makefile.am: Remove w65 support.
938 * configure.ac: Likewise.
939 * disassemble.c: Likewise.
940 * disassemble.h: Likewise.
943 * Makefile.in: Regenerate.
944 * configure: Regenerate.
945 * po/POTFILES.in: Regenerate.
947 2018-04-16 Alan Modra <amodra@gmail.com>
949 * configure.ac: Remove we32k support.
950 * configure: Regenerate.
952 2018-04-16 Alan Modra <amodra@gmail.com>
954 * Makefile.am: Remove m88k support.
955 * configure.ac: Likewise.
956 * disassemble.c: Likewise.
957 * disassemble.h: Likewise.
958 * m88k-dis.c: Delete.
959 * Makefile.in: Regenerate.
960 * configure: Regenerate.
961 * po/POTFILES.in: Regenerate.
963 2018-04-16 Alan Modra <amodra@gmail.com>
965 * Makefile.am: Remove i370 support.
966 * configure.ac: Likewise.
967 * disassemble.c: Likewise.
968 * disassemble.h: Likewise.
969 * i370-dis.c: Delete.
970 * i370-opc.c: Delete.
971 * Makefile.in: Regenerate.
972 * configure: Regenerate.
973 * po/POTFILES.in: Regenerate.
975 2018-04-16 Alan Modra <amodra@gmail.com>
977 * Makefile.am: Remove h8500 support.
978 * configure.ac: Likewise.
979 * disassemble.c: Likewise.
980 * disassemble.h: Likewise.
981 * h8500-dis.c: Delete.
982 * h8500-opc.h: Delete.
983 * Makefile.in: Regenerate.
984 * configure: Regenerate.
985 * po/POTFILES.in: Regenerate.
987 2018-04-16 Alan Modra <amodra@gmail.com>
989 * configure.ac: Remove tahoe support.
990 * configure: Regenerate.
992 2018-04-15 H.J. Lu <hongjiu.lu@intel.com>
994 * i386-dis.c (prefix_table): Replace Em with Edq on tpause and
996 * i386-opc.tbl: Allow 32-bit registers for tpause and umwait in
998 * i386-tbl.h: Regenerated.
1000 2018-04-11 Igor Tsimbalist <igor.v.tsimbalist@intel.com>
1002 * i386-dis.c (enum): Add PREFIX_MOD_0_0FAE_REG_6,
1003 PREFIX_MOD_1_0FAE_REG_6.
1005 (OP_E_register): Use va_mode.
1006 * i386-dis-evex.h (prefix_table):
1007 New instructions (see prefixes above).
1008 * i386-gen.c (cpu_flag_init): Add WAITPKG.
1009 (cpu_flags): Likewise.
1010 * i386-opc.h (enum): Likewise.
1011 (i386_cpu_flags): Likewise.
1012 * i386-opc.tbl: Add umonitor, umwait, tpause.
1013 * i386-init.h: Regenerate.
1014 * i386-tbl.h: Likewise.
1016 2018-04-11 Alan Modra <amodra@gmail.com>
1018 * opcodes/i860-dis.c: Delete.
1019 * opcodes/i960-dis.c: Delete.
1020 * Makefile.am: Remove i860 and i960 support.
1021 * configure.ac: Likewise.
1022 * disassemble.c: Likewise.
1023 * disassemble.h: Likewise.
1024 * Makefile.in: Regenerate.
1025 * configure: Regenerate.
1026 * po/POTFILES.in: Regenerate.
1028 2018-04-04 H.J. Lu <hongjiu.lu@intel.com>
1031 * i386-dis.c (get_valid_dis386): Don't set vex.prefix nor vex.w
1033 (print_insn): Clear vex instead of vex.evex.
1035 2018-04-04 Nick Clifton <nickc@redhat.com>
1037 * po/es.po: Updated Spanish translation.
1039 2018-03-28 Jan Beulich <jbeulich@suse.com>
1041 * i386-gen.c (opcode_modifiers): Delete VecESize.
1042 * i386-opc.h (VecESize): Delete.
1043 (struct i386_opcode_modifier): Delete vecesize.
1044 * i386-opc.tbl: Drop VecESize.
1045 * i386-tlb.h: Re-generate.
1047 2018-03-28 Jan Beulich <jbeulich@suse.com>
1049 * i386-opc.h (NO_BROADCAST, BROADCAST_1TO16, BROADCAST_1TO8,
1050 BROADCAST_1TO4, BROADCAST_1TO2): Delete.
1051 (struct i386_opcode_modifier): Shrink broadcast field to 1 bit.
1052 * i386-opc.tbl: Replace Broadcast=<N> by Broadcast.
1053 * i386-tlb.h: Re-generate.
1055 2018-03-28 Jan Beulich <jbeulich@suse.com>
1057 * i386-opc.tbl (vcvt*d2si, vcvt*d2usi, vcvt*s2si, vcvt*s2usi):
1059 * i386-tlb.h: Re-generate.
1061 2018-03-28 Jan Beulich <jbeulich@suse.com>
1063 * i386-dis.c (prefix_table): Drop Y for cvt*2si.
1064 (vex_len_table): Drop Y for vcvt*2si.
1065 (putop): Replace plain 'Y' handling by abort().
1067 2018-03-28 Nick Clifton <nickc@redhat.com>
1070 * aarch64-tbl.h (aarch64_opcode_table): Add entries for LDFF1xx
1071 instructions with only a base address register.
1072 * aarch64-opc.c (operand_general_constraint_met_p): Add code to
1073 handle AARHC64_OPND_SVE_ADDR_R.
1074 (aarch64_print_operand): Likewise.
1075 * aarch64-asm-2.c: Regenerate.
1076 * aarch64_dis-2.c: Regenerate.
1077 * aarch64-opc-2.c: Regenerate.
1079 2018-03-22 Jan Beulich <jbeulich@suse.com>
1081 * i386-opc.tbl: Drop VecESize from register only insn forms and
1082 memory forms not allowing broadcast.
1083 * i386-tlb.h: Re-generate.
1085 2018-03-22 Jan Beulich <jbeulich@suse.com>
1087 * i386-opc.tbl (vfrczs*, vphadd*, vphsub*, vpmacs*, vpmadcs*,
1088 vprot*, vpsha*, vpshl*, bextr, blc*, bls*, t1mskc, tzmsk, sha1*,
1089 sha256*): Drop Disp<N>.
1091 2018-03-22 Jan Beulich <jbeulich@suse.com>
1093 * i386-dis.c (EbndS, bnd_swap_mode): New.
1094 (prefix_table): Use EbndS.
1095 (OP_E_register, OP_E_memory): Also handle bnd_swap_mode.
1096 * i386-opc.tbl (bndmov): Move misplaced Load.
1097 * i386-tlb.h: Re-generate.
1099 2018-03-22 Jan Beulich <jbeulich@suse.com>
1101 * i386-opc.tbl (vcvtdq2pd, vcvtps2pd, vcvtudq2pd): Use separate
1102 templates allowing memory operands and folded ones for register
1104 * i386-tlb.h: Re-generate.
1106 2018-03-22 Jan Beulich <jbeulich@suse.com>
1108 * i386-opc.tbl (vfrczp*, vpcmov, vpermil2p*): Fold 128- and
1109 256-bit templates. Drop redundant leftover Disp<N>.
1110 * i386-tlb.h: Re-generate.
1112 2018-03-14 Kito Cheng <kito.cheng@gmail.com>
1114 * riscv-opc.c (riscv_insn_types): New.
1116 2018-03-13 Nick Clifton <nickc@redhat.com>
1118 * po/pt_BR.po: Updated Brazilian Portuguese translation.
1120 2018-03-08 H.J. Lu <hongjiu.lu@intel.com>
1122 * i386-opc.tbl: Add Optimize to clr.
1123 * i386-tbl.h: Regenerated.
1125 2018-03-08 H.J. Lu <hongjiu.lu@intel.com>
1127 * i386-gen.c (opcode_modifiers): Remove OldGcc.
1128 * i386-opc.h (OldGcc): Removed.
1129 (i386_opcode_modifier): Remove oldgcc.
1130 * i386-opc.tbl: Remove fsubp, fsubrp, fdivp and fdivrp
1131 instructions for old (<= 2.8.1) versions of gcc.
1132 * i386-tbl.h: Regenerated.
1134 2018-03-08 Jan Beulich <jbeulich@suse.com>
1136 * i386-opc.h (EVEXDYN): New.
1137 * i386-opc.tbl: Fold various AVX512VL templates.
1138 * i386-tlb.h: Re-generate.
1140 2018-03-08 Jan Beulich <jbeulich@suse.com>
1142 * i386-opc.tbl (vexpandpd, vexpandps, vmovapd, vmovaps,
1143 vmovdqa32, vmovdqa64, vmovdqu32, vmovdqu64, vmovupd, vmovups,
1144 vpexpandd, vpexpandq): Fold AFX512VF templates.
1145 * i386-tlb.h: Re-generate.
1147 2018-03-08 Jan Beulich <jbeulich@suse.com>
1149 * i386-opc.tbl (vgf2p8affineinvqb, vgf2p8affineqb, vgf2p8mulb):
1150 Fold 128- and 256-bit VEX-encoded templates.
1151 * i386-tlb.h: Re-generate.
1153 2018-03-08 Jan Beulich <jbeulich@suse.com>
1155 * i386-opc.tbl (vexpandpd, vexpandps, vmovapd, vmovaps,
1156 vmovdqa32, vmovdqa64, vmovdqu32, vmovdqu64, vmovupd, vmovups,
1157 vpexpandd, vpexpandq): Fold AVX512F templates.
1158 * i386-tlb.h: Re-generate.
1160 2018-03-08 Jan Beulich <jbeulich@suse.com>
1162 * i386-opc.tbl (llwpcb, slwpcb, lwpval, lwpins): Fold 32- and
1163 64-bit templates. Drop Disp<N>.
1164 * i386-tlb.h: Re-generate.
1166 2018-03-08 Jan Beulich <jbeulich@suse.com>
1168 * i386-opc.tbl (vfmadd*, vfmsub*, vfnmadd*, vfnmsub*): Fold 128-
1169 and 256-bit templates.
1170 * i386-tlb.h: Re-generate.
1172 2018-03-08 Jan Beulich <jbeulich@suse.com>
1174 * i386-opc.tbl (cmpxchg8b): Add NoRex64.
1175 * i386-tlb.h: Re-generate.
1177 2018-03-08 Jan Beulich <jbeulich@suse.com>
1179 * i386-opc.tbl (cmpxchg16b, fisttp, fisttpll, bndmov, mwaitx):
1181 * i386-tlb.h: Re-generate.
1183 2018-03-08 Jan Beulich <jbeulich@suse.com>
1185 * i386-opc.tbl (ldmxcsr, stmxcsr): Add NoAVX.
1186 * i386-tlb.h: Re-generate.
1188 2018-03-08 Jan Beulich <jbeulich@suse.com>
1190 * i386-gen.c (opcode_modifiers): Delete FloatD.
1191 * i386-opc.h (FloatD): Delete.
1192 (struct i386_opcode_modifier): Delete floatd.
1193 * i386-opc.tbl (fadd, fsub, fsubr, fmul, fdiv, fdivr): Replace
1195 * i386-tlb.h: Re-generate.
1197 2018-03-08 Jan Beulich <jbeulich@suse.com>
1199 * i386-dis.c (float_reg): Adjust DC and DE fsub*/fdiv* patterns.
1201 2018-03-08 Jan Beulich <jbeulich@suse.com>
1203 * i386-opc.tbl (vmovd): Disallow Qword memory operands.
1204 * i386-tlb.h: Re-generate.
1206 2018-03-08 Jan Beulich <jbeulich@suse.com>
1208 * i386-opc.tbl (vcvtpd2ps): Fold AVX 128- and 256-bit memory
1210 * i386-tlb.h: Re-generate.
1212 2018-03-07 Alan Modra <amodra@gmail.com>
1214 * disassemble.c (disassembler): Use bfd_arch_powerpc entry for
1216 * disassemble.h (print_insn_rs6000): Delete.
1217 * ppc-dis.c (powerpc_init_dialect): Handle rs6000.
1218 (disassemble_init_powerpc): Call powerpc_init_dialect for rs6000.
1219 (print_insn_rs6000): Delete.
1221 2018-03-03 Alan Modra <amodra@gmail.com>
1223 * sysdep.h (opcodes_error_handler): Define.
1224 (_bfd_error_handler): Declare.
1225 * Makefile.am: Remove stray #.
1226 * opc2c.c (main): Remove bogus -l arg handling. Print "DO NOT
1228 * aarch64-dis.c, * arc-dis.c, * arm-dis.c, * avr-dis.c,
1229 * d30v-dis.c, * h8300-dis.c, * mmix-dis.c, * ppc-dis.c,
1230 * riscv-dis.c, * s390-dis.c, * sparc-dis.c, * v850-dis.c: Use
1231 opcodes_error_handler to print errors. Standardize error messages.
1232 * msp430-decode.opc, * nios2-dis.c, * rl78-decode.opc: Likewise,
1233 and include opintl.h.
1234 * nds32-asm.c: Likewise, and include sysdep.h and opintl.h.
1235 * i386-gen.c: Standardize error messages.
1236 * msp430-decode.c, * rl78-decode.c, rx-decode.c: Regenerate.
1237 * Makefile.in: Regenerate.
1238 * epiphany-asm.c, * epiphany-desc.c, * epiphany-dis.c,
1239 * epiphany-ibld.c, * fr30-asm.c, * fr30-desc.c, * fr30-dis.c,
1240 * fr30-ibld.c, * frv-asm.c, * frv-desc.c, * frv-dis.c, * frv-ibld.c,
1241 * frv-opc.c, * ip2k-asm.c, * ip2k-desc.c, * ip2k-dis.c, * ip2k-ibld.c,
1242 * iq2000-asm.c, * iq2000-desc.c, * iq2000-dis.c, * iq2000-ibld.c,
1243 * lm32-asm.c, * lm32-desc.c, * lm32-dis.c, * lm32-ibld.c,
1244 * m32c-asm.c, * m32c-desc.c, * m32c-dis.c, * m32c-ibld.c,
1245 * m32r-asm.c, * m32r-desc.c, * m32r-dis.c, * m32r-ibld.c,
1246 * mep-asm.c, * mep-desc.c, * mep-dis.c, * mep-ibld.c, * mt-asm.c,
1247 * mt-desc.c, * mt-dis.c, * mt-ibld.c, * or1k-asm.c, * or1k-desc.c,
1248 * or1k-dis.c, * or1k-ibld.c, * xc16x-asm.c, * xc16x-desc.c,
1249 * xc16x-dis.c, * xc16x-ibld.c, * xstormy16-asm.c, * xstormy16-desc.c,
1250 * xstormy16-dis.c, * xstormy16-ibld.c: Regenerate.
1252 2018-03-01 H.J. Lu <hongjiu.lu@intel.com>
1254 * * i386-opc.tbl: Add "Optimize" to AVX256 and AVX512
1255 vpsub[bwdq] instructions.
1256 * i386-tbl.h: Regenerated.
1258 2018-03-01 Alan Modra <amodra@gmail.com>
1260 * configure.ac (ALL_LINGUAS): Sort.
1261 * configure: Regenerate.
1263 2018-02-27 Thomas Preud'homme <thomas.preudhomme@arm.com>
1265 * arm-dis.c (print_insn_coprocessor): Replace uses of ARM_FEATURE_COPY
1266 macro by assignements.
1268 2018-02-27 H.J. Lu <hongjiu.lu@intel.com>
1271 * i386-gen.c (opcode_modifiers): Add Optimize.
1272 * i386-opc.h (Optimize): New enum.
1273 (i386_opcode_modifier): Add optimize.
1274 * i386-opc.tbl: Add "Optimize" to "mov $imm, reg",
1275 "sub reg, reg/mem", "test $imm, acc", "test $imm, reg/mem",
1276 "and $imm, acc", "and $imm, reg/mem", "xor reg, reg/mem",
1277 "movq $imm, reg" and AVX256 and AVX512 versions of vandnps,
1278 vandnpd, vpandn, vpandnd, vpandnq, vxorps, vxorpd, vpxor,
1280 * i386-tbl.h: Regenerated.
1282 2018-02-26 Alan Modra <amodra@gmail.com>
1284 * crx-dis.c (getregliststring): Allocate a large enough buffer
1285 to silence false positive gcc8 warning.
1287 2018-02-22 Shea Levy <shea@shealevy.com>
1289 * disassemble.c (ARCH_riscv): Define if ARCH_all.
1291 2018-02-22 H.J. Lu <hongjiu.lu@intel.com>
1293 * i386-opc.tbl: Add {rex},
1294 * i386-tbl.h: Regenerated.
1296 2018-02-20 Maciej W. Rozycki <macro@mips.com>
1298 * mips16-opc.c (decode_mips16_operand) <'M'>: Remove case.
1299 (mips16_opcodes): Replace `M' with `m' for "restore".
1301 2018-02-19 Thomas Preud'homme <thomas.preudhomme@arm.com>
1303 * arm-dis.c (thumb_opcodes): Fix BXNS mask.
1305 2018-02-13 Maciej W. Rozycki <macro@mips.com>
1307 * wasm32-dis.c (print_insn_wasm32): Rename `index' local
1308 variable to `function_index'.
1310 2018-02-13 Nick Clifton <nickc@redhat.com>
1313 * metag-dis.c (print_fmmov): Double buffer size to avoid warning
1314 about truncation of printing.
1316 2018-02-12 Henry Wong <henry@stuffedcow.net>
1318 * mips-opc.c (mips_builtin_opcodes): Correct "sigrie" encoding.
1320 2018-02-05 Nick Clifton <nickc@redhat.com>
1322 * po/pt_BR.po: Updated Brazilian Portuguese translation.
1324 2018-01-23 Igor Tsimbalist <igor.v.tsimbalist@intel.com>
1326 * i386-dis.c (enum): Add pconfig.
1327 * i386-gen.c (cpu_flag_init): Add CPU_PCONFIG_FLAGS.
1328 (cpu_flags): Add CpuPCONFIG.
1329 * i386-opc.h (enum): Add CpuPCONFIG.
1330 (i386_cpu_flags): Add cpupconfig.
1331 * i386-opc.tbl: Add PCONFIG instruction.
1332 * i386-init.h: Regenerate.
1333 * i386-tbl.h: Likewise.
1335 2018-01-23 Igor Tsimbalist <igor.v.tsimbalist@intel.com>
1337 * i386-dis.c (enum): Add PREFIX_0F09.
1338 * i386-gen.c (cpu_flag_init): Add CPU_WBNOINVD_FLAGS.
1339 (cpu_flags): Add CpuWBNOINVD.
1340 * i386-opc.h (enum): Add CpuWBNOINVD.
1341 (i386_cpu_flags): Add cpuwbnoinvd.
1342 * i386-opc.tbl: Add WBNOINVD instruction.
1343 * i386-init.h: Regenerate.
1344 * i386-tbl.h: Likewise.
1346 2018-01-17 Jim Wilson <jimw@sifive.com>
1348 * riscv-opc.c (riscv_opcodes) <addi>: Use z instead of 0.
1350 2018-01-17 Igor Tsimbalist <igor.v.tsimbalist@intel.com>
1352 * i386-gen.c (cpu_flag_init): Delete CPU_CET_FLAGS, CpuCET.
1353 Add CPU_IBT_FLAGS, CPU_SHSTK_FLAGS, CPY_ANY_IBT_FLAGS,
1354 CPU_ANY_SHSTK_FLAGS, CpuIBT, CpuSHSTK.
1355 (cpu_flags): Add CpuIBT, CpuSHSTK.
1356 * i386-opc.h (enum): Add CpuIBT, CpuSHSTK.
1357 (i386_cpu_flags): Add cpuibt, cpushstk.
1358 * i386-opc.tbl: Change CpuCET to CpuSHSTK and CpuIBT.
1359 * i386-init.h: Regenerate.
1360 * i386-tbl.h: Likewise.
1362 2018-01-16 Nick Clifton <nickc@redhat.com>
1364 * po/pt_BR.po: Updated Brazilian Portugese translation.
1365 * po/de.po: Updated German translation.
1367 2018-01-15 Jim Wilson <jimw@sifive.com>
1369 * riscv-opc.c (match_c_nop): New.
1370 (riscv_opcodes) <addi>: Handle an addi that compresses to c.nop.
1372 2018-01-15 Nick Clifton <nickc@redhat.com>
1374 * po/uk.po: Updated Ukranian translation.
1376 2018-01-13 Nick Clifton <nickc@redhat.com>
1378 * po/opcodes.pot: Regenerated.
1380 2018-01-13 Nick Clifton <nickc@redhat.com>
1382 * configure: Regenerate.
1384 2018-01-13 Nick Clifton <nickc@redhat.com>
1386 2.30 branch created.
1388 2018-01-11 Igor Tsimbalist <igor.v.tsimbalist@intel.com>
1390 * i386-opc.tbl: Remove VL variants for 4FMAPS and 4VNNIW insns.
1391 * i386-tbl.h: Regenerate.
1393 2018-01-10 Jan Beulich <jbeulich@suse.com>
1395 * i386-opc.tbl (v4fmaddss, v4fnmaddss): Adjust Disp8MemShift.
1396 * i386-tbl.h: Re-generate.
1398 2018-01-10 Jan Beulich <jbeulich@suse.com>
1400 * i386-opc.tbl (vpcmpeqb, vpcmpleb, vpcmpltb, vpcmpneqb,
1401 vpcmpnleb, vpcmpnltb, vpcmpequb, vpcmpleub, vpcmpltub,
1402 vpcmpnequb, vpcmpnleub, vpcmpnltub, vpcmpeqw, vpcmplew,
1403 vpcmpltw, vpcmpneqw, vpcmpnlew, vpcmpnltw, vpcmpequw, vpcmpleuw,
1404 vpcmpltuw, vpcmpnequw, vpcmpnleuw, vpcmpnltuw): Adjust
1405 Disp8MemShift of AVX512VL forms.
1406 * i386-tbl.h: Re-generate.
1408 2018-01-09 Jim Wilson <jimw@sifive.com>
1410 * riscv-dis.c (maybe_print_address): If base_reg is zero,
1411 then the hi_addr value is zero.
1413 2018-01-09 James Greenhalgh <james.greenhalgh@arm.com>
1415 * arm-dis.c (arm_opcodes): Add csdb.
1416 (thumb32_opcodes): Add csdb.
1418 2018-01-09 James Greenhalgh <james.greenhalgh@arm.com>
1420 * aarch64-tbl.h (aarch64_opcode_table): Add "csdb".
1421 * aarch64-asm-2.c: Regenerate.
1422 * aarch64-dis-2.c: Regenerate.
1423 * aarch64-opc-2.c: Regenerate.
1425 2018-01-08 H.J. Lu <hongjiu.lu@intel.com>
1428 * i386-opc.tbl: Properly encode vmovd with Qword memeory operand.
1429 Remove AVX512 vmovd with 64-bit operands.
1430 * i386-tbl.h: Regenerated.
1432 2018-01-05 Jim Wilson <jimw@sifive.com>
1434 * riscv-dis.c (print_insn_args) <'s'>: Call maybe_print_address for a
1437 2018-01-03 Alan Modra <amodra@gmail.com>
1439 Update year range in copyright notice of all files.
1441 2018-01-02 Jan Beulich <jbeulich@suse.com>
1443 * i386-gen.c (operand_type_init): Restore OPERAND_TYPE_REGYMM
1444 and OPERAND_TYPE_REGZMM entries.
1446 For older changes see ChangeLog-2017
1448 Copyright (C) 2018 Free Software Foundation, Inc.
1450 Copying and distribution of this file, with or without modification,
1451 are permitted in any medium without royalty provided the copyright
1452 notice and this notice are preserved.
1458 version-control: never