1 2006-03-06 Nathan Sidwell <nathan@codesourcery.com>
3 * config/tc-m68k.c (m68k_extensions): Allow 'float' on both m68k
5 (m68k_ip): <case 'J'> Check we have some control regs.
6 (md_parse_option): Allow raw arch switch.
7 (m68k_init_arch): Better detection of arch/cpu mismatch. Detect
8 whether 68881 or cfloat was meant by -mfloat.
9 (md_show_usage): Adjust extension display.
10 (m68k_elf_final_processing): Adjust.
12 2006-03-03 Bjoern Haase <bjoern.m.haase@web.de>
14 * config/tc-avr.c (avr_mod_hash_value): New function.
15 (md_apply_fix, exp_mod): Use BFD_RELOC_HH8_LDI and
16 BFD_RELOC_MS8_LDI for hlo8() and hhi8()
17 (md_begin): Set linkrelax variable to 1, use avr_mod_hash_value
18 instead of int avr_ldi_expression: use avr_mod_hash_value instead
20 (tc_gen_reloc): Handle substractions of symbols, if possible do
21 fixups, abort otherwise.
22 * config/tc-avr.h (TC_LINKRELAX_FIXUP, TC_VALIDATE_FIX,
23 tc_fix_adjustable): Define.
25 2006-03-02 James E Wilson <wilson@specifix.com>
27 * config/tc-ia64.c (emit_one_bundle): For IA64_OPCODE_LAST, if we
28 change the template, then clear md.slot[curr].end_of_insn_group.
30 2006-02-28 Jan Beulich <jbeulich@novell.com>
32 * macro.c (get_any_string): Don't insert quotes for <>-quoted input.
34 2006-02-28 Jan Beulich <jbeulich@novell.com>
37 * macro.c (getstring): Don't treat parentheses special anymore.
38 (get_any_string): Don't consider '(' and ')' as quoting anymore.
39 Special-case '(', ')', '[', and ']' when dealing with non-quoting
42 2006-02-28 Mat <mat@csail.mit.edu>
44 * dwarf2dbg.c (get_filenum): Don't inadvertently decrease files_in_use.
46 2006-02-27 Jakub Jelinek <jakub@redhat.com>
48 * dw2gencfi.c (struct fde_entry, struct cie_entry): Add signal_frame
50 (CFI_signal_frame): Define.
51 (cfi_pseudo_table): Add .cfi_signal_frame.
52 (dot_cfi): Handle CFI_signal_frame.
53 (output_cie): Handle cie->signal_frame.
54 (select_cie_for_fde): Don't share CIE if signal_frame flag is
55 different. Copy signal_frame from FDE to newly created CIE.
56 * doc/as.texinfo: Document .cfi_signal_frame.
58 2006-02-27 Carlos O'Donell <carlos@codesourcery.com>
60 * doc/Makefile.am: Add html target.
61 * doc/Makefile.in: Regenerate.
62 * po/Make-in: Add html target.
64 2006-02-27 H.J. Lu <hongjiu.lu@intel.com>
66 * config/tc-i386.c (output_insn): Support Intel Merom New
69 * config/tc-i386.h (CpuMNI): New.
70 (CpuUnknownFlags): Add CpuMNI.
72 2006-02-24 David S. Miller <davem@sunset.davemloft.net>
74 * config/tc-sparc.c (priv_reg_table): Add entry for "gl".
75 (hpriv_reg_table): New table for hyperprivileged registers.
76 (sparc_ip): New cases '$' and '%' for wrhpr/rdhpr hyperprivileged
79 2006-02-24 DJ Delorie <dj@redhat.com>
81 * config/tc-m32c.h (md_apply_fix): Define to m32c_apply_fix.
82 (tc_gen_reloc): Don't define.
83 * config/tc-m32c.c (rl_for, relaxable): New convenience macros.
84 (OPTION_LINKRELAX): New.
85 (md_longopts): Add it.
87 (md_parse_options): Set it.
88 (md_assemble): Emit relaxation relocs as needed.
89 (md_convert_frag): Emit relaxation relocs as needed.
90 (md_cgen_lookup_reloc): Add LAB_8_8 and LAB_8_16.
91 (m32c_apply_fix): New.
93 (m32c_force_relocation): Force out jump relocs when relaxing.
94 (m32c_fix_adjustable): Return false if relaxing.
96 2006-02-24 Paul Brook <paul@codesourcery.com>
98 * config/arm/tc-arm.c (arm_ext_v6_notm, arm_ext_div, arm_ext_v7,
99 arm_ext_v7a, arm_ext_v7r, arm_ext_v7m): New variables.
100 (struct asm_barrier_opt): Define.
101 (arm_v7m_psr_hsh, arm_barrier_opt_hsh): New variables.
102 (parse_psr): Accept V7M psr names.
103 (parse_barrier): New function.
104 (enum operand_parse_code): Add OP_oBARRIER.
105 (parse_operands): Implement OP_oBARRIER.
106 (do_barrier): New function.
107 (do_dbg, do_pli, do_t_barrier, do_t_dbg, do_t_div): New functions.
108 (do_t_cpsi): Add V7M restrictions.
109 (do_t_mrs, do_t_msr): Validate V7M variants.
110 (md_assemble): Check for NULL variants.
111 (v7m_psrs, barrier_opt_names): New tables.
112 (insns): Add V7 instructions. Mark V6 instructions absent from V7M.
113 (md_begin): Initialize arm_v7m_psr_hsh and arm_barrier_opt_hsh.
114 (arm_cpu_option_table): Add Cortex-M3, R4 and A8.
115 (arm_arch_option_table): Add armv7, armv7a, armv7r and armv7m.
116 (struct cpu_arch_ver_table): Define.
118 (aeabi_set_public_attributes): Use cpu_arch_ver. Set
119 Tag_CPU_arch_profile.
120 * doc/c-arm.texi: Document new cpu and arch options.
122 2006-02-23 H.J. Lu <hongjiu.lu@intel.com>
124 * config/tc-ia64.c (operand_match): Handle IA64_OPND_IMMU5b.
126 2006-02-23 H.J. Lu <hongjiu.lu@intel.com>
128 * config/tc-ia64.c: Update copyright years.
130 2006-02-22 H.J. Lu <hongjiu.lu@intel.com>
132 * config/tc-ia64.c (specify_resource): Add the rule 17 from
135 2005-02-22 Paul Brook <paul@codesourcery.com>
137 * config/tc-arm.c (do_pld): Remove incorrect write to
139 (encode_thumb32_addr_mode): Use correct operand.
141 2006-02-21 Paul Brook <paul@codesourcery.com>
143 * config/tc-arm.c (md_apply_fix): Fix off-by-one errors.
145 2006-02-17 Shrirang Khisti <shrirangk@kpitcummins.com>
146 Anil Paranjape <anilp1@kpitcummins.com>
147 Shilin Shakti <shilins@kpitcummins.com>
149 * Makefile.am: Add xc16x related entry.
150 * Makefile.in: Regenerate.
151 * configure.in: Added xc16x related entry.
152 * configure: Regenerate.
153 * config/tc-xc16x.h: New file
154 * config/tc-xc16x.c: New file
155 * doc/c-xc16x.texi: New file for xc16x
156 * doc/all.texi: Entry for xc16x
157 * doc/Makefile.texi: Added c-xc16x.texi
158 * NEWS: Announce the support for the new target.
160 2006-02-16 Nick Hudson <nick.hudson@dsl.pipex.com>
162 * configure.tgt: set emulation for mips-*-netbsd*
164 2006-02-14 Jakub Jelinek <jakub@redhat.com>
166 * config.in: Rebuilt.
168 2006-02-13 Bob Wilson <bob.wilson@acm.org>
170 * config/tc-xtensa.c (xg_add_opcode_fix): Number operands starting
171 from 1, not 0, in error messages.
172 (md_assemble): Simplify special-case check for ENTRY instructions.
173 (tinsn_has_invalid_symbolic_operands): Do not include opcode and
174 operand in error message.
176 2006-02-13 Joseph S. Myers <joseph@codesourcery.com>
178 * configure.tgt (arm-*-linux-gnueabi*): Change to
181 2006-02-10 Nick Clifton <nickc@redhat.com>
183 * config/tc-crx.c (check_range): Ensure that the sign bit of a
184 32-bit value is propagated into the upper bits of a 64-bit long.
186 * config/tc-arc.c (init_opcode_tables): Fix cast.
187 (arc_extoper, md_operand): Likewise.
189 2006-02-09 David Heine <dlheine@tensilica.com>
191 * config/tc-xtensa.c (xg_assembly_relax): Increment steps_taken for
192 each relaxation step.
194 2006-02-09 Eric Botcazou <ebotcazou@libertysurf.fr>
196 * configure.in (CHECK_DECLS): Add vsnprintf.
197 * configure: Regenerate.
198 * messages.c (errno.h, stdarg.h, varargs.h, va_list): Do not
199 include/declare here, but...
200 * as.h: Move code detecting VARARGS idiom to the top.
201 (errno.h, stdarg.h, varargs.h, va_list): ...here.
202 (vsnprintf): Declare if not already declared.
204 2006-02-08 H.J. Lu <hongjiu.lu@intel.com>
206 * as.c (close_output_file): New.
207 (main): Register close_output_file with xatexit before
208 dump_statistics. Don't call output_file_close.
210 2006-02-07 Nathan Sidwell <nathan@codesourcery.com>
212 * config/tc-m68k.c (mcf5208_control_regs, mcf5213_control_regs,
213 mcf5329_control_regs): New.
214 (not_current_architecture, selected_arch, selected_cpu): New.
215 (m68k_archs, m68k_extensions): New.
216 (archs): Renamed to ...
217 (m68k_cpus): ... here. Adjust.
219 (md_pseudo_table): Add arch and cpu directives.
220 (find_cf_chip, m68k_ip): Adjust table scanning.
221 (no_68851, no_68881): Remove.
222 (md_assemble): Lazily initialize.
223 (select_control_regs): Adjust cpu names. Add 5208, 5213, 5329.
224 (md_init_after_args): Move functionality to m68k_init_arch.
225 (mri_chip): Adjust table scanning.
226 (md_parse_option): Reimplement 'm' processing to add -march & -mcpu
227 options with saner parsing.
228 (m68k_lookup_cpu, m68k_set_arch, m68k_set_cpu, m68k_set_extension,
229 m68k_init_arch): New.
230 (s_m68k_cpu, s_m68k_arch): New.
231 (md_show_usage): Adjust.
232 (m68k_elf_final_processing): Set CF EF flags.
233 * config/tc-m68k.h (m68k_init_after_args): Remove.
234 (tc_init_after_args): Remove.
235 * doc/c-m68k.texi (M68K-Opts): Document -march, -mcpu options.
236 (M68k-Directives): Document .arch and .cpu directives.
238 2006-02-05 Arnold Metselaar <arnold.metselaar@planet.nl>
240 * config/tc-z80.c (z80_start_line_hook): allow .equ and .defl as
241 synonyms for equ and defl.
242 (z80_cons_fix_new): New function.
243 (emit_byte): Disallow relative jumps to absolute locations.
244 (emit_data): Only handle defb, prototype changed, because defb is
245 now handled as pseudo-op rather than an instruction.
246 (instab): Entries for defb,defw,db,dw moved from here...
247 (md_pseudo_table): ... to here, use generic cons() for defw,dw.
248 Add entries for def24,def32,d24,d32.
249 (md_assemble): Improved error handling.
250 (md_apply_fix): New case BFD_RELOC_24, set fixP->fx_no_overflow to one.
251 * config/tc-z80.h (TC_CONS_FIX_NEW): Define.
252 (z80_cons_fix_new): Declare.
253 * doc/c-z80.texi (defb, db): Mention warning on overflow.
254 (def24,d24,def32,d32): New pseudo-ops.
256 2006-02-02 Paul Brook <paul@codesourcery.com>
258 * config/tc-arm.c (do_shift): Remove Thumb-1 constraint.
260 2005-02-02 Paul Brook <paul@codesourcery.com>
262 * config/tc-arm.c (T2_OPCODE_MASK, T2_DATA_OP_SHIFT, T2_OPCODE_AND,
263 T2_OPCODE_BIC, T2_OPCODE_ORR, T2_OPCODE_ORN, T2_OPCODE_EOR,
264 T2_OPCODE_ADD, T2_OPCODE_ADC, T2_OPCODE_SBC, T2_OPCODE_SUB,
265 T2_OPCODE_RSB): Define.
266 (thumb32_negate_data_op): New function.
267 (md_apply_fix): Use it.
269 2006-01-31 Bob Wilson <bob.wilson@acm.org>
271 * config/xtensa-istack.h (TInsn): Remove record_fix and sub_symbol
273 * config/tc-xtensa.h (xtensa_frag_type): Remove slot_sub_symbols field.
274 * config/tc-xtensa.c (md_apply_fix): Check for unexpected uses of
276 (relaxation_requirements): Add pfinish_frag argument and use it to
277 replace setting tinsn->record_fix fields.
278 (xg_assemble_vliw_tokens): Adjust calls to relaxation_requirements
279 and vinsn_to_insnbuf. Remove references to record_fix and
280 slot_sub_symbols fields.
281 (xtensa_mark_narrow_branches): Delete unused code.
282 (is_narrow_branch_guaranteed_in_range): Handle expr that is not just
284 (convert_frag_immed): Adjust vinsn_to_insnbuf call and do not set
286 (tinsn_immed_from_frag): Remove code for handling slot_sub_symbols.
287 (vinsn_to_insnbuf): Change use of record_fixup argument, replacing use
288 of the record_fix field. Simplify error messages for unexpected
290 (set_expr_symbol_offset_diff): Delete.
292 2006-01-31 Paul Brook <paul@codesourcery.com>
294 * config/tc-arm.c (arm_reg_parse): Check if reg is non-NULL.
296 2006-01-31 Paul Brook <paul@codesourcery.com>
297 Richard Earnshaw <rearnsha@arm.com>
299 * config/tc-arm.c: Use arm_feature_set.
300 (arm_ext_*, arm_arch_full, arm_arch_t2, arm_arch_none,
301 arm_cext_iwmmxt, arm_cext_xscale, arm_cext_maverick, fpu_fpa_ext_v1,
302 fpu_fpa_ext_v2, fpu_vfp_ext_v1xd, fpu_vfp_ext_v1, fpu_vfp_ext_v2):
305 (md_atof, opcode_select, opcode_select, md_assemble, md_assemble,
306 md_begin, arm_parse_extension, arm_parse_cpu, arm_parse_arch,
307 arm_parse_fpu, arm_parse_float_abi, aeabi_set_public_attributes,
308 s_arm_cpu, s_arm_arch, s_arm_fpu): Use macros for accessing CPU
310 (arm_legacy_option_table, arm_option_cpu_value_table): New types.
311 (arm_opts): Move old cpu/arch options from here...
312 (arm_legacy_opts): ... to here.
313 (md_parse_option): Search arm_legacy_opts.
314 (arm_cpus, arm_archs, arm_extensions, arm_fpus)
315 (arm_float_abis, arm_eabis): Make const.
317 2006-01-25 Bob Wilson <bob.wilson@acm.org>
319 * config/tc-xtensa.c (md_apply_fix): Set value to zero for PLT relocs.
321 2006-01-21 Jie Zhang <jie.zhang@analog.com>
323 * config/bfin-parse.y (asm_1): Check value range for 16 bit immediate
324 in load immediate intruction.
326 2006-01-21 Jie Zhang <jie.zhang@analog.com>
328 * config/bfin-parse.y (value_match): Use correct conversion
329 specifications in template string for __FILE__ and __LINE__.
333 2006-01-18 Alexandre Oliva <aoliva@redhat.com>
335 Introduce TLS descriptors for i386 and x86_64.
336 * config/tc-i386.c (tc_i386_fix_adjustable): Handle
337 BFD_RELOC_386_TLS_GOTDESC, BFD_RELOC_386_TLS_DESC_CALL,
338 BFD_RELOC_X86_64_GOTPC32_TLSDESC, BFD_RELOC_X86_64_TLSDESC_CALL.
339 (optimize_disp): Emit fix up for BFD_RELOC_386_TLS_DESC_CALL and
340 BFD_RELOC_X86_64_TLSDESC_CALL immediately, and clear the
342 (build_modrm_byte): Set up zero modrm for TLS desc calls.
343 (lex_got): Handle @tlsdesc and @tlscall.
344 (md_apply_fix, tc_gen_reloc): Handle the new relocations.
346 2006-01-11 Nick Clifton <nickc@redhat.com>
348 Fixes for building on 64-bit hosts:
349 * config/tc-avr.c (mod_index): New union to allow conversion
350 between pointers and integers.
351 (md_begin, avr_ldi_expression): Use it.
352 * config/tc-i370.c (md_assemble): Add cast for argument to print
354 * config/tc-tic54x.c (subsym_substitute): Likewise.
355 * config/tc-mn10200.c (md_assemble): Use a union to convert the
356 opindex field of fr_cgen structure into a pointer so that it can
358 * config/tc-mn10300.c (md_assemble): Likewise.
359 * config/tc-frv.c (frv_debug_tomcat): Use %p to print pointer
361 * config/tc-v850.c: Replace uses of (int) casts with correct
364 2006-01-09 H.J. Lu <hongjiu.lu@intel.com>
367 * symbols.c (snapshot_symbol): Don't change a defined symbol.
369 2006-01-03 Hans-Peter Nilsson <hp@bitrange.com>
372 * config/tc-mmix.c (mmix_handle_mmixal): Don't treat #[0-9][FB] as
373 a local-label reference.
375 For older changes see ChangeLog-2005
381 version-control: never