3 * testsuite/gas/riscv/priv-reg.d, testsuite/gas/riscv/priv-reg.s: New.
7 * config/tc-riscv.c (risc_ip) <o>: Add comment.
8 * testsuite/gas/riscv/c-nonzero-imm.d,
9 * testsuite/gas/riscv/c-nonzero-imm.l,
10 * testsuite/gas/riscv/c-nonzero-imm.s,
11 * testsuite/gas/riscv/c-nonzero-reg.d,
12 * testsuite/gas/riscv/c-nonzero-reg.l,
13 * testsuite/gas/riscv/c-nonzero-reg.s,
14 * testsuite/gas/riscv/c-zero-imm-64.d,
15 * testsuite/gas/riscv/c-zero-imm-64.s,
16 * testsuite/gas/riscv/c-zero-imm.d, testsuite/gas/riscv/c-zero-imm.s,
17 * testsuite/gas/riscv/c-zero-reg.d,
18 * testsuite/gas/riscv/c-zero-reg.s: New.
23 * config/tc-aarch64.c (vectype_to_qualifier): Support AARCH64_OPND_QLF_S_4B.
24 * gas/testsuite/gas/aarch64/dotproduct.d: Update disassembly.
29 * config/tc-aarch64.c (vectype_to_qualifier): Support AARCH64_OPND_QLF_V_4B.
30 * gas/testsuite/gas/aarch64/pr22529.s: New.
31 * gas/testsuite/gas/aarch64/pr22529.d: New.
32 * gas/testsuite/gas/aarch64/pr22529.l: New.
37 * config/tc-arm.c (encode_ldmstm): Do not use A2 encoding of the
38 PUSH insn when pushing the stack pointer.
42 * config/tc-i386.c (regymm, regzmm): Delete.
43 (operand_type_register_match). Extend comment. Also handle some
44 memory operands here. Extend to cover .regsimd.
45 (build_vex_prefix): Derive vector_length from actual operand
47 (process_operands, build_modrm_byte): Use .regsimd.
51 * config/tc-i386.c (match_simd_size): New.
52 (match_mem_size): Use it.
53 (operand_size_match): Likewise. Split .reg and .acc checks.
54 (pi, check_VecOperands, match_template, check_byte_reg,
55 check_long_reg, check_qword_reg, build_modrm_byte,
56 parse_real_register): Replace .regxmm, .regymm, and .regzmm
58 (md_assemble): Qualify .acc check with .xmmword one.
59 (bad_implicit_operand): Delete.
60 (process_operands): Replace .firstxmm0 checks with .acc plus
61 .xmmword ones. Drop now pointless assertions. Convert .acc to
63 * config/tc-i386-intel.c (i386_intel_simplify_register): Replace
64 .regxmm, .regymm, and .regzmm checks.
65 * testsuite/gas/i386/x86-64-specific-reg.l: Adjust expectations.
69 * config/tc-i386.c (operand_type_check): Extend comment.
70 (match_reg_size): Also check .tbyte.
71 (match_mem_size): No longer check .tbyte here.
72 (md_assemble): Drop .floatacc check.
73 (check_byte_reg): Drop .floatreg and .floatacc checks.
74 (process_operands, parse_real_register): Replace .floatreg
79 * config/tc-i386.c (operand_type_check, pi): Switch .reg<N> to
81 (operand_size_match): Qualify .anysize check with .reg one.
82 Extend .acc check to also cover .reg.
83 (operand_type_register_match): Drop m0 and m1 parameters. Switch
84 .reg<N> to .byte/.word/.dword/.qword. Drop .acc special
86 (md_assemble): Expand .reg8 checks to .reg plus .bytes ones.
87 (optimize_imm, process_suffix, check_byte_reg, check_long_reg,
88 check_qword_reg, check_word_reg): Expand .reg<N> checks to .reg
90 (match_template): Drop arguments from calls to
91 operand_type_register_match().
92 (build_modrm_byte, i386_addressing_mode, i386_index_check,
93 parse_real_register): Replace .reg<N> checks.
94 * config/tc-i386-intel.c (i386_intel_simplify,
95 i386_intel_operand): Switch .reg16 to .word.
100 * gas/config/tc-i386.c (output_insn): Check pseudo prefix
102 * testsuite/gas/i386/i386.exp: Run inval-pseudo.
103 * testsuite/gas/i386/inval-pseudo.l: New file.
104 * testsuite/gas/i386/inval-pseudo.s: Likewise.
108 * config/tc-i386.c (match_template): Add missing ! to
109 reg{x,y,z}mm checks in q- and l-suffix handling.
113 * config/tc-i386.c (build_modrm_byte): Add missing ! to reg64
114 check leading to abort().
118 * config/tc-m32c.c: Update address of FSF in copyright notice.
119 * config/tc-m32c.h: Likewise.
120 * config/tc-mt.c: Likewise.
121 * config/tc-mt.h: Likewise.
122 * config/tc-visium.c: Likewise.
123 * config/tc-visium.h: Likewise.
124 * testsuite/gas/rx/explode: Likewise.
129 * testsuite/gas/riscv/fsxxi.d, testsuite/gas/riscv/fsxxi.s: New.
133 * testsuite/gas/pru/extern.s: New test for print of U16_PMEMM
135 * testsuite/gas/pru/extern.d: New test driver.
140 * config/tc-ppc.c (md_assemble): Don't mask register number.
144 * config/tc-xtensa.c (xg_order_trampoline_chain): Replace
145 xg_order_trampoline_chain_entry call with check for
146 canonicalized symbol equality and offset equality.
151 * doc/as.texinfo (8byte): Correct.
155 * testsuite/gas/ppc/ppc.exp: Don't exclude VLE tests when little-endian.
156 * testsuite/gas/ppc/efs.d: Add -mbig to assembler options.
157 * testsuite/gas/ppc/efs2.d: Likewise.
158 * testsuite/gas/ppc/lsp-checks.d: Likewise.
159 * testsuite/gas/ppc/lsp.d: Likewise.
160 * testsuite/gas/ppc/spe.d: Likewise.
161 * testsuite/gas/ppc/spe2-checks.d: Likewise.
162 * testsuite/gas/ppc/spe2.d: Likewise.
163 * testsuite/gas/ppc/spe_ambiguous.d: Likewise.
164 * testsuite/gas/ppc/vle-mult-ld-st-insns.d: Likewise.
165 * testsuite/gas/ppc/vle-reloc.d: Likewise.
166 * testsuite/gas/ppc/vle-simple-1.d: Likewise.
167 * testsuite/gas/ppc/vle-simple-2.d: Likewise.
168 * testsuite/gas/ppc/vle-simple-3.d: Likewise.
169 * testsuite/gas/ppc/vle-simple-4.d: Likewise.
170 * testsuite/gas/ppc/vle-simple-5.d: Likewise.
171 * testsuite/gas/ppc/vle-simple-6.d: Likewise.
172 * testsuite/gas/ppc/vle.d: Likewise.
176 * doc/c-riscv.texi (RISC-V-Directives): Move @section immediately after
182 * doc/as.texinfo (RISC-V): Alphabetize RISC-V entries. Change
183 RISC-V-Opts to RISC-V-Options. Delete redundant space. Add -fpic
184 and related options to option list.
185 * doc/c-riscv.texi: (RISC-V-Options): Renamed from RISC-V-Opts.
186 (RISC-V Options): Renamed from Options. Add missing period.
187 (-fpic): Also mention -fPIC.
188 (RISC-V Directives): New node.
192 * config/tc-ppc.c (last_insn): Update type.
193 (insn_validate) <omask, mask>: Likewise.
194 (ppc_setup_opcodes) <mask, right_bit>: Likewise.
195 <PRINT_OPCODE_TABLE>: Update types and printf format specifiers.
196 (ppc_insert_operand): Update return and argument types and remove
198 <min, max, right, tmp>: Update type.
199 (md_assemble): Remove unneeded type casts.
200 <insn, val, tmp_insn>: Update type.
204 * config/tc-i386.c (enum i386_error): Remove try_vector_disp8.
205 (mode_from_disp_size, build_modrm_byte, build_modrm_byte,
206 disp_size): Remove reference to .vec_disp8.
207 (output_disp): Likewise. Unconditionally use i.memshift.
208 (fits_in_vec_disp8): Rename to fits_in_disp8.
209 (type_names): Remove OPERAND_TYPE_VEC_DISP8 entry.
210 (optimize_disp): Use fits_in_disp8.
211 (check_VecOperands): Re-work (simplify) .disp8memshift
212 conditional handling.
217 * config/tc-i386-intel.c (i386_intel_simplify): Chain together
218 multiple segment override expressions.
219 (i386_intel_operand): Issue diagnostic for redundant segment
221 * testsuite/gas/i386/intelok.e: New.
222 * testsuite/gas/i386/intelok.d: Reference intelok.e.
223 * testsuite/gas/i386/inval-seg.s: Add redundant override checks.
224 * testsuite/gas/i386/inval-seg.l: Adjust expectations.
229 * config/tc-riscv.c (riscv_frag_align_code): New local insn_alignment.
230 Early return if bytes less than or equal to insn_alignment.
231 * testsuite/gas/riscv/align-1.l: New.
232 * testsuite/gas/riscv/align-1.s: New.
233 * testsuite/gas/riscv/riscv.exp: Use run_dump_tests. Use run_list_test
237 * doc/c-i386.texi (-n): Clarify docs.
241 * config/tc-aarch64.c (reg_names): Fix IP1 register alias typo.
242 * testsuite/gas/aarch64/register_aliases.s: Add IP0 and IP1 tests.
243 * testsuite/gas/aarch64/register_aliases.d: Update.
247 * po/Make-in (datadir): Define as @datadir@.
248 (localedir): Define as @localedir@.
249 (gnulocaledir, gettextsrcdir): Use @datarootdir@.
254 * config/obj-elf.c (obj_elf_version): Use record_alignment rather
255 than bfd_set_section_alignment.
261 * config/tc-riscv.c (riscv_handle_implicit_zero_offset): New.
262 (riscv_ip): Cases 'k', 'l', 'm', 'n', 'M', 'N', add call to
263 riscv_handle_implicit_zero_offset. At label load_store, replace
264 existing code with call to riscv_handle_implicit_zero_offset.
265 * testsuite/gas/riscv/c-ld.d, testsuite/gas/riscv/c-ld.s: New.
266 * testsuite/gas/riscv/c-lw.d, testsuite/gas/riscv/c-lw.s: New.
267 * testsuite/gas/riscv/riscv.exp: Run new tests.
271 * config/tc-xtensa.c (find_trampoline_seg): Add static variable
272 that caches the result of the most recent search.
276 * config/tc-xtensa.c (trampoline_chain_entry, trampoline_chain)
277 (trampoline_chain_index): New structures.
278 (trampoline_index): Add chain_index field.
279 (xg_order_trampoline_chain_entry, xg_sort_trampoline_chain)
280 (xg_find_chain_entry, xg_get_best_chain_entry)
281 (xg_order_trampoline_chain, xg_get_trampoline_chain)
282 (xg_find_best_eq_target, xg_add_location_to_chain)
283 (xg_create_trampoline_chain, xg_get_single_symbol_slot): New
285 (xg_relax_fixups): Call xg_find_best_eq_target to adjust jump
286 target to point to an existing jump. Call
287 xg_create_trampoline_chain to create new jump target. Call
288 xg_add_location_to_chain to add newly created trampoline jump
289 to the corresponding chain.
290 (add_jump_to_trampoline): Extract loop searching for a single
291 slot with a symbol into a separate function, replace that code
292 with a call to that function.
293 (relax_frag_immed): Call xg_find_best_eq_target to adjust jump
294 target to point to an existing jump.
295 * testsuite/gas/xtensa/all.exp: Add trampoline-2 test.
296 * testsuite/gas/xtensa/trampoline.d: Adjust absolute addresses
297 as many duplicate trampoline chains are now coalesced.
298 * testsuite/gas/xtensa/trampoline.s: Add _nop so that objdump
299 stays in sync with instruction stream.
300 * testsuite/gas/xtensa/trampoline-2.l: New test result file.
301 * testsuite/gas/xtensa/trampoline-2.s: New test source file.
305 * config/tc-xtensa.c (search_trampolines, get_best_trampoline):
307 (xg_find_best_trampoline_for_tinsn): New function.
308 (relax_frag_immed): Replace call to get_best_trampoline with a
309 call to xg_find_best_trampoline_for_tinsn.
310 * testsuite/gas/xtensa/trampoline.d: Adjust absolute addresses
311 as the placement of trampolines for relaxed branches has been
316 * config/tc-xtensa.c (trampoline_index): New structure.
317 (trampoline_seg): Replace trampoline list with trampoline index.
318 (xg_find_trampoline, xg_add_trampoline_to_index)
319 (xg_remove_trampoline_from_index, xg_add_trampoline_to_seg)
320 (xg_is_trampoline_frag_full, xg_get_fulcrum)
321 (xg_find_best_trampoline, xg_relax_fixup, xg_relax_fixups)
322 (xg_is_relaxable_fixup): New functions.
323 (J_MARGIN): New macro.
324 (xtensa_create_trampoline_frag): Use xg_add_trampoline_to_seg
325 instead of open-coded addition to the linked list.
326 (dump_trampolines): Iterate through the trampoline_seg::index.
327 (cached_fixupS, cached_fixup, fixup_cacheS, fixup_cache)
328 (fixup_order, xtensa_make_cached_fixup)
329 (xtensa_realloc_fixup_cache, xtensa_cache_relaxable_fixups)
330 (xtensa_find_first_cached_fixup, xtensa_delete_cached_fixup)
331 (xtensa_add_cached_fixup, check_and_update_trampolines): Remove
333 (xg_relax_trampoline): Extract logic into separate functions,
334 replace body with a call to xg_relax_fixups.
335 (search_trampolines): Replace search in linked list with search
336 in index. Change data type of address-tracking variables from
337 int to offsetT. Replace abs with labs.
338 (xg_append_jump): Finish the trampoline frag if it's full.
339 (add_jump_to_trampoline): Remove trampoline frag from the index
341 * config/tc-xtensa.h (xtensa_frag_type): Remove next_trampoline.
342 * testsuite/gas/xtensa/trampoline.d: Adjust absolute addresses
343 as the placement of trampolines has slightly changed.
344 * testsuite/gas/xtensa/trampoline.s: Add _nop so that objdump
345 stays in sync with instruction stream.
349 * config/tc-xtensa.c (init_trampoline_frag): Replace pointer to
350 struct trampoline_frag parameter with pointer to fragS.
351 (xg_append_jump): Remove jump_around parameter.
352 (struct trampoline_frag): Remove.
353 (struct trampoline_seg): Change type of trampoline_list from
354 struct trampoline_frag to fragS.
355 (xtensa_create_trampoline_frag): Don't allocate struct
356 trampoline_frag. Initialize new fragS::tc_frag_data fields.
357 (dump_trampolines, xg_relax_trampoline, search_trampolines)
358 (get_best_trampoline, init_trampoline_frag)
359 (add_jump_to_trampoline, relax_frag_immed): Replace pointer to
360 struct trampoline_frag with a pointer to fragS.
361 (xg_append_jump): Remove jump_around parameter, use
362 fragS::tc_frag_data.jump_around_fix instead.
363 (xg_relax_trampoline, init_trampoline_frag)
364 (add_jump_to_trampoline): Don't pass jump_around parameter to
366 * config/tc-xtensa.h (struct xtensa_frag_type): Add new fields:
367 needs_jump_around, next_trampoline and jump_around_fix.
371 * config/tc-xtensa.c (find_trampoline_seg): Move above the first
373 (xtensa_create_trampoline_frag): Replace trampoline seg search
374 code with a call to find_trampoline_seg.
378 * config/tc-xtensa.c (xg_append_jump): New function.
379 (xg_relax_trampoline, init_trampoline_frag)
380 (add_jump_to_trampoline): Replace trampoline jump assembling
381 code with a call to xg_append_jump.
385 * config/tc-xtensa.c (xg_relax_trampoline): New function.
386 (xtensa_relax_frag): Replace trampoline relaxation code with a
387 call to xg_relax_trampoline.
392 * config/obj-elf.c (obj_elf_version): Set the alignment of the
397 * testsuite/gas/i386/sse-noavx.s: Add tests for fisttps and
399 * testsuite/gas/i386/x86-64-sse-noavx.s: Likewise.
400 * testsuite/gas/i386/ilp32/x86-64-sse-noavx.d: Updated.
401 * testsuite/gas/i386/sse-noavx.d: Likewise.
402 * testsuite/gas/i386/x86-64-sse-noavx.d: Likewise.
406 * write.h (FAKE_LABEL_CHAR): Expand comment.
410 * config/tc-i386.c (check_VecOperations): Check register type
411 for masking. Quote the actual register name in the respective
412 diagnostic. Check {z} wasn't specified on its own.
413 * testsuite/gas/i386/inval-avx512f.s,
414 testsuite/gas/i386/x86-64-inval-avx512f.s: Add further bad
416 * testsuite/gas/i386/inval-avx512f.l,
417 testsuite/gas/i386/x86-64-inval-avx512f.l: Adjust expectations.
421 * testsuite/gas/i386/intel.d, testsuite/gas/i386/opcode.d,
422 testsuite/gas/i386/opcode-suffix.d, testsuite/gas/i386/sse3.d,
423 testsuite/gas/i386/sse-noavx.d, testsuite/gas/i386/x86-64-sse3.d,
424 testsuite/gas/i386/x86-64-sse-noavx.d,
425 testsuite/gas/i386/ilp32/x86-64-sse3.d,
426 testsuite/gas/i386/ilp32/x86-64-sse-noavx.d: Adjust expectations.
430 * testsuite/gas/all/err-fakelabel.s (dg-error): Also accept fatal error
433 * as.c (INITIALIZING_EMULS): Define.
434 * config/obj-multi.h (FAKE_LABEL_NAME): When INITIALIZING_EMULS set,
439 * testsuite/gas/i386/avx512f_vaes-intel.d: Regenerate.
440 * testsuite/gas/i386/avx512f_vaes.d: Likewise.
441 * testsuite/gas/i386/avx512f_vaes-wig1-intel.d: Likewise.
442 * testsuite/gas/i386/avx512f_vaes-wig1.d: Likewise.
443 * testsuite/gas/i386/avx512vl_vaes-intel.d: Likewise.
444 * testsuite/gas/i386/avx512vl_vaes.d: Likewise.
445 * testsuite/gas/i386/x86-64-avx512f_vaes.s: Add instructions with
447 * testsuite/gas/i386/x86-64-avx512f_vaes-intel.d: Regenerate.
448 * testsuite/gas/i386/x86-64-avx512f_vaes.d: Likewise.
449 * testsuite/gas/i386/x86-64-avx512f_vaes-wig.s: Add instructions with
451 * testsuite/gas/i386/x86-64-avx512f_vaes-wig1-intel.d: Regenerate.
452 * testsuite/gas/i386/x86-64-avx512f_vaes-wig1.d: Likewise.
453 * testsuite/gas/i386/x86-64-avx512vl_vaes-intel.d: Regenerate.
454 * testsuite/gas/i386/x86-64-avx512vl_vaes.d: Likewise.
455 * testsuite/gas/i386/x86-64-avx512vl_vaes-wig.s: Add instructions with
457 * testsuite/gas/i386/x86-64-avx512vl_vaes-wig1-intel.d: Regenerate.
458 * testsuite/gas/i386/x86-64-avx512vl_vaes-wig1.d: Regenerate.
462 * tc-i386.c (check_VecOperands): Don't clear .disp16.
463 * testsuite/gas/i386/avx512f.s: Add 16-bit addressing tests.
464 * testsuite/gas/i386/avx512f.d,
465 testsuite/gas/i386/avx512f-intel.d: Adjust expectations.
470 * config/tc-i386.c (build_modrm_byte): Add address override
471 prefix checks alongside 64-bit mode ones.
472 * testsuite/gas/i386/reloc64.s: Add 32-bit signed/unsigned
474 * testsuite/gas/i386/reloc64.d: Adjust expectations.
478 * config/tc-i386.c (build_modrm_byte): Drop VSIB handling from
479 code also setting fake_zero_displacement.
483 * testsuite/gas/i386/arch-4.s: Correct ud1 and ud2b. Add ud0.
484 * testsuite/gas/i386/intel.s: Test ud2 instead of ud2b.
485 * testsuite/gas/i386/opcode.s: Likewise.
486 * testsuite/gas/i386/arch-4.d, testsuite/gas/i386/intel.d,
487 testsuite/gas/i386/opcode.d, testsuite/gas/i386/opcode-intel.d,
488 testsuite/gas/i386/opcode-suffix.d: Adjust expectations.
492 * config/tc-i386-intel.c (i386_intel_operand): Don't call
493 as_bad() if a prior error was already reported.
494 * testsuite/gas/i386/inval-avx512f.l,
495 testsuite/gas/i386/x86-64-inval-avx512f.l: Adjust expectations.
499 * as.c: Include write.h.
500 (common_emul_init): Use FAKE_LABEL_NAME.
501 * ecoff.c (add_file, ecoff_directive_end, ecoff_directive_loc):
503 (ecoff_build_symbols): Use FAKE_LABEL_CHAR.
504 * expr.c (get_symbol_name): Use FAKE_LABEL_CHAR. Accept only if
505 input_from_string is TRUE.
506 * read.c (input_from_string): New.
507 (read_symbol_name): Use FAKE_LABEL_CHAR. Accept only if
508 input_from_string is TRUE.
509 (temp_ilp): Set input_from_string to TRUE.
510 (restore_ilp): Set input_from_string to FALSE.
511 * read.h (input_from_string): Declare.
512 * symbols.c: Include write.h
513 (S_IS_LOCAL): Check for FAKE_LABEL_CHAR.
514 (symbol_relc_make_sym): Fix comment refering to default fake label
516 * write.h (FAKE_LABEL_CHAR): New.
517 * config/tc-riscv.h (FAKE_LABEL_CHAR): Define.
518 * testsuite/gas/all/err-fakelabel.s: New.
520 * doc/as.texinfo (.align): Change some to most for text nop fill.
521 (.balign, .p2align): Likewise.
525 * config/tc-arm.c (arm_reg_type): Comment on the link with
527 (reg_expected_msgs): Initialize using array designators with
532 * testsuite/gas/arc/hregs-err.s: New test.
537 * testsuite/gas/i386/align-1.s: New file.
538 * testsuite/gas/i386/align-1a.d: Likewise.
539 * testsuite/gas/i386/align-1b.d: Likewise.
540 * testsuite/gas/i386/i386.exp: Run align-1a and align-1b.
544 * testsuite/gas/arc/b.d : Update test.
545 * testsuite/gas/arc/bl.d: Likewise.
546 * testsuite/gas/arc/jli-1.d: Likewise.
547 * testsuite/gas/arc/lp.d: Likewise.
548 * testsuite/gas/arc/pcl-relocs.d: Likewise.
549 * testsuite/gas/arc/pcrel-relocs.d: Likewise.
550 * testsuite/gas/arc/pic-relocs.d: Likewise.
551 * testsuite/gas/arc/plt-relocs.d: Likewise.
552 * testsuite/gas/arc/pseudos.d: Likewise.
553 * testsuite/gas/arc/relax-avoid2.d: Likewise.
554 * testsuite/gas/arc/relax-avoid3.d: Likewise.
555 * testsuite/gas/arc/relax-b.d: Likewise.
556 * testsuite/gas/arc/tls-relocs.d: Likewise.
557 * testsuite/gas/arc/relax-add01.d: Likewise.
558 * testsuite/gas/arc/relax-add04.d: Likewise.
559 * testsuite/gas/arc/relax-ld01.d: Likewise.
560 * testsuite/gas/arc/relax-sub01.d: Likewise.
561 * testsuite/gas/arc/relax-sub02.d: Likewise.
562 * testsuite/gas/arc/relax-sub04.d: Likewise.
563 * testsuite/gas/arc/pcl-print.s: New file.
564 * testsuite/gas/arc/pcl-print.d: Likewise.
565 * testsuite/gas/arc/nps400-12.d: Likewise.
569 * config/tc-xtensa.c (finish_vinsn): Avoid multiple ngettext calls
574 * testsuite/gas/i386/x86-64-reg-bad.l: Accept trailing padding.
578 * config/tc-aarch64.c (fp16fml): New.
579 * doc/c-aarch64.texi (fp16fml): New.
580 * testsuite/gas/aarch64/armv8_2-a-crypto-fp16.d (fp16): Make fp16fml.
581 * testsuite/gas/aarch64/armv8_3-a-crypto-fp16.d (fp16): Make fp16fml.
585 * opcodes/aarch64-tbl.h
586 (aarch64_feature_crypto): Add ARCH64_FEATURE_SIMD and AARCH64_FEATURE_FP.
587 (aarch64_feature_crypto_v8_2, aarch64_feature_sm4): Likewise.
588 (aarch64_feature_sha3): Likewise.
592 * doc/c-aarch64.texi (armv8.4-a, sha2, sha3, sm4): New.
593 (dotprod): Update default note.
597 * testsuite/gas/aarch64/armv8_4-a-illegal.d: New.
598 * testsuite/gas/aarch64/armv8_4-a-illegal.l: New.
599 * testsuite/gas/aarch64/armv8_4-a-illegal.s: New.
600 * testsuite/gas/aarch64/armv8_4-a.d: New.
601 * testsuite/gas/aarch64/armv8_4-a.s: New.
602 * testsuite/gas/aarch64/armv8_2-a-crypto-fp16.s: New.
603 * testsuite/gas/aarch64/armv8_2-a-crypto-fp16.d: New.
604 * testsuite/gas/aarch64/armv8_3-a-crypto-fp16.d: New.
605 * testsuite/gas/aarch64/armv8_4-a-crypto-fp16.d: New.
606 * testsuite/gas/aarch64/armv8_2-a-crypto-fp16-illegal.s: New.
607 * testsuite/gas/aarch64/armv8_2-a-crypto-fp16-illegal.l: New.
608 * testsuite/gas/aarch64/armv8_2-a-crypto-fp16-illegal.d: New.
612 * testsuite/gas/i386/noextreg.s: Add tests with register index
614 * testsuite/gas/i386/noextreg.d: Adjust expectations.
618 * config/tc-i386.c (process_suffix): Ignore .no_qsuf outside of
620 * testsuite/gas/i386/ptwrite.s: Add test for memory operand
622 * testsuite/gas/i386/ptwrite.d,
623 testsuite/gas/i386/ptwrite-intel.d: Adjust expectations.
627 * testsuite/gas/i386/noextreg.s: Replace .code64/.code32 and
628 64-bit instructions with .byte. Remove ELF directive.
632 * config/tc-arm.c (arm_ext_fp16_fml, fp16fml): New.
633 (do_neon_fmac_maybe_scalar_long): Use arm_ext_fp16_fml.
634 * doc/c-arm.texi (fp16, fp16fml): New.
635 * testsuite/gas/arm/armv8_2-a-fp16.d (fp16): Make fp16fml.
636 * testsuite/gas/arm/armv8_3-a-fp16.d (fp16): Make fp16fml.
637 * testsuite/gas/arm/armv8_2-a-fp16-illegal.d (fp16): Make fp16fml.
638 * testsuite/gas/arm/armv8_2-a-fp16-thumb2.d (fp16): Make fp16fml.
643 * testsuite/gas/avr/large-debug-line-table.d: Update expected
645 * testsuite/gas/elf/dwarf2-11.d: Likewise.
646 * testsuite/gas/elf/dwarf2-12.d: Likewise.
647 * testsuite/gas/elf/dwarf2-13.d: Likewise.
648 * testsuite/gas/elf/dwarf2-14.d: Likewise.
649 * testsuite/gas/elf/dwarf2-15.d: Likewise.
650 * testsuite/gas/elf/dwarf2-16.d: Likewise.
651 * testsuite/gas/elf/dwarf2-17.d: Likewise.
652 * testsuite/gas/elf/dwarf2-18.d: Likewise.
653 * testsuite/gas/elf/dwarf2-5.d: Likewise.
654 * testsuite/gas/elf/dwarf2-6.d: Likewise.
655 * testsuite/gas/elf/dwarf2-7.d: Likewise.
659 * testsuite/gas/i386/noextreg.s: Add tests for VEX-encoded GPR
660 insns with VEX.W set.
661 * testsuite/gas/i386/noextreg.d: Adjust expectations.
665 * testsuite/gas/i386/noextreg.{s,d}: New.
666 * testsuite/gas/i386/i386.exp: Run new test.
670 * testsuite/gas/i386/x86-64-reg.s: Add extended byte reg tests.
671 * testsuite/gas/i386/x86-64-reg.d,
672 testsuite/gas/i386/x86-64-reg-intel.d,
673 testsuite/gas/i386/ilp32/x86-64-reg.d,
674 testsuite/gas/i386/ilp32/x86-64-reg-intel.d: Adjust
677 * testsuite/gas/i386/x86-64-reg-bad.{s,l}: New.
678 * testsuite/gas/i386/i386.exp: Run new test.
682 * testsuite/gas/lns/lns.exp (lns-common-1): Add riscv*-*-* to alt list.
686 * testsuite/gas/i386/x86-64-xop.d, testsuite/gas/i386/xop.d,
687 testsuite/gas/i386/xop32reg.d: Adjust expectations.
691 * testsuite/gas/i386/avx512bw.s: Add vpcmp* pseudo tests.
692 * testsuite/gas/i386/avx512bw_vl.s: Likewise.
693 * testsuite/gas/i386/avx512bw.d, testsuite/gas/i386/avx512bw-intel.d,
694 testsuite/gas/i386/avx512bw_vl.d,
695 testsuite/gas/i386/avx512bw_vl-intel.d: Adjust expectations.
699 * testsuite/gas/i386/string-ok.s: Add a few more valid patterns.
701 * testsuite/gas/i386/string-bad.s: ... here.
702 * testsuite/gas/i386/string-bad.l: Adjust expectations.
703 * testsuite/gas/i386/string-ok.d: Likewise.
704 * testsuite/gas/i386/string-ok.e: Likewise.
708 * config/tc-aarch64.c (R_Z_BHSDQ_VZP): Rename to ...
709 (R_Z_SP_BHSDQ_VZP): ... and include both stack pointer variants.
713 * testsuite/gas/ia64/group-1.d: Adjust expectations.
714 * testsuite/gas/ia64/group-2.d: Likewise.
715 * testsuite/gas/ia64/xdata.d: Likewise.
719 * config/tc-i386.c (process_suffix): Treat .shiftcount just like
721 * testsuite/gas/i386/inval.s: Add ambiguous shift/rotate cases.
722 * testsuite/gas/i386/inval.l: Adjust expectations.
726 * config/tc-i386-intel.c (i386_intel_simplify_register): Also
727 recognize RegRiz/RegEiz as index-only registers.
728 * testsuite/gas/i386/intel.s: Add tests exercising base/index
730 * testsuite/gas/i386/intel.d: Adjust expectations.
734 * config/tc-i386.c (i386_index_check): Break out ...
735 (i386_addressing_mode): ... this new function.
736 * config/tc-i386-intel.c (i386_intel_operand): Do base/index
737 swapping and the setting of .baseindex earlier. Call
738 i386_addressing_mode.
739 * testsuite/gas/i386/x86-64-inval.s: Add out of range
741 * testsuite/gas/i386/x86-64-inval.l: Adjust expectations.
745 * testsuite/gas/elf/dwarf2-10.l: Accept optional line number in error.
749 * gas/testsuite/gas/aarch64/dotproduct_armv8_4.s: New.
750 * gas/testsuite/gas/aarch64/dotproduct_armv8_4.d: New.
754 * gas/testsuite/gas/aarch64/armv8_4-a-registers-illegal.d: New.
755 * gas/testsuite/gas/aarch64/armv8_4-a-registers-illegal.l: New.
756 * gas/testsuite/gas/aarch64/armv8_4-a-registers-illegal.s: New.
757 * gas/testsuite/gas/aarch64/armv8_4-a-registers.d: New.
758 * gas/testsuite/gas/aarch64/armv8_4-a-registers.s: New.
762 * config/tc-aarch64.c (process_omitted_operand):
763 Add AARCH64_OPND_Va, AARCH64_OPND_SM3_IMM2
764 and AARCH64_OPND_IMM_2.
765 (parse_operands): Add AARCH64_OPND_Va, AARCH64_OPND_SM3_IMM2,
766 AARCH64_OPND_IMM_2, AARCH64_OPND_MASK
767 and AARCH64_OPND_ADDR_OFFSET.
771 * config/tc-aarch64.c (aarch64_arch_option_table): Add armv8.4-a.
772 (aarch64_features): Add SM4 and SHA3.
776 * config/tc-aarch64.c
777 (aarch64_features): Include AES and SHA2 in CRYPTO.
783 * config/tc-arm.c (arm_extensions):
784 (arm_archs): New entry for "armv8.4-a".
785 Add FPU_ARCH_DOTPROD_NEON_VFP_ARMV8.
786 (arm_ext_v8_2): New variable.
787 (enum arm_reg_type): New enumeration REG_TYPE_NSD.
788 (reg_expected_msgs): New entry for REG_TYPE_NSD.
789 (parse_typed_reg_or_scalar): Handle REG_TYPE_NSD.
790 (parse_scalar): Support REG_TYPE_VFS.
791 (enum operand_parse_code): New enumerations OP_RNSD and OP_RNSD_RNSC.
792 (parse_operands): Handle OP_RNSD and OP_RNSD_RNSC.
793 (NEON_SHAPE_DEF): New entries for DHH and DHS.
794 (neon_scalar_for_fmac_fp16_long): New function to generate Rm encoding
795 for new FP16 instructions in ARMv8.2-A.
796 (do_neon_fmac_maybe_scalar_long): New function to encode new FP16
797 instructions in ARMv8.2-A.
798 (do_neon_vfmal): Wrapper function for vfmal.
799 (do_neon_vfmsl): Wrapper function for vfmsl.
800 (insns): New entries for vfmal and vfmsl.
801 * doc/c-arm.texi (-march): Document "armv8.4-a".
802 * testsuite/gas/arm/dotprod-mandatory.d: New test.
803 * testsuite/gas/arm/armv8_2-a-fp16.s: New test source.
804 * testsuite/gas/arm/armv8_2-a-fp16-illegal.s: New test source.
805 * testsuite/gas/arm/armv8_2-a-fp16.d: New test.
806 * testsuite/gas/arm/armv8_3-a-fp16.d: New test.
807 * testsuite/gas/arm/armv8_4-a-fp16.d: New test.
808 * testsuite/gas/arm/armv8_2-a-fp16-thumb2.d: New test.
809 * testsuite/gas/arm/armv8_2-a-fp16-illegal.d: New test.
810 * testsuite/gas/arm/armv8_2-a-fp16-illegal.l: New error file.
814 * config/tc-xtensa.c (finish_vinsn): Properly pluralize error message.
818 * config/tc-riscv.c (append_insn): Call frag_wane and frag_new at
819 end for linker optimizable relocs.
820 * testsuite/gas/riscv/eh-relocs.d: New.
821 * testsuite/gas/riscv/eh-relocs.s: New.
822 * testsuite/gas/riscv/riscv.exp: Run eh-relocs test.
826 * testsuite/gas/riscv/satp.d: New test.
827 testsuite/gas/riscv/satp.s: Likewise.
828 testsuite/gas/riscv/riscv.exp: Likewise.
829 config/tc-riscv.c (md_begin): Handle CSR aliases.
833 * config/tc-arm.c (arm_cpus):
834 Change FPU_ARCH_CRYPTO_NEON_VFP_ARMV8
835 into FPU_ARCH_CRYPTO_NEON_VFP_ARMV8_DOTPROD.
839 * read.c (assemble_one, s_bundle_unlock): Formatting.
840 Consistently add comma and "bytes" to error message.
841 * testsuite/gas/i386/bundle-bad.l: Adjust to suit.
845 * testsuite/gas/arm/got_prel.d,
846 * testsuite/gas/elf/dwarf2-1.d,
847 * testsuite/gas/elf/dwarf2-2.d,
848 * testsuite/gas/elf/dwarf2-3.d,
849 * testsuite/gas/elf/dwarf2-5.d,
850 * testsuite/gas/elf/dwarf2-6.d,
851 * testsuite/gas/i386/debug1.d,
852 * testsuite/gas/i386/dw2-compress-1.d,
853 * testsuite/gas/i386/dw2-compress-3a.d,
854 * testsuite/gas/i386/dw2-compress-3b.d,
855 * testsuite/gas/i386/dw2-compressed-1.d,
856 * testsuite/gas/i386/dw2-compressed-3a.d,
857 * testsuite/gas/i386/dw2-compressed-3b.d,
858 * testsuite/gas/i386/ilp32/x86-64-localpic.d,
859 * testsuite/gas/i386/localpic.d,
860 * testsuite/gas/i386/x86-64-localpic.d,
861 * testsuite/gas/ia64/pr13167.d,
862 * testsuite/gas/mips/loc-swap-2.d,
863 * testsuite/gas/mips/loc-swap.d,
866 * testsuite/gas/mips/mips16-dwarf2-n32.d,
867 * testsuite/gas/mips/mips16-dwarf2.d,
871 * testsuite/gas/mmix/bspec-1.d,
872 * testsuite/gas/mmix/bspec-2.d,
873 * testsuite/gas/tic6x/unwind-1.d,
874 * testsuite/gas/tic6x/unwind-2.d,
875 * testsuite/gas/tic6x/unwind-3.d: Update for pluralization
880 * as.c (main): Properly pluralize messages.
881 * frags.c (frag_grow): Likewise.
882 * read.c (emit_expr_with_reloc, emit_expr_fix): Likewise.
883 (parse_bitfield_cons): Likewise.
884 * write.c (fixup_segment, compress_debug, write_contents): Likewise.
885 (relax_segment): Likewise.
886 * config/tc-arm.c (s_arm_elf_cons): Likewise.
887 * config/tc-cr16.c (l_cons): Likewise.
888 * config/tc-i370.c (i370_elf_cons): Likewise.
889 * config/tc-m68k.c (m68k_elf_cons): Likewise.
890 * config/tc-msp430.c (msp430_operands): Likewise.
891 * config/tc-s390.c (s390_elf_cons, s390_literals): Likewise.
892 * config/tc-mcore.c (md_apply_fix): Likewise.
893 * config/tc-tic54x.c (md_assemble): Likewise.
894 * config/tc-xtensa.c (xtensa_elf_cons): Likewise.
895 (xg_expand_assembly_insn): Likewise.
896 * config/xtensa-relax.c (build_transition): Likewise.
900 * asintl.h (textdomain, bindtextdomain): Use safer "do nothing".
901 (ngettext, dngettext, dcngettext): Define when !ENABLE_NLS.
906 * config/tc-aarch64.c (aarch64_cpus): Add saphira.
907 * doc/c-aarch64.texi: Likewise.
911 * testsuite/gas/arm/copro-thumb_v6t2plus-thumb_v6t2-1.d: Add
912 --disassembler-options=force-thumb to objdump options.
913 * testsuite/gas/arm/copro-thumb_v6t2plus-thumb_v6t2-2.d: Likewise.
917 * config/tc-ft32.c (md_assemble): Add relaxation reloc
918 BFD_RELOC_FT32_RELAX.
919 (md_longopts): Add "norelax" and "no-relax".
920 (md_apply_fix): Add reloc BFD_RELOC_FT32_DIFF32.
921 (relaxable_section, ft32_validate_fix_sub, ft32_force_relocation,
922 ft32_allow_local_subtract): New function.
923 * config/tc-ft32.h: Remove unused MD_PCREL_FROM_SECTION.
924 * testsuite/gas/ft32/insnsc.s: New test exercising all FT32B
926 * testsuite/gas/ft32/insnsc.d: New driver file.
927 * testsuite/gas/all/gas.exp: Update.
928 * testsuite/gas/ft32/ft32.exp: Run the new test.
929 * testsuite/gas/ft32/insn.d: Update.
930 * testsuite/gas/elf/dwarf2-11.d: Update.
931 * testsuite/gas/elf/dwarf2-12.d: Update.
932 * testsuite/gas/elf/dwarf2-13.d: Update.
933 * testsuite/gas/elf/dwarf2-14.d: Update.
934 * testsuite/gas/elf/dwarf2-15.d: Update.
935 * testsuite/gas/elf/dwarf2-16.d: Update.
936 * testsuite/gas/elf/dwarf2-17.d: Update.
937 * testsuite/gas/elf/dwarf2-18.d: Update.
938 * testsuite/gas/elf/dwarf2-3.d: Update.
939 * testsuite/gas/elf/dwarf2-5.d: Update.
940 * testsuite/gas/elf/dwarf2-7.d: Update.
944 * config/tc-arm.c (arm_ext_v2): Define to ARM_EXT_V2 feature bit.
945 * testsuite/gas/arm/copro.s: Split into
946 * testsuite/gas/arm/copro-arm_v2plus-thumb_v6t2plus.s: This while
947 changing it to unified syntax and
948 * testsuite/gas/arm/copro-arm_v5plus-thumb_v6t2plus.s: this and ...
949 * testsuite/gas/arm/copro-arm_v5teplus-thumb_v6t2plus.s: This and ...
950 * testsuite/gas/arm/copro-arm_v6plus-thumb_v6t2plus.s: This.
951 * testsuite/gas/arm/copro.d: Split into ...
952 * testsuite/gas/arm/copro-arm_v2plus-arm_v2.d: This but target ARMv2
954 * testsuite/gas/arm/copro-arm_v5plus-arm_v5.d: this but target ARMv5
956 * testsuite/gas/arm/copro-arm_v5teplus-arm_v5te.d: This but target
958 * testsuite/gas/arm/copro-arm_v6plus-arm_v6.d: This but target ARMv6.
959 * testsuite/gas/arm/copro-arm_v2plus-arm_v1.d: New testcase.
960 * testsuite/gas/arm/copro-thumb_v6t2plus-thumb_v4t-1.d: New testcase.
961 * testsuite/gas/arm/copro-arm_v2plus-thumb_v6t2plus-unavail.l: Expected
962 errors for the above two testcases.
963 * testsuite/gas/arm/copro-thumb_v6t2plus-thumb_v6t2-1.d: New testcase.
964 * testsuite/gas/arm/copro-arm_v5plus-arm_v4.d: New testcase.
965 * testsuite/gas/arm/copro-thumb_v6t2plus-thumb_v4t-2.d: New testcase.
966 * testsuite/gas/arm/copro-arm_v5plus-thumb_v6t2plus-unavail.l:
967 Expected errors for the above two testcases.
968 * testsuite/gas/arm/copro-thumb_v6t2plus-thumb_v6t2-2.d: New testcase.
969 * testsuite/gas/arm/copro-arm_v5teplus-arm_v5.d: New testcase.
970 * testsuite/gas/arm/copro-thumb_v6t2plus-thumb_v4t-3.d: New testcase.
971 * testsuite/gas/arm/copro-arm_v5teplus-thumb_v6t2plus-unavail.l:
972 Expected errors for the above two testcases.
973 * testsuite/gas/arm/copro-thumb_v6t2plus-thumb_v6t2-3.d: New testcase.
974 * testsuite/gas/arm/copro-arm_v6plus-arm_v5te.d: New testcase.
975 * testsuite/gas/arm/copro-thumb_v6t2plus-thumb_v4t-4.d: New testcase.
976 * testsuite/gas/arm/copro-arm_v6plus-thumb_v6t2plus-unavail.l:
977 Expected errors for the above two testcases.
978 * testsuite/gas/arm/copro-thumb_v6t2plus-thumb_v6t2-4.d: New testcase.
983 * config/tc-i386.c (check_VecOperands): Also check XMM register
984 for invalid register in AVX512 gathers.
985 * testsuite/gas/i386/vgather-check.s: Add tests for AVX512
986 gathers with XMM register.
987 * testsuite/gas/i386/x86-64-vgather-check.s: Likewise.
988 * testsuite/gas/i386/vgather-check-error.l: Updated.
989 * testsuite/gas/i386/vgather-check-none.d: Likewise.
990 * testsuite/gas/i386/vgather-check-warn.d: Likewise.
991 * testsuite/gas/i386/vgather-check-warn.e: Likewise.
992 * testsuite/gas/i386/vgather-check.d: Likewise.
993 * testsuite/gas/i386/x86-64-vgather-check-error.l: Likewise.
994 * testsuite/gas/i386/x86-64-vgather-check-none.d: Likewise.
995 * testsuite/gas/i386/x86-64-vgather-check-warn.d: Likewise.
996 * testsuite/gas/i386/x86-64-vgather-check-warn.e: Likewise.
997 * testsuite/gas/i386/x86-64-vgather-check.d: Likewise.
1001 * testsuite/gas/all/fill-1.s: Use L2 rather than .L2.
1006 * config/tc-crx.c (instruction, output_opcode): Make static.
1007 (relocatable, ins_parse, cur_arg_num): Likewise.
1008 (parse_insn): Adjust for renamed opcodes globals.
1009 (check_range): Likewise
1013 * testsuite/gas/all/fill-1.d: Exclude tic4x and tic54x.
1014 * testsuite/gas/all/fill-1.s: Use L1 rather than .L1.
1018 * testsuite/gas/riscv/c-addi16sp-fail.d: New test.
1019 * testsuite/gas/riscv/c-addi16sp-fail.l: Likewise.
1020 * testsuite/gas/riscv/c-addi16sp-fail.s: Likewise.
1021 * testsuite/gas/riscv/c-addi4spn-fail.d: Likewise.
1022 * testsuite/gas/riscv/c-addi4spn-fail.l: Likewise.
1023 * testsuite/gas/riscv/c-addi4spn-fail.s: Likewise.
1024 * testsuite/gas/riscv/riscv.exp: Add new tests.
1028 * testsuite/gas/riscv/c-lui-fail.d: New testcase.
1029 * gas/testsuite/gas/riscv/c-lui-fail.l: Likewise.
1030 * gas/testsuite/gas/riscv/c-lui-fail.s: Likewise.
1031 * gas/testsuite/gas/riscv/riscv.exp: Likewise.
1035 * config/tc-i386.c (md_pseudo_table): Add .code64 directive
1036 only if BFD64 is defined.
1037 * testsuite/gas/i386/code64-inval.l: New file.
1038 * gas/testsuite/gas/i386/code64-inval.s: Likewise.
1039 * gas/testsuite/gas/i386/code64.d: Likewise.
1040 * gas/testsuite/gas/i386/code64.s: Likewise.
1041 * testsuite/gas/i386/i386.exp: Run mixed-mode-reloc32,
1042 att-regs, intel-regs, intel-expr and string-ok tests only if
1043 assembler supports x86-64. Run code64 and code64-inval.
1047 * config/tc-riscv.c (riscv_frag_align_code): Align code by 4
1048 bytes on non-RVC systems.
1052 * config/tc-mips.c (mips_elf_final_processing): Don't set
1053 EF_MIPS_ABI2 in `e_flags'.
1057 * config/tc-i386.c (cpu_arch): Add .avx512_bitalg.
1058 (cpu_noarch): noavx512_bitalg.
1059 * doc/c-i386.texi: Document .avx512_bitalg, noavx512_bitalg.
1060 * testsuite/gas/i386/i386.exp: Add AVX512_BITALG tests.
1061 * testsuite/gas/i386/avx512f_bitalg-intel.d: New test.
1062 * testsuite/gas/i386/avx512f_bitalg.d: Likewise.
1063 * testsuite/gas/i386/avx512f_bitalg.s: Likewise.
1064 * testsuite/gas/i386/avx512vl_bitalg-intel.d: Likewise.
1065 * testsuite/gas/i386/avx512vl_bitalg.d: Likewise.
1066 * testsuite/gas/i386/avx512vl_bitalg.s: Likewise.
1067 * testsuite/gas/i386/x86-64-avx512f_bitalg-intel.d: Likewise.
1068 * testsuite/gas/i386/x86-64-avx512f_bitalg.d: Likewise.
1069 * testsuite/gas/i386/x86-64-avx512f_bitalg.s: Likewise.
1070 * testsuite/gas/i386/x86-64-avx512vl_bitalg-intel.d: Likewise.
1071 * testsuite/gas/i386/x86-64-avx512vl_bitalg.d: Likewise.
1072 * testsuite/gas/i386/x86-64-avx512vl_bitalg.s: Likewise.
1076 * config/tc-i386.c (cpu_arch): Add .avx512_vnni.
1077 (cpu_noarch): Add noavx512_vnni.
1078 * doc/c-i386.texi: Document .avx512_vnni.
1079 * testsuite/gas/i386/i386.exp: Add AVX512_VNNI tests.
1080 * testsuite/gas/i386/avx512vnni-intel.d: New test.
1081 * testsuite/gas/i386/avx512vnni.d: Likewise.
1082 * testsuite/gas/i386/avx512vnni.s: Likewise.
1083 * testsuite/gas/i386/avx512vnni_vl-intel.d: Likewise.
1084 * testsuite/gas/i386/avx512vnni_vl.d: Likewise.
1085 * testsuite/gas/i386/avx512vnni_vl.s: Likewise.
1086 * testsuite/gas/i386/x86-64-avx512vnni-intel.d: Likewise.
1087 * testsuite/gas/i386/x86-64-avx512vnni.d: Likewise.
1088 * testsuite/gas/i386/x86-64-avx512vnni.s: Likewise.
1089 * testsuite/gas/i386/x86-64-avx512vnni_vl-intel.d: Likewise.
1090 * testsuite/gas/i386/x86-64-avx512vnni_vl.d: Likewise.
1091 * testsuite/gas/i386/x86-64-avx512vnni_vl.s: Likewise.
1095 * config/tc-i386.c (cpu_arch): Add VPCLMULQDQ.
1096 * doc/c-i386.texi: Document VPCLMULQDQ.
1097 * testsuite/gas/i386/i386.exp: Run VPCLMULQDQ tests.
1098 * testsuite/gas/i386/avx512f_vpclmulqdq-intel.d: New test.
1099 * testsuite/gas/i386/avx512f_vpclmulqdq-wig.s: Ditto.
1100 * testsuite/gas/i386/avx512f_vpclmulqdq-wig1-intel.d: Ditto.
1101 * testsuite/gas/i386/avx512f_vpclmulqdq-wig1.d: Ditto.
1102 * testsuite/gas/i386/avx512f_vpclmulqdq.d: Ditto.
1103 * testsuite/gas/i386/avx512f_vpclmulqdq.s: Ditto.
1104 * testsuite/gas/i386/avx512vl_vpclmulqdq-intel.d: Ditto.
1105 * testsuite/gas/i386/avx512vl_vpclmulqdq-wig.s: Ditto.
1106 * testsuite/gas/i386/avx512vl_vpclmulqdq-wig1-intel.d: Ditto.
1107 * testsuite/gas/i386/avx512vl_vpclmulqdq-wig1.d: Ditto.
1108 * testsuite/gas/i386/avx512vl_vpclmulqdq.d: Ditto.
1109 * testsuite/gas/i386/avx512vl_vpclmulqdq.s: Ditto.
1110 * testsuite/gas/i386/vpclmulqdq-intel.d: Ditto.
1111 * testsuite/gas/i386/vpclmulqdq.d: Ditto.
1112 * testsuite/gas/i386/vpclmulqdq.s: Ditto.
1113 * testsuite/gas/i386/x86-64-avx512f_vpclmulqdq-intel.d: Ditto.
1114 * testsuite/gas/i386/x86-64-avx512f_vpclmulqdq-wig.s: Ditto.
1115 * testsuite/gas/i386/x86-64-avx512f_vpclmulqdq-wig1-intel.d: Ditto.
1116 * testsuite/gas/i386/x86-64-avx512f_vpclmulqdq-wig1.d: Ditto.
1117 * testsuite/gas/i386/x86-64-avx512f_vpclmulqdq.d: Ditto.
1118 * testsuite/gas/i386/x86-64-avx512f_vpclmulqdq.s: Ditto.
1119 * testsuite/gas/i386/x86-64-avx512vl_vpclmulqdq-intel.d: Ditto.
1120 * testsuite/gas/i386/x86-64-avx512vl_vpclmulqdq-wig.s: Ditto.
1121 * testsuite/gas/i386/x86-64-avx512vl_vpclmulqdq-wig1-intel.d: Ditto.
1122 * testsuite/gas/i386/x86-64-avx512vl_vpclmulqdq-wig1.d: Ditto.
1123 * testsuite/gas/i386/x86-64-avx512vl_vpclmulqdq.d: Ditto.
1124 * testsuite/gas/i386/x86-64-avx512vl_vpclmulqdq.s: Ditto.
1125 * testsuite/gas/i386/x86-64-vpclmulqdq-intel.d: Ditto.
1126 * testsuite/gas/i386/x86-64-vpclmulqdq.d: Ditto.
1127 * testsuite/gas/i386/x86-64-vpclmulqdq.s: Ditto.
1131 * config/tc-i386.c (cpu_arch): Add VAES.
1132 * doc/c-i386.texi: Document VAES.
1133 * testsuite/gas/i386/i386.exp: Run VAES tests.
1134 * testsuite/gas/i386/avx512f_vaes-intel.d: New test.
1135 * testsuite/gas/i386/avx512f_vaes-wig.s: Ditto.
1136 * testsuite/gas/i386/avx512f_vaes-wig1-intel.d: Ditto.
1137 * testsuite/gas/i386/avx512f_vaes-wig1.d: Ditto.
1138 * testsuite/gas/i386/avx512f_vaes.d: Ditto.
1139 * testsuite/gas/i386/avx512f_vaes.s: Ditto.
1140 * testsuite/gas/i386/avx512vl_vaes-intel.d: Ditto.
1141 * testsuite/gas/i386/avx512vl_vaes-wig.s: Ditto.
1142 * testsuite/gas/i386/avx512vl_vaes-wig1-intel.d: Ditto.
1143 * testsuite/gas/i386/avx512vl_vaes-wig1.d: Ditto.
1144 * testsuite/gas/i386/avx512vl_vaes.d: Ditto.
1145 * testsuite/gas/i386/avx512vl_vaes.s: Ditto.
1146 * testsuite/gas/i386/vaes-intel.d: Ditto.
1147 * testsuite/gas/i386/vaes.d: Ditto.
1148 * testsuite/gas/i386/vaes.s: Ditto.
1149 * testsuite/gas/i386/x86-64-avx512f_vaes-intel.d: Ditto.
1150 * testsuite/gas/i386/x86-64-avx512f_vaes-wig.s: Ditto.
1151 * testsuite/gas/i386/x86-64-avx512f_vaes-wig1-intel.d: Ditto.
1152 * testsuite/gas/i386/x86-64-avx512f_vaes-wig1.d: Ditto.
1153 * testsuite/gas/i386/x86-64-avx512f_vaes.d: Ditto.
1154 * testsuite/gas/i386/x86-64-avx512f_vaes.s: Ditto.
1155 * testsuite/gas/i386/x86-64-avx512vl_vaes-intel.d: Ditto.
1156 * testsuite/gas/i386/x86-64-avx512vl_vaes-wig.s: Ditto.
1157 * testsuite/gas/i386/x86-64-avx512vl_vaes-wig1-intel.d: Ditto.
1158 * testsuite/gas/i386/x86-64-avx512vl_vaes-wig1.d: Ditto.
1159 * testsuite/gas/i386/x86-64-avx512vl_vaes.d: Ditto.
1160 * testsuite/gas/i386/x86-64-avx512vl_vaes.s: Ditto.
1161 * testsuite/gas/i386/x86-64-vaes-intel.d: Ditto.
1162 * testsuite/gas/i386/x86-64-vaes.d: Ditto.
1163 * testsuite/gas/i386/x86-64-vaes.s: Ditto.
1167 * config/tc-i386.c (cpu_arch): Add .gfni.
1168 * doc/c-i386.texi: Document .gfni.
1169 * testsuite/gas/i386/i386.exp: Add GFNI tests.
1170 * testsuite/gas/i386/avx.s: New GFNI test.
1171 * testsuite/gas/i386/x86-64-avx.s: Likewise.
1172 * testsuite/gas/i386/avx.d: Adjust.
1173 * testsuite/gas/i386/avx-intel.d: Likewise
1174 * testsuite/gas/i386/ilp32/x86-64-avx-intel.d: Likewise.
1175 * testsuite/gas/i386/ilp32/x86-64-avx.d: Likewise.
1176 * testsuite/gas/i386/avx512f_gfni-intel.d: New test.
1177 * testsuite/gas/i386/avx512f_gfni.d: Likewise.
1178 * testsuite/gas/i386/avx512f_gfni.s: Likewise.
1179 * testsuite/gas/i386/avx512vl_gfni-intel.d: Likewise.
1180 * testsuite/gas/i386/avx512vl_gfni.d: Likewise.
1181 * testsuite/gas/i386/avx512vl_gfni.s: Likewise.
1182 * testsuite/gas/i386/gfni-intel.d: Likewise.
1183 * testsuite/gas/i386/gfni.d: Likewise.
1184 * testsuite/gas/i386/gfni.s: Likewise.
1185 * testsuite/gas/i386/x86-64-avx512f_gfni-intel.d: Likewise.
1186 * testsuite/gas/i386/x86-64-avx512f_gfni.d: Likewise.
1187 * testsuite/gas/i386/x86-64-avx512f_gfni.s: Likewise.
1188 * testsuite/gas/i386/x86-64-avx512vl_gfni-intel.d: Likewise.
1189 * testsuite/gas/i386/x86-64-avx512vl_gfni.d: Likewise.
1190 * testsuite/gas/i386/x86-64-avx512vl_gfni.s: Likewise.
1191 * testsuite/gas/i386/x86-64-avx_gfni-intel.d: Likewise.
1192 * testsuite/gas/i386/x86-64-avx_gfni.d: Likewise.
1193 * testsuite/gas/i386/x86-64-avx_gfni.s: Likewise.
1194 * testsuite/gas/i386/x86-64-gfni-intel.d: Likewise.
1195 * testsuite/gas/i386/x86-64-gfni.d: Likewise.
1196 * testsuite/gas/i386/x86-64-gfni.s: Likewise.
1200 * config/tc-i386.c (cpu_arch): Add .avx512_vbmi2.
1201 (cpu_noarch): noavx512_vbmi2.
1202 * doc/c-i386.texi: Document .avx512_vbmi2, noavx512_vbmi2.
1203 * testsuite/gas/i386/i386.exp: Add AVX512_VBMI2 tests.
1204 * testsuite/gas/i386/avx512vbmi2-intel.d: New test.
1205 * testsuite/gas/i386/avx512vbmi2.d: Likewise.
1206 * testsuite/gas/i386/avx512vbmi2.s: Likewise.
1207 * testsuite/gas/i386/avx512vbmi2_vl-intel.d: Likewise.
1208 * testsuite/gas/i386/avx512vbmi2_vl.d: Likewise.
1209 * testsuite/gas/i386/avx512vbmi2_vl.s: Likewise.
1210 * testsuite/gas/i386/x86-64-avx512vbmi2-intel.d: Likewise.
1211 * testsuite/gas/i386/x86-64-avx512vbmi2.d: Likewise.
1212 * testsuite/gas/i386/x86-64-avx512vbmi2.s: Likewise.
1213 * testsuite/gas/i386/x86-64-avx512vbmi2_vl-intel.d: Likewise.
1214 * testsuite/gas/i386/x86-64-avx512vbmi2_vl.d: Likewise.
1215 * testsuite/gas/i386/x86-64-avx512vbmi2_vl.s: Likewise.
1220 * testsuite/gas/cris/range-err-1.s: Remove quotes left from last edit.
1225 * read.c (s_rept): Use size_t type for count parameter.
1226 (do_repeat): Change type of count parameter to size_t.
1227 Issue an error is the count parameter is negative.
1228 (do_repeat_with_expression): Likewise.
1229 * read.h: Update prototypes for do_repeat and
1230 do_repeat_with_expression.
1231 * doc/as.texinfo (Rept): Document that a zero count is allowed but
1232 negative counts are not.
1233 * config/tc-rx.c (rx_rept): Use size_t type for count parameter.
1234 * config/tc-tic54x.c (tic54x_loop): Cast count parameter to size_t
1236 * testsuite/gas/macros/end.s: Add a test using a negative repeat
1238 * testsuite/gas/macros/end.l: Add expected error message.
1242 * config/tc-riscv.c (md_apply_fix): Mark
1243 BFD_RELOC_RISCV_PCREL_HI20 as relaxable when relaxations are
1249 * config/tc-avr.h (struct avr_frag_data): Add prev_opcode field.
1250 (TC_FRAG_INIT): Define.
1251 (avr_frag_init): Add prototype.
1252 * config/tc-avr.c (avr_frag_init): New function.
1253 (avr_operands): Replace static local 'prev' variable with
1254 prev_opcode field in current frag.
1255 * testsuite/gas/avr/pr21621.s: New test source file.
1256 * testsuite/gas/avr/pr21621.d: New test driver file.
1257 * testsuite/gas/avr/pr21621.s: New test error output file.
1261 * testsuite/gas/all/fill-1.s: Use normal labels. Change .text to
1262 .data. Pick different values. Use .dc.w instead of .word.
1263 * testsuite/gas/all/fill-1.d: New objdump output check.
1264 * testsuite/gas/all/gas.exp: Use run_dump_test to execute fill-1
1269 * testsuite/gas/all/align.d: Mark as unsupported on RISC-V.
1270 testsuite/gas/all/relax.d: Likewise.
1271 testsuite/gas/all/sleb128-2.d: Likewise.
1272 testsuite/gas/all/sleb128-4.d: Likewise.
1273 testsuite/gas/all/sleb128-5.d: Likewise.
1274 testsuite/gas/all/sleb128-7.d: Likewise.
1275 testsuite/gas/elf/section11.d: Likewise.
1276 testsuite/gas/all/gas.exp (diff1.s): Likewise.
1281 * testsuite/gas/cris/range-err-1.s: Remove spurious xfails.
1282 * testsuite/gas/cris/cris.exp: Expect the shexpr-1 test to pass.
1286 * po/sv.po: Updated Swedish translation.
1291 * config/tc-nios2.c (nios2_translate_pseudo_insn): Check for
1292 correct number of arguments.
1293 (md_assemble): Handle failure of nios2_translate_pseudo_insn.
1294 * testsuite/gas/nios2/illegal_pseudoinst.l: New file.
1295 * testsuite/gas/nios2/illegal_pseudoinst.s: New file.
1296 * testsuite/gas/nios2/nios2.exp: Add illegal_pseudoinst test.
1300 * config/tc-ft32.c (md_assemble): Replace FT32_FLD_K8 with
1302 (md_apply_fix, tc_gen_reloc): Add BFD_RELOC_FT32_15.
1307 * listing.c (listing_newline): Use the name of the current
1308 physical input file, rather than the current logical input file,
1309 unless including high level source in the listing.
1310 * input-scrub.c (as_where_physical): New function. Returns the
1311 name of the current physical input file.
1312 * as.h: Add prototype for as_where_physical.
1316 * testsuite/gas/s390/zarch-arch12.d (prno, tpei, irbm): New
1318 * testsuite/gas/s390/zarch-arch12.s: Likewise.
1319 * testsuite/gas/s390/zarch-z13.d: Rename ppno to prno.
1323 * testsuite/gas/all/fill-1.s: Replace nop with .word 42
1327 * read.c (s_fill): Invoke expression instead of
1328 get_known_segmented_expression.
1329 * testsuite/gas/all/fill-1.s: New testcase.
1330 * testsuite/gas/all/gas.exp: Run fill-1 testcase
1335 * config/tc-msp430.c (parse_exp): Skip an 'h' suffix to constant
1337 (msp430_srcoperand): Check that the entire text was parsed by
1339 (msp430_operands): Likewise.
1340 * testsuite/gas/msp430/pr22133.s: New test file.
1341 * testsuite/gas/msp430/pr22133.d: New test driver.
1342 * testsuite/gas/msp430/pr22133.s: Expected error output.
1343 * testsuite/gas/msp430/msp430.exp: Run the new test.
1348 * testsuite/gas/elf/elf.exp: Run group3.
1349 * testsuite/gas/elf/group3.d: New file.
1350 * testsuite/gas/elf/group3.s: Likewise.
1355 * config/obj-elf.c (struct group_list): Delete elt_count.
1356 (groups): New static.
1357 (build_group_lists): Don't count elements.
1358 (elf_adjust_symtab): Use "groups" rather than auto "list". Set up
1359 pointer from group member to SHT_GROUP section. Don't size
1360 SHT_GROUP section or clean up here..
1361 (elf_frob_file_after_relocs): ..do so here instead.
1362 * testsuite/gas/arc/jli-1.d,
1363 * testsuite/gas/elf/groupautob.d,
1364 * testsuite/gas/mips/compact-eh-eb-2.d,
1365 * testsuite/gas/mips/compact-eh-eb-5.d,
1366 * testsuite/gas/mips/compact-eh-el-2.d,
1367 * testsuite/gas/mips/compact-eh-el-5.d: Adjust.
1371 * testsuite/gas/ppc/vle-mult-ld-st-insns.s: New file: Tests the
1372 support for the VLE multiple load/store instructions.
1373 * testsuite/gas/ppc/vle-mult-ld-st-insns.d: New file: Test
1375 * testsuite/gas/ppc/ppc.exp: Run it.
1380 * testsuite/gas/riscv/fmv.x.s: New file: Tests the support for the
1381 renamed fmv.x.s and fmv.s.x instructions.
1382 * testsuite/gas/riscv/fmv.x.d: New file: Test driver.
1386 * testsuite/gas/mips/elf_mach_5900.d: New test.
1387 * testsuite/gas/mips/mips.exp: Run it.
1392 * config/tc-mips.c (s_mips_stab): Insert call to
1393 file_mips_check_options.
1395 * testsuite/gas/mips/mips.exp: Run the new tests.
1397 * testsuite/gas/mips/stabs-symbol-type.d: New test.
1398 * testsuite/gas/mips/stabs-symbol-type.s: New test source.
1402 * config/tc-ppc.h (EH_FRAME_ALIGNMENT): Define.
1407 * write.c (resolve_reloc_expr_symbols): Don't segfault when
1408 sec has been set to NULL.
1412 * config/tc-i386.c (NOTRACK_PREFIX): Removed.
1413 (REX_PREFIX): Updated.
1414 (MAX_PREFIXES): Likewise.
1415 (parse_insn): Remove restriction on NOTRACK prefix position.
1416 * testsuite/gas/i386/notrack.s: Add tests with NOTRACK prefix
1417 before other prefixes.
1418 * testsuite/gas/i386/x86-64-notrack.s: Likewise.
1419 * testsuite/gas/i386/notrackbad.s: Remove tests with NOTRACK
1420 prefix before other prefixes.
1421 * testsuite/gas/i386/x86-64-notrackbad.s: Likewise.
1422 * testsuite/gas/i386/notrack-intel.d: Updated.
1423 * testsuite/gas/i386/notrack.d: Likewise.
1424 * testsuite/gas/i386/notrackbad.l: Likewise.
1425 * testsuite/gas/i386/x86-64-notrack-intel.d: Likewise.
1426 * testsuite/gas/i386/x86-64-notrack.d: Likewise.
1427 * testsuite/gas/i386/x86-64-notrackbad.l: Likewise.
1431 * config/tc-riscv.c (riscv_frag_align_code): Emit the entire
1432 alignment sequence inside R_RISCV_ALIGN.
1437 * config/tc-ppc.c (md_parse_option): Handle "mno-vle" flag.
1438 (ppc_elf_section_letter): New function.
1439 * config/tc-ppc.h (md_elf_section_letter): New.
1440 * testsuite/gas/elf/section10.d: Adjust for VLE.
1444 * config/tc-aarch64.c (aarch64_cpus): Enable DOTPROD for
1445 cortex-a55 and cortx-a75.
1449 * testsuite/gas/mips/branch-addend-micromips.d: New test.
1450 * testsuite/gas/mips/branch-addend-micromips-n32.d: New test.
1451 * testsuite/gas/mips/branch-addend-micromips-n64.d: New test.
1452 * testsuite/gas/mips/branch-addend-micromips.s: New test source.
1453 * testsuite/gas/mips/mips.exp: Run the new tests.
1457 * config/tc-mips.c (md_convert_frag): Respect
1458 `mips_ignore_branch_isa'.
1459 * testsuite/gas/mips/branch-local-5.d: New test.
1460 * testsuite/gas/mips/branch-local-n32-5.d: New test.
1461 * testsuite/gas/mips/branch-local-n64-5.d: New test.
1462 * testsuite/gas/mips/branch-local-6.d: New test.
1463 * testsuite/gas/mips/branch-local-n32-6.d: New test.
1464 * testsuite/gas/mips/branch-local-n64-6.d: New test.
1465 * testsuite/gas/mips/branch-local-7.d: New test.
1466 * testsuite/gas/mips/branch-local-n32-7.d: New test.
1467 * testsuite/gas/mips/branch-local-n64-7.d: New test.
1468 * testsuite/gas/mips/branch-local-ignore-5.d: New test.
1469 * testsuite/gas/mips/branch-local-ignore-n32-5.d: New test.
1470 * testsuite/gas/mips/branch-local-ignore-n64-5.d: New test.
1471 * testsuite/gas/mips/branch-local-ignore-6.d: New test.
1472 * testsuite/gas/mips/branch-local-ignore-n32-6.d: New test.
1473 * testsuite/gas/mips/branch-local-ignore-n64-6.d: New test.
1474 * testsuite/gas/mips/branch-local-5.l: New stderr output.
1475 * testsuite/gas/mips/branch-local-6.l: New stderr output.
1476 * testsuite/gas/mips/branch-local-5.s: New test source.
1477 * testsuite/gas/mips/branch-local-6.s: New test source.
1478 * testsuite/gas/mips/branch-local-7.s: New test source.
1479 * testsuite/gas/mips/mips.exp: Run the new tests.
1483 * testsuite/gas/mips/branch-local-n32-2.d: Use `branch-local-2.l'
1485 * testsuite/gas/mips/branch-local-n64-2.d: Likewise.
1486 * testsuite/gas/mips/branch-local-n32-3.d: Use `branch-local-3.l'
1488 * testsuite/gas/mips/branch-local-n64-3.d: Likewise.
1489 * testsuite/gas/mips/branch-local-n32-2.l: Remove file.
1490 * testsuite/gas/mips/branch-local-n64-2.l: Remove file.
1491 * testsuite/gas/mips/branch-local-n32-3.l: Remove file.
1492 * testsuite/gas/mips/branch-local-n64-3.l: Remove file.
1496 * config/tc-msp430.c (md_parse_option): Define high data and high
1497 bss symbols if -mdata-region is passed.
1498 Define -mdata-region open.
1499 * doc/c-msp430.texi: Document -mdata-region.
1500 * testsuite/gas/msp430/high-data-bss-sym.d: New test.
1501 * testsuite/gas/msp430/high-data-bss-sym.s: New.
1502 * testsuite/gas/msp430/msp430.exp: Add -mdata-region tests.
1508 (md_parse_option): Add mspe2 switch.
1509 (md_show_usage): Document -mspe2.
1510 (ppc_setup_opcodes): Handle spe2_opcodes.
1511 * doc/as.texinfo: Document -mspe2.
1512 * doc/c-ppc.texi: Likewise.
1513 * testsuite/gas/ppc/efs.d: New file.
1514 * testsuite/gas/ppc/efs.s: Likewise.
1515 * testsuite/gas/ppc/efs2.d: Likewise.
1516 * testsuite/gas/ppc/efs2.s: Likewise.
1517 * testsuite/gas/ppc/ppc.exp: Run new tests.
1518 * testsuite/gas/ppc/spe.d: New file.
1519 * testsuite/gas/ppc/spe.s: Likewise.
1520 * testsuite/gas/ppc/spe2-checks.d: Likewise.
1521 * testsuite/gas/ppc/spe2-checks.l: Likewise.
1522 * testsuite/gas/ppc/spe2-checks.s: Likewise.
1523 * testsuite/gas/ppc/spe2.d: Likewise.
1524 * testsuite/gas/ppc/spe2.s: Likewise.
1525 * testsuite/gas/ppc/spe_ambiguous.d: Likewise.
1526 * testsuite/gas/ppc/spe_ambiguous.s: Likewise.
1530 * config/tc-sparc.c (tc_gen_reloc): Convert BFD_RELOC_8/16/32/64
1531 into the corresponding BFD_RELOC_8/16/32/64_PCREL relocation
1533 * config/tc-sparc.h (DIFF_EXPR_OK): Define to enable PC-relative
1535 (TC_FORCE_RELOCATION_SUB_LOCAL): Define to ensure only supported
1536 relocations are made PC-relative.
1537 (CFI_DIFF_EXPR_OK): Define to 0 to force BFD_RELOC_32_PCREL to
1538 be used directly, since otherwise BFD_RELOC_SPARC_UA32 will be
1539 used for .eh_frame which cannot in general be converted to a
1540 BFD_RELOC_32_PCREL due to alignment requirements.
1544 * testsuite/gas/ppc/lsp-checks.d: Assemble with -a32.
1545 * testsuite/gas/ppc/lsp.d: Likewise.
1550 * testsuite/gas/ppc/lsp-checks.d,
1551 * testsuite/gas/ppc/lsp-checks.l,
1552 * testsuite/gas/ppc/lsp-checks.s: New test.
1553 * testsuite/gas/ppc/lsp.d,
1554 * testsuite/gas/ppc/lsp.s: New test.
1555 * testsuite/gas/ppc/ppc.exp: Run new tests.
1559 * config/tc-aarch64.c (REGDEF_ALIAS): Define
1560 (reg_names): Update for ip0, ip1, fp, lr to use REGDEF_ALIAS
1561 * doc/c-aarch64.texi: Update documentation on .req.
1562 * testsuite/gas/diagnostic.s: Update
1563 * testsuite/gas/diagnostic.l: Likewise
1564 * testsuite/gas/register_aliases.s: New file.
1565 * testsuite/gas/register_aliases.d: New file.
1570 * read.c (pseudo_set): Update error message for alias of common
1572 * write.c (write_object_file): Disallow both local and global
1573 aliases of common symbol.
1574 * testsuite/gas/elf/common5a.d: New file.
1575 * testsuite/gas/elf/common5a.l: Likewise.
1576 * testsuite/gas/elf/common5a.s: Likewise.
1577 * testsuite/gas/elf/common5b.d: Likewise.
1578 * testsuite/gas/elf/common5b.l: Likewise.
1579 * testsuite/gas/elf/common5b.s: Likewise.
1580 * testsuite/gas/elf/common5c.d: Likewise.
1581 * testsuite/gas/elf/common5c.s: Likewise.
1582 * testsuite/gas/elf/common5d.d: Likewise.
1583 * testsuite/gas/elf/common5d.s: Likewise.
1584 * testsuite/gas/elf/elf.exp: Run common5a, common5b, common5c
1590 * config/obj-macho.c (obj_mach_o_set_indirect_symbols): Increase
1591 size of indirect_syms array so that it is large enough to hold
1592 every symbol if necessary.
1596 * config/tc-arm.c (do_crc32_1): Remove warning on REG_SP for thumb_mode.
1597 * testsuite/gas/arm/crc32-armv8-a-bad.d: Update exepcted result.
1598 * testsuite/gas/arm/crc32-armv8-r-bad.d: Likewise.
1599 * testsuite/gas/arm/crc32-armv8-a.d: Likewise.
1600 * testsuite/gas/arm/crc32-armv8-r.d: Likewise.
1601 * testsuite/gas/arm/crc32-armv8-ar-bad.s: Update test case.
1602 * testsuite/gas/arm/crc32-armv8-ar.s: Likewise.
1603 * testsuite/gas/arm/crc32-bad.l: Update expected error message.
1607 * testsuite/gas/all/gas.exp: Add am33 to the skip lists of tests
1608 passed over by the mn10300 target.
1609 * testsuite/gas/elf/elf.exp: Likewise.
1610 * testsuite/gas/elf/dwarf2-11.d: Correct skip of am33 target.
1611 * testsuite/gas/elf/dwarf2-12.d: Likewise.
1612 * testsuite/gas/elf/dwarf2-13.d: Likewise.
1613 * testsuite/gas/elf/dwarf2-14.d: Likewise.
1614 * testsuite/gas/elf/dwarf2-15.d: Likewise.
1615 * testsuite/gas/elf/dwarf2-16.d: Likewise.
1616 * testsuite/gas/elf/dwarf2-17.d: Likewise.
1617 * testsuite/gas/elf/dwarf2-18.d: Likewise.
1618 * testsuite/gas/elf/dwarf2-5.d: Likewise.
1619 * testsuite/gas/elf/dwarf2-6.d: Likewise.
1620 * testsuite/gas/elf/dwarf2-7.d: Likewise.
1624 * config/tc-hppa.c (pa_ip): Clear `d' bit in branch on bit instructions
1625 with a double-word condition and a fixed bit position greater than 31.
1629 * config/tc-riscv.c (riscv_set_arch): Handle the Q subset like
1631 Obviate use-after-free.
1636 * testsuite/gas/arc/add_s-err.s: Update expected error message.
1641 * config/tc-aarch64.c (aarch64_init_frag): Do not set a mapping
1642 state for frags in debug sections.
1643 * config/tc-arm.c (arm_init_frag): Likewise.
1647 * dwarf2dbg.c (dwarf2dbg_final_check): Rename local variable exp
1652 * config/tc-s390.c (s390_parse_cpu): Add z14 as alternate CPU
1654 * doc/as.texinfo: Add z14 to CPU string list.
1655 * doc/c-s390.texi: Likewise.
1659 * dwarf2dbg.c (unused): Check offset of next in struct line_entry.
1660 (current): Initialize view.
1661 (force_reset_view, view_assert_failed): New variables.
1662 (reverse_line_entry_list): New function.
1663 (set_or_check_view): Likewise.
1664 (dwarf2_gen_line_info_1): Call it.
1665 (dwarf2_where): Set view to NULL.
1666 (dwarf2_emit_insn): Return early when called before first file.
1667 (dwarf2_directive_loc): Add view support. Emit insn
1668 immediately when view option is given.
1669 (process_entries): Avoid set_address to reset view when a known
1670 address change already implies the view reset.
1671 (dwarf2dbg_final_check): New function.
1672 * dwarf2dbg.h (struct dwarf2_line_info): Add view.
1673 (dwarf2dbg_final_check): Declare.
1674 * read.c (s_leb128): Parse expression as deferred.
1675 * write.c (write_object_file): Check pending view asserts.
1676 (cvt_frag_to_fill): Complain about undefined leb128 operand.
1677 * doc/as.texinfo (.loc): Document view support.
1678 * NEWS: Mention the new feature.
1679 * testsuite/gas/all/gas.exp: Run sleb128-9.
1680 * testsuite/gas/all/sleb128-9.d: New.
1681 * testsuite/gas/all/sleb128-9.l: New.
1682 * testsuite/gas/all/sleb128-9.s: New.
1683 * testsuite/gas/elf/dwarf2-1.d: Add nonzero views.
1684 * testsuite/gas/elf/dwarf2-2.d: Likewise.
1685 * testsuite/gas/elf/dwarf2-5.d: New.
1686 * testsuite/gas/elf/dwarf2-5.s: New.
1687 * testsuite/gas/elf/dwarf2-6.d: New.
1688 * testsuite/gas/elf/dwarf2-6.s: New.
1689 * testsuite/gas/elf/dwarf2-7.d: New.
1690 * testsuite/gas/elf/dwarf2-7.s: New.
1691 * testsuite/gas/elf/dwarf2-8.d: New.
1692 * testsuite/gas/elf/dwarf2-8.l: New.
1693 * testsuite/gas/elf/dwarf2-8.s: New.
1694 * testsuite/gas/elf/dwarf2-9.d: New.
1695 * testsuite/gas/elf/dwarf2-9.l: New.
1696 * testsuite/gas/elf/dwarf2-9.s: New.
1697 * testsuite/gas/elf/dwarf2-10.d: New.
1698 * testsuite/gas/elf/dwarf2-10.l: New.
1699 * testsuite/gas/elf/dwarf2-10.s: New.
1700 * testsuite/gas/elf/dwarf2-11.d: New.
1701 * testsuite/gas/elf/dwarf2-11.s: New.
1702 * testsuite/gas/elf/dwarf2-12.d: New.
1703 * testsuite/gas/elf/dwarf2-12.s: New.
1704 * testsuite/gas/elf/dwarf2-13.d: New.
1705 * testsuite/gas/elf/dwarf2-13.s: New.
1706 * testsuite/gas/elf/dwarf2-14.d: New.
1707 * testsuite/gas/elf/dwarf2-14.s: New.
1708 * testsuite/gas/elf/dwarf2-15.d: New.
1709 * testsuite/gas/elf/dwarf2-15.s: New.
1710 * testsuite/gas/elf/dwarf2-16.d: New.
1711 * testsuite/gas/elf/dwarf2-16.s: New.
1712 * testsuite/gas/elf/dwarf2-17.d: New.
1713 * testsuite/gas/elf/dwarf2-17.s: New.
1714 * testsuite/gas/elf/dwarf2-18.d: New.
1715 * testsuite/gas/elf/dwarf2-18.s: New.
1716 * testsuite/gas/elf/elf.exp: Run dwarf2-5..18 tests.
1717 * testsuite/gas/i386/dw2-compress-1.d: Add nonzero views.
1718 * testsuite/gas/i386/dw2-compressed-1.d: Likewise.
1719 * testsuite/gas/i386/ilp32/lns/lns-duplicate.d: Likewise.
1720 * testsuite/gas/lns/lns-big-delta.d: Likewise.
1721 * testsuite/gas/lns/lns-duplicate.d: Likewise.
1722 * testsuite/gas/mips/loc-swap-2.d: Likewise.
1723 * testsuite/gas/mips/loc-swap-3.d: Likewise.
1724 * testsuite/gas/mips/loc-swap.d: Likewise.
1733 * testsuite/gas/arc/jli-1.d: New file.
1734 * testsuite/gas/arc/jli-1.s: Likewise.
1735 * testsuite/gas/arc/taux.d: Update for jli_base.
1739 * as.c (start_sbrk): Remove.
1740 (main): Remove assignment.
1741 (dump_statistics): Remove display of data size.
1745 * testsuite/gas/pe/seh-x64-err-2.s: New test.
1746 * testsuite/gas/pe/seh-x64-err-2.l: New stderr output.
1747 * testsuite/gas/pe/pe.exp: Add test.
1748 * config/obj-coff-seh.c (obj_coff_seh_do_final): Don't try to end
1754 * config/tc-arm.c: Fix spelling typos.
1755 * config/tc-mips.c: Likewise.
1756 * config/tc-msp430.c: Likewise.
1757 * config/tc-sh64.c: Likewise.
1758 * config/tc-tic4x.c: Likewise.
1759 * ecoff.c: Likewise.
1760 * testsuite/gas/arm/ldr-bad.l: Likewise.
1761 * testsuite/gas/arm/ldr-t-bad.l: Likewise.
1762 * testsuite/gas/tic54x/opcodes.s: Likewise.
1763 * testsuite/gas/msp340/errata_warns.l: Likewise.
1767 * po/uk.po: Updated Ukranian translation.
1772 * config/tc-avr.c (mcu_types): Add entries for: attiny212,
1773 attiny214, attiny412, attiny414, attiny814, attiny1614,
1774 attiny1616, attiny1617, attiny3214, attiny3216, attiny3217.
1775 (md_show_usage): Adjust doc for "avrxmega3".
1776 * doc/c-avr.texi (AVR options) [-mmcu=]: Adjust doc for avrxmega3.
1777 Add MCUs: attiny212, attiny214, attiny412, attiny414, attiny416,
1778 attiny417, attiny814, attiny816, attiny817, attiny1614,
1779 attiny1616, attiny1617, attiny3214, attiny3216, attiny3217.
1783 * config/tc-arch64.c (aarch64_cpus): Add AARCH64_FEATURE_RDMA to
1784 falkor and qdf24xx entries.
1788 * po/es.po: Update from translationproject.org/latest/gas/.
1789 * po/fi.po: Likewise.
1790 * po/fr.po: Likewise.
1791 * po/id.po: Likewise.
1792 * po/ja.po: Likewise.
1793 * po/ru.po: Likewise.
1794 * po/sv.po: Likewise.
1795 * po/tr.po: Likewise.
1796 * po/uk.po: Likewise.
1797 * po/zh_CN.po: Likewise.
1801 Fix compile time warnings using gcc 7.1.1.
1802 * config/tc-pru.c (md_assemble): Add continue statement after
1803 handling 'E' operand character.
1804 * config/tc-v850.c (md_assemble): Initialise the 'insn' variable.
1808 * config/tc-arm.c (arm_cpus): Add Cortex-A55 and Cortex-A75.
1809 * doc/c-arm.texi (-mcpu): Document Cortex-A55 and Cortex-A75.
1813 * testsuite/gas/i386/opcode.s: Add tests for ModRM.reg == 6 variants.
1814 * testsuite/gas/i386/opcode.d: ditto.
1815 * testsuite/gas/i386/x86-64-opcode.s: Add x86_64 variants too.
1816 * testsuite/gas/i386/x86-64-opcode.d: ditto.
1820 * config/tc-arm.c (arm_regs): Add MVFR2.
1821 (do_vmrs): Constraint for MVFR2 and armv8.
1822 (do_vmsr): Likewise.
1823 * testsuite/gas/arm/armv8-a+fp.d: Update.
1824 * testsuite/gas/arm/armv8-ar+fp.s: Likewise.
1825 * testsuite/gas/arm/armv8-r+fp.d: Likewise.
1826 * testsuite/gas/arm/vfp-bad.s: Likewise.
1827 * testsuite/gas/arm/vfp-bad.l: Likewise.
1831 * configure: Regenerate.
1835 * NEWS: Add marker for 2.29.
1839 * testsuite/gas/elf/symver.d: Don't run on hppa64-hpux.
1843 * config/tc-mips.c (md_convert_frag): Use a switch on the
1844 microMIPS relaxation type rather than a chain of conditionals.
1848 * config/tc-mips.c (md_convert_frag): Rewrite `fix_new_exp'
1849 calls in terms of `fix_new'.
1853 * config/tc-mips.c (md_convert_frag): Don't make a helper
1854 expression symbol for `fix_new_exp' called with a non-zero
1856 * testsuite/gas/mips/relax-offset.d: New test.
1861 * testsuite/gas/mips/relax-offset.l: New stderr output.
1862 * testsuite/gas/mips/relax-offset.s: New test source.
1863 * testsuite/gas/mips/mips.exp: Run the new tests.
1868 * doc/c-avr.texi (AVR Options) <-mgcc-isr>: Document it.
1869 (AVR Pseudo Instructions): New node.
1870 * config/tc-avr.h (md_pre_output_hook): Define to avr_pre_output_hook.
1871 (md_undefined_symbol): Define to avr_undefined_symbol.
1872 (avr_pre_output_hook, avr_undefined_symbol): New protos.
1873 * config/tc-avr.c (struc-symbol.h): Include it.
1874 (ISR_CHUNK_Done, ISR_CHUNK_Prologue, ISR_CHUNK_Epilogue): New enums.
1875 (avr_isr, avr_gccisr_opcode)
1876 (avr_no_sreg_hash, avr_no_sreg): New static variables.
1877 (avr_opt_s) <have_gccisr>: Add field.
1878 (avr_opt): Add initializer for have_gccisr.
1879 (enum options) <OPTION_HAVE_GCCISR>: Add enum.
1880 (md_longopts) <"mgcc-isr">: Add entry.
1881 (md_show_usage): Document -mgcc-isr.
1882 (md_parse_option) [OPTION_HAVE_GCCISR]: Handle it.
1883 (md_undefined_symbol): Remove.
1884 (avr_undefined_symbol, avr_pre_output_hook): New fuctions.
1885 (md_begin) <avr_no_sreg_hash, avr_gccisr_opcode>: Initialize them.
1886 (avr_operand) <pregno>: Add argument and set *pregno if function
1887 is called for a register constraint.
1888 [N]: Handle constraint.
1889 (avr_operands) <avr_operand>: Pass 5th parameter to calls.
1890 [avr_opt.have_gccisr]: Call avr_update_gccisr. Call
1891 avr_gccisr_operands instead of avr_operands.
1892 (avr_update_gccisr, avr_emit_insn, avr_patch_gccisr_frag)
1893 (avr_gccisr_operands, avr_check_gccisr_done): New static functions.
1894 * testsuite/gas/avr/gccisr-01.d: New test.
1895 * testsuite/gas/avr/gccisr-01.s: New test.
1896 * testsuite/gas/avr/gccisr-02.d: New test.
1897 * testsuite/gas/avr/gccisr-02.s: New test.
1898 * testsuite/gas/avr/gccisr-03.d: New test.
1899 * testsuite/gas/avr/gccisr-03.s: New test.
1903 * config/tc-mips.c (match_float_constant): Update description.
1904 (match_operand): Likewise.
1909 * config/tc-mips.c (mips_ases): Add microMIPS XPA support.
1911 * testsuite/gas/mips/mips.exp: Run the new test. Enable
1912 `xpa-virt-err' test for `micromips'.
1918 * testsuite/gas/mips/mips.exp: Run the new test.
1923 * config/tc-mips.c (mips_set_ase): Handle the ASE_XPA_VIRT flag.
1924 * testsuite/gas/mips/xpa.d: Remove `xpa' from `-M' in `objdump'
1925 flags. Add `-mvirt' to `as' flags.
1926 * testsuite/gas/mips/xpa-err.d: New test.
1927 * testsuite/gas/mips/xpa-virt-err.d: New test.
1928 * testsuite/gas/mips/xpa-err.l: New stderr output.
1929 * testsuite/gas/mips/xpa-virt-err.l: New stderr output.
1930 * testsuite/gas/mips/xpa-err.s: New test source.
1931 * testsuite/gas/mips/xpa-virt-err.s: New test source.
1932 * testsuite/gas/mips/mips.exp: Run the new tests.
1937 ASE_MIPS16E2_MT flag disassembler fix.
1943 * config/tc-mips.c (mips_set_ase): Clear the ASE_MIPS16E2_MT
1944 flag before recalculating.
1945 * testsuite/gas/mips/mips16e2-mt-err.d: New test.
1946 * testsuite/gas/mips/mips16e2-mt-err.l: New stderr output.
1947 * testsuite/gas/mips/mips16e2-mt-err.s: New test source.
1948 * testsuite/gas/mips/mips.exp: Run the new test.
1952 * config/tc-aarch64.c (aarch64_reg_parse_32_64): Accept 4B.
1953 (aarch64_features): Added dotprod.
1954 * doc/c-aarch64.texi: Added dotprod.
1955 * testsuite/gas/aarch64/dotproduct.d: New.
1956 * testsuite/gas/aarch64/dotproduct.s: New.
1960 * config/tc-arm.c (fpu_neon_ext_dotprod): New variable.
1961 (neon_scalar_for_mul): Improve comments.
1962 (do_neon_dotproduct): New function to encode Dot Product instructions.
1963 (do_neon_dotproduct_s): Wrapper function for signed Dot Product
1965 (do_neon_dotproduct_u): Wrapper function for unsigned Dot Product
1967 (insns): New entries for vsdot and vudot.
1968 (arm_extensions): New entry for "dotprod".
1969 * doc/c-arm.texi: Document new "dotprod" extension.
1970 * testsuite/gas/arm/dotprod.s: New test source.
1971 * testsuite/gas/arm/dotprod-illegal.s: New test source.
1972 * testsuite/gas/arm/dotprod.d: New test.
1973 * testsuite/gas/arm/dotprod-thumb2.d: New test.
1974 * testsuite/gas/arm/dotprod-illegal.d: New test.
1975 * testsuite/gas/arm/dotprod-legacy-arch.d: New test.
1976 * testsuite/gas/arm/dotprod-illegal.l: New error file.
1977 * testsuite/gas/arm/dotprod-legacy-arch.l: New error file.
1981 * testsuite/gas/mips/elf_mach_interaptiv-mr2.d: New test.
1982 * testsuite/gas/mips/save-err.d: New test.
1983 * testsuite/gas/mips/save-sub.d: New test.
2004 * testsuite/gas/mips/mips16e2-copy.d: New test.
2005 * testsuite/gas/mips/mips16e2-copy-err.d: New test.
2006 * testsuite/gas/mips/save.d: Remove `MIPS16e' from the `name'
2007 option. Adjust for trailing padding change.
2008 * testsuite/gas/mips/mips16e2-copy-err.l: New stderr output.
2009 * testsuite/gas/mips/save-sub.s: New test source.
2010 * testsuite/gas/mips/mips16e2-copy.s: New test source.
2011 * testsuite/gas/mips/mips16e2-copy-err.s: New test source.
2012 * testsuite/gas/mips/save.s: Update description, change trailing
2013 padding and remove trailing white space.
2014 * testsuite/gas/mips/mips.exp: Expand `save' and `save-err'
2015 tests across the regular MIPS interAptiv MR2 architecture. Run
2020 * testsuite/gas/mips/mips.exp (interaptiv-mr2): New architecture.
2021 (mips16e2-interaptiv-mr2): Likewise.
2047 * testsuite/gas/mips/attr-gnu-4-5.d: Ignore any number of ASE
2048 flag lines present rather than just one.
2049 * testsuite/gas/mips/attr-gnu-4-6.d: Likewise.
2050 * testsuite/gas/mips/attr-gnu-4-7.d: Likewise.
2051 * testsuite/gas/mips/attr-none-o32-fp64-nooddspreg.d: Likewise.
2052 * testsuite/gas/mips/attr-none-o32-fp64.d: Likewise.
2053 * testsuite/gas/mips/attr-none-o32-fpxx.d: Likewise.
2078 * config/tc-mips.c (validate_mips_insn): Handle
2079 OP_SAVE_RESTORE_LIST specially.
2080 (mips_encode_save_restore, mips16_encode_save_restore): New
2082 (match_save_restore_list_operand): Factor out SAVE/RESTORE
2083 operand insertion into the instruction word or halfword to these
2085 (mips_cpu_info_table): Add "interaptiv-mr2" entry.
2087 * doc/c-mips.texi (MIPS Options): Add `interaptiv-mr2' to the
2088 `-march=' argument list.
2092 * testsuite/gas/mips/mips16e-save.d: Rename to...
2093 * testsuite/gas/mips/save.d: ... this.
2094 * testsuite/gas/mips/mips16e-save-err.d: Update the
2095 `error-output' option and rename to...
2096 * testsuite/gas/mips/save-err.d: ... this.
2097 * testsuite/gas/mips/mips16e-save-err.l: Rename to...
2098 * testsuite/gas/mips/save-err.l: ... this.
2099 * testsuite/gas/mips/mips16e-save.s: Rename to...
2100 * testsuite/gas/mips/save.s: ... this.
2101 * testsuite/gas/mips/mips16e-save-err.s: Rename to...
2102 * testsuite/gas/mips/save-err.s: ... this.
2103 * testsuite/gas/mips/mips.exp: Rename `mips16e-save' and
2104 `mips16e-save-err' invocations to `save' and `save-err'
2105 respectively and reorder these tests away from MIPS16 tests.
2109 * testsuite/gas/mips/mips16e-save.d: Remove `-mmips:isa32
2110 -mmips:16' from `objdump' flags and `-march=mips32 -mips16' from
2112 * testsuite/gas/mips/mips16e-save-err.d: Remove `-march=mips32'
2114 * testsuite/gas/mips/mips16e-save.s: Remove the `.set mips16'
2116 * testsuite/gas/mips/mips16e-save-err.s: Likewise.
2117 * testsuite/gas/mips/mips.exp: Run SAVE/RESTORE tests across all
2118 MIPS16e architectures.
2122 * testsuite/gas/mips/mips16e-save-err.d: New test.
2123 * gas/testsuite/gas/mips/mips.exp: Fold `mips16e-save-err' list
2124 test into the new test.
2128 * testsuite/gas/mips/mips16e-save.d: Capitalize the `name'
2133 * config/tc-riscv.c (md_apply_fix) [BFD_RELOC_32]: Convert to a
2134 R_RISCV_32_PCREL relocation.
2139 * config/obj-elf.c (obj_elf_symver): Don't allow .symver with
2141 (elf_frob_symbol): Likewise.
2142 * testsuite/gas/elf/elf.exp: Run pr21661.
2143 * testsuite/gas/elf/pr21661.d: New file.
2144 * testsuite/gas/elf/pr21661.s: Likewise.
2148 * config/tc-arm.c (fpu_any): Only define for ELF based targets.
2152 * /config/tc-arc.c (is_br_jmp_insn_p): Update macro with known
2153 instructions to be accounted as jumps.
2154 (assemble_insn): Check for limms into the delay slots. Emit an
2156 * testsuite/gas/arc/asm-errors-3.d: New file.
2157 * testsuite/gas/arc/asm-errors-3.err: Likewise.
2158 * testsuite/gas/arc/asm-errors-3.s: Likewise.
2162 * NEWS: Mention support of ARM Cortex-R52 processor.
2163 * config/tc-arm.c (arm_cpus): Add entry for ARM Cortex-R52 processor.
2164 * doc/c-arm.texi: Mention support for -mcpu=cortex-r52.
2168 * NEWS: Mention support for ARMv8-R architecture.
2169 * config/tc-arm.c (arm_archs): Add entry for ARMv8-R.
2170 (arm_extensions): Restrict pan, ras and rdma extension to
2171 ARMv8-A and make crypto, fp and simd extensions available to
2173 (cpu_arch_ver): Add entry for ARMv8-R.
2174 (aeabi_set_public_attributes): Update gas_assert for Tag_DIV_use
2176 * testsuite/gas/arm/armv8-a+fp.s: Rename into ...
2177 * testsuite/gas/arm/armv8-ar+fp.s: This. Remove .arch directive.
2178 * testsuite/gas/arm/armv8-a+fp.d: Specify source to assemble and
2179 architecture to assemble for.
2180 * testsuite/gas/arm/armv8-r+fp.d: New.
2181 * testsuite/gas/arm/armv8-a+simd.s: Rename into ...
2182 * testsuite/gas/arm/armv8-ar+simd.s: This. Remove .arch directive.
2183 * testsuite/gas/arm/armv8-a+simd.d: Specify source to assemble and
2184 architecture to assemble for.
2185 * testsuite/gas/arm/armv8-r+simd.d: New.
2186 * testsuite/gas/arm/armv8-a-bad.s: Rename into ...
2187 * testsuite/gas/arm/armv8-ar-bad.s: This. Remove .arch directive.
2188 * testsuite/gas/arm/armv8-a-bad.l: Rename into ...
2189 * testsuite/gas/arm/armv8-ar-bad.l: This. Decrement line number by 1.
2190 * testsuite/gas/arm/armv8-a-bad.d: Specify source to assemble,
2191 architecture to assemble for and adjust error output file.
2192 * testsuite/gas/arm/armv8-r-bad.d: New.
2193 * testsuite/gas/arm/armv8-a-barrier.s: Rename into ...
2194 * testsuite/gas/arm/armv8-ar-barrier.s: This.
2195 * testsuite/gas/arm/armv8-a-barrier-arm.d: Adjust source.
2196 * testsuite/gas/arm/armv8-a-barrier-thumb.d: Likewise.
2197 * testsuite/gas/arm/armv8-r-barrier-arm.d: New.
2198 * testsuite/gas/arm/armv8-r-barrier-thumb.d: New.
2199 * testsuite/gas/arm/armv8-a-it-bad.s: Rename into ...
2200 * testsuite/gas/arm/armv8-ar-it-bad.s: This. Remove .arch directive.
2201 * testsuite/gas/arm/armv8-a-it-bad.l: Rename into ...
2202 * testsuite/gas/arm/armv8-ar-it-bad.l: This. Decrement line number
2204 * testsuite/gas/arm/armv8-a-it-bad.d: Specify source to assemble,
2205 architecture to assemble for and adjust error output file.
2206 * testsuite/gas/arm/armv8-r-it-bad.d: New.
2207 * testsuite/gas/arm/armv8-a.s: Rename into ...
2208 * testsuite/gas/arm/armv8-ar.s: This. Remove .arch directive.
2209 * testsuite/gas/arm/armv8-a.d: Specify source to assemble and
2210 architecture to assemble for.
2211 * testsuite/gas/arm/armv8-r.d: New.
2212 * testsuite/gas/arm/attr-march-armv8-r+crypto.d: New.
2213 * testsuite/gas/arm/attr-march-armv8-r+fp.d: New.
2214 * testsuite/gas/arm/attr-march-armv8-r+simd.d: New.
2215 * testsuite/gas/arm/attr-march-armv8-r.d: New.
2216 * testsuite/gas/arm/crc32.s: Rename into ...
2217 * testsuite/gas/arm/crc32-armv8-ar.s: This.
2218 * testsuite/gas/arm/crc32.d: Rename into ...
2219 * testsuite/gas/arm/crc32-armv8-a.d: This. Specify source to assemble.
2220 * testsuite/gas/arm/crc32-armv8-r.d: New.
2221 * testsuite/gas/arm/crc32-bad.s: Rename into ...
2222 * testsuite/gas/arm/crc32-armv8-ar-bad.s: This.
2223 * testsuite/gas/arm/crc32-bad.d: Rename into ...
2224 * testsuite/gas/arm/crc32-armv8-a-bad.d: This. Specify source to
2226 * testsuite/gas/arm/crc32-armv8-r-bad.d: New.
2227 * testsuite/gas/arm/mask_1.s: Rename into ...
2228 * testsuite/gas/arm/mask_1-armv8-ar.s: This.
2229 * testsuite/gas/arm/mask_1.d: Rename into ...
2230 * testsuite/gas/arm/mask_1-armv8-a.d: This. Specify source to
2232 * testsuite/gas/arm/mask_1-armv8-r.d: new.
2236 * config/tc-arm.c (arm_ext_v6m): Delete.
2237 (arm_ext_v7m): Delete.
2238 (arm_ext_m): Remove ARM_EXT_OS from the set of feature defined M
2240 (arm_arch_v6m_only): Delete.
2241 (do_t_swi): Remove special case for ARMv6S-M.
2242 (md_assemble): Display error message previously in do_t_swi when
2243 SVC is not available.
2244 (insns): Guard swi and svc by arm_ext_os for Thumb mode.
2245 (aeabi_set_public_attributes): Remove special case for ARMv6S-M.
2249 * config/tc-riscv.c (riscv_ip): Changes as_warn to as_bad for improper
2254 * config/tc-arm.c (arm_ext_v7m): Add ATTRIBUTE_UNUSED.
2258 * config/tc-arm.c (fpu_any): Defined from FPU_ANY.
2259 (cpu_arch_ver): Add all architectures and sort by release date.
2260 (have_ext_for_needed_feat_p): New.
2261 (get_aeabi_cpu_arch_from_fset): New.
2262 (aeabi_set_public_attributes): Call above function to determine
2263 Tag_CPU_arch and Tag_CPU_arch_profile values. Adapt Tag_ARM_ISA_use
2264 and Tag_THUMB_ISA_use selection logic to check absence of feature bit
2266 * testsuite/gas/arm/attr-march-armv1.d: Fix expected Tag_CPU_arch build
2268 * testsuite/gas/arm/attr-march-armv2.d: Likewise.
2269 * testsuite/gas/arm/attr-march-armv2a.d: Likewise.
2270 * testsuite/gas/arm/attr-march-armv2s.d: Likewise.
2271 * testsuite/gas/arm/attr-march-armv3.d: Likewise.
2272 * testsuite/gas/arm/attr-march-armv3m.d: Likewise.
2273 * testsuite/gas/arm/pr12198-2.d: Likewise.
2277 * testsuite/gas/i386/cet-intel.d: Updated.
2278 * testsuite/gas/i386/cet.d: Likewise.
2279 * testsuite/gas/i386/x86-64-cet-intel.d: Likewise.
2280 * testsuite/gas/i386/x86-64-cet.d: Likewise.
2281 * testsuite/gas/i386/cet.s: Update incsspd and setssbsy tests.
2282 * testsuite/gas/i386/x86-64-cet.s: Likewise.
2286 * testsuite/gas/i386/cet-intel.d: Updated.
2287 * testsuite/gas/i386/cet.d: Likewise.
2288 * testsuite/gas/i386/x86-64-cet-intel.d: Likewise.
2289 * testsuite/gas/i386/x86-64-cet.d: Likewise.
2290 * testsuite/gas/i386/cet.s: Replace savessp with saveprevssp.
2291 * testsuite/gas/i386/x86-64-cet.s: Likewise.
2295 * config/tc-i386.c (md_assemble): Update NOTRACK prefix check.
2296 * testsuite/gas/i386/notrack-intel.d: Updated.
2297 * testsuite/gas/i386/notrack.d: Likewise.
2298 * testsuite/gas/i386/notrackbad.l: Likewise.
2299 * testsuite/gas/i386/x86-64-notrack-intel.d: Likewise.
2300 * testsuite/gas/i386/x86-64-notrack.d: Likewise.
2301 * testsuite/gas/i386/x86-64-notrackbad.l: Likewise.
2302 * testsuite/gas/i386/notrack.s: Add NOTRACK prefix tests with
2303 memory indirect branch.
2304 * testsuite/gas/i386/x86-64-notrack.s: Likewise.
2305 * testsuite/gas/i386/notrackbad.s: Remove memory indirect branch
2306 with NOTRACK prefix.
2307 * testsuite/gas/i386/x86-64-notrackbad.s: Likewise.
2311 * config/tc-arm.c (arm_extensions): New duplicate idiv entry to enable
2312 Thumb division for ARMv7 architecture.
2313 (arm_parse_extension): Document expected behavior for duplicate
2315 (s_arm_arch_extension): Likewise.
2316 * testsuite/gas/arm/forbid-armv7-idiv-ext.d: New test.
2317 * testsuite/gas/arm/forbid-armv7-idiv-ext.l: New expected output for
2322 * config/tc-arm.c (aeabi_set_public_attributes): Populate flags from
2323 feature bits used or selected_cpu depending on whether a CPU was
2324 selected by the user.
2328 * config/tc-arm.c (aeabi_set_public_attributes): Test *mcpu_ext_opt to
2329 decide whether to set Tag_DSP_extension build attribute value. Remove
2330 now useless arm_arch variable.
2334 * config/tc-arm.c (dyn_mcpu_ext_opt): New static variable.
2335 (dyn_march_ext_opt): Likewise.
2336 (md_begin): Copy extension feature bits alongside architecture ones.
2337 Merge extensions feature bits in selected_cpu and cpu_variant if there
2339 (arm_parse_extension): Pass architecture and extension feature bits in
2340 separate parameters, with architecture bits being read only. Update
2341 **opt_p directly rather than *ext_set and initialize it if needed.
2342 (arm_parse_cpu): Stop merging architecture and extension feature bits
2343 and instead use mcpu_cpu_opt and dyn_mcpu_ext_opt to memorize them
2344 respectively. Adapt to change in parameters of arm_parse_extension.
2345 (arm_parse_arch): Adapt to change in parameters of arm_parse_extension.
2346 (aeabi_set_attribute_string): Make function static.
2347 (arm_md_post_relax): New function.
2348 (s_arm_cpu): Stop merging architecture and extension feature bits and
2349 instead use mcpu_cpu_opt and dyn_mcpu_ext_opt to memorize them
2350 respectively. Merge extension feature bits in cpu_variant
2352 (s_arm_arch): Reset extension feature bit. Set selected_cpu from
2353 *mcpu_cpu_opt and cpu_variant from selected_cpu and *mfpu_opt for
2354 consistency with s_arm_cpu.
2355 (s_arm_arch_extension): Update *dyn_mcpu_ext_opt rather than
2356 selected_cpu, allocating it before hand if needed. Set selected_cpu
2357 from it and then cpu_variant.
2358 (s_arm_fpu): Merge *mcpu_ext_opt feature bits if any in cpu_variant.
2359 * config/tc-arm.h (md_post_relax_hook): Set to arm_md_post_relax.
2360 (aeabi_set_public_attributes): Delete external declaration.
2361 (arm_md_post_relax): Declare externally.
2365 * config/tc-arm.c (struct arm_cpu_option_table): New ext field.
2366 (ARM_CPU_OPT): Add parameter to set new ext field and reorder canonical
2367 name field just after the name field.
2368 (arm_cpus): Move extension feature bit from value field to ext field,
2369 reorder parameter according to changes in ARM_CPU_OPT and reindent.
2370 (arm_parse_cpu): Point mcpu_cpu_opt to a bitfield merging the value and
2371 ext field from the selected arm_cpus entry.
2372 (s_arm_cpu): Likewise.
2376 * config/tc-aarch64.c (aarch64_cpus): Add cortex-a55 and cortex-a75.
2377 * doc/c-aarch64.texi (-mcpu): Document cortex-a55 and cortex-a75.
2382 * testsuite/gas/i386/mpx.s: Add 2 tests with invalid bnd
2384 * testsuite/gas/i386/x86-64-mpx.s: Likewise.
2385 * testsuite/gas/i386/mpx.d: Updated.
2386 * testsuite/gas/i386/x86-64-mpx.d: Likewise.
2390 * config/tc-xtensa.c (density_supported, xtensa_fetch_width,
2391 absolute_literals_supported): Leave definitions uninitialized.
2392 (directive_state): Leave entries for directive_density and
2393 directive_absolute_literals initialized to false.
2394 (xg_init_global_config, xtensa_init): New functions.
2395 * config/tc-xtensa.h (TARGET_BYTES_BIG_ENDIAN): Define as 0.
2396 (HOST_SPECIAL_INIT): New definition.
2397 (xtensa_init): New declaration.
2401 * config/tc-aarch64.c (reg_entry_reg_names): Add IP0,
2402 IP1, FP, and LR as register aliases of register 16, 17, 29
2403 and 30 respectively.
2404 * testsuite/gas/aarch64/diagnostic.l: Remove diagnostic
2405 prohibiting register 'lr' which is now an alias.
2406 * testsuite/gas/aarch64/diagnostic.s: Remove instruction
2407 utilizing register 'lr' which is now an alias.
2411 * config/tc-arm.c (reject_bad_reg): Allow REG_SP on ARMv8-A.
2412 (parse_operands): Allow REG_SP for OP_oRRnpcsp and OP_RRnpcsp on
2414 (do_co_reg): Allow REG_SP for Rd on ARMv8-A.
2415 (do_t_add_sub): Likewise.
2416 (do_t_mov_cmp): Likewise.
2417 (do_t_tb): Likewise.
2418 * testsuite/gas/arm/ld-sp-warn.l: Delete the warning on REG_SP as Rt for
2420 * testsuite/gas/arm/sp-pc-validations-bad-t-v8a.d: New test.
2421 * testsuite/gas/arm/sp-pc-validations-bad-t-v8a.l: New test.
2422 * testsuite/gas/arm/sp-pc-validations-bad-t.d: Specifies -march=armv7-a.
2423 * testsuite/gas/arm/sp-pc-validations-bad-t.s: Remove ".arch armv7-a".
2424 * testsuite/gas/arm/sp-usage-thumb2-relax-on-v7.d: New test.
2425 * testsuite/gas/arm/sp-usage-thumb2-relax-on-v7.l: New test.
2426 * testsuite/gas/arm/sp-usage-thumb2-relax-on-v8.d: New test.
2427 * testsuite/gas/arm/sp-usage-thumb2-relax.s: New test.
2428 * testsuite/gas/arm/strex-bad-t.d: Specifies -march=armv7-a.
2432 * config/tc-arm.c (arm_cpus): Delete falkor and qdf24xx entries.
2433 * doc/c-arm.texi (-mcpu): Likewise.
2437 * config/tc-arc.c (cpu_types): Include arc-cpu.def
2441 * gas/testsuite/gas/i386/notrackbad.l: Updated for non-ELF
2443 * gas/testsuite/gas/i386/x86-64-notrackbad.l: Likewise.
2447 * config/tc-arc.c (md_apply_fix): Use as_bad_where.
2448 (assemble_insn): Use as_bad.
2452 * config/tc-i386.c (REX_PREFIX): Changed to 7.
2453 (NOTRACK_PREFIX): New.
2454 (MAX_PREFIXES): Changed to 8.
2455 (_i386_insn): Add notrack_prefix.
2456 (PREFIX_GROUP): Add PREFIX_DS.
2457 (add_prefix): Return PREFIX_DS for DS_PREFIX_OPCODE.
2458 (md_assemble): Check if NOTRACK prefix is supported.
2459 (parse_insn): Set notrack_prefix and issue an error for
2460 other prefixes after NOTRACK prefix.
2461 * testsuite/gas/i386/i386.exp: Run tests for NOTRACK prefix.
2462 * testsuite/gas/i386/notrack-intel.d: New file.
2463 * testsuite/gas/i386/notrack.d: Likewise.
2464 * testsuite/gas/i386/notrack.s: Likewise.
2465 * testsuite/gas/i386/notrackbad.l: Likewise.
2466 * testsuite/gas/i386/notrackbad.s: Likewise.
2467 * testsuite/gas/i386/x86-64-notrack-intel.d: Likewise.
2468 * testsuite/gas/i386/x86-64-notrack.d: Likewise.
2469 * testsuite/gas/i386/x86-64-notrack.s: Likewise.
2470 * testsuite/gas/i386/x86-64-notrackbad.l: Likewise.
2471 * testsuite/gas/i386/x86-64-notrackbad.s: Likewise.
2475 * configure.tgt: Set "arch" to "aarch64" if ${cpu} equals "aarch64".
2476 Recognize the new triplet name aarch64*-linux-gnu_ilp32.
2477 * configure.ac: Output DEFAULT_ARCH macro for AArch64.
2478 * configure: Regenerate.
2479 * config/tc-aarch64.h (aarch64_after_parse_args): New declaration.
2480 (md_after_parse_args): New define.
2481 * config/tc-aarch64.c (aarch64_abi_type): New enumeration
2483 (DEFAULT_ARCH): New define.
2484 (aarch64_abi): Set default value to AARCH64_ABI_NONE.
2485 (aarch64_after_parse_args): New function.
2489 * config/tc-sparc.c (sparc_arch_table): Entries for `sparc6',
2490 `v9m8' and `v8plusm8'.
2491 (sparc_md_end): Handle SPARC_OPCODE_ARCH_M8.
2492 (get_hwcap_name): Support the M8 hardware capabilities.
2493 (sparc_ip): Handle new operand types.
2494 * doc/c-sparc.texi (Sparc-Opts): Document -Av9m8, -Av8plusm8 and
2495 -Asparc6, and the corresponding -xarch aliases.
2496 * testsuite/gas/sparc/sparc6.s: New file.
2497 * testsuite/gas/sparc/sparc6.d: Likewise.
2498 * testsuite/gas/sparc/sparc6-diag.s: Likewise.
2499 * testsuite/gas/sparc/sparc6-diag.l: Likewise.
2500 * testsuite/gas/sparc/fpcmpshl.s: Likewise.
2501 * testsuite/gas/sparc/fpcmpshl.d: Likewise.
2502 * testsuite/gas/sparc/fpcmpshl-diag.s: Likewise.
2503 * testsuite/gas/sparc/fpcmpshl-diag.l: Likewise.
2504 * testsuite/gas/sparc/ldm-stm.s: Likewise.
2505 * testsuite/gas/sparc/ldm-stm.d: Likewise.
2506 * testsuite/gas/sparc/ldm-stm-diag.s: Likewise.
2507 * testsuite/gas/sparc/ldm-stm-diag.l: Likewise.
2508 * testsuite/gas/sparc/ldmf-stmf.s: Likewise.
2509 * testsuite/gas/sparc/ldmf-stmf.d: Likewise.
2510 * testsuite/gas/sparc/ldmf-stmf-diag.s: Likewise.
2511 * testsuite/gas/sparc/ldmf-stmf-diag.l: Likewise.
2512 * testsuite/gas/sparc/on.s: Likewise.
2513 * testsuite/gas/sparc/on.d: Likewise.
2514 * testsuite/gas/sparc/on-diag.s: Likewise.
2515 * testsuite/gas/sparc/on-diag.l: Likewise.
2516 * testsuite/gas/sparc/rle.s: Likewise.
2517 * testsuite/gas/sparc/rle.d: Likewise.
2518 * testsuite/gas/sparc/sparc.exp (gas_64_check): Run new tests.
2519 * testsuite/gas/sparc/rdasr.s: Add test for RDENTROPY.
2520 * testsuite/gas/sparc/rdasr.d: Likewise.
2524 * testsuite/gas/sparc/call-relax.d: Support 32-bit targets.
2525 * testsuite/gas/sparc/sparc.exp (gas_64_check): Use -64 to
2531 * config/tc-avr.c (mcu_types): Add entries for: attiny416,
2532 attiny417, attiny816, attiny817.
2536 * config/tc-aarch64.c: Don't compare booleans against TRUE or FALSE.
2537 * config/tc-hppa.c: Likewise.
2538 * config/tc-mips.c: Likewise.
2539 * config/tc-score7.c: Likewise.
2543 * write.c (GENERIC_FORCE_RELOCATION_LOCAL): Define.
2544 (TC_FORCE_RELOCATION_LOCAL): Use it.
2545 (GENERIC_FORCE_RELOCATION_SUB_SAME): Define.
2546 (TC_FORCE_RELOCATION_SUB_SAME): Use it.
2547 * config/tc-arm.h (TC_FORCE_RELOCATION_LOCAL,
2548 TC_FORCE_RELOCATION_SUB_SAME): Use GENERIC defines.
2549 * config/tc-aarch64.h: Similarly.
2550 * config/tc-avr.h: Similarly.
2551 * config/tc-cris.h: Similarly.
2552 * config/tc-i386.h: Similarly.
2553 * config/tc-i960.h: Similarly.
2554 * config/tc-ia64.h: Similarly.
2555 * config/tc-microblaze.h: Similarly.
2556 * config/tc-mips.h: Similarly.
2557 * config/tc-msp430.h: Similarly.
2558 * config/tc-nds32.h: Similarly.
2559 * config/tc-pru.h: Similarly.
2560 * config/tc-riscv.h: Similarly.
2561 * config/tc-rl78.h: Similarly.
2562 * config/tc-s390.h: Similarly.
2563 * config/tc-sh.h: Similarly.
2564 * config/tc-sh64.h: Similarly.
2565 * config/tc-sparc.h: Similarly.
2566 * config/tc-xtensa.h: Similarly.
2567 * config/tc-mn10300.h: Similarly.
2568 (GENERIC_FORCE_RELOCATION_LOCAL): Define.
2569 * config/tc-msp430.c (msp430_force_relocation_local): Modify to
2570 be addition to rather than replacement of standard
2571 TC_FORCE_RELOCATION_LOCAL.
2576 * config/tc-arm.c (do_adr): If the ADR involves a thumb function
2577 symbol, ensure that the T bit will be set.
2578 (do_adrl): Likewise.
2579 (do_t_adr): Likewise.
2580 * testsuite/gas/arm/pr21458.s: New test.
2581 * testsuite/gas/arm/pr21458.d: New test driver.
2585 * testsuite/gas/mips/mips16-pcrel-1.d: Remove `-mips3' from `as'
2587 * testsuite/gas/mips/mips16-pcrel-pic-1.d: Likewise.
2588 * testsuite/gas/mips/mips16-pcrel-n32-0.d: Likewise.
2589 * testsuite/gas/mips/mips16-pcrel-n32-1.d: Likewise.
2590 * testsuite/gas/mips/mips16-pcrel-n64-0.d: Likewise.
2591 * testsuite/gas/mips/mips16-pcrel-n64-1.d: Likewise.
2592 * testsuite/gas/mips/mips16-pcrel-n64-sym32-0.d: Likewise.
2593 * testsuite/gas/mips/mips16-pcrel-n64-sym32-1.d: Likewise.
2594 * testsuite/gas/mips/mips16-pcrel-reloc-4.d: Likewise.
2595 * testsuite/gas/mips/mips16-pcrel-reloc-5.d: Likewise.
2596 * testsuite/gas/mips/mips16-pcrel-reloc-6.d: Likewise.
2597 * testsuite/gas/mips/mips16-pcrel-reloc-7.d: Likewise.
2598 * testsuite/gas/mips/mips16-pcrel-addend-4.d: Likewise.
2599 * testsuite/gas/mips/mips16-pcrel-addend-5.d: Likewise.
2600 * testsuite/gas/mips/mips16-pcrel-addend-6.d: Likewise.
2601 * testsuite/gas/mips/mips16-pcrel-addend-7.d: Likewise.
2602 * testsuite/gas/mips/mips16-pcrel-addend-9.d: Likewise.
2603 * testsuite/gas/mips/mips16-pcrel-addend-pic-9.d: Likewise.
2604 * testsuite/gas/mips/mips16-pcrel-addend-n32-8.d: Likewise.
2605 * testsuite/gas/mips/mips16-pcrel-addend-n32-9.d: Likewise.
2606 * testsuite/gas/mips/mips16-pcrel-addend-n64-sym32-8.d:
2608 * testsuite/gas/mips/mips16-pcrel-addend-n64-sym32-9.d:
2610 * testsuite/gas/mips/mips16-pcrel-addend-n64-8.d: Likewise.
2611 * testsuite/gas/mips/mips16-pcrel-addend-n64-9.d: Likewise.
2612 * testsuite/gas/mips/mips16-pcrel-absolute-2.d: Likewise.
2613 * testsuite/gas/mips/mips16-pcrel-absolute-3.d: Likewise.
2614 * testsuite/gas/mips/mips16-pcrel-absolute-6.d: Likewise.
2615 * testsuite/gas/mips/mips16-pcrel-absolute-7.d: Likewise.
2616 * testsuite/gas/mips/mips16-pcrel-absolute-pic-6.d: Likewise.
2617 * testsuite/gas/mips/mips16-pcrel-absolute-n32-4.d: Likewise.
2618 * testsuite/gas/mips/mips16-pcrel-absolute-n32-6.d: Likewise.
2619 * testsuite/gas/mips/mips16-pcrel-absolute-n64-4.d: Likewise.
2620 * testsuite/gas/mips/mips16-pcrel-absolute-n64-6.d: Likewise.
2621 * testsuite/gas/mips/mips16-pcrel-absolute-n64-sym32-4.d:
2623 * testsuite/gas/mips/mips16-pcrel-absolute-n64-sym32-6.d:
2625 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n32-4.d:
2627 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n32-6.d:
2629 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n64-4.d:
2631 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n64-6.d:
2633 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n64-sym32-4.d:
2635 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n64-sym32-6.d:
2701 * testsuite/gas/mips/mips16-pcrel-1.l: Adjust line numbers.
2702 * testsuite/gas/mips/mips16-pcrel-1.s: Adjust for alignment
2703 preservation between MIPS16 and MIPS16e2 code.
2704 * testsuite/gas/mips/mips.exp: Run MIPS16 relaxation tests over
2705 all MIPS16 architectures.
2709 * testsuite/gas/mips/mips16e2.d: New test.
2710 * testsuite/gas/mips/mips16e2-mt.d: New test.
2711 * testsuite/gas/mips/mips16e2-sub.d: New test.
2713 * testsuite/gas/mips/mips16e2-mt-sub.d: New test.
2715 * testsuite/gas/mips/mips16e2-hilo.d: New test.
2716 * testsuite/gas/mips/mips16e2-hilo-n32.d: New test.
2717 * testsuite/gas/mips/mips16e2-reloc-error.d: New test.
2718 * testsuite/gas/mips/mips16e2-imm-error.d: New test.
2719 * testsuite/gas/mips/elf_ase_mips16e2.d: New test.
2720 * testsuite/gas/mips/elf_ase_mips16e2-2.d: New test.
2721 * testsuite/gas/mips/elf-rel9-mips16e2.d: New test.
2722 * testsuite/gas/mips/mips16e2-lui.d: New test.
2726 * testsuite/gas/mips/mips16e2-reloc-error.l: New stderr output.
2727 * testsuite/gas/mips/mips16e2-imm-error.l: New stderr output.
2729 * testsuite/gas/mips/mips16e2.s: New test source.
2730 * testsuite/gas/mips/mips16e2-mt.s: New test source.
2731 * testsuite/gas/mips/mips16e2-sub.s: New test source.
2732 * testsuite/gas/mips/mips16e2-mt-sub.s: New test source.
2733 * testsuite/gas/mips/mips16e2-hilo.s: New test source.
2734 * testsuite/gas/mips/mips16e2-reloc-error.s: New test source.
2735 * testsuite/gas/mips/mips16e2-imm-error.s: New test source.
2736 * testsuite/gas/mips/elf-rel9-mips16e2.s: New test source.
2737 * testsuite/gas/mips/mips16e2-lui.s: New test source.
2738 * testsuite/gas/mips/mips.exp: Expand `mips32r2-sync',
2739 `mips32r2-sync-1', `lui-1' and `lui-2' tests across MIPS16e2
2740 architectures. Run the new tests.
2744 * testsuite/gas/mips/mips.exp (run_dump_test_arch): Add
2746 (run_list_test_arch): Likewise.
2747 (mips16e2-32, mips16e2-64): New architectures.
2758 tag. Add `-I$srcdir/$subdir' to `as' flags.
2770 * testsuite/gas/mips/mips16-sub.s: Add `.set nomips16e2'.
2771 * testsuite/gas/mips/mips16e-sub.s: Likewise.
2772 * testsuite/gas/mips/mips16e-64-sub.s: Likewise.
2773 * testsuite/gas/mips/mips16-asmacro.s: Remove `.set mips32'.
2783 * config/tc-mips.c (RELAX_MIPS16_ENCODE): Add `e2' flag.
2784 (RELAX_MIPS16_E2): New macro.
2785 (RELAX_MIPS16_PIC, RELAX_MIPS16_SYM32, RELAX_MIPS16_NOMACRO)
2786 (RELAX_MIPS16_USER_SMALL, RELAX_MIPS16_USER_EXT)
2787 (RELAX_MIPS16_DSLOT, RELAX_MIPS16_JAL_DSLOT)
2788 (RELAX_MIPS16_EXTENDED, RELAX_MIPS16_MARK_EXTENDED)
2789 (RELAX_MIPS16_CLEAR_EXTENDED, RELAX_MIPS16_ALWAYS_EXTENDED)
2790 (RELAX_MIPS16_MARK_ALWAYS_EXTENDED)
2791 (RELAX_MIPS16_CLEAR_ALWAYS_EXTENDED, RELAX_MIPS16_MACRO)
2792 (RELAX_MIPS16_MARK_MACRO, RELAX_MIPS16_CLEAR_MACRO): Shift bits.
2793 (mips16_immed_extend): New prototype.
2794 (options): Add OPTION_MIPS16E2 and OPTION_NO_MIPS16E2 enum
2796 (md_longopts): Add "mmips16e2" and "mno-mips16e2" options.
2797 (mips_ases): Add "mips16e2" entry.
2798 (mips_set_ase): Handle MIPS16e2 ASE.
2799 (insn_insert_operand): Explicitly handle immediates with MIPS16
2800 instructions that require 32-bit encoding.
2801 (is_opcode_valid_16): Pass enabled ASE bitmask on to
2803 (validate_mips_insn): Explicitly handle immediates with MIPS16
2804 instructions that require 32-bit encoding.
2805 (operand_reg_mask) <OP_REG28>: Add handler.
2806 (match_reg28_operand): New function.
2807 (match_operand) <OP_REG28>: Add handler.
2808 (append_insn): Pass ASE_MIPS16E2 setting to RELAX_MIPS16_ENCODE.
2809 (match_mips16_insn): Handle MIPS16 instructions that require
2810 32-bit encoding and `V' and `u' operand codes.
2811 (mips16_ip): Allow any characters except from `.' in opcodes.
2812 (mips16_immed_extend): Handle 9-bit immediates. Do not shuffle
2813 immediates whose width is not one of these listed.
2814 (md_estimate_size_before_relax): Handle MIPS16e2 relaxation.
2815 (mips_relax_frag): Likewise.
2816 (md_convert_frag): Likewise.
2817 (mips_convert_ase_flags): Handle MIPS16e2 ASE.
2819 * doc/as.texinfo (Target MIPS options): Add `-mmips16e2' and
2820 `-mno-mips16e2' options.
2821 (-mmips16e2, -mno-mips16e2): New options.
2822 * doc/c-mips.texi (MIPS Options): Add `-mmips16e2' and
2823 `-mno-mips16e2' options.
2824 (MIPS ASE Instruction Generation Overrides): Add `.set mips16e2'
2825 and `.set nomips16e2'.
2829 * config/tc-mips.c (match_int_operand): Call
2830 `match_out_of_range' before returning failure for 0x8000-0xffff
2831 values conditionally allowed.
2835 * config/tc-mips.c (match_int_operand): Call
2836 `match_not_constant' before returning failure for a non-constant
2837 16-bit immediate conditionally allowed.
2841 * config/tc-mips.c (match_const_int): Call `match_out_of_range'
2842 rather than `match_not_constant' for unrelocated operands
2843 retrieved as an `O_big' expression.
2844 (match_int_operand): Call `match_out_of_range' for relocatable
2845 operands retrieved as an `O_big' expression.
2846 (match_mips16_insn): Call `match_out_of_range' for relaxable
2847 operands retrieved as an `O_big' expression.
2848 * testsuite/gas/mips/addiu-error.d: New test.
2851 * testsuite/gas/mips/break-error.d: New test.
2852 * testsuite/gas/mips/lui-1.l: Adjust error message.
2853 * testsuite/gas/mips/addiu-error.l: New stderr output.
2856 * testsuite/gas/mips/break-error.l: New stderr output.
2857 * testsuite/gas/mips/addiu-error.s: New test source.
2858 * testsuite/gas/mips/break-error.s: New test source.
2859 * testsuite/gas/mips/mips.exp: Run the new tests.
2863 * config/tc-mips.c (match_mips16_insn): Remove the explicit
2864 OT_INTEGER check before the `match_expression' call.
2865 * testsuite/gas/mips/mips16-insn-e.l: Adjust messages.
2869 * testsuite/gas/mips/mips16-reg-error.d: New test.
2870 * testsuite/gas/mips/mips16-reg-error.l: New stderr output.
2871 * testsuite/gas/mips/mips16-reg-error.s: New test source.
2872 * testsuite/gas/mips/mips.exp: Run the new test.
2876 * config/tc-mips.c (match_mips16_insn): Call
2877 `match_not_constant' for a disallowed relocation operation.
2878 * testsuite/gas/mips/mips16-reloc-error.d: New test.
2879 * testsuite/gas/mips/mips16-reloc-error.l: New stderr output.
2880 * testsuite/gas/mips/mips16-reloc-error.s: New test source.
2881 * testsuite/gas/mips/mips.exp: Run the new test.
2885 * testsuite/gas/mips/lui-1.d: New test.
2886 * testsuite/gas/mips/lui-2.d: New test.
2887 * gas/testsuite/gas/mips/mips.exp: Fold corresponding list tests
2892 * config/tc-mips.c (match_const_int): Update description.
2896 * doc/as.texinfo (-mips16, -no-mips16): Refer to `.module
2897 mips16' rather than `.set mips16'.
2898 (-mmicromips, -mno-micromips): Refer to `.module micromips' and
2899 `.module nomicromips' rather than `.set micromips' and `.set
2901 (-msmartmips, -mno-smartmips): Refer to `.module smartmips'
2902 rather than `.set smartmips'.
2903 * doc/c-mips.texi (MIPS Options): Refer to `.module mips16',
2904 `.module micromips', `.module nomicromips' and `.module
2905 smartmips' rather than `.set mips16', `.set micromips', `.set
2906 nomicromips' and `.set smartmips' respectively.
2911 * config/tc-mips.c (mips_percent_op): Add "%gprel".
2912 (mips16_percent_op): Add "%gp_rel".
2913 * testsuite/gas/mips/elf-rel8.s:: Add `%gprel' forms.
2914 * testsuite/gas/mips/elf-rel8-mips16.s: Add `%gp_rel' forms.
2915 * testsuite/gas/mips/elf-rel8.d: Adjust accordingly.
2916 * testsuite/gas/mips/elf-rel8-mips16.d: Likewise.
2920 * testsuite/gas/mips/mips16.d: Adjust BREAK disassembly.
2922 * testsuite/gas/mips/mips16-64.d: Likewise.
2924 * testsuite/gas/mips/mips16-macro.d: Likewise.
2926 * testsuite/gas/mips/mips16-sub.d: Likewise.
2931 * testsuite/gas/mips/mips32r2-sync-1.d: New test.
2933 * testsuite/gas/mips/mips.exp: Run the new tests.
2937 * testsuite/gas/mips/isa-override-2.d: New test.
2965 * gas/testsuite/gas/mips/mips.exp: Fold corresponding list tests
2970 * testsuite/gas/mips/mips16e-sub.d: Correct test name.
2973 * testsuite/gas/mips/mips16e-64-sub.d: Likewise.
2980 * testsuite/gas/mips/mips16-macro.l: Remove list test.
3007 * testsuite/gas/arc/attr-arc600.d: New file.
3008 * testsuite/gas/arc/attr-arc600_mul32x16.d: Likewise.
3009 * testsuite/gas/arc/attr-arc600_norm.d: Likewise.
3010 * testsuite/gas/arc/attr-arc601.d: Likewise.
3011 * testsuite/gas/arc/attr-arc601_mul32x16.d: Likewise.
3012 * testsuite/gas/arc/attr-arc601_mul64.d: Likewise.
3013 * testsuite/gas/arc/attr-arc601_norm.d: Likewise.
3014 * testsuite/gas/arc/attr-arc700.d: Likewise.
3015 * testsuite/gas/arc/attr-arcem.d: Likewise.
3016 * testsuite/gas/arc/attr-archs.d: Likewise.
3017 * testsuite/gas/arc/attr-autodetect-1.d: Likewise.
3018 * testsuite/gas/arc/attr-autodetect-1.s: Likewise.
3019 * testsuite/gas/arc/attr-cpu-a601.d: Likewise.
3020 * testsuite/gas/arc/attr-cpu-a601.s: Likewise.
3021 * testsuite/gas/arc/attr-cpu-a700.d: Likewise.
3022 * testsuite/gas/arc/attr-cpu-a700.s: Likewise.
3023 * testsuite/gas/arc/attr-cpu-em.d: Likewise.
3024 * testsuite/gas/arc/attr-cpu-em.s: Likewise.
3025 * testsuite/gas/arc/attr-cpu-hs.d: Likewise.
3026 * testsuite/gas/arc/attr-cpu-hs.s: Likewise.
3027 * testsuite/gas/arc/attr-em.d: Likewise.
3028 * testsuite/gas/arc/attr-em4.d: Likewise.
3029 * testsuite/gas/arc/attr-em4_dmips.d: Likewise.
3030 * testsuite/gas/arc/attr-em4_fpuda.d: Likewise.
3031 * testsuite/gas/arc/attr-em4_fpus.d: Likewise.
3032 * testsuite/gas/arc/attr-hs.d: Likewise.
3033 * testsuite/gas/arc/attr-hs34.d: Likewise.
3034 * testsuite/gas/arc/attr-hs38.d: Likewise.
3035 * testsuite/gas/arc/attr-hs38_linux.d: Likewise.
3036 * testsuite/gas/arc/attr-mul64.d: Likewise.
3037 * testsuite/gas/arc/attr-name.d: Likewise.
3038 * testsuite/gas/arc/attr-name.s: Likewise.
3039 * testsuite/gas/arc/attr-nps400.d: Likewise.
3040 * testsuite/gas/arc/attr-override-mcpu.d: Likewise.
3041 * testsuite/gas/arc/attr-override-mcpu.s
3042 * testsuite/gas/arc/attr-quarkse_em.d: Likewise.
3043 * testsuite/gas/arc/blank.s: Likewise.
3044 * testsuite/gas/elf/section2.e-arc: Likewise.
3045 * testsuite/gas/arc/cpu-pseudop-1.d: Update test.
3046 * testsuite/gas/arc/cpu-pseudop-2.d: Likewise.
3047 * testsuite/gas/arc/nps400-0.d: Likewise.
3048 * testsuite/gas/elf/elf.exp: Set target_machine for ARC.
3049 * config/tc-arc.c (opcode/arc-attrs.h): Include.
3050 (ARC_GET_FLAG, ARC_SET_FLAG, streq): Define.
3051 (arc_attribute): Declare new function.
3052 (md_pseudo_table): Add arc_attribute.
3053 (cpu_types): Rename default cpu features.
3054 (selected_cpu): Set the default OSABI flag.
3055 (mpy_option): New variable.
3056 (pic_option): Likewise.
3057 (sda_option): Likewise.
3058 (tls_option): Likewise.
3059 (feature_type, feature_list): Remove.
3060 (arc_initial_eflag): Likewise.
3061 (attributes_set_explicitly): New variable.
3062 (arc_check_feature): Check also for the conflicting features.
3063 (arc_select_cpu): Refactor assignment of selected_cpu.eflags.
3064 (arc_option): Remove setting of private flags and architecture.
3065 (check_cpu_feature): Refactor feature names.
3066 (autodetect_attributes): New function.
3067 (assemble_tokens): Use above function.
3068 (md_parse_option): Refactor feature names.
3069 (arc_attribute): New function.
3070 (arc_set_attribute_int): Likewise.
3071 (arc_set_attribute_string): Likewise.
3072 (arc_stralloc): Likewise.
3073 (arc_set_public_attributes): Likewise.
3074 (arc_md_end): Likewise.
3075 (arc_copy_symbol_attributes): Likewise.
3076 (rc_convert_symbolic_attribute): Likewise.
3077 * config/tc-arc.h (md_end): Define.
3078 (CONVERT_SYMBOLIC_ATTRIBUTE): Likewise.
3079 (TC_COPY_SYMBOL_ATTRIBUTES): Likewise.
3080 * doc/c-arc.texi: Document ARC object attributes.
3084 * config/tc-mips.c (RELAX_MIPS16_ENCODE): Add `pic', `sym32' and
3086 (RELAX_MIPS16_PIC, RELAX_MIPS16_SYM32, RELAX_MIPS16_NOMACRO):
3088 (RELAX_MIPS16_USER_SMALL, RELAX_MIPS16_USER_EXT)
3089 (RELAX_MIPS16_DSLOT, RELAX_MIPS16_JAL_DSLOT)
3090 (RELAX_MIPS16_EXTENDED, RELAX_MIPS16_MARK_EXTENDED)
3091 (RELAX_MIPS16_CLEAR_EXTENDED, RELAX_MIPS16_ALWAYS_EXTENDED)
3092 (RELAX_MIPS16_MARK_ALWAYS_EXTENDED)
3093 (RELAX_MIPS16_CLEAR_ALWAYS_EXTENDED): Shift bits.
3094 (RELAX_MIPS16_MACRO, RELAX_MIPS16_MARK_MACRO)
3095 (RELAX_MIPS16_CLEAR_MACRO): New macros.
3096 (append_insn): Pass `mips_pic', HAVE_32BIT_SYMBOLS and
3097 `mips_opts.warn_about_macros' settings to RELAX_MIPS16_ENCODE.
3098 (mips16_macro_frag): New function.
3099 (md_estimate_size_before_relax): Handle HI16/LO16 relaxation.
3100 (mips_relax_frag): Likewise.
3101 (md_convert_frag): Likewise.
3109 * testsuite/gas/mips/mips16-pcrel-reloc-2.d: Remove error
3110 output, add dump patterns.
3111 * testsuite/gas/mips/mips16-pcrel-reloc-3.d: Remove error
3112 output, add dump patterns.
3113 * testsuite/gas/mips/mips16-pcrel-reloc-6.d: Remove error
3114 output, add dump patterns.
3115 * testsuite/gas/mips/mips16-pcrel-reloc-7.d: Remove error
3116 output, add dump patterns.
3117 * testsuite/gas/mips/mips16-pcrel-addend-2.d: Remove error
3118 output, add dump patterns.
3119 * testsuite/gas/mips/mips16-pcrel-addend-3.d: Remove error
3120 output, add dump patterns.
3121 * testsuite/gas/mips/mips16-pcrel-absolute.d: Remove error
3122 output, add dump patterns.
3123 * testsuite/gas/mips/mips16-pcrel-absolute-1.d: Remove error
3124 output, add dump patterns.
3126 * testsuite/gas/mips/mips16-pcrel-reloc-2.l: Remove file.
3127 * testsuite/gas/mips/mips16-pcrel-reloc-3.l: Remove file.
3128 * testsuite/gas/mips/mips16-pcrel-reloc-6.l: Remove file.
3129 * testsuite/gas/mips/mips16-pcrel-reloc-7.l: Remove file.
3130 * testsuite/gas/mips/mips16-pcrel-addend-2.l: Remove file.
3131 * testsuite/gas/mips/mips16-pcrel-addend-3.l: Remove file.
3132 * testsuite/gas/mips/mips16-pcrel-absolute.l: Remove file.
3133 * testsuite/gas/mips/mips16-pcrel-absolute-1.l: Remove file.
3134 * testsuite/gas/mips/relax-swap3.s: Adjust trailing padding.
3136 * testsuite/gas/mips/mips16-pcrel-0.d: New test.
3137 * testsuite/gas/mips/mips16-pcrel-1.d: New test.
3138 * testsuite/gas/mips/mips16-pcrel-2.d: New test.
3139 * testsuite/gas/mips/mips16-pcrel-3.d: New test.
3140 * testsuite/gas/mips/mips16-pcrel-4.d: New test.
3141 * testsuite/gas/mips/mips16-pcrel-5.d: New test.
3142 * testsuite/gas/mips/mips16-pcrel-pic-0.d: New test.
3143 * testsuite/gas/mips/mips16-pcrel-pic-1.d: New test.
3144 * testsuite/gas/mips/mips16-pcrel-n32-0.d: New test.
3145 * testsuite/gas/mips/mips16-pcrel-n32-1.d: New test.
3146 * testsuite/gas/mips/mips16-pcrel-n64-sym32-0.d: New test.
3147 * testsuite/gas/mips/mips16-pcrel-n64-sym32-1.d: New test.
3148 * testsuite/gas/mips/mips16-pcrel-n64-0.d: New test.
3149 * testsuite/gas/mips/mips16-pcrel-n64-1.d: New test.
3150 * testsuite/gas/mips/mips16-pcrel-delay-0.d: New test.
3151 * testsuite/gas/mips/mips16-pcrel-delay-1.d: New test.
3152 * testsuite/gas/mips/mips16-pcrel-addend-4.d: New test.
3153 * testsuite/gas/mips/mips16-pcrel-addend-5.d: New test.
3154 * testsuite/gas/mips/mips16-pcrel-addend-6.d: New test.
3155 * testsuite/gas/mips/mips16-pcrel-addend-7.d: New test.
3156 * testsuite/gas/mips/mips16-pcrel-addend-8.d: New test.
3157 * testsuite/gas/mips/mips16-pcrel-addend-9.d: New test.
3158 * testsuite/gas/mips/mips16-pcrel-addend-pic-8.d: New test.
3159 * testsuite/gas/mips/mips16-pcrel-addend-pic-9.d: New test.
3160 * testsuite/gas/mips/mips16-pcrel-addend-n32-8.d: New test.
3161 * testsuite/gas/mips/mips16-pcrel-addend-n32-9.d: New test.
3162 * testsuite/gas/mips/mips16-pcrel-addend-n64-sym32-8.d: New test.
3163 * testsuite/gas/mips/mips16-pcrel-addend-n64-sym32-9.d: New test.
3164 * testsuite/gas/mips/mips16-pcrel-addend-n64-8.d: New test.
3165 * testsuite/gas/mips/mips16-pcrel-addend-n64-9.d: New test.
3166 * testsuite/gas/mips/mips16-pcrel-absolute-2.d: New test.
3167 * testsuite/gas/mips/mips16-pcrel-absolute-3.d: New test.
3168 * testsuite/gas/mips/mips16-pcrel-absolute-4.d: New test.
3169 * testsuite/gas/mips/mips16-pcrel-absolute-5.d: New test.
3170 * testsuite/gas/mips/mips16-pcrel-absolute-6.d: New test.
3171 * testsuite/gas/mips/mips16-pcrel-absolute-7.d: New test.
3172 * testsuite/gas/mips/mips16-pcrel-absolute-pic-4.d: New test.
3173 * testsuite/gas/mips/mips16-pcrel-absolute-pic-6.d: New test.
3174 * testsuite/gas/mips/mips16-pcrel-absolute-n32-4.d: New test.
3175 * testsuite/gas/mips/mips16-pcrel-absolute-n32-6.d: New test.
3176 * testsuite/gas/mips/mips16-pcrel-absolute-n64-4.d: New test.
3177 * testsuite/gas/mips/mips16-pcrel-absolute-n64-6.d: New test.
3178 * testsuite/gas/mips/mips16-pcrel-absolute-n64-sym32-4.d: New
3180 * testsuite/gas/mips/mips16-pcrel-absolute-n64-sym32-6.d: New
3182 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n32-4.d: New
3184 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n32-6.d: New
3186 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n64-4.d: New
3188 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n64-6.d: New
3190 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n64-sym32-4.d:
3192 * testsuite/gas/mips/mips16-pcrel-absolute-pic-n64-sym32-6.d:
3194 * testsuite/gas/mips/mips16-pcrel-0.l: New stderr output.
3195 * testsuite/gas/mips/mips16-pcrel-1.l: New stderr output.
3196 * testsuite/gas/mips/mips16-pcrel-2.l: New stderr output.
3197 * testsuite/gas/mips/mips16-pcrel-3.l: New stderr output.
3198 * testsuite/gas/mips/mips16-pcrel-4.l: New stderr output.
3199 * testsuite/gas/mips/mips16-pcrel-5.l: New stderr output.
3200 * testsuite/gas/mips/mips16-pcrel-delay-0.l: New stderr output.
3201 * testsuite/gas/mips/mips16-pcrel-delay-1.l: New stderr output.
3202 * testsuite/gas/mips/mips16-pcrel-addend-8.l: New stderr output.
3203 * testsuite/gas/mips/mips16-pcrel-addend-9.l: New stderr output.
3204 * testsuite/gas/mips/mips16-pcrel-absolute-4.l: New stderr
3206 * testsuite/gas/mips/mips16-pcrel-absolute-6.l: New stderr
3208 * testsuite/gas/mips/mips16-pcrel-0.s: New test source.
3209 * testsuite/gas/mips/mips16-pcrel-1.s: New test source.
3210 * testsuite/gas/mips/mips16-pcrel-2.s: New test source.
3211 * testsuite/gas/mips/mips16-pcrel-3.s: New test source.
3212 * testsuite/gas/mips/mips16-pcrel-4.s: New test source.
3213 * testsuite/gas/mips/mips16-pcrel-5.s: New test source.
3214 * testsuite/gas/mips/mips16-pcrel-delay-0.s: New test source.
3215 * testsuite/gas/mips/mips16-pcrel-delay-1.s: New test source.
3216 * testsuite/gas/mips/mips16-pcrel-addend-4.s: New test source.
3217 * testsuite/gas/mips/mips16-pcrel-addend-5.s: New test source.
3218 * testsuite/gas/mips/mips16-pcrel-addend-6.s: New test source.
3219 * testsuite/gas/mips/mips16-pcrel-addend-7.s: New test source.
3220 * testsuite/gas/mips/mips16-pcrel-addend-8.s: New test source.
3221 * testsuite/gas/mips/mips16-pcrel-addend-9.s: New test source.
3222 * testsuite/gas/mips/mips16-pcrel-absolute-2.s: New test.
3223 * testsuite/gas/mips/mips16-pcrel-absolute-3.s: New test.
3224 * testsuite/gas/mips/mips16-pcrel-absolute-4.s: New test.
3225 * testsuite/gas/mips/mips16-pcrel-absolute-5.s: New test.
3226 * testsuite/gas/mips/mips16-pcrel-absolute-6.s: New test.
3227 * testsuite/gas/mips/mips16-pcrel-absolute-7.s: New test.
3228 * testsuite/gas/mips/mips.exp: Run the new tests.
3233 * symbols.c (snapshot_symbol): Handle the case where
3234 resolve_expression returns a local symbol.
3238 * config/tc-mips.c (append_insn): Call `symbol_append' for any
3239 expression symbol created for MIPS16 relaxation.
3240 (match_mips16_insn): Don't encode a constant value as an
3241 immediate with a PC-relative operand.
3243 * testsuite/gas/mips/mips16-pcrel-absolute-1.d: New test.
3244 * testsuite/gas/mips/mips16-branch-absolute-1.d: New test.
3245 * testsuite/gas/mips/mips16-branch-absolute-2.d: New test.
3246 * testsuite/gas/mips/mips16-branch-absolute-addend-1.d: New
3248 * testsuite/gas/mips/mips16-branch-absolute-n32-1.d: New test.
3249 * testsuite/gas/mips/mips16-branch-absolute-n32-2.d: New test.
3250 * testsuite/gas/mips/mips16-branch-absolute-addend-n32-1.d: New
3252 * testsuite/gas/mips/mips16-branch-absolute-n64-1.d: New test.
3253 * testsuite/gas/mips/mips16-branch-absolute-n64-2.d: New test.
3254 * testsuite/gas/mips/mips16-branch-absolute-addend-n64-1.d: New
3256 * testsuite/gas/mips/mips16-pcrel-absolute-1.l: New stderr
3258 * testsuite/gas/mips/mips16-pcrel-absolute-1.s: New test source.
3259 * testsuite/gas/mips/mips16-branch-absolute-1.s: New test
3261 * testsuite/gas/mips/mips16-branch-absolute-2.s: New test
3263 * testsuite/gas/mips/mips16-branch-absolute-addend-1.s: New test
3265 * testsuite/gas/mips/mips.exp: Run the new tests.
3269 * config/tc-mips.c (mips16_pcrel_val): New function, factored
3271 (mips16_extended_frag): ... here.
3272 (md_convert_frag): Use `mips16_pcrel_val' rather than repeated
3273 code in MIPS16 relaxation, with `stretch' hardcoded to 0.
3277 * config/tc-mips.c (RELAX_MIPS16_LONG_BRANCH): Rename to...
3278 (RELAX_MIPS16_ALWAYS_EXTENDED): ... this.
3279 (RELAX_MIPS16_MARK_LONG_BRANCH): Rename to...
3280 (RELAX_MIPS16_MARK_ALWAYS_EXTENDED): ... this.
3281 (RELAX_MIPS16_CLEAR_LONG_BRANCH): Rename to...
3282 (RELAX_MIPS16_CLEAR_ALWAYS_EXTENDED): ... this.
3283 (mips16_extended_frag): Adjust accordingly.
3287 * symbols.c (S_FORCE_RELOC): Separate section and symbol tests.
3291 * config/tc-mips.c (RELAX_ENCODE): Add `PIC' flag.
3292 (RELAX_PIC): New macro.
3293 (RELAX_USE_SECOND, RELAX_SECOND_LONGER, RELAX_NOMACRO)
3294 (RELAX_DELAY_SLOT, RELAX_DELAY_SLOT_16BIT)
3295 (RELAX_DELAY_SLOT_SIZE_FIRST, RELAX_DELAY_SLOT_SIZE_SECOND):
3297 (RELAX_BRANCH_ENCODE): Add `pic' flag.
3298 (RELAX_BRANCH_UNCOND, RELAX_BRANCH_LIKELY, RELAX_BRANCH_LINK)
3299 (RELAX_BRANCH_TOOFAR): Shift bits.
3300 (RELAX_BRANCH_PIC): New macro.
3301 (RELAX_MICROMIPS_ENCODE): Add `pic' flag.
3302 (RELAX_MICROMIPS_PIC): New macro.
3303 (RELAX_MICROMIPS_UNCOND, RELAX_MICROMIPS_COMPACT)
3304 (RELAX_MICROMIPS_LINK, RELAX_MICROMIPS_NODS)
3305 (RELAX_MICROMIPS_RELAX32): Shift bits.
3306 (relax_close_frag): Pass `mips_pic' setting to RELAX_ENCODE.
3307 (append_insn): Pass `mips_pic' setting to RELAX_BRANCH_ENCODE
3308 and RELAX_MICROMIPS_ENCODE, and record it in `fx_tcbit2' of the
3309 first fixup created.
3310 (md_apply_fix) <BFD_RELOC_16_PCREL_S2>: Use `fx_tcbit2' of the
3311 fixup processed rather than `mips_pic' in choosing to relax an
3312 out of range branch to a jump.
3313 (relaxed_branch_length): Use the `pic' flag of the relaxed frag
3314 rather than `mips_pic'.
3315 (relaxed_micromips_32bit_branch_length): Likewise.
3316 (md_estimate_size_before_relax): Likewise.
3317 (md_convert_frag): Likewise.
3319 * testsuite/gas/mips/option-pic-relax-0.d: New test.
3320 * testsuite/gas/mips/option-pic-relax-1.d: New test.
3321 * testsuite/gas/mips/option-pic-relax-2.d: New test.
3322 * testsuite/gas/mips/option-pic-relax-3.d: New test.
3323 * testsuite/gas/mips/option-pic-relax-3a.d: New test.
3324 * testsuite/gas/mips/option-pic-relax-4.d: New test.
3325 * testsuite/gas/mips/option-pic-relax-5.d: New test.
3326 * testsuite/gas/mips/option-pic-relax-2.l: New stderr output.
3327 * testsuite/gas/mips/option-pic-relax-3.l: New stderr output.
3328 * testsuite/gas/mips/option-pic-relax-4.l: New stderr output.
3329 * testsuite/gas/mips/option-pic-relax-5.l: New stderr output.
3330 * testsuite/gas/mips/option-pic-relax-0.s: New test source.
3331 * testsuite/gas/mips/option-pic-relax-1.s: New test source.
3332 * testsuite/gas/mips/option-pic-relax-2.s: New test source.
3333 * testsuite/gas/mips/option-pic-relax-3.s: New test source.
3334 * testsuite/gas/mips/option-pic-relax-4.s: New test source.
3335 * testsuite/gas/mips/option-pic-relax-5.s: New test source.
3336 * testsuite/gas/mips/mips.exp: Run the new tests.
3340 * testsuite/gas/arc/leave_enter.d: Update test.
3341 * testsuite/gas/arc/leave_enter.s: Likewise.
3345 * testsuite/gas/arc/b.d: Update test.
3346 * testsuite/gas/arc/noargs_hs.d: Likewise.
3350 * config/tc-mips.c (md_convert_frag): Correct
3351 BFD_RELOC_MIPS16_16_PCREL_S1 fixup size.
3352 * testsuite/gas/mips/mips16-branch-addend-4.d: New test.
3353 * testsuite/gas/mips/mips16-branch-addend-5.d: New test.
3354 * testsuite/gas/mips/mips16-branch-addend-5.l: New stderr
3356 * testsuite/gas/mips/mips16-branch-addend-4.s: New test source.
3357 * testsuite/gas/mips/mips16-branch-addend-5.s: New test source.
3358 * testsuite/gas/mips/mips.exp: Run the new tests.
3363 * config/tc-sparc.c (md_apply_fix): Do not transform `call'
3364 instructions into branch instructions in fixups generating
3365 additional relocations.
3366 * testsuite/gas/sparc/call-relax.s: New file.
3367 * testsuite/gas/sparc/call-relax.d: Likewise.
3368 * testsuite/gas/sparc/call-relax-aout.d: Likewise.
3369 * testsuite/gas/sparc/sparc.exp: Test call-relax and call-relax-aout.
3373 * config/tc-arm.c (move_or_literal_pool): Remove code generating MOVS.
3374 Forbid MOV.W and MOVW if destination is SP or PC.
3375 * testsuite/gas/arm/thumb2_ldr_immediate_highregs_armv6t2.s: Explain
3376 expectation of LDR not generating a MOVS for low registers and small
3377 constants. Add tests of MOVW generation.
3378 * testsuite/gas/arm/thumb2_ldr_immediate_highregs_armv6t2.d: Update
3379 expected disassembly.
3383 * testsuite/gas/ppc/vle.s: Format. Add se_rfgi and e_sc.
3384 * testsuite/gas/ppc/vle.d: Update.
3389 * testsuite/gas/aarch64/illegal-3.s: New file.
3390 * testsuite/gas/aarch64/illegal-3.d: New file.
3394 * config/tc-ppc.c (md_show_usage): Delete mention of -mhtm.
3395 * testsuite/gas/ppc/htm.d: Pass -mpower8 and -Mpower8.
3399 * config/tc-xtensa.c (xtensa_maybe_create_literal_pool_frag):
3400 Initialize lps->frag_count with auto_litpool_limit.
3401 (xg_promote_candidate_litpool): New function.
3402 (xtensa_move_literals): Extract candidate litpool promotion code
3403 into separate function. Call it for all possible found
3405 (xtensa_switch_to_literal_fragment): Drop 'recursive' flag and
3406 call to xtensa_mark_literal_pool_location that it guards.
3407 Replace it with call to xtensa_maybe_create_literal_pool_frag.
3408 Initialize pool_location with created literal pool candidate.
3409 * testsuite/gas/xtensa/all.exp: Add new tests.
3410 * testsuite/gas/xtensa/auto-litpools-first1.d: New test results.
3411 * testsuite/gas/xtensa/auto-litpools-first1.s: New test.
3412 * testsuite/gas/xtensa/auto-litpools-first2.d: New test results.
3413 * testsuite/gas/xtensa/auto-litpools-first2.s: New test.
3414 * testsuite/gas/xtensa/auto-litpools.d: Fix offsets changed due
3415 to additional jump instruction.
3419 * testsuite/gas/ppc/altivec2.s: Delete E6500 vector insns.
3420 * testsuite/gas/ppc/altivec2.d: Adjust to suit.
3424 * testsuite/gas/elf/section12a.d: Don't expect alignment of 1
3429 * testsuite/gas/wasm32/allinsn.d: Adjust test for disassembler
3431 * testsuite/gas/wasm32/disass.d: New test.
3432 * testsuite/gas/wasm32/disass.s: New test.
3433 * testsuite/gas/wasm32/disass-2.d: New test.
3434 * testsuite/gas/wasm32/disass-2.s: New test.
3435 * testsuite/gas/wasm32/reloc.d: Adjust test for changed reloc
3437 * testsuite/gas/wasm32/reloc.s: Update test for changed assembler
3439 * testsuite/gas/wasm32/wasm32.exp: Run new tests. Expect allinsn
3444 * NEWS: Mention support for ELF SHF_GNU_MBIND.
3445 * config/obj-elf.c (section_match): New.
3446 (get_section): Match both sh_info and group name.
3447 (obj_elf_change_section): Add argument for sh_info. Pass both
3448 sh_info and group name to get_section. Issue an error for
3449 SHF_GNU_MBIND section without SHF_ALLOC. Set sh_info.
3450 (obj_elf_parse_section_letters): Set SHF_GNU_MBIND for 'd'.
3451 (obj_elf_section): Support SHF_GNU_MBIND section info.
3452 * config/obj-elf.h (obj_elf_change_section): Add argument for
3454 * config/tc-arm.c (start_unwind_section): Pass 0 as sh_info to
3455 obj_elf_change_section.
3456 * config/tc-ia64.c (obj_elf_vms_common): Likewise.
3457 * config/tc-microblaze.c (microblaze_s_data): Likewise.
3458 (microblaze_s_sdata): Likewise.
3459 (microblaze_s_rdata): Likewise.
3460 (microblaze_s_bss): Likewise.
3461 * config/tc-mips.c (s_change_section): Likewise.
3462 * config/tc-msp430.c (msp430_profiler): Likewise.
3463 * config/tc-rx.c (parse_rx_section): Likewise.
3464 * config/tc-tic6x.c (tic6x_start_unwind_section): Likewise.
3465 * doc/as.texinfo: Document 'd' for SHF_GNU_MBIND.
3466 * testsuite/gas/elf/elf.exp: Run section12a, section12b and
3468 * testsuite/gas/elf/section10.d: Updated.
3469 * testsuite/gas/elf/section10.s: Likewise.
3470 * testsuite/gas/elf/section12.s: New file.
3471 * testsuite/gas/elf/section12a.d: Likewise.
3472 * testsuite/gas/elf/section12b.d: Likewise.
3473 * testsuite/gas/elf/section13.l: Likewise.
3474 * testsuite/gas/elf/section13.d: Likewise.
3475 * testsuite/gas/elf/section13.s: Likewise.
3479 * config/tc-riscv.c (riscv_clear_subsets): Cast argument to free to
3480 avoid const warnings.
3484 * config/tc-riscv.c (riscv_clear_subsets): New function.
3485 (riscv_add_subset): Call riscv_clear_subsets and riscv_set_rvc to
3486 clear RVC when it's been previously set.
3491 * config/tc-s390.c (tc_s390_fix_adjustable): Allow non pc-relative
3492 fixups in mergeable sections to be adjusted.
3496 * config/tc-wasm32.h: New file: Add WebAssembly assembler target.
3497 * config/tc-wasm32.c: New file: Add WebAssembly assembler target.
3498 * Makefile.am: Add WebAssembly assembler target.
3499 * configure.tgt: Add WebAssembly assembler target.
3500 * doc/c-wasm32.texi: New file: Start documenting WebAssembly
3502 * doc/all.texi: Define WASM32.
3503 * doc/as.texinfo: Add WebAssembly entries.
3504 * NEWS: Mention the new support.
3505 * Makefile.in: Regenerate.
3506 * po/gas.pot: Regenerate.
3507 * po/POTFILES.in: Regenerate.
3508 * testsuite/gas/wasm32: New directory.
3509 * testsuite/gas/wasm32/allinsn.d: New file.
3510 * testsuite/gas/wasm32/allinsn.s: New file.
3511 * testsuite/gas/wasm32/illegal.l: New file.
3512 * testsuite/gas/wasm32/illegal.s: New file.
3513 * testsuite/gas/wasm32/illegal-2.l: New file.
3514 * testsuite/gas/wasm32/illegal-2.s: New file.
3515 * testsuite/gas/wasm32/illegal-3.l: New file.
3516 * testsuite/gas/wasm32/illegal-3.s: New file.
3517 * testsuite/gas/wasm32/illegal-4.l: New file.
3518 * testsuite/gas/wasm32/illegal-4.s: New file.
3519 * testsuite/gas/wasm32/illegal-5.l: New file.
3520 * testsuite/gas/wasm32/illegal-5.s: New file.
3521 * testsuite/gas/wasm32/illegal-6.l: New file.
3522 * testsuite/gas/wasm32/illegal-6.s: New file.
3523 * testsuite/gas/wasm32/illegal-7.l: New file.
3524 * testsuite/gas/wasm32/illegal-7.s: New file.
3525 * testsuite/gas/wasm32/illegal-8.l: New file.
3526 * testsuite/gas/wasm32/illegal-8.s: New file.
3527 * testsuite/gas/wasm32/illegal-9.l: New file.
3528 * testsuite/gas/wasm32/illegal-9.s: New file.
3529 * testsuite/gas/wasm32/illegal-10.l: New file.
3530 * testsuite/gas/wasm32/illegal-10.s: New file.
3531 * testsuite/gas/wasm32/illegal-11.l: New file.
3532 * testsuite/gas/wasm32/illegal-11.s: New file.
3533 * testsuite/gas/wasm32/illegal-12.l: New file.
3534 * testsuite/gas/wasm32/illegal-12.s: New file.
3535 * testsuite/gas/wasm32/illegal-13.l: New file.
3536 * testsuite/gas/wasm32/illegal-13.s: New file.
3537 * testsuite/gas/wasm32/illegal-14.l: New file.
3538 * testsuite/gas/wasm32/illegal-14.s: New file.
3539 * testsuite/gas/wasm32/illegal-15.l: New file.
3540 * testsuite/gas/wasm32/illegal-15.s: New file.
3541 * testsuite/gas/wasm32/illegal-16.l: New file.
3542 * testsuite/gas/wasm32/illegal-16.s: New file.
3543 * testsuite/gas/wasm32/illegal-17.l: New file.
3544 * testsuite/gas/wasm32/illegal-17.s: New file.
3545 * testsuite/gas/wasm32/illegal-18.l: New file.
3546 * testsuite/gas/wasm32/illegal-18.s: New file.
3547 * testsuite/gas/wasm32/illegal-19.l: New file.
3548 * testsuite/gas/wasm32/illegal-19.s: New file.
3549 * testsuite/gas/wasm32/illegal-20.l: New file.
3550 * testsuite/gas/wasm32/illegal-20.s: New file.
3551 * testsuite/gas/wasm32/illegal-21.l: New file.
3552 * testsuite/gas/wasm32/illegal-21.s: New file.
3553 * testsuite/gas/wasm32/illegal-22.l: New file.
3554 * testsuite/gas/wasm32/illegal-22.s: New file.
3555 * testsuite/gas/wasm32/illegal-24.l: New file.
3556 * testsuite/gas/wasm32/illegal-24.s: New file.
3557 * testsuite/gas/wasm32/illegal-25.l: New file.
3558 * testsuite/gas/wasm32/illegal-25.s: New file.
3559 * testsuite/gas/wasm32/reloc.d: New file.
3560 * testsuite/gas/wasm32/reloc.s: New file.
3561 * testsuite/gas/wasm32/wasm32.exp: New tests for WebAssembly
3566 * config/tc-ppc.c (md_parse_option): Reject -mraw.
3571 * testsuite/gas/ppc/pr21303.d,
3572 * testsuite/gas/ppc/pr21303.s: New test
3573 * testsuite/gas/ppc/ppc.exp: Run it.
3577 * testsuite/gas/arc/nps400-12.s: New file.
3578 * testsuite/gas/arc/nps400-12.d: New file.
3582 * config/tc-arm.: (md_begin): Set selected_cpu from *mcpu_cpu_opt when
3583 CPU_DEFAULT is defined.
3587 * config/tc-riscv.c (md_show_usage): Remode defuct -m32, -m64,
3588 -msoft-float, -mhard-float, -mno-rvc, and -mrvc options; and don't
3589 print an invalid default ISA string.
3590 * doc/c-riscv.texi (OPTIONS): Add -fpic and -fno-pic options.
3594 * config/tc-xtensa.c (xtensa_relax_frag): Change fx_size of the
3595 reassigned fixup to size of jump instruction (3) and fx_r_type
3596 to BFD_RELOC_XTENSA_SLOT0_OP, as there's only one slot.
3597 (add_jump_to_trampoline): Search
3598 origfrag->tc_frag_data.slot_symbols for the slot with non-NULL
3599 symbol and use that slot instead of slot 0.
3603 * config/tc-s390.c (s390_parse_cpu): Remove S390_INSTR_FLAG_VX2
3604 from cpu_table. Remove vx2, and novx2 from cpu_flags.
3608 * testsuite/gas/arc/nps400-11.s: New file.
3609 * testsuite/gas/arc/nps400-11.d: New file.
3613 * doc/as.texinfo (2byte): Note that if no expressions are present
3614 the directive does nothing. Emphasize that the output is
3615 unaligned, and that this can have an effect on the relocations
3617 (4byte): Simplify description. Refer back to the 2byte
3623 * config/tc-arm.c (arm_fpus): Note entires that should not be
3625 * doc/c-arm.texi (-mfpu): Add missing FPU entries for neon-vfpv3 and
3626 neon-fp16. Fix spelling error.
3630 * config/tc-arm.c (arm_fpus): Add neon-vfpv3 as an alias for neon.
3634 * config/tc-arc.c (assemble_insn): Only handle ".t" and ".nt"
3635 specially for ARCv2.
3639 * config/tc-riscv.c (validate_riscv_insn): Add 'o' RVC immediate
3640 encoding format, which can accept 0-valued immediates.
3641 (riscv_ip): Likewise.
3645 * config/tc-riscv.c (riscv_pre_output_hook): Fix compile time
3646 warning about discarding a const qualifier.
3650 * config/tc-riscv.h (HWARD2_USE_FIXED_ADVANCE_PC): New define.
3654 * config/tc-riscv.c (md_apply_fix): Set fx_frag and
3655 fx_next->fx_frag for CFA_advance_loc relocations.
3659 * config/tc-riscv.c (md_apply_fix): Compute the correct offsets
3660 for CFA relocations.
3665 * config/tc-aarch64.c (reloc_table): Rename
3666 BFD_RELOC_AARCH64_TLSDESC_LD64_LO12_NC to
3667 BFD_RELOC_AARCH64_TLSDESC_LD64_LO12. Rname
3668 BFD_RELOC_AARCH64_TLSDESC_ADD_LO12_NC to
3669 BFD_RELOC_AARCH64_TLSDESC_ADD_LO12.
3670 (md_apply_fix): Likewise.
3671 (aarch64_force_relocation): Likewise.
3672 * testsuite/gas/aarch64/tls.d: Update regexp.
3677 * doc/as.texinfo (2byte): Tidy up wording. Add note that
3678 overlarge values will produce a warning message and be trunacted.
3683 * config/tc-i386.c (_i386_insn): Add dir_encoding and
3684 vec_encoding. Remove swap_operand and need_vrex.
3685 (extra_symbol_chars): Add '}'.
3686 (md_begin): Mark '}' with LEX_BEGIN_NAME. Allow '}' in
3688 (build_vex_prefix): Don't use 2-byte VEX encoding with
3689 {vex3}. Check dir_encoding and load.
3690 (parse_insn): Check pseudo prefixes. Set dir_encoding.
3691 (VEX_check_operands): Likewise.
3692 (match_template): Check dir_encoding and load.
3693 (parse_real_register): Set vec_encoding instead of need_vrex.
3694 (parse_register): Likewise.
3695 * doc/c-i386.texi: Document {disp8}, {disp32}, {load}, {store},
3696 {vex2}, {vex3} and {evex}. Remove ".s", ".d8" and ".d32"
3697 * testsuite/gas/i386/i386.exp: Run pseudos and x86-64-pseudos.
3698 * testsuite/gas/i386/pseudos.d: New file.
3699 * testsuite/gas/i386/pseudos.s: Likewise.
3700 * testsuite/gas/i386/x86-64-pseudos.d: Likewise.
3701 * testsuite/gas/i386/x86-64-pseudos.s: Likewise.
3705 * testsuite/gas/ppc/altivec2.d (as): Use the -mpower8 option.
3706 (objdump): Use the -Mpower8 option.
3710 * testsuite/gas/ppc/power9.d <lnia> New test.
3711 * testsuite/gas/ppc/power9.s: Likewise.
3715 * doc/as.texinfo (2byte, 4byte, 8byte): Correct @section placement.
3720 * doc/as.texinfo (2byte, 4byte, 8byte): Document.
3721 * doc/c-arm.texi (2byte, 4byte, 8byte): Omit if ELF.
3725 * config/tc-i386.c (cpu_arch): Add .cet.
3726 * doc/c-i386.texi: Document cet.
3727 * testsuite/gas/i386/cet-intel.d: New file.
3728 * testsuite/gas/i386/cet.d: Likewise.
3729 * testsuite/gas/i386/cet.s: Likewise.
3730 * testsuite/gas/i386/x86-64-cet-intel.d: Likewise.
3731 * testsuite/gas/i386/x86-64-cet.d: Likewise.
3732 * testsuite/gas/i386/x86-64-cet.s: Likewise.
3733 * testsuite/gas/i386/i386.exp: Run Intel CET tests.
3737 * testsuite/gas/i386/x86-64-mpx-inval-2.s: Force a good alignment.
3738 * testsuite/gas/i386/x86-64-mpx-inval-2.l: Expect [0-9A-F]+.
3742 * dw2gencfi.c (encoding_size): Return unsigned int.
3743 (emit_expr_encoded): Assert size matches reloc bitsize.
3744 (output_fde): Use unsigned for offset_size and addr_size. Set
3745 addr_size earlier and use in place of constant 4 and uses of
3746 DWARF2_FDE_RELOC_SIZE. Assert it matches reloc bitsize.
3750 * dw2gencfi.c: Wrap overlong lines. Add parens for emacs
3751 auto reformat. Formatting and whitespace fixes.
3755 * dwarf2dbg.c (out_debug_abbrev): Use DW_FORM_strp instead of
3756 DW_FORM_string for DW_AT_name, DW_AT_comp_dir and DW_AT_producer.
3757 (out_debug_info): Accept symbols to name, comp_dir and producer in
3758 the .debug_str section and emit those offsets not full strings.
3759 (out_debug_str): New function that outputs the strings for name,
3760 comp_dir and producer in .debug_str and generates symbols to those
3762 (out_debug_line): Create a .debug_str section if necessary and call
3763 out_debug_str before calling out_debug_info.
3764 * testsuite/gas/aarch64/dwarf.d: Add extra section symbol to expected
3769 * write.c (relax_segment) <rs_org>: Only bail out if the fixed
3770 part of the frag has overrun the location requested.
3772 * testsuite/gas/all/org-1.d: New test.
3773 * testsuite/gas/all/org-2.d: New test.
3774 * testsuite/gas/all/org-3.d: New test.
3775 * testsuite/gas/all/org-4.d: New test.
3776 * testsuite/gas/all/org-5.d: New test.
3777 * testsuite/gas/all/org-6.d: New test.
3778 * testsuite/gas/all/org-1.l: New stderr output.
3779 * testsuite/gas/all/org-2.l: New stderr output.
3780 * testsuite/gas/all/org-3.l: New stderr output.
3781 * testsuite/gas/all/org-1.s: New test source.
3782 * testsuite/gas/all/org-2.s: New test source.
3783 * testsuite/gas/all/org-3.s: New test source.
3784 * testsuite/gas/all/org-4.s: New test source.
3785 * testsuite/gas/all/org-5.s: New test source.
3786 * testsuite/gas/all/org-6.s: New test source.
3787 * testsuite/gas/all/gas.exp: Run the new tests.
3789 * testsuite/gas/mips/org-1.d: New test.
3790 * testsuite/gas/mips/org-2.d: New test.
3791 * testsuite/gas/mips/org-3.d: New test.
3792 * testsuite/gas/mips/org-4.d: New test.
3793 * testsuite/gas/mips/org-5.d: New test.
3794 * testsuite/gas/mips/org-6.d: New test.
3795 * testsuite/gas/mips/org-7.d: New test.
3796 * testsuite/gas/mips/org-8.d: New test.
3797 * testsuite/gas/mips/org-9.d: New test.
3798 * testsuite/gas/mips/org-10.d: New test.
3799 * testsuite/gas/mips/org-11.d: New test.
3800 * testsuite/gas/mips/org-12.d: New test.
3801 * testsuite/gas/mips/org-1.l: New stderr output.
3802 * testsuite/gas/mips/org-4.l: New stderr output.
3803 * testsuite/gas/mips/org-5.l: New stderr output.
3804 * testsuite/gas/mips/org-6.l: New stderr output.
3805 * testsuite/gas/mips/org-10.l: New stderr output.
3806 * testsuite/gas/mips/org-1.s: New test source.
3807 * testsuite/gas/mips/org-2.s: New test source.
3808 * testsuite/gas/mips/org-3.s: New test source.
3809 * testsuite/gas/mips/org-4.s: New test source.
3810 * testsuite/gas/mips/org-5.s: New test source.
3811 * testsuite/gas/mips/org-6.s: New test source.
3812 * testsuite/gas/mips/org-7.s: New test source.
3813 * testsuite/gas/mips/org-8.s: New test source.
3814 * testsuite/gas/mips/org-9.s: New test source.
3815 * testsuite/gas/mips/org-10.s: New test source.
3816 * testsuite/gas/mips/org-11.s: New test source.
3817 * testsuite/gas/mips/org-12.s: New test source.
3818 * testsuite/gas/mips/mips.exp: Run the new tests.
3822 * doc/c-aarch64.texi (AArch64 Extensions): Document rcpc.
3826 * testsuite/gas/i386/x86-64-avx.s: Add suffixed variants of
3828 * testsuite/gas/i386/x86-64-sse2avx.s: Likewise.
3829 * testsuite/gas/i386/x86-64-sse4_2.s: Add suffixed variants
3831 * testsuite/gas/i386/ilp32/x86-64-avx-intel.d: Likewise.
3832 * testsuite/gas/i386/ilp32/x86-64-avx.d: Likewise.
3833 * testsuite/gas/i386/ilp32/x86-64-sse2avx.d: Likewise.
3834 * testsuite/gas/i386/ilp32/x86-64-sse4_2-intel.d: Likewise.
3835 * testsuite/gas/i386/ilp32/x86-64-sse4_2.d: Likewise.
3836 * testsuite/gas/i386/x86-64-avx-intel.d: Likewise.
3837 * testsuite/gas/i386/x86-64-avx.d: Likewise.
3838 * testsuite/gas/i386/x86-64-sse2avx.d: Likewise.
3839 * testsuite/gas/i386/x86-64-sse4_2-intel.d: Likewise.
3840 * testsuite/gas/i386/x86-64-sse4_2.d: Likewise.
3844 * config/tc-nios2.h (TC_FORCE_RELOCATION_SUB_LOCAL): Define.
3848 * config/tc-ppc.c (md_assemble): Use BFD_RELOC_PPC_16DX_HA for addpcis.
3849 (md_apply_fix): Remove fx_subsy check. Move code converting to
3850 pcrel reloc earlier and handle BFD_RELOC_PPC_16DX_HA. Remove code
3851 emiiting errors on seeing fx_pcrel set on unexpected relocs, as
3852 that is done now by the generic code via..
3853 * config/tc-ppc.h (TC_FORCE_RELOCATION_SUB_LOCAL): ..this. Define.
3854 (TC_VALIDATE_FIX_SUB): Define.
3858 * testsuite/gas/mips/jalr4.s: Add `jalr $0, $25' instructions.
3859 * testsuite/gas/mips/jalr4.d: Adjust accordingly. Remove MIPSr6
3861 * testsuite/gas/mips/jalr4-n64.d: Likewise.
3868 * testsuite/gas/elf/strtab.s: Don't put directives on first
3869 column or continuation with labels not in first column.
3873 * doc/c-aarch64.texi: Document that sve implies fp16, simd and compnum.
3874 * config/tc-aarch64.c (parse_vector_type_for_operand): Allow .q
3875 to be used with SVE registers.
3876 (parse_operands): Handle new SVE operands.
3877 (aarch64_features): Make "sve" require F16 rather than FP. Also
3879 * testsuite/gas/aarch64/sve.s: Add tests for new instructions.
3880 Include compnum tests.
3881 * testsuite/gas/aarch64/sve.d: Update accordingly.
3882 * testsuite/gas/aarch64/sve-invalid.s: Add tests for new instructions.
3883 * testsuite/gas/aarch64/sve-invalid.l: Update accordingly. Also
3884 update expected output for new FMOV and MOV alternatives.
3888 * doc/c-aarch64.texi: Add a "compnum" entry.
3889 * config/tc-aarch64.c (aarch64_features): Likewise,
3890 * testsuite/gas/aarch64/advsimd-compnum.s: New test.
3891 * testsuite/gas/aarch64/advsimd-compnum.d: Likewise.
3895 * testsuite/gas/i386/opcode.s: Add alternative TEST forms.
3896 * testsuite/gas/i386/x86-64-opcode.s: Likewise.
3897 * testsuite/gas/i386/opcode.d: Adjust accordingly.
3898 * testsuite/gas/i386/opcode-intel.d: Likewise.
3899 * testsuite/gas/i386/x86-64-opcode.d: Likewise.
3900 * testsuite/gas/i386/ilp32/x86-64-opcode.d: Likewise.
3904 Test cases for the architecture level aware SPARC ASI work.
3905 * gas/testsuite/gas/sparc/sparc.exp: 2 new tests
3906 * gas/testsuite/gas/sparc/asi-bump-warn.s: New test
3907 * gas/testsuite/gas/sparc/asi-bump-warn.l: Likewise
3908 * gas/testsuite/gas/sparc/asi-arch-error.s: Likewise
3909 * gas/testsuite/gas/sparc/asi-arch-error.l: Likewise
3913 * testsuite/gas/mips/jalr4.d: New test.
3914 * testsuite/gas/mips/jalr4-n32.d: New test.
3915 * testsuite/gas/mips/jalr4-n64.d: New test.
3916 * testsuite/gas/mips/jalr4.s: New test source.
3917 * testsuite/gas/mips/mips.exp: Run the new tests.
3921 Add support for associating SPARC ASIs with an architecture level.
3922 * config/tc-sparc.c (parse_sparc_asi): New encode SPARC ASIs.
3926 * testsuite/gas/all/err-sizeof.s: Don't use sums or differences
3927 of symbols as expression.
3931 * gas/testsuite/gas/i386/x86-64-mpx-inval-2.d: Add 32- and 16-
3932 bit GPR forms of BNDCL, BNDCU, and BNDCN. Add RSP-as-index
3933 Intel syntax forms of BNDMK, BNDSTX, and BNDLDX.
3934 * gas/testsuite/gas/i386/x86-64-mpx-inval-2.l: Adjust.
3938 * ecoff.c (ecoff_directive_end) [md_flush_pending_output]: Call
3939 `md_flush_pending_output'.
3940 * config/tc-mips.c (s_mips_end) [md_flush_pending_output]: Call
3941 `md_flush_pending_output' unconditionally.
3942 * testsuite/gas/mips/debug-label-end-1.d: New test.
3943 * testsuite/gas/mips/debug-label-end-2.d: New test.
3944 * testsuite/gas/mips/debug-label-end-3.d: New test.
3945 * testsuite/gas/mips/debug-label-end.s: New test source.
3946 * testsuite/gas/mips/mips.exp: Run the new tests.
3950 * testsuite/gas/all/err-sizeof.s: Include cris*-*-* in the list of
3951 targets yielding an error message matching "too complex".
3955 * testsuite/gas/arm/vcmp-noprefix-imm.d: Skip for non-ELF targets.
3959 * expr.c (operand): Handle missing operand to .startof.() and
3961 * testsuite/gas/all/err-sizeof.s: New.
3966 * NEWS: Revise powerpc register check.
3967 * config/tc-ppc.c (ppc_optimize_expr, md_assemble): Make "invalid
3968 register expression" a warning.
3972 * ecoff.c (ecoff_directive_ent, add_procedure): Handle `.aent'.
3973 * config/obj-ecoff.c (obj_pseudo_table): Add "aent" entry.
3974 * config/obj-elf.c (ecoff_debug_pseudo_table): Likewise.
3975 * testsuite/gas/mips/aent-2.d: New test.
3976 * testsuite/gas/mips/aent-mdebug.d: New test.
3977 * testsuite/gas/mips/aent-mdebug-2.d: New test.
3978 * testsuite/gas/mips/mips.exp: Run the new tests.
3982 * testsuite/gas/aarch64/sve-sysreg.s,
3983 testsuite/gas/aarch64/sve-sysreg.d,
3984 testsuite/gas/aarch64/sve-sysreg-invalid.d,
3985 testsuite/gas/aarch64/sve-sysreg-invalid.l: New tests.
3989 * doc/c-aarch64.texi: Fix sve entry.
3993 * config/tc-arc.c (md_convert_frag): Remove @pcl relocation
3994 information from input expression.
3995 (assemble_insn): Make sure pcrel is correctly set.
3996 (arc_pcrel_adjust): Compensate for PCL rounding.
3997 * testsuite/gas/arc/relax-add01.d: New file.
3998 * testsuite/gas/arc/relax-add01.s: Likewise.
3999 * testsuite/gas/arc/relax-add02.d: Likewise.
4000 * testsuite/gas/arc/relax-add02.s: Likewise.
4001 * testsuite/gas/arc/relax-add03.d: Likewise.
4002 * testsuite/gas/arc/relax-add03.s: Likewise.
4003 * testsuite/gas/arc/relax-add04.d: Likewise.
4004 * testsuite/gas/arc/relax-add04.s: Likewise.
4005 * testsuite/gas/arc/relax-ld01.d: Likewise.
4006 * testsuite/gas/arc/relax-ld01.s: Likewise.
4007 * testsuite/gas/arc/relax-ld02.d: Likewise.
4008 * testsuite/gas/arc/relax-ld02.s: Likewise.
4009 * testsuite/gas/arc/relax-mov01.d: Likewise.
4010 * testsuite/gas/arc/relax-mov01.s: Likewise.
4011 * testsuite/gas/arc/relax-mov02.d: Likewise.
4012 * testsuite/gas/arc/relax-mov02.s: Likewise.
4013 * testsuite/gas/arc/relax-mpy01.d: Likewise.
4014 * testsuite/gas/arc/relax-mpy01.s: Likewise.
4015 * testsuite/gas/arc/relax-sub01.d: Likewise.
4016 * testsuite/gas/arc/relax-sub01.s: Likewise.
4017 * testsuite/gas/arc/relax-sub02.d: Likewise.
4018 * testsuite/gas/arc/relax-sub02.s: Likewise.
4019 * testsuite/gas/arc/relax-sub03.d: Likewise.
4020 * testsuite/gas/arc/relax-sub03.s: Likewise.
4021 * testsuite/gas/arc/relax-sub04.d: Likewise.
4022 * testsuite/gas/arc/relax-sub04.s: Likewise.
4026 * testsuite/gas/arc/st.d: Update for 0xe having a name now
4031 * NEWS: Mention powerpc register checks.
4032 * config/tc-ppc.c (struct pd_reg): Make value a short. Add flags.
4033 (pre_defined_registers): Delete fpscr and pmr entries. Set
4034 register type in flags.
4035 (cr_names): Set type in flags.
4036 (reg_name_search): Return pointer to struct pd_reg rather than value.
4037 (register_name): Adjust to suit. Set X_md from flags.
4038 (ppc_parse_name): Likewise.
4039 (ppc_optimize_expr): New function.
4040 (md_assemble): Verify expresion reg flags match operand.
4041 * config/tc-ppc.h (md_optimize_expr): Define.
4042 (ppc_optimize_expr): Declare.
4046 * testsuite/gas/ppc/cell.s: Correct invalid registers.
4047 * testsuite/gas/ppc/vle-simple-1.s: Likewise.
4048 * testsuite/gas/ppc/vle-simple-2.s: Likewise.
4052 * config/tc-arm.c (parse_ifimm_zero): Make prefix optional in unified
4054 * testsuite/gas/arm/vcmp-noprefix-imm.d: New file.
4055 * testsuite/gas/arm/vcmp-noprefix-imm.s: New file.
4059 * testsuite/gas/ppc/power9.d <scv, rfscv>: New tests.
4063 * doc/as.texinfo (Overview): Select MIPS options for man page
4068 * config/tc-mips.c (mips_ignore_branch_isa): New variable.
4069 (options): Add OPTION_IGNORE_BRANCH_ISA and
4070 OPTION_NO_IGNORE_BRANCH_ISA enum values.
4071 (md_longopts): Add "mignore-branch-isa" and
4072 "mno-ignore-branch-isa" options.
4073 (md_parse_option): Handle OPTION_IGNORE_BRANCH_ISA and
4074 OPTION_NO_IGNORE_BRANCH_ISA.
4075 (fix_bad_cross_mode_branch_p): Return FALSE if
4076 `mips_ignore_branch_isa' has been set.
4077 (md_show_usage): Add `-mignore-branch-isa' and
4078 `-mno-ignore-branch-isa'.
4080 * doc/as.texinfo (Target MIPS options): Add
4081 `-mignore-branch-isa' and `-mno-ignore-branch-isa' options.
4082 (-mignore-branch-isa, -mno-ignore-branch-isa): New options.
4083 * doc/c-mips.texi (MIPS Options): Add `-mignore-branch-isa' and
4084 `-mno-ignore-branch-isa' options.
4086 * testsuite/gas/mips/branch-local-ignore-2.d: New test.
4087 * testsuite/gas/mips/branch-local-ignore-3.d: New test.
4088 * testsuite/gas/mips/branch-local-ignore-n32-2.d: New test.
4089 * testsuite/gas/mips/branch-local-ignore-n32-3.d: New test.
4090 * testsuite/gas/mips/branch-local-ignore-n64-2.d: New test.
4091 * testsuite/gas/mips/branch-local-ignore-n64-3.d: New test.
4092 * testsuite/gas/mips/mips.exp: Run the new tests.
4096 * testsuite/gas/mips/branch-local-2.d: New test.
4097 * testsuite/gas/mips/branch-local-3.d: New test.
4098 * testsuite/gas/mips/branch-local-n32-2.d: New test.
4099 * testsuite/gas/mips/branch-local-n32-3.d: New test.
4100 * testsuite/gas/mips/branch-local-n64-2.d: New test.
4101 * testsuite/gas/mips/branch-local-n64-3.d: New test.
4102 * testsuite/gas/mips/mips.exp: Fold corresponding list tests
4108 * testsuite/gas/tic6x/insns16-parallel.s: New test case.
4109 * testsuite/gas/tic6x/insns16-parallel.d: New test driver.
4113 * configure.tgt (aarch64*-*-rtems*): Remove.
4114 (bfin-*-rtems*): Likewise.
4115 (h8300-*-rtems*): Likewise.
4116 (i386-*-rtems*): Likewise.
4117 (m32c-*-rtems*): Likewise.
4118 (m32r-*-rtems*): Likewise.
4119 (m68k-*-rtems*): Likewise.
4120 (mips-*-rtems*): Likewise.
4121 (nios2-*-rtems*): Likewise.
4122 (ppc-*-rtems*): Likewise.
4123 (sh-*-rtems*): Likewise.
4124 (sparc64-*-rtems*): Likewise.
4125 (sparc-*-rtems*): Likewise.
4126 (*-*-rtems*) Use ELF format.
4130 * configure.tgt (arm-*-rtems*): Move to (arm-*-eabi*).
4134 * configure.tgt (sh-*-rtemscoff*): Remove.
4138 * configure.tgt (riscv*-*-*): Remove em=linux.
4143 * asintl.h: Fix spelling mistakes and typos.
4144 * atof-generic.c: Likewise.
4145 * bit_fix.h: Likewise.
4146 * config/atof-ieee.c: Likewise.
4147 * config/bfin-defs.h: Likewise.
4148 * config/bfin-parse.y: Likewise.
4149 * config/obj-coff-seh.h: Likewise.
4150 * config/obj-coff.c: Likewise.
4151 * config/obj-evax.c: Likewise.
4152 * config/obj-macho.c: Likewise.
4153 * config/rx-parse.y: Likewise.
4154 * config/tc-aarch64.c: Likewise.
4155 * config/tc-alpha.c: Likewise.
4156 * config/tc-arc.c: Likewise.
4157 * config/tc-arm.c: Likewise.
4158 * config/tc-avr.c: Likewise.
4159 * config/tc-bfin.c: Likewise.
4160 * config/tc-cr16.c: Likewise.
4161 * config/tc-cris.c: Likewise.
4162 * config/tc-crx.c: Likewise.
4163 * config/tc-d10v.c: Likewise.
4164 * config/tc-d30v.c: Likewise.
4165 * config/tc-dlx.c: Likewise.
4166 * config/tc-epiphany.c: Likewise.
4167 * config/tc-frv.c: Likewise.
4168 * config/tc-hppa.c: Likewise.
4169 * config/tc-i370.c: Likewise.
4170 * config/tc-i386-intel.c: Likewise.
4171 * config/tc-i386.c: Likewise.
4172 * config/tc-i960.c: Likewise.
4173 * config/tc-ia64.c: Likewise.
4174 * config/tc-m32r.c: Likewise.
4175 * config/tc-m68hc11.c: Likewise.
4176 * config/tc-m68k.c: Likewise.
4177 * config/tc-mcore.c: Likewise.
4178 * config/tc-mep.c: Likewise.
4179 * config/tc-mep.h: Likewise.
4180 * config/tc-metag.c: Likewise.
4181 * config/tc-microblaze.c: Likewise.
4182 * config/tc-mips.c: Likewise.
4183 * config/tc-mmix.c: Likewise.
4184 * config/tc-mn10200.c: Likewise.
4185 * config/tc-mn10300.c: Likewise.
4186 * config/tc-msp430.c: Likewise.
4187 * config/tc-msp430.h: Likewise.
4188 * config/tc-nds32.c: Likewise.
4189 * config/tc-nds32.h: Likewise.
4190 * config/tc-nios2.c: Likewise.
4191 * config/tc-nios2.h: Likewise.
4192 * config/tc-ns32k.c: Likewise.
4193 * config/tc-pdp11.c: Likewise.
4194 * config/tc-ppc.c: Likewise.
4195 * config/tc-pru.c: Likewise.
4196 * config/tc-rx.c: Likewise.
4197 * config/tc-s390.c: Likewise.
4198 * config/tc-score.c: Likewise.
4199 * config/tc-score7.c: Likewise.
4200 * config/tc-sh.c: Likewise.
4201 * config/tc-sh64.c: Likewise.
4202 * config/tc-sparc.c: Likewise.
4203 * config/tc-tic4x.c: Likewise.
4204 * config/tc-tic54x.c: Likewise.
4205 * config/tc-v850.c: Likewise.
4206 * config/tc-vax.c: Likewise.
4207 * config/tc-visium.c: Likewise.
4208 * config/tc-xgate.c: Likewise.
4209 * config/tc-xtensa.c: Likewise.
4210 * config/tc-z80.c: Likewise.
4211 * config/tc-z8k.c: Likewise.
4212 * config/te-vms.c: Likewise.
4213 * config/xtensa-relax.c: Likewise.
4214 * doc/as.texinfo: Likewise.
4215 * doc/c-arm.texi: Likewise.
4216 * doc/c-hppa.texi: Likewise.
4217 * doc/c-i370.texi: Likewise.
4218 * doc/c-i386.texi: Likewise.
4219 * doc/c-m32r.texi: Likewise.
4220 * doc/c-m68k.texi: Likewise.
4221 * doc/c-mmix.texi: Likewise.
4222 * doc/c-msp430.texi: Likewise.
4223 * doc/c-nds32.texi: Likewise.
4224 * doc/c-ns32k.texi: Likewise.
4225 * doc/c-riscv.texi: Likewise.
4226 * doc/c-rx.texi: Likewise.
4227 * doc/c-s390.texi: Likewise.
4228 * doc/c-tic6x.texi: Likewise.
4229 * doc/c-tilegx.texi: Likewise.
4230 * doc/c-tilepro.texi: Likewise.
4231 * doc/c-v850.texi: Likewise.
4232 * doc/c-xgate.texi: Likewise.
4233 * doc/c-xtensa.texi: Likewise.
4234 * dwarf2dbg.c: Likewise.
4235 * ecoff.c: Likewise.
4236 * itbl-ops.c: Likewise.
4237 * listing.c: Likewise.
4238 * macro.c: Likewise.
4239 * po/gas.pot: Likewise.
4241 * struc-symbol.h: Likewise.
4242 * symbols.h: Likewise.
4243 * testsuite/gas/arc/relocs-errors.err: Likewise.
4244 * write.c: Likewise.
4248 * po/sv.po: Updated Swedish translation.
4252 * config/tc-i386.c (parse_operands): Check for operand overflow
4253 before setting the unspecified bit.
4258 * config/tc-mips.c (pic_need_relax): Don't check for linkonce
4259 symbols, remove the `segtype' parameter.
4260 (mips_frob_file, md_estimate_size_before_relax): Adjust
4262 (s_is_linkonce): Add an explanatory comment.
4263 * testsuite/gas/mips/comdat-reloc.d: New test.
4264 * testsuite/gas/mips/comdat-reloc.s: New test source.
4265 * testsuite/gas/mips/mips.exp: Run the new test.
4269 * testsuite/gas/arm/armv8_3-a-simd.s: Add vcmla tests.
4270 * testsuite/gas/arm/armv8_3-a-simd.d: Update.
4275 * config/bfin-lex.l: Support processing with flex 2.6.3.
4276 * itbl-lex.l: Likewise.
4280 * as.h (gas_assert): Use abort.
4281 (as_assert): Remove.
4282 (signal_init): Declare.
4283 * as.c (main): Call signal_init.
4284 * messages.c: #include <signal.h>
4285 (as_assert): Delete.
4286 (as_abort): Allow NULL FILE.
4287 (signal_crash): New.
4288 (signal_init): Register fatal signal handlers.
4289 * configure.ac: Check for strsignal.
4290 * config.in: Rebuilt.
4291 * configure: Rebuilt.
4295 * po/sv.po: Updated Swedish translation.
4299 * config/tc-i386.c (cpu_arch): Add .avx512_vpopcntdq.
4300 (cpu_noarch): Add noavx512_vpopcntdq.
4301 * doc/c-i386.texi: Document avx512_vpopcntdq, noavx512_vpopcntdq.
4302 * testsuite/gas/i386/i386.exp: Run AVX512_VPOPCNTDQ tests.
4303 * testsuite/gas/i386/avx512_vpopcntdqd-intel.d: New file.
4304 * testsuite/gas/i386/avx512_vpopcntdqd.d: Ditto.
4305 * testsuite/gas/i386/avx512_vpopcntdqd.s: Ditto.
4306 * testsuite/gas/i386/x86-64-avx512_vpopcntdqd-intel.d: Ditto.
4307 * testsuite/gas/i386/x86-64-avx512_vpopcntdqd.d: Ditto.
4308 * testsuite/gas/i386/x86-64-avx512_vpopcntdqd.s: Ditto.
4312 * read.c (temp_ilp): New function. Installs a temporary input
4314 (restore_ilp): New function. Restores the original input line
4316 * read.h (temp_ilp): Prototype.
4317 (restore_ilp): Prototype.
4318 * stabs.c (dot_func_p): Use bfd_boolean type.
4319 (generate_asm_file): Use temp_ilp and restore_ilp.
4320 (stabs_generate_asm_lineno): Likewise.
4321 (stabs_generate_asm_endfunc): Likewise.
4325 * configure.tgt: Add entry for i386-redox.
4329 * po/sv.po: Updated Swedish translation.
4333 * testsuite/gas/all/sleb128-8.d: Adjust test.
4334 * testsuite/gas/all/gas.exp (test_cond): Likewise.
4338 * read.c (emit_leb128_expr): Extended unsigned big number for
4340 * testsuite/gas/all/gas.exp (test_cond): Add sleb128-8 test.
4341 * testsuite/gas/all/sleb128.d: New test.
4342 * testsuite/gas/all/sleb128.s: New test source.
4346 * config/tc-riscv.c (append_insn): Don't eagerly apply relocations
4348 (md_apply_fix): Mark relocations against constants as "done."
4352 * config/tc-riscv.c (append_insn): Don't eagerly apply relocations
4354 (md_apply_fix): Mark relocations against constants as "done."
4359 * emulparams/elf32lriscv-defs.sh (INITIAL_READONLY_SECTIONS):
4361 (SDATA_START_SYMBOLS): Likewise.
4365 * po/sv.po: New Swedish translation.
4366 * configure.ac (ALL_LINGUAS): Add sv.
4367 * configure: Regenerate.
4371 * config/tc-riscv.c (relaxed_branch_length): Use the long
4372 sequence when the target is a weak symbol.
4376 * config/tc-aarch64.c (aarch64_features): Add rcpc.
4377 * doc/c-aarch64.texi (AArch64 Extensions): Document rcpc.
4378 * testsuite/gas/aarch64/ldst-exclusive-armv8_3.d: Rename to ...
4379 * testsuite/gas/aarch64/ldst-rcpc.d: This.
4380 * testsuite/gas/aarch64/ldst-exclusive-armv8_3.s: Rename to ...
4381 * testsuite/gas/aarch64/ldst-rcpc.s: This.
4382 * testsuite/gas/aarch64/ldst-rcpc-armv8_2.d: New test.
4387 * configure.tgt: Treat sparcv9 as sparc64.
4391 * config/tc-riscv.c (riscv_set_arch): Whitelist the "q" ISA
4393 (riscv_after_parse_args): Set FLOAT_ABI_QUAD when the Q ISA is
4394 enabled and no other ABI is specified.
4398 * config/tc-pru.c (md_number_to_chars): Fix parameter to be
4399 valueT, as declared in tc.h.
4400 (md_apply_fix): Fix to work on 32-bit hosts.
4404 Update year range in copyright notice of all files.
4406 For older changes see ChangeLog-2016
4408 Copyright (C) 2017 Free Software Foundation, Inc.
4410 Copying and distribution of this file, with or without modification,
4411 are permitted in any medium without royalty provided the copyright
4412 notice and this notice are preserved.
4418 version-control: never