x86: allow VEX et al encodings in 16-bit (protected) mode
[deliverable/binutils-gdb.git] / gas / ChangeLog
index 216d17ede7f8ac2a8956d49a4dc34a0f4dbb4950..e08db78cc3279cf6157e325bab4806badacb99d9 100644 (file)
@@ -1,3 +1,969 @@
+2019-06-27  Jan Beulich  <jbeulich@suse.com>
+
+       config/tc-i386.c (md_assemble): Check for protected mode
+       incapable processor before encoding VEX and alike insns.
+       * testsuite/gas/i386/inval-16.s: For 80186 architecture.
+       * testsuite/gas/i386/inval-16.l: Adjust expectations.
+       * testsuite/gas/i386/avx-16bit.d,
+       testsuite/gas/i386/avx-16bit.s,
+       testsuite/gas/i386/avx512f-16bit.d,
+       testsuite/gas/i386/avx512f-16bit.s,
+       testsuite/gas/i386/bmi-16bit.d,
+       testsuite/gas/i386/bmi-16bit.s,
+       testsuite/gas/i386/bmi2-16bit.d,
+       testsuite/gas/i386/bmi2-16bit.s,
+       testsuite/gas/i386/lwp-16bit.d,
+       testsuite/gas/i386/lwp-16bit.s: New
+       testsuite/gas/i386/i386.exp: Run new tests.
+
+2019-06-26  Jim Wilson  <jimw@sifive.com>
+
+       * testsuite/gas/xstormy16/allinsn.sh: Change first line to
+       #!/bin/bash and make it executable.
+       * testsuite/gas/xstormy16/gcc.sh: Likewise.
+
+2019-06-26  Lili Cui  <lili.cui@intel.com>
+
+       * doc/c-i386.texi: Document x/y/z instruction sufffixes in AT&T
+       syntax and xmmword/ymmword/zmmword/fword/tbyte/oword ptr in
+       Intel syntax.
+
+2019-06-25  Faraz Shahbazker  <fshahbazker@wavecomp.com>
+
+       * config/tc-mips.c (macro) <M_LI>: Re-order MTHC1 with
+       respect to MTC1 and use $0 for either part where possible.
+       * testsuite/gas/mips/li-d.s: Add test cases for non-zero
+       words in double precision constants.
+       * testsuite/gas/mips/li-d.d: Update reference output.
+       * testsuite/gas/mips/micromips@isa-override-1.d: Likewise.
+       * testsuite/gas/mips/mips32r2@isa-override-1.d: Likewise.
+       * testsuite/gas/mips/mips64r2@isa-override-1.d: Likewise.
+
+2019-06-25  Jan Beulich  <jbeulich@suse.com>
+
+       * tc-i386.c (acc32, acc64): Delete.
+       (pi): Make first parameter pinter-to-const.
+       (type_names): Remove Acc. Add acc8, acc16, acc32, and acc64.
+       (pt): Use operand_type_equal().
+       (match_template): Replace use of acc32.
+       (process_suffix): Replace use of acc64.
+
+2019-06-25  Jan Beulich  <jbeulich@suse.com>
+
+       * doc/c-i386.texi: Mark -mavxscalar= and -mvexwig as dangrous to
+       use.
+
+2019-06-25  Jan Beulich  <jbeulich@suse.com>
+
+       * tc-i386.c (process_suffix): Use is_any_vex_encoding().
+
+2019-06-25  Jan Beulich  <jbeulich@suse.com>
+
+       * testsuite/gas/i386/sse2-16bit.d,
+       testsuite/gas/i386/sse2-16bit.s: New.
+       testsuite/gas/i386/i386.exp: Run new test.
+
+2019-06-25  Jan Beulich  <jbeulich@suse.com>
+
+       * config/tc-i386.c (optimize_encoding): Also handle ANDQ with
+       immediatie fitting in 7 bits.
+       * testsuite/gas/i386/x86-64-optimize-1.s: Add ANDQ cases with
+       7- and 8-bit immediates.
+       * testsuite/gas/i386/x86-64-optimize-1.d: Adjust expectations.
+
+2019-06-25  Jan Beulich  <jbeulich@suse.com>
+
+       * testsuite/gas/i386/xmmword.s: Add cvtps2pi and cvttps2pi
+       tests.
+       * testsuite/gas/i386/xmmword.l: Adjust expectations.
+
+2019-06-25  Alan Modra  <amodra@gmail.com>
+
+       * config/tc-ppc.c (ppc_handle_align): Add parentheses.
+
+2019-06-25  Alan Modra  <amodra@gmail.com>
+
+       * config/tc-ppc.h (ppc_nop_select): Declare.
+       (NOP_OPCODE): Define.
+       * config/tc-ppc.c (ppc_elf_end, ppc_xcoff_end): Zero ppc_cpu.
+       (ppc_nop_encoding_for_rs_align_code): New enum.
+       (ppc_nop_select): New function.
+       (ppc_handle_align): Don't use ppc_cpu here.  Get nop type from frag.
+       * testsuite/gas/ppc/groupnop.d,
+       * testsuite/gas/ppc/groupnop.s: New test.
+       * testsuite/gas/ppc/ppc.exp: Run it.
+
+2019-06-19  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR binutils/24700
+       * testsuite/gas/i386/disassem.s: Add test for vbroadcasti32x8
+       with invalid vector length.
+       * testsuite/gas/i386/x86-64-disassem.s: Likewise.
+       * testsuite/gas/i386/disassem.d: Updated.
+       * testsuite/gas/i386/x86-64-disassem.d: Likewise.
+
+2019-06-17  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR binutils/24691
+       * testsuite/gas/i386/disassem.s: Add test for vshuff32x4 with
+       invalid vector length.
+       * testsuite/gas/i386/x86-64-disassem.s: Likewise.
+       * testsuite/gas/i386/disassem.d: Updated.
+       * testsuite/gas/i386/x86-64-disassem.d: Likewise.
+
+2019-06-14  Alan Modra  <amodra@gmail.com>
+
+       * Makefile.in: Regenerate.
+       * configure: Regenerate.
+       * doc/Makefile.in: Regenerate.
+
+2019-06-12  Peter Bergner  <bergner@linux.ibm.com>
+
+       * testsuite/gas/ppc/power9.d: Delete ldmx tests.
+       * testsuite/gas/ppc/power9.s: Likewise.
+
+2019-06-06  Lili Cui  <lili.cui@intel.com>
+
+       * config/tc-i386.c (cpu_arch): Add .enqcmd.
+       (cpu_noarch): Add noenqcmd.
+       * doc/c-i386.texi: Document noenqcmd.
+
+2019-06-05  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR binutils/24633
+       * testsuite/gas/i386/disassem.s: Add tests for invalid vector
+       lengths for EVEX vextractfXX and vinsertfXX.
+       * testsuite/gas/i386/x86-64-disassem.s: Likewise.
+       * testsuite/gas/i386/disassem.d: Updated.
+       * testsuite/gas/i386/x86-64-disassem.d: Likewise.
+
+2019-06-04  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR binutils/24626
+       * testsuite/gas/i386/disassem.s: Add tests for reserved VEX.vvvv
+       and EVEX.vvvv.
+       * testsuite/gas/i386/x86-64-disassem.s: Likewise.
+       * testsuite/gas/i386/disassem.d: Updated.
+       * testsuite/gas/i386/x86-64-disassem.d: Likewise.
+
+2019-06-04  Igor Tsimbalist  <igor.v.tsimbalist@intel.com>
+           Lili Cui  <lili.cui@intel.com>
+
+       * config/tc-i386.c (cpu_arch): Add .avx512_vp2intersect.
+       (cpu_noarch): Likewise.
+       * doc/c-i386.texi: Document avx512_vp2intersect.
+       * testsuite/gas/i386/i386.exp: Run vp2intersect tests.
+       * testsuite/gas/i386/vp2intersect-intel.d: New test.
+       * testsuite/gas/i386/vp2intersect.d: Likewise.
+       * testsuite/gas/i386/vp2intersect.s: Likewise.
+       * testsuite/gas/i386/vp2intersect-inval-bcast.l: Likewise.
+       * testsuite/gas/i386/vp2intersect-inval-bcast.s: Likewise.
+       * testsuite/gas/i386/x86-64-vp2intersect-intel.d: Likewise.
+       * testsuite/gas/i386/x86-64-vp2intersect.d: Likewise.
+       * testsuite/gas/i386/x86-64-vp2intersect.s: Likewise.
+       * testsuite/gas/i386/x86-64-vp2intersect-inval-bcast.l: Likewise.
+       * testsuite/gas/i386/x86-64-vp2intersect-inval-bcast.s: Likewise.
+
+2019-06-04  Xuepeng Guo  <xuepeng.guo@intel.com>
+           Lili Cui  <lili.cui@intel.com>
+
+       * doc/c-i386.texi: Document enqcmd.
+       * testsuite/gas/i386/enqcmd-intel.d: New file.
+       * testsuite/gas/i386/enqcmd-inval.l: Likewise.
+       * testsuite/gas/i386/enqcmd-inval.s: Likewise.
+       * testsuite/gas/i386/enqcmd.d: Likewise.
+       * testsuite/gas/i386/enqcmd.s: Likewise.
+       * testsuite/gas/i386/x86-64-enqcmd-intel.d: Likewise.
+       * testsuite/gas/i386/x86-64-enqcmd-inval.l: Likewise.
+       * testsuite/gas/i386/x86-64-enqcmd-inval.s: Likewise.
+       * testsuite/gas/i386/x86-64-enqcmd.d: Likewise.
+       * testsuite/gas/i386/x86-64-enqcmd.s: Likewise.
+       * testsuite/gas/i386/i386.exp: Run enqcmd-intel, enqcmd-inval,
+       enqcmd, x86-64-enqcmd-intel, x86-64-enqcmd-inval,
+       and x86-64-enqcmd.
+
+2019-05-30  Jim Wilson  <jimw@sifive.com>
+
+       * config/tc-riscv.c (riscv_ip) <'u'>: Move O_constant check inside if
+       statement.  Delete O_symbol and O_constant check after if statement.
+       * testsuite/gas/riscv/auipc-parsing.s: Test lui with missing %hi.
+       * testsuite/gas/riscv/auipc-parsing.l: Update.
+
+2019-05-28  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR gas/24625
+       * testsuite/gas/i386/inval-avx512f.s: Add tests for AVX512_BF16
+       instructions with invalid broadcast.
+       * testsuite/gas/i386/x86-64-inval-avx512f.s: Likewise.
+       * testsuite/gas/i386/inval-avx512f.l: Updated.
+       * testsuite/gas/i386/x86-64-inval-avx512f.l: Likewise.
+
+2019-05-27  Alan Modra  <amodra@gmail.com>
+
+       * config/tc-ppc.c (is_ppc64_target): New function.
+       (md_show_usage): Split up usage message.  Don't show -a64 when
+       unsupported.
+       testsuite/gas/ppc/ppc.exp (supports_ppc64): New.
+       (prefix-reloc): Only run for ppc64.
+
+2019-05-24  Szabolcs Nagy  <szabolcs.nagy@arm.com>
+
+       * config/tc-aarch64.c (aarch64_elf_copy_symbol_attributes): Define.
+       * config/tc-aarch64.h (aarch64_elf_copy_symbol_attributes): Declare.
+       (OBJ_COPY_SYMBOL_ATTRIBUTES): Define.
+       * testsuite/gas/aarch64/symbol-variant_pcs-3.d: New test.
+       * testsuite/gas/aarch64/symbol-variant_pcs-3.s: New test.
+
+2019-05-24  Szabolcs Nagy  <szabolcs.nagy@arm.com>
+
+       * config/tc-aarch64.c (s_variant_pcs): New function.
+       * doc/c-aarch64.texi: Document .variant_pcs.
+       * testsuite/gas/aarch64/symbol-variant_pcs-1.d: New test.
+       * testsuite/gas/aarch64/symbol-variant_pcs-1.s: New test.
+       * testsuite/gas/aarch64/symbol-variant_pcs-2.d: New test.
+       * testsuite/gas/aarch64/symbol-variant_pcs-2.s: New test.
+
+2019-05-24  Alan Modra  <amodra@gmail.com>
+
+       * po/POTFILES.in: Regenerate.
+
+2019-05-24  Alan Modra  <amodra@gmail.com>
+
+       * config/tc-ppc.c (ppc_elf_suffix): Support @pcrel, @got@pcrel,
+       @plt@pcrel, @higher34, @highera34, @highest34, and @highesta34.
+       (fixup_size): Handle new powerxx relocs.
+       (md_assemble): Warn for @pcrel on non-prefix insns.
+       Accept @l, @h and @ha on prefix insns, and infer reloc without
+       any @ suffix.  Translate powerxx relocs to suit DQ and DS field
+       instructions.  Include operand tests as well as opcode test to
+       translate BFD_RELOC_HI16_S to BFD_RELOC_PPC_16DX_HA.
+       (ppc_fix_adjustable): Return false for pcrel GOT and PLT relocs.
+       (md_apply_fix): Handle new powerxx relocs.
+       * config/tc-ppc.h (TC_FORCE_RELOCATION_SUB_LOCAL): Accept
+       BFD_RELOC_PPC64_ADDR16_HIGHER34, BFD_RELOC_PPC64_ADDR16_HIGHERA34,
+       BFD_RELOC_PPC64_ADDR16_HIGHEST34, BFD_RELOC_PPC64_ADDR16_HIGHESTA34,
+       BFD_RELOC_PPC64_D34, and BFD_RELOC_PPC64_D28.
+       * testsuite/gas/ppc/prefix-reloc.d,
+       * testsuite/gas/ppc/prefix-reloc.s: New test.
+       * testsuite/gas/ppc/ppc.exp: Run it.
+
+2019-05-24  Peter Bergner  <bergner@linux.ibm.com>
+           Alan Modra  <amodra@gmail.com>
+
+       * config/tc-ppc.c (ppc_insert_operand): Only sign extend fields that
+       are 32-bits or smaller.
+       * messages.c (as_internal_value_out_of_range): Do not truncate
+       variables and use BFD_VMA_FMT to print them.
+       * testsuite/gas/ppc/prefix-pcrel.s,
+       * testsuite/gas/ppc/prefix-pcrel.d: New test.
+       * testsuite/gas/ppc/ppc.exp: Run it.
+
+2019-05-24  Peter Bergner  <bergner@linux.ibm.com>
+           Alan Modra  <amodra@gmail.com>
+
+       * config/tc-ppc.c (ppc_setup_opcodes): Handle prefix_opcodes.
+       (struct insn_label_list): New.
+       (insn_labels, free_insn_labels): New variables.
+       (ppc_record_label, ppc_clear_labels, ppc_start_line_hook): New funcs.
+       (ppc_frob_label, ppc_new_dot_label): Move functions earlier in file
+       and call ppc_record_label.
+       (md_assemble): Handle 64-bit prefix instructions.  Align labels
+       that are on the same line as a prefix instruction.
+       * config/tc-ppc.h (tc_frob_label, ppc_frob_label): Move to
+       later in the file.
+       (md_start_line_hook): Define.
+       (ppc_start_line_hook): Declare.
+       * testsuite/gas/ppc/prefix-align.d,
+       * testsuite/gas/ppc/prefix-align.s: New test.
+       * testsuite/gas/ppc/ppc.exp: Run new test.
+
+2019-05-23  Jose E. Marchesi  <jose.marchesi@oracle.com>
+
+       * configure.ac: Handle bpf-*-* targets.
+       * configure.tgt (generic_target): Likewise.
+       * configure: Regenerate.
+       * Makefile.am (TARGET_CPU_CFILES): Add tc-bpf.c.
+       (TARGET_CPU_HFILES): Add tc-bpf.h.
+       * Makefile.in: Regenerated.
+       * config/tc-bpf.c: New file.
+       * config/tc-bpf.h: Likewise.
+       * doc/Makefile.am (CPU_DOCS): Add c-bpf.texi.
+       * doc/Makefile.in: Regenerated.
+       * doc/all.texi: set BPF.
+       * doc/as.texi: Add eBPF contents.
+       * doc/c-bpf.texi: New file.
+       * testsuite/gas/bpf/alu.d: New file.
+       * testsuite/gas/bpf/mem-be.d: Likewise.
+       * testsuite/gas/bpf/mem.s: Likewise.
+       * testsuite/gas/bpf/mem.d: Likewise.
+       * testsuite/gas/bpf/lddw-be.d: Likewise.
+       * testsuite/gas/bpf/lddw.s: Likewise.
+       * testsuite/gas/bpf/lddw.d: Likewise.
+       * testsuite/gas/bpf/jump-be.d: Likewise.
+       * testsuite/gas/bpf/jump.s: Likewise.
+       * testsuite/gas/bpf/jump.d: Likewise.
+       * testsuite/gas/bpf/exit-be.d: Likewise.
+       * testsuite/gas/bpf/exit.s: Likewise.
+       * testsuite/gas/bpf/exit.d: Likewise.
+       * testsuite/gas/bpf/call-be.d: Likewise.
+       * testsuite/gas/bpf/call.s: Likewise.
+       * testsuite/gas/bpf/call.d: Likewise.
+       * testsuite/gas/bpf/bpf.exp: Likewise.
+       * testsuite/gas/bpf/atomic-be.d: Likewise.
+       * testsuite/gas/bpf/atomic.s: Likewise.
+       * testsuite/gas/bpf/atomic.d: Likewise.
+       * testsuite/gas/bpf/alu-be.d: Likewise.
+       * testsuite/gas/bpf/alu32-be.d: Likewise.
+       * testsuite/gas/bpf/alu32.s: Likewise.
+       * testsuite/gas/bpf/alu32.d: Likewise.
+       * testsuite/gas/bpf/alu.s: Likewise.
+       * testsuite/gas/all/gas.exp: Introduce a nop_type for eBPF.
+       * testsuite/gas/all/org-1.s: Support nop_type 6.
+       * testsuite/gas/all/org-1.l: Updated to reflect changes in
+       org-1.s.
+
+2019-05-22  John Darrington <john@darrington.wattle.id.au>
+
+       * config/tc-s12z.c (s12z_strtol): New function. (md_show_usage): Update.
+       (md_parse_option): new case OPTION_DOLLAR_HEX. (s12z_init_after_args):
+       (<global>): Use s12z_strtol instead of strtol.
+       * doc/c-s12z.texi (S12Z Options): Document new option -mdollar-hex.
+       * testsuite/gas/s12z/dollar-hex.d: New file.
+       * testsuite/gas/s12z/dollar-hex.s: New file.
+       * testsuite/gas/s12z/s12z.exp: Add them.
+
+2019-05-21  Sudakshina Das  <sudi.das@arm.com>
+
+       * config/tc-arm.c (parse_operands): Update case OP_RVC to
+       parse p0 and P0.
+       (do_vmrs): Add checks for valid operands with respect to
+       cpu and fpu options.
+       (do_vmsr): Likewise.
+       (reg_names): New reg_names for FPSCR_nzcvqc, VPR, FPCXT_NS
+       and FPCXT_S.
+       * testsuite/gas/arm/armv8_1-m-spec-reg.d: New.
+       * testsuite/gas/arm/armv8_1-m-spec-reg.s: New.
+       * testsuite/gas/arm/armv8_1-m-spec-reg-bad1.d: New.
+       * testsuite/gas/arm/armv8_1-m-spec-reg-bad2.d: New.
+       * testsuite/gas/arm/armv8_1-m-spec-reg-bad3.d: New.
+       * testsuite/gas/arm/armv8_1-m-spec-reg-bad1.l: New.
+       * testsuite/gas/arm/armv8_1-m-spec-reg-bad2.l: New.
+       * testsuite/gas/arm/armv8_1-m-spec-reg-bad3.l: New.
+       * testsuite/gas/arm/vfp1xD.d: Updated to allow new valid values.
+       * testsuite/gas/arm/vfp1xD_t2.d: Likewise.
+
+2019-05-21  Sudakshina Das  <sudi.das@arm.com>
+
+       * config/tc-arm.c (TOGGLE_BIT): New.
+       (T16_32_TAB): New entries for cinc, cinv, cneg, csinc,
+       csinv, csneg, cset, csetm and csel.
+       (operand_parse_code): New OP_RR_ZR.
+       (parse_operand): Handle case for OP_RR_ZR.
+       (do_t_cond): New.
+       (insns): New instructions for cinc, cinv, cneg, csinc,
+       csinv, csneg, cset, csetm, csel.
+       * testsuite/gas/arm/armv8_1-m-cond-bad.d: New test.
+       * testsuite/gas/arm/armv8_1-m-cond-bad.l: New test.
+       * testsuite/gas/arm/armv8_1-m-cond-bad.s: New test.
+       * testsuite/gas/arm/armv8_1-m-cond.d: New test.
+       * testsuite/gas/arm/armv8_1-m-cond.s: New test.
+
+2019-05-21  Sudakshina Das  <sudi.das@arm.com>
+
+       * config/tc-arm.c (operand_parse_code): New entries for
+       OP_RRnpcsp_I32 (register or integer operands).
+       (do_mve_scalar_shift): New.
+       (insns): New instructions for asrl, lsll, lsrl, sqrshrl, sqrshr, sqshl
+       sqshll, srshr, srshrl, uqrshll, uqrshl, uqshll, uqshl, urshrl and urshr.
+       * testsuite/gas/arm/mve-shift.d: New.
+       * testsuite/gas/arm/mve-shift.s: New.
+       * testsuite/gas/arm/mve-shift-bad.d: New.
+       * testsuite/gas/arm/mve-shift-bad.s: New.
+       * testsuite/gas/arm/mve-shift-bad.l: New.
+
+2019-05-21  Faraz Shahbazker  <fshahbazker@wavecomp.com>
+
+       * testsuite/gas/mips/r6-branch-constraints.s: Rename to ...
+       * testsuite/gas/mips/r6-reg-constraints.s: this and add test
+       case for DAUI.
+       * testsuite/gas/mips/r6-branch-constraints.l: Rename to ...
+       * testsuite/gas/mips/r6-reg-constraints.l: this and add test
+       for DAUI.
+       * testsuite/gas/mips/mips.exp: Rename test from
+       r6-branch-constraints to r6-reg-constraints.
+
+2019-05-21  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       PR 24559
+       * config/tc-arm.c (move_or_literal_pool): Set size_req to 0 for MOVW
+       replacement.
+       * testsuite/gas/arm/load-pseudo.s: New test input.
+       * testsuite/gas/arm/m0-load-pseudo.d: New test.
+       * testsuite/gas/arm/m23-load-pseudo.d: New test.
+       * testsuite/gas/arm/m33-load-pseudo.d: New test.
+
+2019-05-21  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * testsuite/gas/arm/armv8_1-m-bf.d: Allow different branch target naming
+       conventions.
+       * testsuite/gas/arm/armv8_1-m-bfl.d: Likewise.
+       * testsuite/gas/arm/armv8_1-m-bfcsel.d: Likewise.
+       * testsuite/gas/arm/armv8_1-m-loloop.d: Likewise.
+       * testsuite/gas/arm/armv8_1-m-bf-rel.d: Skip for vxworks.
+       * testsuite/gas/arm/armv8_1-m-bf-rela.d: New test.
+       * testsuite/gas/arm/armv8_1-m-bfl-rel.d: Skip for vxworks.
+       * testsuite/gas/arm/armv8_1-m-bfl-rela.d: New test.
+
+2019-05-21  John Darrington <john@darrington.wattle.id.au>
+
+       * expr.c (literal_prefix_dollar_hex): New variable.
+       (operand)[case '$']: Use the new variable instead of the old macro.
+       Also, move this instance of "case '$'" next to the other one, and
+       enable it only in the complementary proprocessor case.
+       * expr.h (literal_prefix_dollar_hex): Declare it.
+       * config/tc-epiphany.c (md_begin): Assign literal_prefix_dollar_hex.
+       * config/tc-ip2k.c:      ditto
+       * config/tc-mt.c:        ditto
+       * config/tc-epiphany.h (LITERAL_PREFIXDOLLAR_HEX): Remove macro definition.
+       * config/tc-ip2k.h:      ditto
+       * config/tc-mt.h:        ditto
+
+2019-05-20  Faraz Shahbazker  <fshahbazker@wavecomp.com>
+
+       PR 14798
+       * config/tc-mips.c (s_mips_globl): Only treat symbols that are
+       not explicitly labelled as BSF_OBJECTs for IRIX targets.
+       * testsuite/gas/mips/pr14798.s: New test source.
+       * testsuite/gas/mips/pr14798-irix.d: New test.
+       * testsuite/gas/mips/pr14798.d: Likewise.
+       * testsuite/gas/mips/mips.exp: Run the new tests.
+
+2019-05-17  John Darrington  <john@darrington.wattle.id.au>
+
+       * doc/c-arm.texi (ARM Options): Remove "(r)" and "(tm)"
+       * doc/c-bfin.texi (Blackfin Syntax): Remove "(r)"
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (check_simd_pred_availability): Refactor.
+       (do_neon_dyadic_i_su): Refactor use of check_simd_pred_availability.
+       (do_neon_dyadic_i64_su): Likewise.
+       (do_neon_shl): Likewise.
+       (do_neon_qshl): Likewise.
+       (do_neon_rshl): Likewise.
+       (do_neon_logic): Likewise.
+       (do_neon_dyadic_if_su): Likewise.
+       (do_neon_addsub_if_i): Likewise.
+       (do_neon_mac_maybe_scalar): Likewise.
+       (do_neon_fmac): Likewise.
+       (do_neon_mul): Likewise.
+       (do_neon_qdmulh): Likewise.
+       (do_neon_qrdmlah): Likewise.
+       (do_neon_abs_neg): Likewise.
+       (do_neon_sli): Likewise.
+       (do_neon_sri): Likewise.
+       (do_neon_qshlu_imm): Likewise.
+       (do_neon_cvt_1): Likewise.
+       (do_neon_cvttb_1): Likewise.
+       (do_neon_mvn): Likewise.
+       (do_neon_rev): Likewise.
+       (do_neon_dup): Likewise.
+       (do_neon_mov): Likewise.
+       (do_neon_rshift_round_imm): Likewise.
+       (do_neon_sat_abs_neg): Likewise.
+       (do_neon_cls): Likewise.
+       (do_neon_clz): Likewise.
+       (do_vmaxnm): Likewise.
+       (do_vrint_1): Likewise.
+       (do_vcmla): Likewise.
+       (do_vcadd): Likewise.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * NEWS: Mention Armv8.1-M Mainline and MVE.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * testsuite/gas/arm/mve-tailpredloop.d: New test.
+       * testsuite/gas/arm/mve-tailpredloop.s: New test.
+       * testsuite/gas/arm/mve-vabav.d: New test.
+       * testsuite/gas/arm/mve-vabav.s: New test.
+       * testsuite/gas/arm/mve-vabd.d: New test.
+       * testsuite/gas/arm/mve-vabd.s: New test.
+       * testsuite/gas/arm/mve-vabsneg.d: New test.
+       * testsuite/gas/arm/mve-vabsneg.s: New test.
+       * testsuite/gas/arm/mve-vadc.d: New test.
+       * testsuite/gas/arm/mve-vadc.s: New test.
+       * testsuite/gas/arm/mve-vaddlv.d: New test.
+       * testsuite/gas/arm/mve-vaddlv.s: New test.
+       * testsuite/gas/arm/mve-vaddsub.d: New test.
+       * testsuite/gas/arm/mve-vaddsub.s: New test.
+       * testsuite/gas/arm/mve-vaddv.d: New test.
+       * testsuite/gas/arm/mve-vaddv.s: New test.
+       * testsuite/gas/arm/mve-vand.d: New test.
+       * testsuite/gas/arm/mve-vand.s: New test.
+       * testsuite/gas/arm/mve-vbic.d: New test.
+       * testsuite/gas/arm/mve-vbic.s: New test.
+       * testsuite/gas/arm/mve-vbrsr.d: New test.
+       * testsuite/gas/arm/mve-vbrsr.s: New test.
+       * testsuite/gas/arm/mve-vcadd.d: New test.
+       * testsuite/gas/arm/mve-vcadd.s: New test.
+       * testsuite/gas/arm/mve-vcls.d: New test.
+       * testsuite/gas/arm/mve-vcls.s: New test.
+       * testsuite/gas/arm/mve-vclz.d: New test.
+       * testsuite/gas/arm/mve-vclz.s: New test.
+       * testsuite/gas/arm/mve-vcmla.d: New test.
+       * testsuite/gas/arm/mve-vcmla.s: New test.
+       * testsuite/gas/arm/mve-vcmp.d: New test.
+       * testsuite/gas/arm/mve-vcmp.s: New test.
+       * testsuite/gas/arm/mve-vcmul.d: New test.
+       * testsuite/gas/arm/mve-vcmul.s: New test.
+       * testsuite/gas/arm/mve-vcvt-1.d: New test.
+       * testsuite/gas/arm/mve-vcvt-1.s: New test.
+       * testsuite/gas/arm/mve-vcvt-2.d: New test.
+       * testsuite/gas/arm/mve-vcvt-2.s: New test.
+       * testsuite/gas/arm/mve-vcvt-3.d: New test.
+       * testsuite/gas/arm/mve-vcvt-3.s: New test.
+       * testsuite/gas/arm/mve-vcvt-4.d: New test.
+       * testsuite/gas/arm/mve-vcvt-4.s: New test.
+       * testsuite/gas/arm/mve-vddup.d: New test.
+       * testsuite/gas/arm/mve-vddup.s: New test.
+       * testsuite/gas/arm/mve-vdup.d: New test.
+       * testsuite/gas/arm/mve-vdup.s: New test.
+       * testsuite/gas/arm/mve-veor.d: New test.
+       * testsuite/gas/arm/mve-veor.s: New test.
+       * testsuite/gas/arm/mve-vfma-vfms.d: New test.
+       * testsuite/gas/arm/mve-vfma-vfms.s: New test.
+       * testsuite/gas/arm/mve-vfmas.d: New test.
+       * testsuite/gas/arm/mve-vfmas.s: New test.
+       * testsuite/gas/arm/mve-vhadd-vhsub-vrhadd.d: New test.
+       * testsuite/gas/arm/mve-vhadd-vhsub-vrhadd.s: New test.
+       * testsuite/gas/arm/mve-vhcadd.d: New test.
+       * testsuite/gas/arm/mve-vhcadd.s: New test.
+       * testsuite/gas/arm/mve-vmax-vmin.d: New test.
+       * testsuite/gas/arm/mve-vmax-vmin.s: New test.
+       * testsuite/gas/arm/mve-vmaxa-vmina.d: New test.
+       * testsuite/gas/arm/mve-vmaxa-vmina.s: New test.
+       * testsuite/gas/arm/mve-vmaxnm-vminnm.d: New test.
+       * testsuite/gas/arm/mve-vmaxnm-vminnm.s: New test.
+       * testsuite/gas/arm/mve-vmaxnma-vminnma.s: New test.
+       * testsuite/gas/arm/mve-vmaxnmv-vminnmv.d: New test.
+       * testsuite/gas/arm/mve-vmaxnmv-vminnmv.s: New test.
+       * testsuite/gas/arm/mve-vmaxv-vminv.d: New test.
+       * testsuite/gas/arm/mve-vmaxv-vminv.s: New test.
+       * testsuite/gas/arm/mve-vmla.d: New test.
+       * testsuite/gas/arm/mve-vmla.s: New test.
+       * testsuite/gas/arm/mve-vmladav.d: New test.
+       * testsuite/gas/arm/mve-vmladav.s: New test.
+       * testsuite/gas/arm/mve-vmlaldav.d: New test.
+       * testsuite/gas/arm/mve-vmlaldav.s: New test.
+       * testsuite/gas/arm/mve-vmlalv.d: New test.
+       * testsuite/gas/arm/mve-vmlalv.s: New test.
+       * testsuite/gas/arm/mve-vmlas.d: New test.
+       * testsuite/gas/arm/mve-vmlas.s: New test.
+       * testsuite/gas/arm/mve-vmlav.d: New test.
+       * testsuite/gas/arm/mve-vmlav.s: New test.
+       * testsuite/gas/arm/mve-vmlsdav.d: New test.
+       * testsuite/gas/arm/mve-vmlsdav.s: New test.
+       * testsuite/gas/arm/mve-vmlsldav.d: New test.
+       * testsuite/gas/arm/mve-vmlsldav.s: New test.
+       * testsuite/gas/arm/mve-vmov-1.d: New test.
+       * testsuite/gas/arm/mve-vmov-1.s: New test.
+       * testsuite/gas/arm/mve-vmov-2.d: New test.
+       * testsuite/gas/arm/mve-vmov-2.s: New test.
+       * testsuite/gas/arm/mve-vmul.d: New test.
+       * testsuite/gas/arm/mve-vmul.s: New test.
+       * testsuite/gas/arm/mve-vmulh.d: New test.
+       * testsuite/gas/arm/mve-vmulh.s: New test.
+       * testsuite/gas/arm/mve-vmullbt.d: New test.
+       * testsuite/gas/arm/mve-vmullbt.s: New test.
+       * testsuite/gas/arm/mve-vmvn.d: New test.
+       * testsuite/gas/arm/mve-vmvn.s: New test.
+       * testsuite/gas/arm/mve-vorn.d: New test.
+       * testsuite/gas/arm/mve-vorn.s: New test.
+       * testsuite/gas/arm/mve-vorr.d: New test.
+       * testsuite/gas/arm/mve-vorr.s: New test.
+       * testsuite/gas/arm/mve-vpnot.d: New test.
+       * testsuite/gas/arm/mve-vpnot.s: New test.
+       * testsuite/gas/arm/mve-vpsel.d: New test.
+       * testsuite/gas/arm/mve-vpsel.s: New test.
+       * testsuite/gas/arm/mve-vpt.d: New test.
+       * testsuite/gas/arm/mve-vpt.s: New test.
+       * testsuite/gas/arm/mve-vqabsneg.s: New test.
+       * testsuite/gas/arm/mve-vqaddsub.d: New test.
+       * testsuite/gas/arm/mve-vqaddsub.s: New test.
+       * testsuite/gas/arm/mve-vqdmladh.d: New test.
+       * testsuite/gas/arm/mve-vqdmladh.s: New test.
+       * testsuite/gas/arm/mve-vqdmlah.d: New test.
+       * testsuite/gas/arm/mve-vqdmlah.s: New test.
+       * testsuite/gas/arm/mve-vqdmlash.d: New test.
+       * testsuite/gas/arm/mve-vqdmlash.s: New test.
+       * testsuite/gas/arm/mve-vqdmlsdh.d: New test.
+       * testsuite/gas/arm/mve-vqdmlsdh.s: New test.
+       * testsuite/gas/arm/mve-vqdmulh.d: New test.
+       * testsuite/gas/arm/mve-vqdmulh.s: New test.
+       * testsuite/gas/arm/mve-vqdmull.d: New test.
+       * testsuite/gas/arm/mve-vqdmull.s: New test.
+       * testsuite/gas/arm/mve-vqmovn.d: New test.
+       * testsuite/gas/arm/mve-vqmovn.s: New test.
+       * testsuite/gas/arm/mve-vqrshl.d: New test.
+       * testsuite/gas/arm/mve-vqrshl.s: New test.
+       * testsuite/gas/arm/mve-vqrshrn.d: New test.
+       * testsuite/gas/arm/mve-vqrshrn.s: New test.
+       * testsuite/gas/arm/mve-vqshl.d: New test.
+       * testsuite/gas/arm/mve-vqshl.s: New test.
+       * testsuite/gas/arm/mve-vrev.d: New test.
+       * testsuite/gas/arm/mve-vrev.s: New test.
+       * testsuite/gas/arm/mve-vrint.d: New test.
+       * testsuite/gas/arm/mve-vrint.s: New test.
+       * testsuite/gas/arm/mve-vrmlaldavh.d: New test.
+       * testsuite/gas/arm/mve-vrmlaldavh.s: New test.
+       * testsuite/gas/arm/mve-vrshl.d: New test.
+       * testsuite/gas/arm/mve-vrshl.s: New test.
+       * testsuite/gas/arm/mve-vsbc.d: New test.
+       * testsuite/gas/arm/mve-vsbc.s: New test.
+       * testsuite/gas/arm/mve-vshl.d: New test.
+       * testsuite/gas/arm/mve-vshl.s: New test.
+       * testsuite/gas/arm/mve-vshlc.d: New test.
+       * testsuite/gas/arm/mve-vshlc.s: New test.
+       * testsuite/gas/arm/mve-vshll.d: New test.
+       * testsuite/gas/arm/mve-vshll.s: New test.
+       * testsuite/gas/arm/mve-vshr.d: New test.
+       * testsuite/gas/arm/mve-vshr.s: New test.
+       * testsuite/gas/arm/mve-vshrn.d: New test.
+       * testsuite/gas/arm/mve-vshrn.s: New test.
+       * testsuite/gas/arm/mve-vsli.d: New test.
+       * testsuite/gas/arm/mve-vsli.s: New test.
+       * testsuite/gas/arm/mve-vsri.d: New test.
+       * testsuite/gas/arm/mve-vsri.s: New test.
+       * testsuite/gas/arm/mve-vstld.d: New test.
+       * testsuite/gas/arm/mve-vstld.s: New test.
+       * testsuite/gas/arm/mve-vstrldr-1.d: New test.
+       * testsuite/gas/arm/mve-vstrldr-1.s: New test.
+       * testsuite/gas/arm/mve-vstrldr-2.d: New test.
+       * testsuite/gas/arm/mve-vstrldr-2.s: New test.
+       * testsuite/gas/arm/mve-vstrldr-3.d: New test.
+       * testsuite/gas/arm/mve-vstrldr-3.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (T16_32_TAB): Add new instructions.
+       (do_t_loloop): Changed to handle tail predication variants.
+       (md_apply_fix): Likewise.
+       (insns): Add entries for MVE mnemonics.
+       * testsuite/gas/arm/mve-tailpredloop-bad.d: New test.
+       * testsuite/gas/arm/mve-tailpredloop-bad.l: New test.
+       * testsuite/gas/arm/mve-tailpredloop-bad.s: New test.
+       * testsuite/gas/arm/mve-tailpredloop.d: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (do_mve_vshll): New encoding function.
+       (do_mve_vshlc): Likewise.
+       (insns): Add entries for MVE mnemonics.
+       * testsuite/gas/arm/mve-vshlc-bad.d: New test.
+       * testsuite/gas/arm/mve-vshlc-bad.l: New test.
+       * testsuite/gas/arm/mve-vshlc-bad.s: New test.
+       * testsuite/gas/arm/mve-vshll-bad.d: New test.
+       * testsuite/gas/arm/mve-vshll-bad.l: New test.
+       * testsuite/gas/arm/mve-vshll-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (enum operand_parse_code): Add new operand.
+       (parse_operands): Handle new operand.
+       (do_neon_shl_imm): Accept MVE variants.
+       (do_neon_shl): Likewise.
+       (do_neon_qshl_imm): Likewise.
+       (do_neon_qshl): Likewise.
+       (do_neon_qshlu_imm): Likewise.
+       (insns): Likewise.
+       * testsuite/gas/arm/mve-vqshl-bad.d: New test.
+       * testsuite/gas/arm/mve-vqshl-bad.l: New test.
+       * testsuite/gas/arm/mve-vqshl-bad.s: New test.
+       * testsuite/gas/arm/mve-vshl-bad.d: New test.
+       * testsuite/gas/arm/mve-vshl-bad.l: New test.
+       * testsuite/gas/arm/mve-vshl-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (do_neon_sli): Accept MVE variants.
+       (do_neon_sri): Likewise.
+       (do_neon_rev): Likewise.
+       (do_neon_rshift_round_imm): Likewise.
+       (insns): Likewise.
+       * testsuite/gas/arm/mve-vrev-bad.d: New test.
+       * testsuite/gas/arm/mve-vrev-bad.l: New test.
+       * testsuite/gas/arm/mve-vrev-bad.s: New test.
+       * testsuite/gas/arm/mve-vshr-bad.d: New test.
+       * testsuite/gas/arm/mve-vshr-bad.l: New test.
+       * testsuite/gas/arm/mve-vshr-bad.s: New test.
+       * testsuite/gas/arm/mve-vsli-bad.d: New test.
+       * testsuite/gas/arm/mve-vsli-bad.l: New test.
+       * testsuite/gas/arm/mve-vsli-bad.s: New test.
+       * testsuite/gas/arm/mve-vsri-bad.d: New test.
+       * testsuite/gas/arm/mve-vsri-bad.l: New test.
+       * testsuite/gas/arm/mve-vsri-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (do_vrint_1): Accept MVE variants.
+       (insns): Change entries to accept MVE variants.
+       * testsuite/gas/arm/mve-vrint-bad.d: New test.
+       * testsuite/gas/arm/mve-vrint-bad.l: New test.
+       * testsuite/gas/arm/mve-vrint-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (M_MNEM_vshrnt, M_MNEM_vshrnb, M_MNEM_vrshrnt,
+        M_MNEM_vqshrnt, M_MNEM_vqshrnb, M_MNEM_vqshrunt, M_MNEM_vqshrunb,
+        M_MNEM_vrshrnb, M_MNEM_vqrshrnt, M_MNEM_vqrshrnb, M_MNEM_vqrshrunt,
+        M_MNEM_vqrshrunb): New instruction encodings.
+       (do_mve_vshrn): New encoding function.
+       (insns): Add entries for MVE mnemonics.
+       * testsuite/gas/arm/mve-vqrshrn-bad.d: New test.
+       * testsuite/gas/arm/mve-vqrshrn-bad.l: New test.
+       * testsuite/gas/arm/mve-vqrshrn-bad.s: New test.
+       * testsuite/gas/arm/mve-vshrn-bad.d: New test.
+       * testsuite/gas/arm/mve-vshrn-bad.l: New test.
+       * testsuite/gas/arm/mve-vshrn-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (M_MNEM_vqmovnt, M_MNEM_vqmovnb,
+        M_MNEM_vqmovunt, M_MNEM_vqmovunb): New instruction encodings.
+       (do_mve_vqmovn): New encoding function.
+       (do_neon_rshl): Change to accepte MVE variants.
+       (insns): Change entries and add new for MVE mnemonics.
+       * testsuite/gas/arm/mve-vqmovn-bad.d: New test.
+       * testsuite/gas/arm/mve-vqmovn-bad.l: New test.
+       * testsuite/gas/arm/mve-vqmovn-bad.s: New test.
+       * testsuite/gas/arm/mve-vqrshl-bad.d: New test.
+       * testsuite/gas/arm/mve-vqrshl-bad.l: New test.
+       * testsuite/gas/arm/mve-vqrshl-bad.s: New test.
+       * testsuite/gas/arm/mve-vrshl-bad.d: New test.
+       * testsuite/gas/arm/mve-vrshl-bad.l: New test.
+       * testsuite/gas/arm/mve-vrshl-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (enum operand_parse_code): Add new operand.
+       (parse_operands): Handle new operand.
+       (do_mve_vqdmull): New encoding function.
+       (insns): Add entry for MVE mnemonics.
+       * testsuite/gas/arm/mve-vqdmull-bad.d: New test.
+       * testsuite/gas/arm/mve-vqdmull-bad.l: New test.
+       * testsuite/gas/arm/mve-vqdmull-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (enum operand_parse_code): Add new operand.
+       (parse_operands): Handle new operand.
+       (mve_encode_qqr): Handle new instructions.
+       (do_neon_qdmulh): Add support for MVE variants.
+       (do_neon_qrdmlah): Likewise.
+       (do_mve_vqdmlah): New encoding function.
+       (insns): Change entries and add new entries for MVE mnemonics.
+       * testsuite/gas/arm/mve-vqdmulh-bad.d: New test.
+       * testsuite/gas/arm/mve-vqdmulh-bad.l: New test.
+       * testsuite/gas/arm/mve-vqdmulh-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (do_mve_vqdmladh): New encoding function.
+       (insns): Add entries for MVE mnemonics.
+       * testsuite/gas/arm/mve-vqdmladh-bad.d: New test.
+       * testsuite/gas/arm/mve-vqdmladh-bad.l: New test.
+       * testsuite/gas/arm/mve-vqdmladh-bad.s: New test.
+       * testsuite/gas/arm/mve-vqdmlsdh-bad.d: New test.
+       * testsuite/gas/arm/mve-vqdmlsdh-bad.l: New test.
+       * testsuite/gas/arm/mve-vqdmlsdh-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (do_mve_vpsel): New encoding function.
+       (do_mve_vpnot): Likewise.
+       (insns): Add entries for MVE mnemonics.
+       * testsuite/gas/arm/mve-vpnot-bad.d: New test.
+       * testsuite/gas/arm/mve-vpnot-bad.l: New test.
+       * testsuite/gas/arm/mve-vpnot-bad.s: New test.
+       * testsuite/gas/arm/mve-vpsel-bad.d: New test.
+       * testsuite/gas/arm/mve-vpsel-bad.l: New test.
+       * testsuite/gas/arm/mve-vpsel-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (do_neon_mvn): Change to accept MVE variants.
+       (do_neon_sat_abs_neg): Likewise.
+       (insns): Likewise.
+       * testsuite/gas/arm/mve-vmvn-bad.d: New test.
+       * testsuite/gas/arm/mve-vmvn-bad.l: New test.
+       * testsuite/gas/arm/mve-vmvn-bad.s: New test.
+       * testsuite/gas/arm/mve-vqabsneg-bad.d: New test.
+       * testsuite/gas/arm/mve-vqabsneg-bad.l: New test.
+       * testsuite/gas/arm/mve-vqabsneg-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (do_mve_vmlas): New encoding function.
+       (do_mve_vmulh): Likewise.
+       (insns): Add entries for MVE mnemonics.
+       * testsuite/gas/arm/mve-vmlas-bad.d: New test.
+       * testsuite/gas/arm/mve-vmlas-bad.l: New test.
+       * testsuite/gas/arm/mve-vmlas-bad.s: New test.
+       * testsuite/gas/arm/mve-vmulh-bad.d: New test.
+       * testsuite/gas/arm/mve-vmulh-bad.l: New test.
+       * testsuite/gas/arm/mve-vmulh-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (enum operand_parse_code): New operand.
+       (parse_operands): Handle new operand.
+       (mve_encode_qqr): Handle new instructions.
+       (do_neon_dyadic_i64_su): Accept MVE variants.
+       (neon_dyadic_misc): Likewise.
+       (do_neon_mac_maybe_scalar): Likewise.
+       (do_neon_mul): Likewise.
+       (insns): Change to accept MVE variants.
+       * testsuite/gas/arm/mve-vmla-bad.d: New test.
+       * testsuite/gas/arm/mve-vmla-bad.l: New test.
+       * testsuite/gas/arm/mve-vmla-bad.s: New test.
+       * testsuite/gas/arm/mve-vmul-bad-1.d: New test.
+       * testsuite/gas/arm/mve-vmul-bad-1.l: New test.
+       * testsuite/gas/arm/mve-vmul-bad-1.s: New test.
+       * testsuite/gas/arm/mve-vmul-bad-2.d: New test.
+       * testsuite/gas/arm/mve-vmul-bad-2.l: New test.
+       * testsuite/gas/arm/mve-vmul-bad-2.s: New test.
+       * testsuite/gas/arm/mve-vqaddsub-bad.d: New test.
+       * testsuite/gas/arm/mve-vqaddsub-bad.l: New test.
+       * testsuite/gas/arm/mve-vqaddsub-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (M_MNEM_vmlaldav, M_MNEM_vmlaldava,
+        M_MNEM_vmlaldavx, M_MNEM_vmlaldavax, M_MNEM_vmlsldav,
+        M_MNEM_vmlsldava, M_MNEM_vmlsldavx, M_MNEM_vmlsldavax,
+        M_MNEM_vrmlaldavhx, M_MNEM_vrmlaldavhax, M_MNEM_vrmlsldavh,
+        M_MNEM_vrmlsldavha, M_MNEM_vrmlsldavhx, M_MNEM_vrmlsldavhax): New
+       instruction encodings.
+       (NEON_SHAPE_DEF): New shape
+       (mve_encode_rrqq): New encoding helper function.
+       (do_mve_vmlaldav): New encoding function.
+       (do_mve_vrmlaldavh): New encoding function.
+       (insns): Add entries for MVE mnemonics.
+       * testsuite/gas/arm/mve-vmlaldav-bad.d: New test.
+       * testsuite/gas/arm/mve-vmlaldav-bad.l: New test.
+       * testsuite/gas/arm/mve-vmlaldav-bad.s: New test.
+       * testsuite/gas/arm/mve-vmlalv-bad.d: New test.
+       * testsuite/gas/arm/mve-vmlalv-bad.l: New test.
+       * testsuite/gas/arm/mve-vmlalv-bad.s: New test.
+       * testsuite/gas/arm/mve-vmlsldav-bad.d: New test.
+       * testsuite/gas/arm/mve-vmlsldav-bad.l: New test.
+       * testsuite/gas/arm/mve-vmlsldav-bad.s: New test.
+       * testsuite/gas/arm/mve-vrmlaldavh-bad.d: New test.
+       * testsuite/gas/arm/mve-vrmlaldavh-bad.l: New test.
+       * testsuite/gas/arm/mve-vrmlaldavh-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (M_MNEM_vmaxv, M_MNEM_vmaxav, M_MNEM_vminv,
+        M_MNEM_vminav): New instruction encodings.
+       (do_mve_vmaxv): New encoding function.
+       (insns): Add entries for new MVE mnemonics.
+       * testsuite/gas/arm/mve-vmaxv-vminv-bad.d: New test.
+       * testsuite/gas/arm/mve-vmaxv-vminv-bad.l: New test.
+       * testsuite/gas/arm/mve-vmaxv-vminv-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (do_mve_vmaxnmv): New encoding function.
+       (insns): Add entries for new mnemonics.
+       * testsuite/gas/arm/mve-vmaxnmv-vminnmv-bad.d: New test.
+       * testsuite/gas/arm/mve-vmaxnmv-vminnmv-bad.l: New test.
+       * testsuite/gas/arm/mve-vmaxnmv-vminnmv-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (do_mve_vmaxa_vmina): New encoding function.
+       (do_mve_vmaxnma_vminnma): Likewise.
+       (do_neon_dyadic_if_su): Change to support MVE variants.
+       (do_vmaxnm): Likewise.
+       (insns): Change to accept MVE variants and add new.
+       * testsuite/gas/arm/mve-vmax-vmin-bad.d: New test.
+       * testsuite/gas/arm/mve-vmax-vmin-bad.l: New test.
+       * testsuite/gas/arm/mve-vmax-vmin-bad.s: New test.
+       * testsuite/gas/arm/mve-vmaxa-vmina-bad.d: New test.
+       * testsuite/gas/arm/mve-vmaxa-vmina-bad.l: New test.
+       * testsuite/gas/arm/mve-vmaxa-vmina-bad.s: New test.
+       * testsuite/gas/arm/mve-vmaxnm-vminnm-bad.d: New test.
+       * testsuite/gas/arm/mve-vmaxnm-vminnm-bad.l: New test.
+       * testsuite/gas/arm/mve-vmaxnm-vminnm-bad.s: New test.
+       * testsuite/gas/arm/mve-vmaxnma-vminnma-bad.d: New test.
+       * testsuite/gas/arm/mve-vmaxnma-vminnma-bad.l: New test.
+       * testsuite/gas/arm/mve-vmaxnma-vminnma-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (enum operand_parse_code): New operand.
+       (parse_operands): Handle new operand.
+       (mve_encode_qqr): Change to support new instructions.
+       (enum vfp_or_neon_is_neon_bits): Moved.
+       (vfp_or_neon_is_neon): Moved.
+       (check_simd_pred_availability): Moved.
+       (do_neon_dyadic_i_su): Changed to support MVE variants.
+       (neon_dyadic_misc): Changed mve_encode_qqr call.
+       (do_mve_vbrsr): Likewise.
+       (do_mve_vhcadd): New encoding function.
+       (insns): Change existing to accept MVE variants and add new.
+       * testsuite/gas/arm/mve-vhadd-vhsub-vrhadd-bad.d: New test.
+       * testsuite/gas/arm/mve-vhadd-vhsub-vrhadd-bad.l: New test.
+       * testsuite/gas/arm/mve-vhadd-vhsub-vrhadd-bad.s: New test.
+       * testsuite/gas/arm/mve-vhcadd-bad.d: New test.
+       * testsuite/gas/arm/mve-vhcadd-bad.l: New test.
+       * testsuite/gas/arm/mve-vhcadd-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (do_neon_fmac): Change to support MVE variants.
+       (insns): Change to accept MVE variants.
+       * testsuite/gas/arm/mve-vfma-vfms-bad.d: New test.
+       * testsuite/gas/arm/mve-vfma-vfms-bad.l: New test.
+       * testsuite/gas/arm/mve-vfma-vfms-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (M_MNEM_vddup, M_MNEM_vdwdup, M_MNEM_vidup,
+        M_MNEM_viwdup): New instruction encodings.
+       (NEON_SHAPE_DEF): New shapes.
+       (do_mve_viddup): New encoding function.
+       (do_neon_dup): Change to support new MVE variants.
+       (insns): Change existing to accept MVE variants and add new.
+       * testsuite/gas/arm/mve-vddup-bad.d: New test.
+       * testsuite/gas/arm/mve-vddup-bad.l: New test.
+       * testsuite/gas/arm/mve-vddup-bad.s: New test.
+       * testsuite/gas/arm/mve-vdup-bad.d: New test.
+       * testsuite/gas/arm/mve-vdup-bad.l: New test.
+       * testsuite/gas/arm/mve-vdup-bad.s: New test.
+       * testsuite/gas/arm/mve-vidup-bad.d: New test.
+       * testsuite/gas/arm/mve-vidup-bad.l: New test.
+       * testsuite/gas/arm/mve-vidup-bad.s: New test.
+
+2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
+
+       * config/tc-arm.c (do_mve_vfmas): New encoding function.
+       (do_neon_cls): Change to support MVE variants.
+       (do_neon_clz): Change to support MVE variants.
+       (insns): Change to support MVE variants and add new.
+       * testsuite/gas/arm/mve-vcls-bad.d: New test.
+       * testsuite/gas/arm/mve-vcls-bad.l: New test.
+       * testsuite/gas/arm/mve-vcls-bad.s: New test.
+       * testsuite/gas/arm/mve-vclz-bad.d: New test.
+       * testsuite/gas/arm/mve-vclz-bad.l: New test.
+       * testsuite/gas/arm/mve-vclz-bad.s: New test.
+       * testsuite/gas/arm/mve-vfmas-bad.d: New test.
+       * testsuite/gas/arm/mve-vfmas-bad.l: New test.
+       * testsuite/gas/arm/mve-vfmas-bad.s: New test.
+
 2019-05-16  Andre Vieira  <andre.simoesdiasvieira@arm.com>
 
        * config/tc-arm.c (enum operand_parse_code): New operands.
This page took 0.032779 seconds and 4 git commands to generate.