3 * configure.tgt: Fix mep cpu case.
7 * config/tc-arm.c (do_t_strexd): Remove
8 operand[1] != operand[2] contraint.
12 * config/tc-arm.c (neon_select_shape): No need to match
13 the remaining operands in the shape when one operand does
18 * config/tc-arm.c (do_neon_ld_st_interleave): Reject bad
23 * cgen.c: Whitespace fixes.
24 (weak_operand_overflow_check): Formatting fix.
28 * config/tc-i386.c (match_template): Update error messages.
32 * config/tc-i386.c (_i386_insn): Add err_msg.
33 (operand_size_match): Set err_msg on failure.
34 (operand_type_match): Likewise.
35 (operand_type_register_match): Likewise.
36 (VEX_check_operands): Likewise.
37 (match_template): Likewise. Use i.err_msg with as_bad.
41 * config/tc-mips.c (mips_fix_loongson2f, mips_fix_loongson2f_nop,
42 mips_fix_loongson2f_jump): New variables.
43 (md_longopts): Add New options -mfix-loongson2f-nop/jump,
44 -mno-fix-loongson2f-nop/jump.
45 (md_parse_option): Initialize variables via above options.
46 (options): New enums for the above options.
47 (md_begin): Initialize nop_insn from LOONGSON2F_NOP_INSN.
48 (fix_loongson2f, fix_loongson2f_nop, fix_loongson2f_jump):
50 (append_insn): call fix_loongson2f().
51 (mips_handle_align): Replace the implicit nops.
52 * config/tc-mips.h (MAX_MEM_FOR_RS_ALIGN_CODE): Modified
53 for the new mips_handle_align().
54 * doc/c-mips.texi: Document the new options.
58 * config/tc-arm.c (do_rd_rm_rn): Added warning
64 * config/tc-avr.c (md_apply_fix): Handle BFD_RELOC_8.
65 (avr_cons_fix_new): Handle fixups of a single byte.
70 * config/tc-arm.c (CPU_DEFAULT): Do not define based upon build
71 compiler's predefines.
75 * configure.tgt: Whiltespace. Sort moxie entry.
79 * config/tc-arm.c (arm_convert_symbolic_attribute): Add Tag_DIV_use.
80 * doc/c-arm.texi: Likewise.
84 * config/tc-arm.c (asm_opcode): operands type
86 (BAD_PC_ADDRESSING): New macro message.
87 (BAD_PC_WRITEBACK): Likewise.
88 (MIX_ARM_THUMB_OPERANDS): New macro.
89 (operand_parse_code): Added enum values.
90 (parse_operands): Added thumb/arm distinction,
91 plus new enum values handling.
92 (encode_arm_addr_mode_2): Validations enhanced.
93 (encode_arm_addr_mode_3): Likewise.
94 (do_rm_rd_rn): Likewise.
95 (encode_thumb32_addr_mode): Likewise.
96 (do_t_ldrex): Likewise.
97 (do_t_ldst): Likewise.
98 (do_t_strex): Likewise.
99 (md_assemble): Call parse_operands with
107 (insns): Updated insns operands.
112 * config/tc-ia64.c (enum reloc_func): Add FUNC_SLOTCOUNT_RELOC.
113 (DUMMY_RELOC_IA64_SLOTCOUNT): Added.
114 (pseudo_func): Add an entry for slotcount.
115 (md_begin): Initialize slotcount pseudo symbol.
116 (ia64_parse_name): Handle @slotcount parameter.
117 (ia64_gen_real_reloc_type): Handle slotcount.
118 (md_apply_fix): Ditto.
119 * doc/c-ia64.texi (IA-64-Relocs): Document @slotcount.
123 * config/tc-xtensa.c (istack_init): Don't call memset.
127 * config/tc-xtensa.c (cache_literal_section): Handle prefixes as
132 * config/tc-xtensa.c (xtensa_find_unaligned_loops): Rewrite.
136 * config/tc-i386.c (build_modrm_byte): Reformat.
140 * config/tc-i386.c: Update copyright.
145 * config/tc-i386.c (vec_imm4) New operand type.
147 (VEX_check_operands): New.
148 (check_reverse): Call VEX_check_operands.
149 (build_modrm_byte): Reintroduce code for 5
150 operand insns. Fix whitespace.
154 * config/tc-ppc.c (md_show_usage): Add -mpwr4, -mpwr5, -mpwr5x,
159 * config/tc-xtensa.c (RELAXED_LOOP_INSN_BYTES): New.
160 (next_frag_pre_opcode_bytes): Use RELAXED_LOOP_INSN_BYTES.
161 (xtensa_mark_zcl_first_insns): Rewrite to handle corner case.
165 * config/tc-arm.c (md_pcrel_from_section): Keep base to zero for
166 non-local branches (BFD_RELOC_THUMB_PCREL_BRANCH23,
167 BFD_RELOC_THUMB_PCREL_BLX, BFD_RELOC_ARM_PCREL_BLX,
168 BFD_RELOC_ARM_PCREL_CALL)
172 * config/tc-xtensa.c (frag_format_size): Generalize logic to
173 handle more instruction sizes and fetch widths.
174 (branch_align_power): Likewise.
175 (text_align_power): Likewise.
176 (bytes_to_stretch): Likewise.
180 * config/tc-ppc.c (md_show_usage): Mention -mtitan. Don't use tabs.
181 (ppc_mach): Handle titan.
182 * doc/c-ppc.texi: Mention -mtitan.
186 * config/tc-xtensa.c (UNREACHABLE_MAX_WIDTH): Delete and
188 (xtensa_fetch_width) ...this.
192 * Makefile.am (CPU_TYPES, OBJ_FORMATS, CPU_OBJ_VALID,
193 MULTI_CPU_TYPES, MULTI_CPU_OBJ_VALID): Remove.
194 * Makefile.in: Regenerate.
198 * config/tc-i386.c (cpu_arch): Change amdfam15 to bdver1.
199 (i386_align_code): Rename PROCESSOR_AMDFAM15 to PROCESSOR_BDVER1.
200 * config/tc-i386.h (processor_type): Same.
201 * doc/c-i386.texi: Change amdfam15 to bdver1.
206 * config/tc-arm.c (neon_check_type): Handle a neon_shape value of
211 * NEWS: Mention new feature.
212 * config/obj-coff.c (obj_coff_section): Accept digits and use
213 to override default section alignment power if specified.
214 * doc/as.texinfo (.section directive): Update documentation.
218 * config/tc-i386.c (avxscalar): New.
219 (OPTION_MAVXSCALAR): Likewise.
220 (build_vex_prefix): Select vector_length for scalar instructions
222 (md_longopts): Add OPTION_MAVXSCALAR.
223 (md_parse_option): Handle OPTION_MAVXSCALAR.
224 (md_show_usage): Add -mavxscalar=.
226 * doc/c-i386.texi: Document -mavxscalar=.
230 * config/tc-i386.c (build_vex_prefix): Set i.vex.bytes[0] to
235 * write.h (fix_at_start): Declare.
236 * write.c (fix_new_internal): Add at_beginning parameter.
237 Use it instead of REVERSE_SORT_RELOCS. Fix the handling of
238 seg_fix_tailP for the at_beginning/REVERSE_SORT_RELOCS case.
239 (fix_new, fix_new_exp): Update accordingly.
240 (fix_at_start): New function.
241 * config/tc-ppc.c (md_pseudo_table): Add .ref to the OBJ_XCOFF section.
242 (ppc_ref): New function, for OBJ_XCOFF.
243 (md_apply_fix): Handle BFD_RELOC_NONE for OBJ_XCOFF.
244 * config/te-i386aix.h (REVERSE_SORT_RELOCS): Remove #undef.
248 * config/te-solaris.h (DWARF2_EH_FRAME_READ_ONLY): Make read-only
249 on 64-bit Solaris/x86.
250 Include obj-format.h earlier.
254 * config/tc-s390.c (s390_elf_final_processing): New function.
255 * config/tc-s390.h (elf_tc_final_processing): New macro definition.
256 (s390_elf_final_processing): Added prototype.
262 * config/tc-arm.c (do_neon_cvt): Rename to do_neon_cvt_1. Add
263 code to handle round-to-zero for VCVT conversions.
264 (do_neon_cvt): New. Call do_neon_cvt_1.
265 (do_neon_cvtr): New. Call do_neon_cvt_1.
266 (insns): Use do_neon_cvt for VCVT insn and do_neon_cvtr for VCVTR
271 * config/tc-ia64.c (ia64_vms_note): Generate 24 bytes note headers.
275 * config/tc-i386.c (md_assemble): Before accessing the IMM field
276 check that it's not an XOP insn.
280 * config/bfin-aux.h: Remove argument names in function
282 * config/bfin-lex.l (parse_int): Fix shadowed variable name
284 * config/bfin-parse.y (value_match): Remove argument names
286 (notethat): Likewise.
291 * config/tc-arm.c (do_t_nop): Correct check for Thumb-2 NOP.
295 * config/tc-h8300.c (h8300_elf_section): New function - issue a
296 warning message if a new section is created without setting any
298 (md_pseudo_table): Intercept section creation pseudos.
299 (md_pcrel_from): Replace abort with an error message.
300 * config/obj-elf.c (obj_elf_section_name): Export this function.
301 * config/obj-elf.h (obj_elf_section_name): Prototype.
306 * listing.c (print_source): Add one to line number.
310 * Makefile.in: Regenerate.
311 * configure: Regenerate.
312 * doc/Makefile.in: Regenerate.
316 * version.c (parse_args): Change to "Copyright 2010".
320 * config/tc-i386.c (cpu_arch): Add amdfam15.
321 (i386_align_code): Add PROCESSOR_AMDFAM15 cases.
322 * config/tc-i386.h (processor_type): Add PROCESSOR_AMDFAM15.
323 * doc/c-i386.texi: Add amdfam15.
327 * config/tc-arm.c (do_neon_logic): Accept imm value
328 in the third operand too.
329 (operand_parse_code): OP_RNDQ_IMVNb renamed to
331 (parse_operands): OP_NILO case removed, applied renaming.
332 (insns): Neon shape changed for some logic instructions.
336 * config/tc-arm.c (do_neon_ldx_stx): Added
337 validation for vector load/store insns.
341 * config/tc-ppc.c (md_show_usage): Document -me500mc64.
345 * config/tc-arm.c (struct arm_it): New flag 'is_neon'.
346 (NEON_ENC_*): Macros renamed to _NEON_ENC_*.
347 (NEON_ENCODE): New macro.
348 (check_neon_suffixes): New macro.
349 (do_vfp_cond_or_thumb): Set the 'is_neon' flag.
350 (do_vfp_nsyn_opcode): Likewise.
351 (do_vfp_nsyn_nmul): Use the new 'NEON_ENCODE' macro.
352 (do_vfp_nsyn_cmp): Likewise.
353 (do_neon_shl_imm): Likewise.
354 (do_neon_qshl_imm): Likewise.
355 (neon_dyadic_misc): Likewise.
356 (do_neon_mac_maybe_scalar): Likewise.
357 (do_neon_qdmulh): Likewise.
358 (do_neon_qmovn): Likewise.
359 (do_neon_qmovun): Likewise.
360 (do_neon_movn): Likewise.
361 (neon_mac_reg_scalar_long): Likewise.
362 (do_neon_vmull): Likewise.
363 (do_neon_trn): Likewise.
364 (do_neon_ldx_stx): Likewise.
365 (neon_dp_fixup): Changed signature and set the flag.
366 (neon_three_same): Call the above with new signature.
367 (neon_two_same): Likewise.
368 (neon_imm_shift): Likewise.
369 (neon_mul_mac): Likewise.
370 (do_neon_abs_neg): Likewise.
371 (neon_mixed_length): Likewise.
372 (do_neon_ext): Likewise.
373 (do_neon_mov): Likewise.
374 (do_neon_tbl_tbx): Likewise.
375 (do_neon_logic): Likewise, and use the new 'NEON_ENCODE' macro.
376 (neon_compare): Likewise.
377 (do_neon_shll): Likewise.
378 (do_neon_cvt): Likewise.
379 (do_neon_mvn): Likewise.
380 (do_neon_dup): Likewise.
381 (md_assemble): Call check_neon_suffixes ().
383 For older changes see ChangeLog-2009
389 version-control: never