* fixes to silence all compiler warnings.
[binutils.git] / gas / ChangeLog
blobb84d812a9c55160b0e39ea94dc2e32bbe6ec038f
1 2001-06-24  Ben Elliston  <bje@redhat.com>
3         * config/tc-m88k.c (get_reg): Adjust type of `reg_prefix' to char.
4         (md_parse_option): Mark parameters as unused.
5         (md_show_usage): Ditto.
6         (calcop): Adjust type of `reg_prefix' to char.
7         (get_reg): Ditto.
8         (getval): Adjust type of local `c' to char.
9         (md_create_short_jump): Mark from_addr, to_addr params as unused.
10         (md_create_long_jump): Ditto.
11         (md_estimate_size_before_relax): Mark parameters as unused.
12         
13         * config/tc-m88k.c (md_pseudo_table): Properly terminate the table
14         to allay a possible compiler warning.
16 2001-06-22  Nick Clifton  <nickc@cambridge.redhat.com>
18         * doc/internals.texi (CPU backend): Document md_atof.
20 2001-06-22  Matthew Wilcox  <willy@ldl.fc.hp.com>
22         * config/tc-hppa.c: Add %mrp (millicode return pointer) alias
23         for %r2 or %r31, depending on 32 or 64 bit architecture.
25 2001-06-21  Philip Blundell  <philb@gnu.org>
27         * config/tc-arm.c (cplong_flag): Rename to long_flag.  All uses
28         updated.
29         (insns): Remove entry for adrl.  Add long_flag for adr.
30         (do_adr): Handle `l' suffix.
31         (do_adrl): Delete.
33 2001-06-21  Alan Modra  <amodra@bigpond.net.au>
35         * config/tc-hppa.c (CHECK_FIELD_WHERE): Define.
36         (md_apply_fix): Use it here.  Replace printf with equivalent
37         as_bad_where.
38         (tc_gen_reloc): Use as_bad_where instead of as_bad.
39         (md_apply_fix): Here too.
40         * config/tc-i386.c (tc_gen_reloc): Use as_bad_where instead of as_bad.
41         * config/tc-m68k.c (tc_gen_reloc): Likewise.
42         (md_convert_frag_1): Likewise.
44 2000-06-20  Tom Rix <trix@redhat.com>
46         * config/tc-ppc.c (ppc_comm): Change default alignment to 4 bytes.
48 2001-06-18  H.J. Lu <hjl@gnu.org>
50         * doc/Makefile.am (info): Depend on $(MANS).
51         (as.1): Remove the prefix `$(srcdir)/'.
52         * doc/Makefile.in: Regenerated.
54         * as.1: Removed.
56 2001-06-18  Philip Blundell  <philb@gnu.org>
58         * config/tc-arm.c (do_msr): Remove restriction on usage of
59         immediate operands.
61 2001-06-19  Alan Modra  <amodra@bigpond.net.au>
63         * dwarf2dbg.c (dwarf2_finish): Output file info even when no
64         line info.
66 2001-06-13  Philip Blundell  <philb@gnu.org>
68         * config/tc-arm.c (thumb_shift): Improve wording of error message.
69         (do_t_arit): Likewise.
71 2001-06-13  Nick Clifton  <nickc@cambridge.redhat.com>
73         * config/tc-sh.c (md_pseudo_table): Only intercept the .file and
74         .loc pseudos if the dfwarf2 functions are available.
75         (md_assemble): Only call dwarf2_emit_insn if it is available.
77         * expr.c: Fix typo in comment.
79 2001-06-12  Nick Clifton  <nickc@cambridge.redhat.com>
81         * doc/as.texinfo (Infix Ops): Document that comparison and
82         combiner operators can be used as infix operators.
84 2001-06-12  Peter Jakubek <pjak@snafu.de>
86         * gas/config/tc-m68k.c (parse_mri_control_operand): Fix handling
87         of AND/OR.
88         (swap_mri_condition): Add HS (alias fo CC) and LO (alias for CS).
89         (reverse_mri_condition): Likewise.
90         (swap_mri_condition): Issue warning for conditions that can not be
91         swapped.
92         (build_mri_control_operand): Fix order of operands (swapped).
93         (build_mri_control_operand): Allow upper case extension in structured
94         control directives.
95         (s_mri_else): Likewise.
96         (s_mri_next): Likewise.
97         (s_mri_for): Likewise.
98         (s_mri_if): Fix handling comment ('*') in mri mode.
99         (s_mri_while): Likewise.
100         * gas/macro.c (macro_expand): Allow macro invocation with empty
101         extension.
103 2001-06-12  Nick Clifton  <nickc@cambridge.redhat.com>
105         * config/tc-arm.c: Fix test for overlow of literal pool.
107 2001-06-11  H.J. Lu  <hjl@gnu.org>
109         * NEWS: Updated for the new -n option for the MIPS assembler.
111         * config/tc-mips.c (md_show_usage): Add -n.
113         * doc/as.texinfo: Document the new -n option.
114         * doc/c-mips.texi: Likewise.
115         * doc/as.1: Regenerated.
117 2001-06-10  Alan Modra  <amodra@bigpond.net.au>
119         * config/obj-coff.c (obj_coff_section): Formatting fix.
121         * config/tc-i386.c (md_assemble): Accept branch hints as ",pt" and
122         ",pn".
124 2001-06-08  H.J. Lu  <hjl@gnu.org>
126         * config/tc-mips.c (warn_nops): New variable. Set to 0 to
127         disable warning about all NOPS that the assembler generates.
128         (macro): Warn NOPS generated only if warn_nops is not 0.
129         (md_shortopts): Add `n'.
130         (md_parse_option): Set warn_nops to 1 for `n'.
132 2001-06-08  H.J. Lu  <hjl@gnu.org>
134         * config/tc-mips.c (mips_ip): Properly handle illegal operands.
136 2001-06-08  H.J. Lu  <hjl@gnu.org>
138         * config/tc-mips.c (md_apply_fix): Don't adjust common
139         extern/weak symbols for ELF.
140         (md_estimate_size_before_relax): Treat weak like extern for
141         ELF.
142         (mips_fix_adjustable): Don't adjust extern/weak symbols for
143         ELF.
145 2001-06-08  Alan Modra  <amodra@bigpond.net.au>
147         * Makefile.am: 'som' is not wrongly spelled 'some'.
148         * Makefile.in: Regenerate.
150         * config/tc-mips.c (mips16_mark_labels): Reduce number of calls to
151         S_GET_VALUE by using a temp.
152         (append_insn): Likewise, and for S_SET_VALUE too.
153         (mips_emit_delays): Likewise.
154         (my_getExpression): Likewise.
155         (md_apply_fix): Likewise.  Use "valueT" rather than "long" for "value".
156         (mips16_extended_frag): Remove code concerned with avoiding
157         locking in a frag address now that symbols are not finalized until
158         relaxation is complete.  Cater for first relaxation pass having
159         bogus addresses.  Use relax_marker to reliably determine whether a
160         symbol frag has been reached on the current pass.
162 2001-06-07  H.J. Lu  <hjl@gnu.org>
164         * configure.in: Move "mips-*-linux-gnu*" before "mips-*-gnu*".
165         * configure: Regenerate.
167 2001-06-07  H.J. Lu  <hjl@gnu.org>
169         * configure.in: Use MIPS_STABS_ELF for Linux/mips and remove
170         ecoff emulation.
171         * configure: Regenerate.
173 2001-06-07  H.J. Lu  <hjl@gnu.org>
175         * config/tc-mips.c (mips_pseudo_table): Add "extern" if
176         MIPS_STABS_ELF is defined.
178 2001-06-06  Nick Clifton  <nickc@cambridge.redhat.com>
180         * as.c (show_usage): Remove L from listing options.  It is not a
181         generic option.
183 2001-06-06  Christian Groessler <cpg@aladdin.de>
185         * config/tc-z8k.c: Removed many warnings by removing unused
186         variables and tagging unused parameters as such.
187         (md_begin): Fixed a typo (","instead of ";").
188         (struct ctrl_table): Add parentheses to initialize array
189         correctly.
190         (struct flag_table): Likewise.
191         (struct intr_table): Likewise.
192         (struct table): Likewise.
193         (check_operand): "#if 0"'ed since it doesn't seem to be used.
195 2001-06-06  Peter Jakubek <pjak@snafu.de>
197         * gas/config/tc-m68k.c (md_show_usage): Add all supported ColdFire
198         options to list (e.g. m5206e, m5307, m5407).
200 2001-06-06  Martin Schwidefsky <schwidefsky@de.ibm.com>
202         * config/tc-s390.h (TC_FORCE_RELOCATION): Always emit relocations
203         BFD_RELOC_VTABLE_INHERIT and BFD_RELOC_VTABLE_ENTRY.
205 2001-06-06  Alan Modra  <amodra@bigpond.net.au>
207         * config/tc-i386.c (md_assemble): Handle Pentium4 branch hints.
208         <JumpByte, JumpDword insn output>: Remove dead code.
210 2001-06-06  Tracy Kuhrt <Tracy.Kuhrt@microchip.com>
212         * as.c (parse_args): Correct option name "listing-lhs-width2".
214 2001-06-05  Nick Clifton  <nickc@cambridge.redhat.com>
216         * symbols.c (S_SET_EXTERNAL): Do not override a section symbol's
217         status.
219 2001-05-30  Richard Henderson  <rth@redhat.com>
221         * read.c (emit_leb128_expr): Call md_cons_align.
223 2001-05-28  Jeff Sturm  <jsturm@one-point.com>
225         * config/tc-sparc.c (md_apply_fix3): Handle BFD_RELOC_SPARC_UA16,
226         BFD_RELOC_SPARC_UA32 and BFD_RELOC_SPARC_UA64.
227         (tc_gen_reloc): Likewise.
228         (sparc_cons_align): Don't clear sparc_no_align_cons.
229         (cons_fix_new_sparc): Substitute BFD_RELOC_SPARC_UA{16|32|64} for
230         BFD_RELOC_{16|32|64} iff sparc_no_align_cons is set.
232 2001-05-27  Alan Modra  <amodra@one.net.au>
234         * write.c (relax_segment <rs_space>): Check the section of a
235         symbol to determine whether it is absolute rather than comparing
236         its frag against zero_address_frag as listings play tricks with
237         frags.
239         * config/tc-m68k.c (md_assemble): Ensure variable part of frag is
240         allocated in the same chunk as the fixed part.
242 2001-05-26  Alan Modra  <amodra@one.net.au>
244         * write.c (relax_segment <rs_space>): Calculate growth using
245         addresses before stretch.  Prevent repeated error messages.
246         From Peter Jakubek  <pjak@snafu.de>
247         Use as_bad_where and as_warn_where to pinpoint errors.
249 2001-05-25  Alan Modra  <amodra@one.net.au>
251         * symbols.c (resolve_symbol_value): Always set segment, even when
252         not finalizing symbol value.
254         * config/obj-ieee.c (write_object_file): Set finalize_syms.
255         * config/obj-coff.c (write_object_file): Likewise.
256         * (size_section): Remove rs_space assert as fr_symbol is no longer
257         removed.
258         (fill_section): Likewise.
260         * configure.in: Replace linuxoldld with linux*oldld.
261         * configure: Regenerate.
263         From 2.11 branch 2001-03-30  Richard Henderson  <rth@redhat.com>
264         * config/tc-i386.c (md_convert_frag): Don't die on local symbols
265         that have been finalized.
267         * symbols.c (resolve_symbol_value): Clear sy_resolving before
268         taking exit_dont_set_value.
270         * write.c (relax_segment <rs_space>): Don't zap fr_symbol when
271         relaxing.
273 2000-05-24  Tom Rix <trix@redhat.com>
275         * config/obj-coff.c (add_lineno): xcoff allows negative line
276         numbers
277         * config/tc-ppc.c (ppc_stabx): fix generated symbol
279 2001-05-24  Alan Modra  <amodra@one.net.au>
281         * write.c (write_object_file): Set finalize_syms = 1 before
282         size_seg is called.
284 2001-05-23  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
286         * config/tc-mips.c (ISA_HAS_64BIT_REGS): Add ISA_MIPS64 as 64 bit
287         architecture, remove erraneous ISA_MIPS32.
288         (md_show_usage): Add MIPS r12k support.
289         (mips_cpu_info_table): Add MIPS r12k support.
291 2001-05-22  Alan Modra  <amodra@one.net.au>
293         * config/tc-arc.c (md_assemble): Use is_end_of_line instead of
294         testing for NULs.
296         * symbols.c (resolve_symbol_value): Remove "finalize" param,
297         instead use finalize_syms directly.  Don't treat expressions
298         specially with regard to finalize_syms.  Update calls to self.
299         (resolve_local_symbol): Update call to resolve_symbol_value.
300         (S_GET_VALUE): Likewise.  Return resolve_symbol_value if
301         !finalize_syms.
302         * symbols.h (resolve_symbol_value): Update prototype.
303         * config/obj-aout.c (obj_crawl_symbol_chain): Update call
304         to resolve_symbol_value.
305         * config/obj-bout.c (obj_crawl_symbol_chain): Likewise.
306         * config/obj-coff.c (do_relocs_for): Likewise.
307         (yank_symbols): Likewise.
308         (fixup_segment): Likewise.
309         * config/obj-vms.c (obj_crawl_symbol_chain): Likewise.
310         * config/tc-mips.c (md_convert_frag): Likewise.
311         * config/tc-ppc.c (ppc_frob_symbol): Likewise.
312         (ppc_fix_adjustable): Likewise.
313         * dwarf2dbg.c (dwarf2dbg_estimate_size_before_relax): Likewise.
314         (dwarf2dbg_convert_frag): Likewise.
315         * ehopt.c (eh_frame_estimate_size_before_relax): Likewise.
316         (eh_frame_convert_frag): Likewise.
317         * expr.c (make_expr_symbol): Likewise.
318         * write.c (adjust_reloc_syms): Likewise.
319         (write_object_file): Likewise.
320         (relax_segment): Likewise.
321         (fixup_segment): Likewise.
322         (finalize_syms): Init to zero, and update comment.
323         (write_object_file): Set finalize_syms to 1 rather than 2.
324         * doc/internals.texi (sy_value): Mention finalize_syms.
325         (S_GET_VALUE): Remove restriction on when S_GET_VALUE can be called.
327         * config/tc-m68k.c (relaxable_symbol): Only treat external symbols
328         as relaxable if embedded system, make weak syms non-relaxable.
329         Move definition..
330         (tc_m68k_fix_adjustable): ..so it can be used here.
331         (md_apply_fix_2): Sign extend without conditional.
333         * config/tc-v850.c: Update copyright.
335 2001-05-16  Jeff Johnston  <jjohnstn@redhat.com>
337         * cgen.c (gas_cgen_tc_gen_reloc): Changed error message when
338         howto entry is not found.
340 2001-05-15  Alexandre Oliva  <aoliva@redhat.com>
342         * config/tc-mn10300.c (mn10300_force_relocation): Don't
343         optimize differences between symbols in code sections to
344         constants.
345         (mn10300_fix_adjustable): Don't adjust to section+offset
346         relocations pointing at symbols in code sections.
348 2001-05-16  Alan Modra  <amodra@one.net.au>
350         * config/tc-arc.c (md_assemble): Correct dwarf2_emit_insn param
351         for 8 byte insns.
352         * config/tc-i386.c (md_assemble): Call dwarf2_emit_insn before
353         opcodes are output rather than after.  Delete insn_size.
354         * config/tc-v850.c (md_assemble): Similarly, but delete
355         total_insn_size.
357 2001-05-14  Richard Henderson  <rth@redhat.com>
359         * ehopt.c (eh_frame_convert_frag): Fix missed subtype adjustment
360         last change.
362 2001-05-14  Richard Henderson  <rth@redhat.com>
364         * ehopt.c (get_cie_info): Rename from eh_frame_code_alignment;
365         also collect whether to expect an FDE augmentation.
366         (check_eh_frame): Rewrite as a state machine.  Track where in
367         an FDE we are located, skip any augmentation.
368         (eh_frame_estimate_size_before_relax): Get code alignment from
369         the fragment subtype.
370         (eh_frame_relax_frag, eh_frame_convert_frag): Likewise.
371         * read.c (emit_leb128_expr): Call check_eh_frame.
373 2001-05-14  Alexandre Oliva  <aoliva@redhat.com>
375         * config/tc-mn10300.c (md_assemble): Anchor dwarf2 line info
376         before a relaxable insns.
378 2001-05-13  Alexandre Oliva  <aoliva@redhat.com>
380         * config/tc-mn10300.c (tc_gen_reloc): Don't reject differences
381         between symbols if the base symbol is in the current section;
382         emit a PC-relative relocation instead.
384 2001-05-12  Peter Targett  <peter.targett@arccores.com>
386         * config/tc-arc.c: Update copyright and tidy source comments.
387         (md_pseudo_table): Add directive .cpu back as an alias for
388         .option.  Add .file and .line for dwarf2 support.
389         (arc_mach_type): Make bfd_mach_arc_6 default.
390         (md_longopts): Add entry 'pre-v6' representing old command line
391         option when assembling for 'arc5' core versions.
392         (md_parse_option): Make OPTION_ARC same as OPTION_ARC6, for new
393         default behaviour.
394         (arc_code_symbol): Make symbol value for @h30 fixup expression
395         equal to O_constant.
396         (md_assemble): Call dwarf2_emit_insn.
397         Include "dwarf2dbg2.h".  Formatting fixes throughout file.
398         * config/tc-arc.h (DWARF2_LINE_MIN_INSN_LENGTH): Define.
399         * doc/c-arc.texi (ARC_CORE_DEFAULT): Update to new default.
401 2001-05-11  Jakub Jelinek  <jakub@redhat.com>
403         * config/tc-ia64.c (special_linkonce_name): New.
404         (make_unw_section): Map .gnu.linkonce.t.FOO text section into
405         .gnu.linkonce.ia64unw{,i}.FOO.
406         (ia64_elf_section_type): Handle .gnu.linkonce.ia64unw{,i}.FOO.
407         (dot_endp): Add comment about it.
409 2001-05-11  Nick Clifton  <nickc@cambridge.redhat.com>
411         * config/tc-arm.c (arm_handle_align): When truncating an aligned
412         block, ensure that the low order bits of the alignment are
413         preserved.
415 2001-05-10  Alan Modra  <amodra@one.net.au>
417         * config/obj-vms.c (obj_crawl_symbol_chain): Don't take address of
418         symbol_next.
420         * config/tc-fr30.c (md_estimate_size_before_relax): Return size of
421         current variable part of frag.
422         * config/tc-m32r.c (md_estimate_size_before_relax): Likewise.
423         * config/tc-openrisc.c (md_estimate_size_before_relax): Likewise.
424         * config/tc-m68hc11.c (RELAX_STATE): Define.
425         (RELAX_LENGTH): Define.
426         (md_estimate_size_before_relax): Handle non-relaxable cases
427         separately from relaxable cases for clarity, and return correct
428         size for multi-pass relaxation.
429         * config/tc-tahoe.c (RELAX_LENGTH): Correct.
430         (md_estimate_size_before_relax): As for tc-m68hc11.c.
431         (md_convert_frag): Remove "length_code".
432         * config/tc-vax.c (RELAX_STATE): Define.
433         (RELAX_LENGTH): Define.
434         (md_relax_table): Add missing entry.
435         (md_estimate_size_before_relax): As for tc-m68hc11.c.
436         (md_convert_frag): Remove "length_code".
437         * config/tc-ns32k.c (md_estimate_size_before_relax): Simplify and
438         don't bother setting fr_var.  Return correct size for multi-pass
439         relaxation.
440         * config/tc-v850.c (md_estimate_size_before_relax): Rewrite.
441         (md_convert_frag): Don't bother clearing fr_var.
442         (md_pseudo_table): Correct initialization.
443         * config/tc-h8500.c (md_convert_frag): Don't bother clearing fr_var.
444         (md_estimate_size_before_relax): No need to set fr_var.
445         * config/tc-mcore.c (md_convert_frag): Don't bother clearing fr_var.
446         (md_estimate_size_before_relax): No need to set fr_var.
448 2001-05-09  Richard Henderson  <rth@redhat.com>
450         * config/tc-ia64.c (generate_unwind_image): Align the fragment
451         beginning a function's unwind info block.
453 2001-05-09  Alexandre Oliva  <aoliva@redhat.com>
455         * config/tc-mn10300.c (md_apply_fix3): Accept PC-relative relocs.
457 2001-05-08  Andreas Schwab  <schwab@suse.de>
459         * config/tc-m68k.c: Instead of replacing -1 by 64 in assignment to
460         fx_pcrel_adjust explicitly sign extend when reading it.
462 2001-05-08  Alan Modra  <amodra@one.net.au>
464         * config/tc-m68k.c (md_estimate_size_before_relax): Set fr_var
465         from md_relax_table, and combine some switch cases.
467 2001-05-06  Alexandre Oliva  <aoliva@redhat.com>
469         * config/tc-mn10300.c (md_assemble): Subtract operand->shift
470         from offset in non-pcrel operands too.
472 2001-05-06  Nick Clifton  <nickc@cambridge.redhat.com>
474         * config/tc-arm.h (MAX_MEM_FOR_RS_ALIGN_CODE): Define.
475         * config/tc-arm.c (arm_handle_align): Do not insert more than
476         MAX_MEM_FOR_RS_ALIGN_CODE bytes.
477         (arm_frag_align_code): Use MAX_MEM_FOR_RS_ALIGN_CODE.
479 2001-05-03  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
481         * Makefile.am (TARG_ENV_HFILES): Add te-hppa64.h and te-hppalinux64.h.
482         Run "make dep-am".
483         * Makefile.in: Regenerate.
484         * configure.in: Remove duplicate mips-*-ecoff* entry.
485         * configure: Regenerate.
487         * config/obj-ecoff.c (obj_pseudo_table): Fix terminating entry.
488         (n_names): Cast away type mismatch.
489         (ecoff_sec_sym_ok_for_reloc): Add unused attribute.
490         (obj_ecoff_frob_symbol): Likewise.
491         * ecoff.c: (add_file): Add unused attribute.
492         (ecoff_directive_begin): Likewise.
493         (ecoff_directive_bend): Likewise.
494         (ecoff_directive_def): Likewise.
495         (ecoff_directive_dim): Likewise.
496         (ecoff_directive_scl): Likewise.
497         (ecoff_directive_size): Likewise.
498         (ecoff_directive_type): Likewise.
499         (ecoff_directive_tag): Likewise.
500         (ecoff_directive_val): Likewise.
501         (ecoff_directive_endef): Likewise.
502         (ecoff_directive_end): Likewise.
503         (ecoff_directive_ent): Likewise.
504         (ecoff_directive_extern): Likewise.
505         (ecoff_directive_file): Likewise.
506         (ecoff_directive_fmask): Likewise.
507         (ecoff_directive_frame): Likewise.
508         (ecoff_directive_mask): Likewise.
509         (ecoff_directive_loc): Likewise.
510         (mark_stabs): Likewise.
511         (ecoff_stab):  Likewise.
512         (ecoff_frob_symbol): Cast away type mismatch.
513         (ecoff_padding_adjust): Likewise.
514         (ecoff_build_symbols): Likewise.
515         (ecoff_build_procs): Likewise.
516         (ecoff_build_aux): Likewise.
517         (ecoff_build_strings): Likewise.
518         (ecoff_build_fdr): Likewise.
519         (ecoff_build_debug): Likewise.
520         * itbl-ops.c (itbl_assemble): Variable initialization.
522 2001-05-03  Alan Modra  <amodra@one.net.au>
524         * config/tc-i386.c (i386_displacement): Call as_bad for bad GOTOFF
525         expressions rather than triggering an assert.
527 2001-05-02  Johan Rydberg  <jrydberg@opencores.org>
529         * config/tc-openrisc.c: New file.
530         * config/tc-openrisc.h: Likewise.
532         * Makefile.am: Add OpenRISC target.
533         * Makefile.in: Regenerated.
535         * configure.in (openrisc-*-*): Add target.
536         * configure: Regenerated.
538 2001-05-02  Nick Clifton  <nickc@cambridge.redhat.com>
540         * config/tc-arm.c (arm_frag_align_code): Change error message to
541         more explanatory version.
543 2001-04-29  Keith M Wesolowski <wesolows@foobazco.org>
545         * config/tc-mips.c (md_parse_option): Also accept
546         elf64-tradbigmips and elf64-tradlittlemips for OPTION_64.
548 2001-04-27  David Mosberger  <davidm@hpl.hp.com>
550         * config/tc-ia64.c (dot_spillmem_p): Fix output_spill_?sprel_p()
551         argument passing order: predicate goes last, not first.
553 2001-04-27  Sean McNeil <sean@mcneil.com>
555         * configure.in: Add arm-vxworks.
556         * configure: Regenerate.
558 2001-04-26  Nick Clifton  <nickc@cambridge.redhat.com>
560         * config/tc-arm.c (arm_handle_align): New Function:  Generate
561         no-op filled alignment frags.
562         (arm_frag_align_code): New Function: Create a code alignment frag.
563         (arm_init_frag): New Function: Initialse the target dependent
564         parts of a frag.
566         * config/tc-arm.h (TC_FRAG_TYPE): Define.
567         (TC_FRAG_INIT): Define.
568         (HANDLE_ALIGN): Define.
569         (md_do_align): Define.
571 2001-04-25  Nick Clifton  <nickc@cambridge.redhat.com>
573         * config/obj-coff.c (do_linenos_for): Check to see if the filename
574         symbol has been initialised before extracting its symbol index.
576 2001-04-24  H.J. Lu  <hjl@gnu.org>
578         * configure: Regenerated with the right version of autoconf.
580 2001-04-24  Christian Groessler  <cpg@aladdin.de>
582         * config/tc-z8k.c (build_bytes): 12 and 16 bit displacements now
583         generate R_CALLR and R_REL16 relocations
585 2000-04-20  Jason Eckhardt  <jle@redhat.com>
587         * config/tc-d10v.h (tc_frob_label): Update the symbol's frag
588         since frag_now can change after d10v_cleanup is called.
590 2001-04-16  David O'Brien  <obrien@FreeBSD.org>
592         * configure.in: Add the em type for FreeBSD targets.
593         * configure: Regenerate.
595 2001-04-14  Alexandre Oliva  <aoliva@redhat.com>
597         * struc-symbol.h (struct local_symbol): New TC_LOCAL_SYMFIELD_TYPE.
598         * symbols.c (local_symbol_convert): Call TC_LOCAL_SYMFIELD_CONVERT.
600         * config/tc-mn10300.c (md_assemble): Simplify offset adjustment of
601         pc-relative relocations not placed at the end of the instruction.
603 2001-04-13  Jim Wilson  <wilson@redhat.com>
605         * tc-ia64.c (is_conditional_branch): Return true for br, brl, and br.
606         excluding br.i.
608 2001-04-13  Jakub Jelinek  <jakub@redhat.com>
610         * config/obj-elf.c (obj_elf_change_section): Add entsize argument,
611         handle SHF_MERGE and SHF_STRINGS.
612         (obj_elf_parse_section_letters): Set SHF_MERGE and SHF_STRINGS.
613         (obj_elf_section): Allow additional argument specifying entity size.
614         * write.c (adjust_reloc_syms): Keep relocations against local symbols
615         in SEC_MERGE sections.
617 2001-04-12  Jason Merrill  <jason_merrill@redhat.com>
619         * dwarf2dbg.c (process_entries): Don't optimize redundant line notes.
621 2001-04-12  Alexandre Oliva  <aoliva@redhat.com>
623         * expr.c (operand): Pass &c to md_parse_name().
624         * config/tc-ia64.h, config/tc-ppc.h, config/tc-tic54x.h: Adjust.
626 2001-04-07  Steven J. Hill  <sjhill@cotw.com>
628         * config/tc-mips.c: Support ELF64 for traditional MIPS targets.
630         * Makefile.am: (TARG_ENV_HFILES): Add tc-mips.h.
631         * Makefile.in: Regenerated.
633         * configure.in: Use traditional MIPS targets for Linux/MIPS.
634         * configure: Regenerated.
636 2001-04-06  Alexandre Oliva  <aoliva@redhat.com>
638         * config/tc-mn10300.c (xr_registers): Added `pc'.
640 2001-04-05  Alan Modra  <alan@linuxcare.com.au>
642         * configure.in: Add h8500-*-coff and h8500-*-rtems targets.
643         * configure: Regenerate.
645         * config/tc-h8500.c (md_estimate_size_before_relax): Add missing
646         cases, and always return size based on current fr_subtype.
647         (md_begin): Move initialization of md_relax_table..
648         (md_relax_table): ..to static initializer.  Set rlx_length for
649         UNDEF_WORD_DISP cases.
650         * config/tc-w65.c (md_estimate_size_before_relax): Likewise.
651         (md_begin): Likewise.
652         (md_relax_table): Likewise.
653         * config/tc-mcore.c (md_estimate_size_before_relax): Likewise.
654         (md_relax_table): Set rlx_length for UNDEF_WORD_DISP cases.
655         Set rlx_backward and rlx_forward to zero for unused states.
656         * config/tc-sh.c (md_estimate_size_before_relax): Likewise.
657         (md_relax_table): Set rlx_length for UNDEF_WORD_DISP cases.
658         (UNCOND12, UNCOND32): Remove duplicate defines.
660 2001-04-04  Hans-Peter Nilsson  <hp@axis.com>
662         * config/tc-cris.c (md_estimate_size_before_relax) <case
663         ENCODE_RELAX (STATE_CONDITIONAL_BRANCH, STATE_UNDF)>: Don't emit
664         32-bit branch, just set fragP->fr_subtype.  Set fragP->fr_var.
665         <all cases>: Always set fragP->fr_var using md_cris_relax_table.
666         Add cases to cover all relax states.
667         (cris_insn_first_word_frag): New.
668         (md_assemble): Call cris_insn_first_word_frag to get the first
669         frag in an insn, not frag_more.  Don't call dwarf2_emit_insn at
670         end.  Drop variable insn_size.
671         (gen_bdap): Call cris_insn_first_word_frag, not frag_more.
672         (cris_sym_leading_underscore): Wrap first as_bad parameter in _().
673         (cris_sym_no_leading_underscore, s_cris_file, s_cris_loc): Ditto.
675         * write.c (write_object_file): Reset broken word state before
676         calling relax_seg.
678 2001-03-31  Alan Modra  <alan@linuxcare.com.au>
680         * listing.c (listing_listing): Enable listing on EDICT_NOLIST_NEXT
681         for one line if not already enabled.
682         * cond.c (s_elseif): Correct conditional assembly listing.
683         (s_else): Likewise.
685         * cond.c (s_endif): Correct handling of "if .. elseif .." trees.
686         Don't abort on NULL current_cframe.
688 2001-03-30  Alan Modra  <alan@linuxcare.com.au>
690         * dwarf2dbg.c (dwarf2_directive_file): Fix warnings.
691         (dwarf2dbg_convert_frag): Pass `finalize_syms' to resolve_symbol_value.
692         * config/obj-aout.c (obj_crawl_symbol_chain): Likewise.
693         * config/obj-bout.c (obj_crawl_symbol_chain): Likewise.
694         * config/obj-coff.c (do_relocs_for): Likewise.
695         (yank_symbols): Likewise.
696         (fixup_segment): Likewise.
697         * config/tc-ppc.c (ppc_frob_symbol): Likewise.
698         (ppc_fix_adjustable): Likewise.
699         * config/tc-mips.c (md_convert_frag): Likewise.
700         * config/obj-vms.c (obj_crawl_symbol_chain): Likewise.
701         * ehopt.c (eh_frame_convert_frag): Likewise.
702         * expr.c (make_expr_symbol): Likewise.
704         * frags.h (struct frag): Add last_fr_address.  Reorder fields for
705         better packing.
706         * symbols.c (resolve_symbol_value): Don't fix expression values
707         until relaxation is complete.
708         (resolve_local_symbol): Pass `finalize_syms' to resolve_symbol_value.
709         (S_GET_VALUE): Likewise, and return unresolved expression value.
710         * write.c (finalize_syms): New.
711         (relax_and_size_seg): Split into..
712         (relax_seg): New function, returns 1 if anything changed..
713         (size_seg): And the remainder of relax_and_size_seg.
714         (fixup_segment): Arrange for final resolution of sym values.
715         (adjust_reloc_syms): Likewise.
716         (write_object_file): Likewise, and repeatedly call relax_seg until
717         nothing more changes.
718         (relax_segment): Return 1 if anything changed.  Use correct types
719         for rs_org `target' and `after'.
720         * write.h (finalize_syms): Declare.
721         (relax_segment): Update prototype.
723         * config/tc-sh.c (md_estimate_size_before_relax): Add extra
724         do-nothing cases to switch to avoid abort on a second relaxation
725         pass, and tidy code a little.
726         * config/tc-cris.c (md_estimate_size_before_relax): Likewise.
727         * config/tc-h8500.c (md_estimate_size_before_relax): Likewise.
728         * config/tc-w65.c (md_estimate_size_before_relax): Likewise.
729         * config/tc-i386.c (UNCOND_JUMP, COND_JUMP, COND_JUMP86): Decrement.
730         (md_relax_table): Remove first four unused entries.  Increment
731         rlx_length by one throughout table, and update comments to suit.
732         (md_estimate_size_before_relax): Return size of current variable
733         part of frag to reflect reality when relaxing more than once.
734         * config/tc-mcore.c (COND12, UNCD12): Rename to DISP12 throughout.
735         (COND32, UNCD32): Rename to DISP32 throughout.
736         (UNDEF_WORD_DISP): Renumber to 3.
737         (md_estimate_size_before_relax): Add extra do-nothing cases.
738         * config/tc-mn10200.c (md_estimate_size_before_relax): Rewrite.
739         * config/tc-mn10300.c (md_estimate_size_before_relax): Rewrite.
740         * config/tc-ns32k.c (md_estimate_size_before_relax): Add cases to
741         handle word and dword branches.
743 2001-03-29  Hans-Peter Nilsson  <hp@axis.com>
745         * config/tc-cris.h (tc_fix_adjustable): Allow only
746         BFD_RELOC_CRIS_32_GOTREL of the PIC relocs.
747         * config/tc-cris.c (cris_get_pic_suffix): Correct reloc type in
748         example in comment to valid type.
750 2001-03-28  H.J. Lu  <hjl@gnu.org>
752         * read.c (equals): Set to local for COFF only if it hasn't been
753         defined before.
755 2001-03-28  Alan Modra  <alan@linuxcare.com.au>
757         * config/tc-hppa.c (DEFAULT_LEVEL): Define.
758         (md_begin): Use it when setting default architecture.
760 2001-03-27  Nick Papadonis  <nick@coelacanth.com>
762         * read.c (equals): (for COFF) default symbols to being local.
764 2001-03-27  Hans-Peter Nilsson  <hp@axis.com>
766         * configure.in (cris-*-*): Change default emulation to criself.
767         (cris-*-*aout*): New rule.
768         * configure: Regenerate.
770 2001-03-26  Martin Schwidefsky  <schwidefsky@de.ibm.com>
772         * config/tc-s390.c (tc_s390_fix_adjustable): Add test for
773         BFD_RELOC_390_GOTENT.
774         * config/tc-s390.h (TC_RELOC_RTSYM_LOC_FIXUP): Add test for
775         BFD_RELOC_390_GOTENT.
777 2001-03-26  Nick Clifton  <nickc@redhat.com>
779         * config/tc-s390.h (TC_FORCE_RELOCATION): Define.
780         * config/tc-s390.c (s390_force_relocation): New function: Force
781         relocations for VTINHERIT relocs.
783 2001-03-23  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
785         * doc/as.texinfo: Put @c man begin to generate the as man page.
786         When generating man, define all the variables. Re-organize some
787         options to obtain better indentation of man page.
788         * doc/Makefile.am (MANCONF, TEXI2POD, POD2MAN): New variable.
789         (as.1): Build from as.texinfo.
790         * doc/Makefile.in: Regenerate.Index: binutils/Makefile.am
792 2001-03-25  Alan Modra  <alan@linuxcare.com.au>
794         * config/tc-i386.c (i386_scale): Accept an absolute expression for
795         scale factor, and return the end of the expression.
796         (i386_operand): Modify for above.
798 2001-03-23  Nick Clifton  <nickc@redhat.com>
800         * doc/as.texinfo: Document --listing-XXX command line switches.
801         Explain why listings behave differently when -pipe is used.
803 2001-03-23  Richard Sandiford  <rsandifo@redhat.com>
805         * write.c (fix_new_exp): Print an error if passed a register.
807 2001-03-23  Hans-Peter Nilsson  <hp@axis.com>
809         * config/tc-cris.c: Tweak attribution.  Fix typos.  PIC support.
810         (PIC_SUFFIX_CHAR): New macro.
811         (cris_get_pic_suffix, cris_get_pic_reloc_size): New functions.
812         (pic): New variable.
813         (md_longopts): New option --pic.
814         (OPTION_PIC): Define.
815         (md_estimate_size_before_relax): Tweak longish comment.
816         (md_create_long_jump): Make the long jumps generate ADD.D offset,PC.
817         (md_assemble): Handle a PIC relocation on prefix and normal
818         instruction operands.
819         <output_instruction.insn_type == CRIS_INSN_BRANCH>: Handle
820         "complex" operand expressions.  Call frag_more outside
821         gen_cond_branch_32 parameter list.
822         (cris_process_instruction): Handle PIC relocs on parsed
823         operand expressions.  Validize PIC reloc sizes.
824         (get_autoinc_prefix_or_indir_op): Handle PIC suffix.
825         (gen_bdap): Handle "complex" operand expressions.
826         (gen_cond_branch_32): Use as_warn_where, not as_warn.  Use
827         ADD.D offset,PC as jump instruction if generating PIC.  Generate
828         error instead of crashing on complex expressions.
829         (cris_number_to_imm): Add segT parameter.  All callers changed.
830         Use segT parameter, not now_seg, for segment of fixup.  Handle
831         PCREL relocations but check that they are fully resolved.
832         (md_parse_option): Handle OPTION_PIC.
833         (tc_gen_reloc): Handle PIC relocs.
834         (md_show_usage): Update for --pic.
835         (md_apply_fix3): Renamed from md_apply_fix.
836         (md_pcrel_from): Accept emitting PCREL relocs when ELF.
837         (md_cris_force_relocation): Force relocation for PIC relocs.
839         * config/tc-cris.h: Tweak attribution.
840         (MD_APPLY_FIX3): Define.
841         (IS_CRIS_PIC_RELOC): New macro.
842         (TC_RELOC_RTSYM_LOC_FIXUP): Define.
843         (tc_fix_adjustable): Don't adjust a globally visible symbol when
844         generating ELF.
845         (tc_frob_symbol): Avoid emitting undefined symbols.
847 2001-03-20  Alan Modra  <alan@linuxcare.com.au>
849         * frags.h (struct frag): Add relax_marker.
850         * write.c (is_dnrange): Delete.
851         (relax_frag): Use correct types for `aim', `target', `address'.
852         Delete `offset', `was_address'.  Test `relax_marker' instead of
853         using fragile (and slow) address test.
854         (relax_segment): Init and flip `relax_marker'.
856 2001-03-19  Alan Modra  <alan@linuxcare.com.au>
858         * config/tc-i386.c (md_assemble <REGISTER_WARNINGS>): Correct
859         used register name.
861 2001-03-18  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
863         * config/tc-m68hc11.c (md_pseudo_table): Recognize xrefb to comply
864         with 'Motorola specification for assembly language input standard'.
866 2001-03-17  Richard Henderson  <rth@redhat.com>
868         * dwarf2dbg.c (user_filenum, user_filenum_allocated): Remove.
869         (dwarf2_directive_loc): Don't use them.
870         (dwarf2_directive_file): Reject duplicate file definitions.
871         (get_filenum): Zero allocated memory.
872         (out_file_list): Complain about missing file definitions.
874 2001-03-17  Alan Modra  <alan@linuxcare.com.au>
876         * read.c (do_org): Handle complex expressions.
877         * cgen.c (gas_cgen_finish_insn): Likewise.
879 2001-03-15  David Mosberger  <davidm@hpl.hp.com>
881         * config/tc-ia64.c (md): New member keep_pending_output.
882         (ia64_flush_pending_output): Flush only if md.keep_pending_output
883         is not set.
884         (dot_xdata): Turn on md.keep_pending_output for the duration of
885         this function.
886         (dot_xfloat_cons): Ditto.
887         (dot_xstringer): Ditto.
888         (dot_xdata_ua): Ditto.
889         (dot_xfloat_cons_ua): Ditto.
891 2001-03-15  Jim Wilson  <wilson@redhat.com>
893         * config/tc-ia64.c (ia64_unrecognized_line, case '['): Add local
894         label support.
896 2001-03-15  Alexandre Oliva  <aoliva@redhat.com>
898         * config/tc-sh.c (parse_reg): Match capital MACH and MACL.
900 2001-03-15  DJ Delorie  <dj@redhat.com>
902         * stabs.c (s_stab_generic): Don't corrupt the notes obstack by
903         blindly freeing string if it isn't at the top of the obstack.
905 2001-03-13  Alan Modra  <alan@linuxcare.com.au>
907         * config/tc-i386.c (RELOC_ENUM): Define.  Use throughout file.
908         (NUM_FLAG_CODE): Define.
909         (lex_got): New function.
910         (got_reloc): New global var.
911         (x86_cons_fix_new): New function.
912         (x86_cons): New function.
913         (i386_immediate): Use lex_got here, replacing inline code.  Change
914         "ignoring junk.." error message to "junk.."
915         (i386_displacement): Likewise.
916         * config/tc-i386.h (TC_PARSE_CONS_EXPRESSION): Define.
917         (x86_cons): Declare.
918         (TC_CONS_FIX_NEW): Define.
919         (x86_cons_fix_new): Declare.
921 2001-03-12  Nick Clifton  <nickc@redhat.com>
923         * config/tc-arm.c (md_begin): Always set machine type based on
924         cpu_variant.
926 2001-03-07  Alan Modra  <alan@linuxcare.com.au>
928         * config/tc-i386.c (struct _i386_insn): Rename disp_reloc to reloc.
929         (md_assemble) <smallest displacement>: Use correct field of i.op[]
930         union.
931         <JumpInterSegment output>: Use correct i.disp_reloc[].
932         <immediate output>: Likewise.
934 2001-03-06  Nick Clifton  <nickc@redhat.com>
936         * config/tc-arm.c (md_apply_fix3): Clear bit zero of offset in
937         BLX(1) instruction.
939 2001-03-06  Igor Shevlyakov  <igor@windriver.com>
941         * config/tc-m68k.c : Add 5407 to archs[] table.
942         (HAVE_LONG_BRANCH): Add mcf5407.
943         (select_control_regs): Recognize 5407.
945 2001-03-02  Dave Brolley  <brolley@redhat.com>
947         * config/tc-m32r.c (expand_debug_syms): Call frag_align_code rather
948         than m32r_do_align.
950 2001-03-02  Richard Sandiford  <rsandifo@redhat.com>
952         * config/atof-ieee.c (TC_LARGEST_EXPONENT_IS_NORMAL): New macro.
953         (gen_to_words): Print warnings if NaNs are found and the target CPU
954         does not support them.  Allow largest exponent to be used in normal
955         numbers if TC_LARGEST_EXPONENT_IS_NORMAL evaluates to true.
957 2001-02-28  Andreas Jaeger  <aj@suse.de>, Bo Thorsen  <bo@suse.de>
959         * config/tc-i386.c (tc_gen_reloc): Remove ugly hack which is not needed
960         anymore since we use bfd_elf_generic_reloc now.
961         (md_apply_fix3): Only apply hack for partial_inplace if not using RELA.
963 2001-02-27  Alan Modra  <alan@linuxcare.com.au>
965         * configure.in (BFD_VERSION): New.
966         (AM_INIT_AUTOMAKE): Use $BFD_VERSION.
967         * configure: Regenerate.
968         * Makefile.am: Run "make dep-am"
969         * Makefile.in: Regenerate.
970         * doc/Makefile.in: Regenerate.
972 2001-02-26  Mark Elbrecht  <snowball3@bigfoot.com>
974         * config/obj-coff.c [BFD_ASSEMBLER] (obj_coff_section): Set
975         SEC_NEVER_LOAD when the 'n' flag is used.
976         Add SEC_NEVER_LOAD to matchflags.
978 2001-02-24  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
980         * symbols.c (decode_local_label_name): Initialize message_format
981         only when an error is reported (perf pb due to I18N).
983 2001-02-23  H.J. Lu  <hjl@gnu.org>
985         * dwarf2dbg.c (dwarf2_directive_file): Call s_app_file (0) if
986         BFD_ASSEMBLER is not defined.
988 2001-02-23   Richard Sandiford <rsandifo@redhat.com>
990         * config/tc-mn10300.c (md_apply_fix3): Don't mark a fixup as
991         done if it's against a symbol.
993 2001-02-22  Timothy Wall  <twall@cygnus.com>
995         * config/tc-ia64.c (ia64_target_format): Return ia64-aix-specific
996         target formats if applicable.
997         * config/te-ia64aix.h: New.  Configuration for AIX5 on IA-64.
998         * Makefile.am (TARG_ENV_HFILES): Added config/te-ia64aix.h.
999         * Makefile.in: Regenerated.
1000         * configure.in: Added configuration for ia64-*-aix*.
1001         * configure: Regenerated.
1003 2001-02-21  David Mosberger  <davidm@hpl.hp.com>
1005         * config/tc-ia64.c (enum operand_match_result): New type.
1006         (operand_match): Change return type to operand_match_result.
1007         Fix all returns appropriately, adding support for returning the
1008         out-of-range result.
1009         (parse_operands): New locals result, error_pos, out_of_range_pos,
1010         curr_out_of_range_pos.  Rewrite operand matching loop to give better
1011         error messages.
1013 2001-02-21  David Mosberger  <davidm@hpl.hp.com>
1015         * config/tc-ia64.c (struct unwind): Add member "prologue_count".
1016         (dot_proc): Clear unwind.prologue_count to zero.
1017         (dot_prologue): Increment unwind.prologue_count.
1018         (dot_restore): If second operand is omitted, use
1019         unwind.prologue_count -1 for "ecount" (# of additional regions to
1020         pop).  Decrement unwind.prologue_count by number of regions
1021         popped.
1023 2001-02-21  Nick Clifton  <nickc@redhat.com>
1025         * doc/as.texinfo (Section): Note that some flags to the COFF
1026         version of .section remove attributes rather than setting them.
1028 2001-02-20  Kazu Hirata  <kazu@hxi.com>
1030         * config/tc-pdp11.c: Fix formatting.
1031         * config/tc-pdp11.h: Likewise.
1033 2001-02-20  Bo Thorsen  <bo@suse.de>
1035         * config/tc-i386.c (tc_i386_fix_adjustable): Fix GOTPCREL GOT
1036         entry.
1038 2001-02-18  David O'Brien  <obrien@FreeBSD.org>
1040         * configure.in (cpu_type, arch): Add a generic FreeBSD specification as
1041         all FreeBSD platforms should look the same at this level.
1042         * configure: Rebuilt.
1043         * config/tc-i386.c: Add support for old FreeBSD a.out hosts.
1045 2001-02-18  lars brinkhoff  <lars@nocrew.org>
1047         * Makefile.am: Add PDP-11 target.
1048         * configure.in: Likewise.
1049         * config/tc-pdp11.c: New file.
1050         * config/tc-pdp11.h: New file.
1051         * doc/Makefile.am: Add PDP-11 documentation.
1052         * doc/all.texi: Likewise.
1053         * doc/as.texinfo: Likewise.
1054         * doc/c-pdp11.texi: New file.
1056 2001-02-16  matthew green  <mrg@redhat.com>
1058         * cgen.c (gas_cgen_md_apply_fix3): Support BFD_RELOC_64.
1060 2001-02-13  Jim Wilson  <wilson@redhat.com>
1062         * config/tc-ia64.c (operand_match, case TAG13): Make a BFD_RELOC_UNUSED
1063         reloc instead of a 0 reloc.
1064         (md_apply_fix3): Check for BFD_RELOC_UNUSED instead of 0, and mark it
1065         as done.
1066         * config/tc-ia64.h (TC_RELOC_RTSYM_LOC_FIXUP): Likewise.
1068 2001-02-13  Ian Lance Taylor  <ian@zembu.com>
1070         * write.c (is_dnrange): Stop as soon as the address becomes
1071         larger.
1072         (relax_frag): Add segment parameter.  Only call symbol_get_frag
1073         once.  Only call is_dnrange if the symbol is in the same segment,
1074         and the symbol address is larger.
1075         (relax_segment): Pass segment to md_relax_frag and relax_frag.
1076         * write.h (relax_frag): Update declaration.
1077         * config/tc-fr30.c (fr30_relax_frag): Add segment parameter.  Pass
1078         it to relax_frag.
1079         * config/tc-m32r.c (m32r_relax_frag): Likewise.
1080         * config/tc-m32r.h (md_relax_frag): Add segment parameter.
1081         (m32r_relax_frag): Update declaration.
1082         * config/tc-mips.h (md_relax_frag): Add segment parameter.
1083         * config/tc-tic54x.h (md_relax_frag): Likewise.
1084         * doc/internals.texi (CPU backend): Update documentation for
1085         md_relax_frag.
1087 2001-02-13  Alan Modra  <alan@linuxcare.com.au>
1089         * doc/c-i386.texi (i386-Arch): Add "jumps"/"nojumps" blurb.
1090         Mention effect of < 386 architectures on jump promotion.
1091         (i386-Jumps): xref above.  Don't assume long disp is 32 bits.
1093         * config/tc-i386.c (no_cond_jump_promotion): New.
1094         (set_cpu_arch): Parse "jumps" arch modifier.
1095         (insn_size): Modify usage comment.
1096         (ENCODE_RELAX_STATE): Reformat and protect macro arg.
1097         (SIZE_FROM_RELAX_STATE): Rename to DISP_SIZE_FROM_RELAX_STATE.
1098         (TYPE_FROM_RELAX_STATE): New define.
1099         (UNCOND_JUMP, COND_JUMP): Renumber.
1100         (md_relax_table): Reorder to suit.
1101         (COND_JUMP86): New define.
1102         (md_relax_table): Handle COND_JUMP86 cases. Add a few comments.
1103         (md_assemble): Create frag var for jumps of max size, encode relax
1104         state for COND_JUMP86.
1105         (md_estimate_size_before_relax): Handle COND_JUMP86 cases, and
1106         leave conditional jumps small if no_cond_jump_promotion.
1107         (md_convert_frag): Likewise.
1109         * expr.c (operator): Don't bump input_line_pointer for two char
1110         operators.  Instead return operator size via new param num_chars.
1111         (expr): Use above to parse multi-char operators correctly.
1113 Mon Feb 12 17:45:50 CET 2001  Jan Hubicka  <jh@suse.cz>
1115         * config/tc-i386.c (i386_displacement): Fix handling of
1116         BFD_RELOC_X86_64_GOTPCREL.
1117         (i386_validate_fix): Likewise.
1119 2001-02-12  Philip Blundell  <pb@futuretv.com>
1121         * config/tc-arm.c (do_ldst): Improve warnings for unpredictable
1122         ldrt/strt instructions.
1124 2001-02-11  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
1126         * config/tc-mips.c (macro): For M_LA_AB emit a
1127         BFD_RELOC_MIPS_CALL16 relocation or a
1128         BFD_RELOC_MIPS_CALL_HI16/BFD_RELOC_MIPS_CALL_LO16 pair instead of
1129         BFD_RELOC_MIPS_GOT16 and
1130         BFD_RELOC_MIPS_GOT_HI16/BFD_RELOC_MIPS_GOT_LO16, respectively for
1131         loading the jump register when generating SVR4_PIC code.
1133 2001-02-10  Chris Demetriou  <cgd@broadcom.com>
1135         * configure.in: Make 'mipself' and 'mipsecoff' emulations
1136         map to MIPS-specific files, as they used to do before the
1137         change on 2000-05-21.
1138         * configure: Regerate.
1140 2001-02-10  Chris Demetriou  <cgd@broadcom.com>
1142         * config/tc-mips.c (md_parse_option): Don't try to compile
1143         ELF-only option code if not ELF.
1145 2001-02-08  David Mosberger  <davidm@hpl.hp.com>
1147         * config/tc-ia64.h (md_elf_section_type): New macro.
1148         (ELF_TC_SPECIAL_SECTIONS): Drop .IA_64.unwind and .IA_64.unwind_info
1149         (they're now handled via ia64_elf_section_type.
1151         * config/tc-ia64.c (unwind): New members saved_text_seg,
1152         saved_text_subseg, and force_unwind_entry.
1153         (optimize_unw_records): New function to optimize away unnecessary
1154         unwind directives.
1155         (ia64_elf_section_type): New function.
1156         (output_unw_records): Generate unwind info only if the size is
1157         non-zero or if it's forced for some other reason (e.g.,
1158         handlerdata or a personality routine).
1159         (generate_unwind_image): Don't switch back to previous
1160         section---stay inside the unwind info section instead so that
1161         handlerdata that may follow goes into the right place.
1162         (dot_handlerdata): Force generation of unwind entry and save the
1163         current active text segment before generating unwind image.
1164         (dot_unwentry): Force generation of unwind entry.
1165         (dot_personality): Ditto.
1166         (dot_endp): Generate unwind table entry only if there is
1167         some unwind info or the unwind entry was forced.
1169         * config/tc-ia64.c (make_unw_section_name): New macro to form
1170         unwind section name.
1171         (generate_unwind_image): Add "text_name" argument.  Use it to
1172         form unwind section name.
1173         (dot_handlerdata): Determine current segment (section) name and
1174         pass it to generate_unwind_image().
1175         (dot_endp): Determine current segment (section) name and use
1176         it to determine the appropriate unwind section name.
1177         (ia64_md_do_align): Add missing ATTRIBUTE_UNUSED declarations to
1178         n, fill, and max arguments.
1180 2001-02-09  Schwidefsky  <schwidefsky@de.ibm.com>
1182         * Makefile.am: Add linux target for S/390.
1183         * configure.in: Likewise.
1184         * config/tc-s390.c: New file.
1185         * config/tc-s390.h: New file.
1187 2001-02-09  Alexandre Oliva  <aoliva@redhat.com>
1189         * config/tc-sh.c (md_pseudo_table): Add uaquad.  Use s_uacons for
1190         2byte, 4byte and 8byte.
1192 2001-02-08  Alan Modra   <alan@linuxcare.com.au>
1194         * config/tc-hppa.c (pa_build_unwind_subspace): Don't call
1195         md_number_to_chars with size > sizeof (valueT).
1197 2001-02-06  H.J. Lu  <hjl@gnu.org>
1199         * config/tc-ia64.h (TC_RELOC_RTSYM_LOC_FIXUP): Do fixup if
1200         there is no relocation.
1202 2001-02-06  H.J. Lu  <hjl@gnu.org>
1204         * config/tc-ia64.h (TC_RELOC_RTSYM_LOC_FIXUP): New. Defined.
1206         * config/tc-ia64.c (md_parse_option): Only accept the valid
1207         ia64 options on "-axxx".
1209 2001-02-05  Jim Wilson  <wilson@redhat.com>
1211         * config/tc-ia64.c (errata_nop_necessary_p): Return 0 instead of
1212         aborting for invalid operands.
1214 2001-02-06  Alan Modra  <alan@linuxcare.com.au>
1216         * config/tc-hppa.c (fix_new_hppa): Pass in unwind directly rather
1217         than via pointer.  Update all callers.
1218         (UNWIND_LOW32): Define.
1219         (UNWIND_HIGH32): Define.
1220         (pa_build_unwind_subspace): Use the above macros instead of dumping
1221         bitfields directly.  Call frag_more once rather than multiple times.
1222         (md_assemble): Use UNWIND_LOW32.
1223         (pa_entry): Likewise
1224         (pa_procend): Likewise.
1225         (process_exit): Use UNWIND_HIGH32.
1227 2001-02-04  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
1229         * config/tc-m68hc11.h (LISTING_HEADER): Use m68hc11_listing_header
1230         function to select the header according to the cpu.
1231         (md_after_pass_hook, md_do_align): Remove.
1232         (md_cleanup, m68hc11_cleanup): Remove.
1233         (md_pcrel_from_section): Declare.
1234         * config/tc-m68hc11.c (build_dbranch_insn): Remove insn_size.
1235         (build_jump_insn, build_insn): Likewise.
1236         (m68hc11_listing_header): New function.
1237         (m68hc11_cleanup): Remove.
1239 2001-02-02  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
1241         * config/tc-m68hc11.c (relaxable_symbol): Relax externally visible
1242         symbols because there is no support for shared libraries and these
1243         symbols can't be overridden (unless they are weak).
1245 2001-02-01  Momchil Velikov  <velco@fadata.bg>
1247         * dwarf2dbg.c (out_debug_abbrev): Terminate the abbreviations
1248         for the compilation unit with a zero byte.
1250 2001-01-30  Alan Modra  <alan@linuxcare.com.au>
1252         * config/tc-hppa.c (pa_ip): Support 12 bit branches to absolute
1253         destinations.  Correct range check for 17 and 22 bit branches.
1255 2001-01-25  Nick Clifton  <nickc@redhat.com>
1257         * config/tc-m68k.c (tc_gen_reloc): Do not abort if tcbit is
1258         still set.  Issue an error message instead.
1259         (md_estimate_size_before_relax): Delete unused variable
1260         'buffer_address'.  Fixup parentheses around if statement.
1262 2001-01-23  Kazu Hirata  <kazu@hxi.com>
1264         * as.c: Fix formatting.
1265         * ehopt.c: Likewise.
1266         * messages.c: Likewise.
1267         * stabs.c: Likewise.
1268         * symbols.c: Likewise.
1270 2001-01-23  Ben Elliston  <bje@redhat.com>
1272         * config/tc-m32r.c (m32r_handle_align): Declare type of fragp.
1274 2001-01-22  Kazu Hirata  <kazu@hxi.com>
1276         * config/tc-alpha.c: Fix formatting.
1278 2001-01-19  Kazu Hirata  <kazu@hxi.com>
1280         * config/tc-alpha.c: Fix formatting.
1282 2001-01-18  Kazu Hirata  <kazu@hxi.com>
1284         * config/tc-alpha.c: Fix formatting.
1286 2001-01-18  Nick Clifton  <nickc@redhat.com>
1288         * config/tc-arm.c (ldm_flags): Remove redundant bit from "fa" and
1289         "da" flags.
1290         (stm_flags): Remove redundant bit from "ed" and "da" flags.
1292 2001-01-18  Alexandre Oliva  <aoliva@redhat.com>
1294         * configure.in (cpu_type, arch): Match i386 too.
1295         * configure: Rebuilt.
1297 2001-01-16  Kazu Hirata  <kazu@hxi.com>
1299         * config/tc-i386.c: Fix formatting.
1301 2001-01-16  Alan Modra  <alan@linuxcare.com.au>
1303         * config/tc-hppa.c (tc_gen_reloc): Use SEGREL32 instead of DIR32
1304         relocs for .PARISC.unwind section.
1306         * config/tc-hppa.c (pa_build_unwind_subspace): Build unwind
1307         depending on section flags, not just for .text.
1309 2001-01-15  Jim Wilson  <wilson@redhat.com>
1311         * config/tc-ia64.c (ia64_flush_insns): Handle unwind directives
1312         not immediately followed by an instruction.
1314 2001-01-15  Kazu Hirata  <kazu@hxi.com>
1316         * config/tc-m68hc11.c: Fix formatting.
1318 2001-01-15  Nick Clifton  <nickc@redhat.com>
1320         * symbols.c (colon): Change 'already defined symbol' from a
1321         fatal error to an ordinary error.  There is no reason why this
1322         error should be fatal.
1324         * message.c (as_fatal): Delete output file, if one has been
1325         created.
1327 2001-01-14  Alan Modra  <alan@linuxcare.com.au>
1329         * config/tc-hppa.h (TARGET_FORMAT): Add hppa-linux variants.
1331 2001-01-14  Kazu Hirata  <kazu@hxi.com>
1333         * config/tc-alpha.c: Fix formatting.
1334         * config/tc-arc.c: Likewise.
1335         * config/tc-arc.h: Likewise.
1336         * config/tc-d10v.c: Likewise.
1337         * config/tc-i370.c: Likewise.
1338         * config/tc-i386.c: Likewise.
1339         * config/tc-i960.c: Likewise.
1340         * config/tc-m68k.c: Likewise.
1341         * config/tc-ppc.c: Likewise.
1342         * config/tc-sparc.c: Likewise.
1343         * config/tc-tahoe.c: Likewise.
1344         * config/tc-vax.c: Likewise.
1346         * config/tc-arc.c: Fix formatting.
1348         * config/tc-arc.c: Fix formatting.
1350 2001-01-14  Alan Modra  <alan@linuxcare.com.au>
1352         * config/tc-hppa.c (pa_build_unwind_subspace): Use SEGREL32 for
1353         both 32 and 64 bit ELF.
1355         * config/tc-hppa.c (pa_ip): Store `a' flag in bit zero of operand
1356         and don't bother storing `m' for "ce" completer.  Tidy handling of
1357         'J' and 'K' operands to suit.  Handle '<' and '>' operands.
1359 Sun Jan 14 00:36:42 MET 2001  Jan Hubicka  <jh@suse.cz>
1361         * config/tc-i386.h (TARGET_MACH): New macro.
1362         (i386_mach): Declare.
1363         * config/tc-i386.c (i386_mach): New function.
1365 2001-01-13  Philip Blundell  <philb@gnu.org>
1367         * doc/as.texinfo: Fix spelling and cross-references.
1369         * doc/c-arm.texi: Fix typos.  Say that `;' is a line separator
1370         character for all systems, not just GNU/Linux.  Make it explicit
1371         that `-k' doesn't affect code generation, just ELF flags.
1373 Sat Jan 13 01:47:35 MET 2001  Jan Hubicka <jh@suse.cz>
1375         * config/tc-i386.c (md_assemble): Check cpu_flags even for nullary
1376         instructions.
1378 2001-01-12  Frank Ch. Eigler  <fche@redhat.com>
1380         * cgen.c (gas_cgen_finish_insn): Call dwarf2_emit_insn.
1382 2001-01-12  Nick Clifton  <nickc@redhat.com>
1384         * as.c (print_args): Update copyright date to 2001.
1386 2001-01-12  Peter Targett  <peter.targett@arccores.com>
1388         * doc/c-arc.texi: New file.
1389         Some sections to be expanded.
1391 2001-01-12  Alan Modra  <alan@linuxcare.com.au>
1393         * config/tc-i386.c (md_longopts): Recognize "--64" only for ELF.
1394         (md_parse_option): Always accept "--32".
1396 2001-01-11  Peter Targett  <peter.targett@arccores.com>
1398         * as.h (TC_ARC): Ensure struc-symbol.h included.
1399         * as.c (dwarf2dbg.h): Include to remove implicit declaration
1400         warnings.
1401         * struc-symbol.h (SYMBOLS_NEED_BACKPOINTERS): Define.
1402         (TARGET_SYMBOL_FIELDS) added.
1404         * doc/Makefile.am (CPU_DOCS): Added c-arc.texi.
1405         * doc/c-arc.texi: New file.
1406         Some sections to be expanded.
1407         * doc/as.texinfo: Update command-line options.
1408         Removed outdated text for ARC dependant features, instead include
1409         text from above file.
1411         * config/obj-elf.h (ELF_TARGET_SYMBOL_FIELDS): Define local flag.
1412         (TARGET_SYMBOL_FIELDS): Alias to previous definition.
1413         (targ-cpu.h) header.
1414         * config/tc-arc.h:
1415         * config/tc-arc.c: New updated configuration for
1416         ARC, including selection of core variants, and extensibility of
1417         instructions, registers etc. through directives.
1419         * config/tc-arc.c (arc_extinst): Minor corrections for
1420         error messages.
1421         (arc_common) Likewise. Make alignment argument optional for local
1422         symbols also, with default of zero.
1424 2001-01-11  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
1426         * config/tc-m68hc11.c (md_estimate_size_before_relax): Fix
1427         STATE_INDEXED_OFFSET when the symbol is undefined (16-bit offset).
1428         (build_indexed_byte): Don't relax indexed byte, use 16-bit offset
1429         and fix_new_exp() instead.
1430         (md_convert_frag): For indexed post byte use the symbol value
1431         rather than the displacement.
1432         (md_relax_table): Fix indexed offset relax.
1434 2001-01-11  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
1436         * config/tc-m68hc11.c (md_estimate_size_before_relax):Don't
1437         relax weak symbols.
1438         (relaxable_symbol): New function.
1440 2001-01-11  Andreas Jaeger  <aj@suse.de>
1442         * config/tc-i386.h (TC_RELOC_GLOBAL_OFFSET_TABLE): Removed, it's
1443         not used anywhere.
1445 2001-01-10  Nick Clifton  <nickc@redhat.com>
1447         * config/tc-arm.c (arm_fix_adjustable): Define for OBJ_COFF.
1448         * config/tc-arm.h (obj_fix_adjustable): Define for OBJ_COFF
1450 2001-01-10  Nick Clifton  <nickc@redhat.com>
1452         * symbols.c (DOLLAR_LABEL_CHAR): New constant - the magic
1453         character used to dollar local symbols.
1454         (LOCAL_LABEL_CHAR): New constant - the magic character used to
1455         local label symbols.
1456         (dollar_label_name): Use DOLLAR_LABEL_CHAR.
1457         (fb_label_name): Prefix local labels with LOCAL_LABEL_PREFIX,
1458         if defined.
1459         Use LOCAL_LABEL_CHAR.
1460         (decode_local_label_name): Skip LOCAL_LABEL_PREFIX.
1461         Use DOLLAR_LABEL_CHAR and LOCAL_LABEL_CHAR.
1462         (S_IS_LOCAL): Use DOLLAR_LABEL_CHAR and LOCAL_LABEL_CHAR.
1464 2001-01-08  Bo Thorsen  <bo@suse.de>
1466         * config/tc-i386.c (i386_immediate, i386_displacement):
1467         GOTPCREL check fix.
1469 2001-01-07  Ian Lance Taylor  <ian@zembu.com>
1471         * doc/c-i386.texi (i386-Arch): Remove spaces incorrectly inserted
1472         in last change.
1474 2001-01-07  Philip Blundell  <philb@gnu.org>
1476         * doc/as.texinfo (Bug Reporting): Update email address for
1477         reports.
1478         * README: Likewise.
1480 Sat Jan  6 13:33:10 MET 2001  Jan Hubicka  <jh@suse.cz>
1482         * configure.in: Define DEFAULT_ARCH for i386.
1483         * config/tc-i386.c (md_assemble): Return after the error message;
1484         move testing for 64bit operands to proper place.
1486 2001-01-06  Jan Hubicka <jh@suse.cz>, Andreas Jaeger  <aj@suse.de>
1488         * doc/as.texinfo: Document '#' as comment character for i386 and
1489         x86_64. Add AMD x86-64 into menu of machine dependent information.
1491         * doc/c-i386.texi: Document x86_64 extensions.
1493 Fri Jan  5 13:26:42 MET 2001  Jan Hubicka  <jh@suse.cz>
1495         * config/tc-i386.c (md_assemble): Handle third byte of the opcode as prefix.
1497 Thu Jan  4 22:25:26 MET 2001  Jan Hubicka  <jh@suse.cz>
1499         * config/tc-i386.c (cpu_arch): Add Pentium4 and modify sledgehammer entry.
1500         * NEWS: Add note about Pentium4 support.
1502 Wed Jan  3 17:26:32 MET 2001  Jan Hubicka  <jh@suse.cz>
1504         * config/tc-i387.c (pi, pte, pt): Update.
1505         (type_names): Add new types.
1507 Wed Jan  3 16:26:52 MET 2001  Jan Hubicka  <jh@suse.cz>
1509         * config/tc-i386.h (CpuK6, CpuAthlon, CpuSledgehammer, CpuMMX, Cpu3dnow,
1510         CpuUnknown): Renumber
1511         (CpuP4, CpuSSE2): New.
1512         (CpuUnknownFlags): Add CpuP4 and CpuSSE2
1514 2001-01-03  Philip Blundell  <pb@futuretv.com>
1516         * config/tc-alpha.c (alpha_force_relocation): Handle vtable
1517         relocs.
1518         (alpha_fix_adjustable): Likewise.
1519         (md_apply_fix): Likewise.
1521 2000-12-31  H.J. Lu  <hjl@gnu.org>
1523         * listing.c (listing_message): Allocate string only if it is
1524         used.
1526         * configure: Rebuild.
1528 2000-12-31  Hans-Peter Nilsson  <hp@bitrange.com>
1530         * doc/internals.texi (Relaxing with a table) <after relaxation>:
1531         Point out caveats with generating fixups for the opcode in a frag.
1533 Sat Dec 30 19:02:48 MET 2000  Jan Hubicka  <jh@suse.cz>
1535         * configure.in: Add support for x86_64 and x86_64-*-linux-gnu*
1536         * NEWS: Add x86_64.
1538 2000-12-29  H.J. Lu  <hjl@gnu.org>
1540         * listing.c (calc_hex): Print the variable part only if the
1541         fragment type is rs_fill.
1543 2000-12-29  Hans-Peter Nilsson  <hp@bitrange.com>
1545         * doc/internals.texi (tc_conditional_pseudoop,
1546         TC_LINKRELAX_FIXUP): Fix typos.
1548 2000-12-28  Richard Henderson  <rth@redhat.com>
1550         * write.c (subsegs_finish): Fix thinko last change -- don't
1551         "optimize" the alignment == 0 case.
1553 2000-12-28  Richard Henderson  <rth@redhat.com>
1555         * as.h (rs_align_test): New.
1556         * frags.c (NOP_OPCODE): Move default from read.c.
1557         (MAX_MEM_FOR_RS_ALIGN_CODE): New default.
1558         (frag_align_code): New.
1559         * frags.h (frag_align_code): Declare.
1560         * read.c (NOP_OPCODE): Remove.
1561         (do_align): Use frag_align_code.
1562         * write.c (NOP_OPCODE): Remove.
1563         (get_recorded_alignment): New.
1564         (cvt_frag_to_fill): Handle rs_align_test.
1565         (relax_segment): Likewise.
1566         (subsegs_finish): Align last subseg in section to the
1567         section alignment.  Use frag_align_code.
1568         * write.h (get_recorded_alignment): Declare.
1569         * config/obj-coff.c (size_section): Handle rs_align_test.
1570         (fill_section, fixup_mdeps): Likewise.
1571         (write_object_file): Use frag_align_code.
1573         * config/tc-alpha.c (alpha_align): Use frag_align_code.
1574         (alpha_handle_align): New.
1575         * config/tc-alpha.h (HANDLE_ALIGN): New.
1576         (MAX_MEM_FOR_RS_ALIGN_CODE): New.
1578         * config/tc-i386.h (md_do_align): Use frag_align_code.
1579         (MAX_MEM_FOR_RS_ALIGN_CODE): New.
1581         * config/tc-ia64.c (ia64_md_do_align): Don't do code alignment.
1582         (ia64_handle_align): New.
1583         * config/tc-ia64.h (HANDLE_ALIGN): New.
1584         (MAX_MEM_FOR_RS_ALIGN_CODE): New.
1586         * config/tc-m32r.c (m32r_do_align): Remove.
1587         (m32r_handle_align): New.
1588         (fill_insn): Use frag_align_code.
1589         * config/tc-m32r.h (md_do_align): Remove.
1590         (HANDLE_ALIGN, MAX_MEM_FOR_RS_ALIGN_CODE): New.
1591         * config/tc-m88k.c, config/tc-m88k.h: Similarly.
1592         * config/tc-mips.c, config/tc-mips.h: Similarly.
1594         * config/tc-sh.c (sh_cons_align): Use rs_align_test.
1595         (sh_handle_align): Likewise.  Handle rs_align_code.
1596         (sh_do_align): Remove.
1597         * config/tc-sh.h (md_do_align): Remove.
1598         (MAX_MEM_FOR_RS_ALIGN_CODE): New.
1600         * config/tc-sparc.c (sparc_cons_align): Use rs_align_test.
1601         (sparc_handle_align): Likewise.  Handle rs_align_code.
1602         * config/tc-sparc.h (md_do_align): Remove.
1603         (MAX_MEM_FOR_RS_ALIGN_CODE): New.
1605 2000-12-22  DJ Delorie  <dj@redhat.com>
1607         * config/tc-d10v.c (md_assemble): set prev_seg and prev_subseg
1608         when we assemble the first half of a pair.
1610 2000-12-22  H.J. Lu  <hjl@gnu.org>
1612         * config/tc-i386.c (reloc): Update the macro for non-bfd
1613         assembler.
1614         (BFD_RELOC_X86_64_GOTPCREL): Set to 0 for non-bfd assembler.
1616 2000-12-22  H.J. Lu  <hjl@gnu.org>
1618         * dwarf2dbg.c (dwarf2_finish): Remove #if BFD_ASSEMBLER.
1620 Wed Dec 20 14:21:22 MET 2000  Jan Hubicka  <jh@suse.cz>
1622         * config/tc-i386.h (i386_target_format): Define even for ELFs.
1623         (QWORD_MNEM_SUFFIX): New macro.
1624         (CpuK6,CpuAthlon,CpuSledgehammer, Cpu64, CpuNo64, CpuUnknownFlags):
1625         New macros
1626         (CpuMMX,CpuSSE,Cpu3dnow, CpuUnknown): Renumber.
1627         (IgnoreSize, DefaultSize, No_?Suf, FWait, IsString, regKludge, IsPrefix,
1628         ImmExt): Renumber.
1629         (Size64, No_qSuf, NoRex64, Rex64): New macros.
1630         (Reg64, Imm32S, Imm64, Disp32S, Disp64): New macros.
1631         (Imm8, Imm8S, Imm16, Imm32, Imm1, BaseIndex, Disp8, Disp16, Disp32,
1632         InOutPortReg,ShiftCount, Control, Debug, Test, FloatReg, FloatAcc,
1633         SReg2, SReg3, Acc, JumpAbsolute, RegMMX, RegXMM, EsSeg, InvMem):
1634         Renumber.
1635         (Reg, WordReg): Add Reg64.
1636         (Imm): Add Imm32S and Imm64.
1637         (EncImm): New.
1638         (Disp): Add Disp64 and Disp32S.
1639         (AnyMem): Add Disp32S.
1640         (RegRex, RegRex64): New macros.
1641         (rex_byte): New type.
1642         * config/tc-i386.c (set_16bit_code_flag): Kill.
1643         (fits_in_unsigned_long, fits_in_signed_long): New functions.
1644         (reloc): New parameter "signed"; support x86_64.
1645         (set_code_flag): New.
1646         (DEFAULT_ARCH): New macro; default to "i386".
1647         (default_arch): New static variable.
1648         (struct _i386_insn): New fields Operand_PCrel; rex.
1649         (flag_16bit_code): Kill; All tests replaced to "flag_code == CODE_64BIT"
1650         (flag_code): New enum and static variable.
1651         (use_rela_relocations): New static variable.
1652         (flag_code_names): New static variable.
1653         (cpu_arch_flags): Default to CpuUnknownFlags|CpuNo64.
1654         (cpu_arch): Add "sledgehammer"; Add CPUAthlon to Athlon and CpuK6 to
1655         K6 and Athlon.
1656         (i386_align_code): Return plain "nop" for x86_64.
1657         (mode_from_disp_size): Support Disp32S.
1658         (smallest_imm_type): Support Imm32S and Imm64.
1659         (offset_in_range): Support size of 8.
1660         (set_cpu_arch): Do not clobber to Cpu64/CpuNo64.
1661         (md_pseudo_table): Add "code64"; use set_code_flat.
1662         (md_begin): Emit sane error message on hash failure.
1663         (tc_i386_fix_adjustable): Support x86_64 relocations.
1664         (md_assemble): Support QWORD_MNEM_SUFFIX, REX registers,
1665         instructions supported on particular arch just partially,
1666         output of 64bit immediates, handling of Imm32S and Disp32S type.
1667         (i386_immedaite): Support x86_64 relocations; support 64bit constants.
1668         (i386_displacement): Likewise.
1669         (i386_index_check): Cleanup; support 64bit addresses.
1670         (md_apply_fix3): Support x86_64 relocation and rela.
1671         (md_longopts): Add "32" and "64".
1672         (md_parse_option): Add OPTION_32 and OPTION_64.
1673         (i386_target_format): Call even for ELFs; choose between
1674         elf64-x86-64 and elf32-i386.
1675         (i386_validate_fix): Refuse GOTOFF in 64bit mode.
1676         (tc_gen_reloc): Support rela relocations and x86_64.
1677         (intel_e09_1): Support QWORD.
1679 2000-12-15  Diego Novillo  <dnovillo@redhat.com>
1681         * config/tc-i386.c (intel_e09_1): Only flag as a memory operand if
1682         it's not an offset expression.
1683         (intel_e10_1): Ditto. Also, if the operand is an offset expression,
1684         keep the braces '[' and ']' in the output string.
1685         (intel_e11): Ditto. Also remove comparison intel_parser.op_modifier
1686         != FLAT. There is no such op_modifier.
1688 2000-12-14  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
1690         * dwarf2dbg.c: If we don't have <limits.h>, try including <sys/param.h>
1691         if we have it.
1693 2000-12-13  Kazu Hirata  <kazu@hxi.com>
1695         * as.h: Fix formatting.
1696         * cgen.h: Likewise.
1697         * dwarf2dbg.c: Likewise.
1698         * input-scrub.c: Likewise.
1699         * read.h: Likewise.
1701 2000-12-13  Mark Elbrecht  <snowball3@bigfoot.com>
1703         * configure.in (i386-*-msdosdjgpp): Set bfd_gas to yes.
1704         configure: Regenerate.
1706 2000-12-13  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
1708         * dwarf2dbg.c: #include <limits.h> only if it exists.
1710 2000-12-13  Rodney Brown  <RodneyBrown@mynd.com>
1712         * config/tc-hppa.c (pa_ip): Correct CHECK_FIELD typo.
1713         (md_apply_fix): Here too.
1715 2000-12-12  Jim Wilson  <wilson@redhat.com>
1717         * config/tc-ia64.h (ia64_init): Add prototype.
1719 2000-12-12  H.J. Lu  <hjl@gnu.org>
1721         * dwarf2dbg.c: Enabled only if BFD_ASSEMBLER is defined.
1723         * read.h (outputting_stabs_line_debug): Change it to int.
1724         * stabs.c (outputting_stabs_line_debug): Likewise.
1726 2000-12-12  Geoffrey Keating  <geoffk@redhat.com>
1728         * config/obj-bout.c (obj_crawl_symbol_chain): Don't take
1729         the address of a function result.
1731 2000-12-12  Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>
1733         * config/tc-ppc.c (md_pseudo_table): Add .file and .loc.
1734         (md_assemble): Call dwarf2_emit_insn.
1735         (shlib): Fix typo SHILB -> SHLIB.
1736         (md_parse_option): Likewise.
1737         (ppc_elf_validate_fix): Likewise:
1738         * config/tc-ppc.h (DWARF2_LINE_MIN_INSN_LENGTH): New.
1740 2000-12-12  Nick Clifton  <nickc@redhat.com>
1742         * cgen.h: Fix formatting.
1743         * input-scrub.c: Fix formatting.
1744         * macro.c: Fix formatting.
1745         * config/tc-mips.c: Fix formatting.
1746         * doc/c-mips.texi: Fix formatting.
1748 Mon Dec 11 14:35:42 MET 2000  Jan hubicka  <jh@suse.cz>
1750         * config/tc-i386.c (md_assemble): Refuse 's' and 'l' suffixes in the intel
1751         mode; convert 'd' suffix to 's' or 'l'; remove all DWORD_MNEM_SUFFIX
1752         references.
1753         (intel_e09_1): Convert QWORD to 'l' suffix for FP operations; refuse
1754         otherwise.
1755         * config/tc-i386.h (DWORD_MNEM_SUFFIX): Kill.
1756         (No_dSuf): Kill.
1758         * i386.h (*_Suf): Remove No_dSuf.
1759         (d_suf, wld_Suf,sld_Suf, sldx_Suf, bwld_Suf, d_FP, sld_FP, sldx_FP)
1760         Remove.
1761         (i386_optab): Remove 'd' in the suffixes.
1763 2000-12-06  Mark Elbrecht  <snowball3@bigfoot.com>
1765         * config/tc-i386.c (T_SHORT): Undefine before defining.
1767 2000-12-05  Kazu Hirata  <kazu@hxi.com>
1769         * config/tc-mips.c: Fix formatting.
1771 2000-12-04  Matthew Hiller  <hiller@redhat.com>
1773         * config/tc-d10v.c (flag_allow_gstabs_packing): New variable.
1774         (md_longopts): New options --gstabs-packing, --no-gstabs-packing.
1775         (md_show_usage): Ditto.
1776         (md_parse_option): Ditto.
1777         (d10v_cleanup): Writes pending instruction only if
1778         ! outputting_stabs_line_debug || ! flag_allow_gstabs_packing.
1779         Fix compile time warning messages.
1781         * doc/c-d10v.texi: Documents new options.
1783 2000-12-04  Matthew Hiller  <hiller@redhat.com>
1785         * stabs.c (outputting_stabs_line_debug): New variable.
1786         (stabs_generate_asm_lineno): Set outputting_stabs_line_debug at
1787         function entry and unset at function exit.
1789         * read.h (outputting_stabs_line_debug): New extern declaration.
1791         * as.c: Include dwarf2dbg.h for definition of dwarf2_finish.
1793         * dwarf2dbg.c: Fix compile time warning messages.
1795 2000-12-03  Kazu Hirata  <kazu@hxi.com>
1797         * config/tc-a29k.c: Fix formatting.
1798         * config/tc-alpha.c: Likewise.
1799         * config/tc-arm.c: Likewise.
1800         * config/tc-cris.c: Likewise.
1801         * config/tc-hppa.c: Likewise.
1802         * config/tc-i370.c: Likewise.
1803         * config/tc-i386.c: Likewise.
1804         * config/tc-i860.c: Likewise.
1805         * config/tc-i960.c: Likewise.
1806         * config/tc-ia64.c: Likewise.
1807         * config/tc-m68hc11.c: Likewise.
1808         * config/tc-m68k.c: Likewise.
1809         * config/tc-m88k.c: Likewise.
1810         * config/tc-pj.c: Likewise.
1811         * config/tc-ppc.c: Likewise.
1812         * config/tc-sh.c: Likewise.
1813         * config/tc-sparc.c: Likewise.
1814         * config/tc-tahoe.c: Likewise.
1815         * config/tc-vax.c: Likewise.
1817 2000-12-01  Chris Demetriou  <cgd@sibyte.com>
1819         * config/tc-mips.c (mips_ip): When calculating offsets,
1820         don't accept as constant the difference between the
1821         addresses of symbols in two different sections.
1823         * config/tc-mips.c (macro_build): Add new 'U' and 'J' operand
1824         specifiers.
1825         (validate_mips_insn): Likewise.  Also, update 'B' operand
1826         specifier to use OP_*_CODE20 constants and delete 'm' operand
1827         specifier.
1828         (mips_ip): Remove 'm' operand specifier, add 'U' and 'J'
1829         operand specifiers.  Change warning generated by 'B' operand
1830         specifier to reflect its new multi-purpose usage.
1832         * config/tc-mips.c (mips_set_options): Use ISA_UNKNOWN rather than
1833         -1, and update comment.
1834         (file_mips_isa): Likewise.
1835         (mips_cpu): Use CPU_UNKNOWN rather than -1, and update comment.
1836         (ISA_HAS_COPROC_DELAYS, ISA_HAS_64BIT_REGS, gpr_interlocks): Use
1837         ISA_* constants rather than hard-coded numbers.
1838         (mips_cpu_info): New structure.
1839         (mips_cpu_info_table): New table describing CPU and ISA names
1840         and numbers.
1841         (mips_cpu_info_from_name, mips_cpu_info_from_isa,
1842         mips_cpu_info_from_cpu): New functions.
1843         (mips_isa_to_str): New function to get string for ISA name.
1844         (mips_cpu_to_str): Convert to use mips_cpu_info_from_cpu, and
1845         return const char *.
1846         (md_begin): Redo CPU and ISA selection logic, using
1847         mips_cpu_info_from_*.  Convert to use ISA_* constants rather
1848         than hard-coded numbers.
1849         (append_insn, mips_emit_delays, macro, macro2): Convert to use
1850         ISA_* constants rather than hard-coded numbers.
1851         (mips_ip): Convert to use mips_isa_to_str to get ISA name.
1852         (md_longopts): Delete OPTION_NO_MIPS32.
1853         (md_parse_option): Convert to use ISA_* constants rather than
1854         hard-coded numbers.  Make OPTIONS_MIPS32 case treat MIPS32
1855         as an ISA.  Delete OPTION_NO_MIPS32 case.  Convert OPTION_MCPU
1856         to use strcasecmp to recognize "default" and to use
1857         mips_cpu_info_from_name to get CPU numbers from argument.
1858         (md_show_usage): Move -mips32 so it's with the rest of the ISA
1859         flags.  Change 4Kc, 4Kp and 4Km CPU entries to just be
1860         mips32-4k.
1861         (s_mipsset): Accept ISA value 32.
1862         * doc/as.texinfo: Clean up MIPS options summary slightly,
1863         remove -no-mips32.  Add note about -mips4 and -mips32
1864         specifying those ISA levels.  Delete -mips32 and -no-mips32
1865         cpu flag descriptions.
1866         * doc/c-mips.texi: Add -mips32 to list of ISA switches.  Clean
1867         up the supported CPU switch list, and replace 4Kc, 4Km, and
1868         4Kp entries with a single mips32-4k entry.  Note that you can
1869         use ".set mips32".
1871         * config/tc-mips.c (ISA_HAS_64BIT_REGS): Add checks for ISA_MIPS5 and
1872         ISA_MIPS64.
1873         (md_longopts, OPTION_MIPS5, OPTION_MIPS64): Add options for
1874         -mips5 and -mips64.
1875         (md_parse_option): Add cases for OPTION_MIPS5 and
1876         OPTION_MIPS64.
1877         (md_show_usage): Mention -mips5 and -mips64 arguments.
1878         (s_mipsset): Add cases for MIPS5 and MIPS64.
1879         (mips_cpu_info_table): Add entries for MIPS5 and MIPS64 ISAs
1880         and pseudo-CPUs.
1881         * doc/as.texinfo: Mention -mips5 and -mips64 options
1882         and their meanings.
1883         * doc/c-mips.texi: Likewise.  Also update introduction
1884         and ".set" usage information.
1886         * config/tc-mips.c (md_show_usage): Add "sb1" to the
1887         CPU list.
1888         (mips_cpu_info_table): Add SB-1 entries.
1889         * doc/c-mips.texi: Add "sb1" to the list of CPUs
1890         known to the -mcpu option.
1892         * doc/as.texinfo: Correct description of MIPS -mcpu
1893         option, by copying some of the text from doc/c-mips.texi.
1895 2000-12-01      Joel Sherrill <joel@OARcorp.com>
1897         * configure.in (arm-*-rtems*, a29k-*rtems*, h8300-*-rtems*):
1898         New targets.
1899         (sparc*-*-rtemself*, sparc*-*-rtemsaout*): New targets.
1900         (sparc*-*-rtems*): Switched from a.out to ELF.
1901         * configure: Regenerate.
1902         * config.in: Regenerate.
1903         * Makefile.in: Regenerate.
1904         * aclocal.m4: Regenerate.
1905         * po/gas.pot: Regenerate.
1907 2000-11-30  Philip Blundell  <pb@futuretv.com>
1909         * config/obj-coff.c (obj_coff_weak): Use S_SET_WEAK if it exists,
1910         even in non BFD_ASSEMBLER case.
1912 2000-11-30  Diego Novillo  <dnovillo@redhat.com>
1914         * config/tc-i386.c (md_assemble): Swap i.disp_relocs when using intel
1915         syntax.
1917 2000-11-29  Richard Henderson  <rth@redhat.com>
1919         * dwarf2dbg.c: Rewrite from scratch.  Queue all debugging output
1920         until dwarf2_finish; use relaxation to get cross-fragment offsets;
1921         thread multiple subsegments properly; handle multiple code
1922         sections properly; emit proper compilation unit info for assembler
1923         generated debugging.
1925         * as.h (enum _relax_state): Add rs_dwarf2dbg.
1926         * dwarf2dbg.h (struct dwarf2_line_info): Remove filename.
1927         (dwarf2dbg_estimate_size_before_relax): Declare.
1928         (dwarf2dbg_relax_frag, dwarf2dbg_convert_frag): Declare.
1929         * write.c: Include dwarf2dbg.h.
1930         (cvt_frag_to_fill): Handle rs_dwarf2dbg.
1931         (relax_segment): Likewise.
1933 2000-11-28  Hans-Peter Nilsson  <hp@bitrange.com>
1935         * config/tc-sh.c (md_convert_frag) <undefined symbol, conditional
1936         jump>: Use as_bad_where instead of as_bad.  Tweak error message
1937         accordingly.  Stabilize frag by updating fix part and resetting
1938         variant part.
1939         <undefined symbol, unconditional jump>: Ditto.
1940         (sh_elf_cons): Cast *input_line_pointer to unsigned char when
1941         indexing is_end_of_line[].
1942         (md_assemble): Initialize size to 0.
1943         (md_section_align): Mark parameter seg as unused.
1944         (parse_reg): Parse names case-insensitively.
1946 2000-11-28  Kazu Hirata  <kazu@hxi.com>
1948         * config/obj-aout.h: Fix formatting.
1949         * config/obj-bout.h: Likewise.
1950         * config/obj-coff.c: Likewise.
1951         * config/obj-coff.h: Likewise.
1952         * config/obj-elf.h: Likewise.
1953         * config/obj-som.h: Likewise.
1954         * config/obj-vms.c: Likewise.
1955         * config/obj-vms.h: Likewise.
1956         * config/tc-h8300.h: Likewise.
1957         * config/tc-ns32k.h: Likewise.
1958         * config/tc-sparc.h: Likewise.
1959         * config/tc-tic54x.h: Likewise.
1960         * config/tc-z8k.h: Likewise.
1962 2000-11-28  Nick Clifton  <nickc@redhat.com>
1964         * doc/as.1 (COPYING): Mention that the GNU Free Documentation
1965         License is present in the sources, but not the output, and
1966         also available from the GNU website.
1967         (GNU Free Documentation License): Comment out this section.
1969 2000-11-28  Hans-Peter Nilsson  <hp@axis.com>
1971         * Makefile.am (CPU_OBJ_VALID): Add case to filter out invalid coff
1972         targets.  Remove i860 from valid a.out targets.
1973         * Makefile.in: Regenerate.
1975         * config/tc-cris.c: Include dwarf2dbg.h.
1976         (md_pseudo_table): Add .file and .loc.
1977         (md_assemble): Call dwarf2_emit_insn if generating ELF.
1978         (s_cris_file, s_cris_loc): New.
1979         * config/tc-cris.h (DWARF2_LINE_MIN_INSN_LENGTH): Define.
1980         * Makefile.am: Regenerate dependencies.
1981         * Makefile.in: Regenerate.
1983 2000-11-28  Alan Modra  <alan@linuxcare.com.au>
1985         * expr.c (STANDARD_MUL_PRECEDENCE): Correct value.
1986         (MRI_MUL_PRECEDENCE): Likewise.
1987         (op_rank): Fix a comment typo.
1989 2000-11-26  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
1991         * config/tc-m68hc11.c (build_indexed_byte): Print the offset in
1992         the error message.
1993         (get_operand): Fix analysis for movw/movb instructions.
1995 2000-11-24  Nick Clifton  <nickc@redhat.com>
1997         * configure.in (xscale-elf): Add target.
1998         (xscale-coff): Add target.
1999         * configure: Regenerate.
2001         * config/tc-arm.c (ARM_EXT_V5E): New ARM architecture
2002         extenstion.
2003         (ARM_EXT_XSCALE): New ARM architecture extension.
2004         (ARM_LONGMUL): Rename to ARM_EXT_LONGMUL.
2005         (ARM_HALFWORD): Rename to ARM_EXT_HALFWORD.
2006         (ARM_THUMB): Rename to ARM_EXT_THUMB.
2007         (ARM_ARCH_V4): Remove processor from architecture.
2008         (ARM_ARCH_3M): New architecutre definition.
2009         (ARM_ARCH_V5TE): New architecutre definition.
2010         (ARM_ARCH_XSCALE): New architecutre definition.
2011         (CPU_DEFAULT): Allow to be defaulted to XScale.
2012         (atpcs): New boolean variable.
2013         (ldr_flags): Support 'd' flag for double word loads.
2014         (str_flags): Support 'd' flag for double word stored.
2015         (do_mia): New function.
2016         (do_mar): New function.
2017         (do_mra): New function.
2018         (do_pld): New function.
2019         (do_ldrd): New function.
2020         (do_blx): New function.
2021         (do_bkpt): New function.
2022         (do_clz): New function.
2023         (do_lstc2): New function.
2024         (do_cdp2): New function.
2025         (do_t_blx): New function.
2026         (do_t_bkpt): New function.
2027         (do_smla): New function.
2028         (do_smlal): New function.
2029         (do_smul): New function.
2030         (do_qadd): New function.
2031         (do_co_reg2c): New function.
2032         (LONGEST_INSN): Redefine to 7.
2034         * doc/c-arm.texi: Document -mxscale, -mmarmv5te and -matpcs
2035         command line switches.
2037 2000-11-22  Jim Wilson  <wilson@redhat.com>
2039         * config/tc-ia64.c (pseudo_func): Add missing initializers.
2040         (struct rsrc): Make line unsigned.
2041         (gr_values): Add missing initializer.
2042         (SLOT_NUM_NOT_SET): Add unsigned cast.
2043         (ia64_elf_section_flags, output_vbyte_mem, count_output, dot_radix,
2044         dot_fframe, dot_vframe, dot_vframesp, dot_vframepsp, dot_save,
2045         dot_restore, dot_restorereg, dot_restorereg_p, dot_handlerdata,
2046         dot_unwentry, dot_altrp, dot_saveg, dot_savef, dot_saveb, dot_savegf,
2047         dot_spill, dot_spillreg, dot_spillreg_p, dot_label_state,
2048         dot_copy_state, dot_unwabi, dot_personality, dot_proc, dot_body,
2049         dot_prologue, dot_endp, dot_regstk, dot_psr, dot_alias, dot_ln,
2050         dot_reg_val, dot_entry, dot_mem_offset, ia64_init, mark_resource,
2051         md_undefined_symbol, md_apply_fix3, tc_gen_reloc, ia64_md_do_align):
2052         Add ATTRIBUTE_UNUSED to unused parameters.
2053         (convert_expr_to_ab_reg): Add parens.
2054         (convert_expr_to_xy_reg): Add parens.  Comment out >= REG_GR test.
2055         (dot_prologue): Initialize grsave when declared.
2056         (md_pseudo_table): Add missing initializers.
2057         (operand_match): Add casts to bfd_vma.
2058         (emit_one_bundle): Delete unused local prev.  Make required_template
2059         unsigned.
2060         (specify_resource): Cast i to unsigned.
2061         (note_register_values): Use fprintf_vma.
2062         (print_dependency): Likewise.
2064 2000-11-21  Jim Wilson  <wilson@redhat.com>
2066         * config/tc-ia64.c (generate_unwind_image): Call record_alignment
2067         for unwind info section.
2068         (dot_endp): Likewise for unwind section.
2070         * config/tc-ia64.c (emit_one_bundle): Pass size of 8 not 4 to
2071         fix_new_exp.
2073 2000-11-21  Jakub Jelinek  <jakub@redhat.com>
2075         * config/tc-sparc.c (md_pseudo_table): Add .file and .loc.
2076         (output_insn): Call dwarf2_emit_insn.
2077         * config/tc-sparc.h (DWARF2_LINE_MIN_INSN_LENGTH): New.
2079 2000-11-17  Richard Henderson  <rth@redhat.com>
2081         * ehopt.c (eh_frame_code_alignment): New arg `in_seg', update all
2082         callers.  Don't switch segments.  Expect CIE == -1 in .debug_frame.
2083         (check_eh_frame): Handle .eh_frame and .debug_frame concurrently.
2085 2000-11-17  Nick Clifton  <nickc@redhat.com>
2087         * config/tc-arm.c (md_pseudo_table): Add support for .line and
2088         .file pseudo ops.
2090 2000-11-17  Richard Henderson  <rth@redhat.com>
2092         * config/tc-i386.c (md_pseudo_table): Add .file and .loc.
2094 2000-11-17  Richard Henderson  <rth@redhat.com>
2096         * dwarf2dbg.c (dwarf2_gen_line_info): Early out for no line number.
2097         * config/obj-elf.h (ECOFF_DEBUGGING) [TC_ALPHA]: Adjust for
2098         tri-state definition of alpha_flag_mdebug.
2099         * config/tc-alpha.c (alpha_flag_mdebug): Init to -1.
2100         (s_alpha_file): Store first .file directive.
2101         (s_alpha_stab): New.
2102         (md_pseudo_table): Add stabs and stabn.
2104 2000-11-17  Richard Henderson  <rth@redhat.com>
2106         * config/tc-i386.c (md_assemble): Call dwarf2_emit_insn.
2108 2000-11-17  Richard Henderson  <rth@redhat.com>
2110         * as.c (debug_type): Init to DEBUG_UNSPECIFIED.
2111         (main): Call dwarf2_finish.
2112         * as.h (debug_type): Clarify documentation of the meaning
2113         of this variable.
2114         * dwarf2dbg.c (DWARF2_LINE_MIN_INSN_LENGTH): Default to 1.
2115         (print_stats): Fix parenthesis problem.
2116         (now_subseg_size): New.
2117         (dwarf2_finish): Use it.  If DEBUG_DWARF2, emit bits for .debug_info.
2118         (dwarf2_directive_file): Don't set debug_type.
2119         (dwarf2_where): Honor DEBUG_DWARF2 first.
2120         (dwarf2_emit_insn): Renamed from dwarf2_generate_asm_lineno;
2121         do nothing if not emitting dwarf2 debug info, or no work.
2122         * dwarf2dbg.h (dwarf2_emit_insn): Update.
2123         * ecoff.c (add_file): Turn on DEBUG_ECOFF only if DEBUG_UNSPECIFIED.
2124         (ecoff_new_file): Likewise.
2125         * read.c (generate_lineno_debug): Kill ecoff hackery.  Update
2126         commentary wrt dwarf2.
2128         * config/tc-alpha.c (alpha_adjust_symtab_relocs): Add
2129         ATTRIBUTE_UNUSED as needed.
2130         (emit_insn): Call dwarf2_emit_insn.
2131         (s_alpha_file): New.
2132         (s_alpha_loc): New.
2133         (s_alpha_coff_wrapper): Don't handle them.
2134         (md_pseudo_table): Update for .file and .loc.
2135         * config/tc-alpha.h (DWARF2_LINE_MIN_INSN_LENGTH): New.
2137         * config/tc-arm.c (output_inst): Update for dwarf2_emit_insn;
2138         don't protect with debug_type.
2139         * config/tc-hppa.c (md_assemble): Likewise.
2140         * config/tc-m68hc11.c (m68hc11_new_insn): Likewise.
2141         * config/tc-mn10300.c (md_assemble): Likewise.
2142         * config/tc-sh.c (md_assemble): Likewise.
2143         * config/tc-v850.c (md_assemble): Likewise.
2145         * config/tc-arm.c (arm_end_of_source): Remove.
2146         * config/tc-hppa.c (pa_end_of_source): Remove.
2147         * config/tc-m68hc11.c (m68hc11_end_of_source): Remove.
2148         * config/tc-mn10300.c (mn10300_finalize): Remove.
2149         * config/tc-sh.c (sh_finalize): Remove.
2150         * config/tc-v850.c (sh_finalize): Remove.
2152         * config/tc-arm.h (md_end): Remove.
2153         * config/tc-hppa.h (md_end): Remove.
2154         (DWARF2_LINE_MIN_INSN_LENGTH): New.
2155         * config/tc-m68hc11.h (md_end): Remove.
2156         * config/tc-mn10300.h (md_end): Remove.
2157         * config/tc-sh.h (md_end): Remove.
2158         * config/tc-v850.h (md_end): Remove.
2160         * config/tc-ia64.c (emit_one_bundle): Don't protect
2161         dwarf2 bits with debug_type.
2162         (md_assemble): Likewise.
2163         (ia64_end_of_source): Don't call dwarf2_finish.
2165 2000-11-16  Jim Wilson  <wilson@redhat.com>
2167         * config/tc-ia64.c (errata_nop_necessary_p): Abort if general regno
2168         >= 128 instead of > 128.  Abort if predicate regno is >= 64 instead of
2169         > 16.
2171 2000-11-16  H.J. Lu  <hjl@gnu.org>
2173         * config/obj-elf.c (obj_elf_symver): Don't check the missing
2174         version name.
2176 2000-11-15  Kazu Hirata  <kazu@hxi.com>
2178         * config/tc-tic30.c: Fix formatting.
2179         * config/tc-tic80.c: Likewise.
2180         * config/tc-v850.c: Likewise.
2181         * config/tc-vax.c: Likewise.
2182         * config/tc-w65.c: Likewise.
2183         * config/tc-z8k.c: Likewise.
2185 2000-11-14  DJ Delorie  <dj@redhat.com>
2187         * config/tc-v850.c: Support dwarf2.
2188         * config/tc-v850.h: Ditto.
2190         * config/tc-v850.c (cons_fix_new_v850): Don't rely on
2191         parse_cons_expression_v850 to initialize hold_cons_reloc.
2193 2000-11-15  Bernd Schmidt  <bernds@redhat.com>
2195         * config/tc-ia64.c (struct md): New entries LAST_GROUPS, GROUP_IDX.
2196         (errata_nops_necessary_p): New function.
2197         (emit_one_bundle): Call it.  Update the GROUP_IDX field in struct
2198         md.
2200 2000-11-14  Jim Wilson  <wilson@redhat.com>
2202         * config/tc-ia64.c (ia64_target_format): If EF_IA_64_BE not set, then
2203         return little endian bfd formats.
2205 2000-11-14  Kazu Hirata  <kazu@hxi.com>
2207         * config/aout_gnu.h: Fix formatting.
2208         * config/atof-vax.c: Likewise.
2209         * config/m68k-parse.h: Likewise.
2210         * config/m88k-opcode.h: Likewise.
2211         * config/obj-elf.c: Likewise.
2212         * config/tc-arm.c: Likewise.
2213         * config/tc-cris.c: Likewise.
2214         * config/tc-i386.c: Likewise.
2215         * config/tc-ia64.c: Likewise.
2216         * config/tc-mn10300.c: Likewise.
2217         * config/te-386bsd.h: Likewise.
2218         * config/te-hppa.h: Likewise.
2219         * config/te-nbsd.h: Likewise.
2220         * config/te-ppcnw.h: Likewise.
2221         * config/te-sparcaout.h: Likewise.
2222         * config/te-tmips.h: Likewise.
2223         * config/vax-inst.h: Likewise.
2224         * config/vms-conf.h: Likewise.
2226 2000-11-14  Jakub Jelinek  <jakub@redhat.com>
2228         * config/tc-alpha.c (s_alpha_prologue): Preserve visibility bits.
2230 2000-11-13  H.J. Lu  <hjl@gnu.org>
2232         * config/obj-elf.c (elf_frob_symbol): Support
2233         ".symver name,name2@@@nodename".
2234         (elf_frob_file_before_adjust): Likewise.
2236         * doc/as.texinfo: Updated for ".symver name,name2@@@nodename"
2237         and ".symver name,name2@@@nodename".
2238         Fix a typo.
2240 2000-11-12  H.J. Lu  (hjl@gnu.org)
2242         * config/obj-elf.c (obj_elf_symver): Check missing version
2243         name.
2245 2000-11-12  H.J. Lu  (hjl@gnu.org)
2247         * dwarf2dbg.c (dwarf2_generate_asm_lineno): Use addressT
2248         instead of bfd_vma for non-bfd assemblers.
2250 2000-11-09  Kazu Hirata  <kazu@hxi.com>
2252         * itbl-ops.c: Fix comment typos.
2254 2000-11-08  Jim Wilson  <wilson@redhat.com>
2256         * config/tc-ia64.c (struct unw_rec_list): Add slot_frag field.
2257         (struct unwind): Add next_slot_frag field.
2258         (slot_index): New parameters slot_frag and first_frag.  Add code
2259         to add in frag sizes when different.  Add comments.
2260         (fixup_unw_records): New locals first_frag and last_frag.  Pass new
2261         arguments to slot_index.
2262         (emit_one_bundle): Set slot_frag field.  Set next_slot_number after
2263         loop end.  Set next_slot_frag field.
2265 2000-11-07  H.J. Lu  <hjl@gnu.org>
2267         * doc/as.texinfo (.symver): Updated for versioned symbol
2268         reference.
2270         * obj.h (format_ops): Add the frob_file_before_adjust field.
2272         * config/obj-aout.c (aout_format_ops): Set the
2273         frob_file_before_adjust field to 0.
2274         * config/obj-coff.c (coff_format_ops): Likewise.
2275         * config/obj-ecoff.c (ecoff_format_ops): Likewise.
2277         * config/obj-elf.c (obj_elf_symver): Allow duplicated version
2278         name.
2279         (elf_frob_file_before_adjust): New function to remove unneeded
2280         versioned symbols from the symbol table.
2281         (elf_format_ops): Set the frob_file_before_adjust field to
2282         elf_frob_file_before_adjust.
2284         * config/obj-elf.h (obj_frob_file_before_adjust): Defined if
2285         not defined.
2287         * config/obj-multi.h (obj_frob_file_before_adjust): Defined.
2289 2000-11-07  Peter Targett  <peter.targett@arccores.com>
2291         * gas/config/tc-arc.h: Avoid warnings for LITTLE_ENDIAN and
2292         BIG_ENDIAN macros.
2293         * gas/config/tc-arc.c: Use S_IS_LOCAL to test local symbols.
2294         Fix compile time warning messages.
2296 2000-11-07  Nick Clifton  <nickc@redhat.com>
2298         * stabs.c (generate_asm_file): Increase length of xmalloc'ed
2299         buffer in order to avoid buffer overflows.
2301 2000-11-06  Steve Ellcey <sje@cup.hp.com>
2303         * config/tc-ia64.c (md_shortopts, md_parse_option, md_show_usage):
2304         Change M to m for -milp32 or -mlp64 to match gcc.
2305         (dot_endp): Use bytes_per_address instead of 8.
2306         (emit_one_bundle): Use number_to_chars_littleendian instead of
2307         md_number_to_chars.
2308         (fix_insn): Likewise.
2309         (ia64_init): New function.
2310         (ia64_target_format): New function.
2311         (md_begin): Set endianness, arch, and machine as appropriate.
2312         * config/tc-ia64.h: (TARGET_BYTES_BIG_ENDIAN, md_number_to_chars):
2313         Make these macros depend on TE_HPUX macro.
2314         (TARGET_FORMAT): Define.
2315         (HOST_SPECIAL_INIT): Define.
2316         * config/te-hpux.h: New file.
2317         * configure.in: Add "ia64-*-hpux*" target to configure.
2318         * configure: Regenerate.
2320 2000-11-06  Kazu Hirata  <kazu@hxi.com>
2322         * as.c: Fix formatting.
2323         * dwarf2dbg.c: Likewise.
2324         * input-file.c: Likewise.
2325         * input-file.h: Likewise.
2326         * input-scrub.c: Likewise.
2327         * itbl-ops.c: Likewise.
2328         * listing.c: Likewise.
2329         * macro.h: Likewise.
2330         * messages.c: Likewise.
2331         * read.c: Likewise.
2332         * subsegs.c: Likewise.
2333         * subsegs.h: Likewise.
2334         * write.c: Likewise.
2336 2000-11-06  Nick Clifton  <nickc@redhat.com>
2338         * doc/as.texinfo: Add GNU Free Documentation License.
2339         * doc/gasp.texi:  Add GNU Free Documentation License.
2340         * doc/as.1:  Add GNU Free Documentation License.
2342 2000-11-05  Nick Clifton  <nickc@redhat.com>
2344         * config/tc-arm.c: Add include of "dwarf2dbg.h"
2346 2000-11-02  Per Lundberg  <plundis@chaosdev.org>
2348         * configure.in: Recognise i[3456]86-chaosdev-storm-chaos.
2349         * configure: Regenerate.
2351 2000-11-01  Nick Clifton  <nickc@redhat.com>
2353         * read.c (original_case_string): New global variable.
2354         (read_a_source_file): Copy opcode string into
2355         original_case_string if clobbering the case of the opcode.
2356         * read.h: Export the definition of original_case_string.
2357         * config/tc-arm.c (md_assembler): When parsing a .req
2358         directive use the original opcode string, not the case
2359         clobbered version.
2361 2000-11-02  Nick Clifton  <nickc@redhat.com>
2363         * config/tc-mn10300.c (debug_line): Remove this static
2364         variable.
2365         (md_assemble): Call dwarf2_generate_asm_lineno instead of
2366         dwarf2_where and dwarf2_gen_line_info.
2368 2000-11-02  Theo Honohan  <th@futuretv.com>
2370         * config/tc-arm.c (do_msr): Improve error message.
2372 2000-10-31  Eric Christopher  <echristo@redhat.com>
2374         * config/tc-mn10300.c (md_apply_fix3): Use valuep if fully resolved
2375         or pc-relative, else use fx_offset.
2377 2000-10-31  Jim Wilson  <wilson@redhat.com>
2379         * config/tc-ia64.c (struct md): New field tag_fixups.
2380         (ia64_flush_insns): Handle tag_fixups.  Error if dangling
2381         qualifying predicate.
2382         (emit_one_bundle): Delete spurious multiplication by one.  Handle
2383         tag_fixups.
2384         (ia64_start_line): Error if dangling qualifying predicate.
2385         (defining_tag): New static variable.
2386         (ia64_unrecognized_line, case '['): Parse tags.
2387         (ia64_frob_label): Create tag_fixups.
2388         (md_assemble): Reset md.qp.X_op after using it.
2390 2000-10-31  Kaz Kojima <kkojima@rr.iij4u.or.jp>
2392         * config/tc-sh.c (md_apply_fix [BFD_RELOC_SH_PCDISP12BY2]): Allow 4094.
2394 2000-10-31  Bernd Schmidt  <bernds@redhat.co.uk>
2396         * config/tc-ia64.c (extra_goodness): Only prefer F in slot 1 and B in slot 2.
2398 2000-10-30  Kazu Hirata  <kazu@hxi.com>
2400         * expr.c: Fix formatting.
2401         * flonum-copy.c: Likewise.
2402         * flonum.h: Likewise.
2403         * gasp.c: Likewise.
2404         * hash.c: Likewise.
2406 2000-10-30  Hans-Peter Nilsson  <hp@bitrange.com>
2408         * as.h (OPTION_MD_BASE): Bump to 190.
2409         * as.c (parse_args) <std_longopts>: Add comment about the need to
2410         check OPTION_MD_BASE in as.h.
2412         * config/tc-sh.c (md_apply_fix): For ELF, do not "adjust back" VAL
2413         for weak symbols.
2415 2000-10-27  Nick Clifton  <nickc@redhat.com>
2417         * configure.in (emulations): Add m68hc12.
2418         * configure: Regenerate.
2419         * po/gas.pot: Regenerate.
2421 2000-10-27  Aldy Hernandez  <aldyh@redhat.com>
2423         * config/tc-arm.c (psrs): Remove lowercase versions of spsr* and
2424         cpsr*.
2425         (arm_psr_parse): Handle lowercase CPSR and SPSR.
2427 2000-10-25  Nick Clifton  <nickc@redhat.com>
2429         * dwarf2out.c (dwarf2_generate_asm_lineno): New function: Generate
2430         a DWARF2 line number information sequence.
2432         *dwarf2out.h: Add prototype for dwarf2_generate_asm_lineno.
2434         * read.c (generate_lineno_debug): Update comment describing why
2435         DWARF2 line number debug information is not generated
2436         automatically by this function.
2438         * doc/as.texinfo: Note that --gdwarf2 only works on some targets,
2439         not all.
2441         * config/tc-arm.h (md_end): Define.
2442         (DWARF2_LINE_MIN_INSN_LENGTH): Define.
2444         * config/tc-arm.c (output_inst): Call dwarf2_generate_asm_lineno
2445         if generating DWARF2 line numbers.
2446         (arm_end_of_source): New function.  Call dwarf2_finish if
2447         necessary.
2449         * config/tc-hppa.c (md_assemble): Use dwarf2_generate_asm_lineno.
2450         * config/tc-m68hc11.c (m68hc11_new_insn): Use dwarf2_generate_asm_lineno.
2451         * config/tc-sh.c (md_assemble): Use dwarf2_generate_asm_lineno.
2453 2000-10-25  Diego Novillo  <dnovillo@cygnus.com>
2455         * config/tc-i386.c: Fix prototype declarations for functions taking no
2456         arguments.
2458 2000-10-24  Diego Novillo  <dnovillo@cygnus.com>
2460         * config/tc-i386.c (i386_operand_modifier): Remove.
2461         (build_displacement_string): Remove.
2462         (i386_parse_seg): Remove.
2463         (i386_intel_memory_operand): Remove.
2464         (i386_intel_operand): Re-write using recursive descent parser based
2465         on MASM documentation.
2466         (struct intel_parser_s): New structure.
2467         (intel_parser): New static variable.
2468         (struct intel_token): New structure.
2469         (cur_token, prev_token): New static variables.
2470         (T_NIL): Define.
2471         (T_CONST): Define.
2472         (T_REG): Define.
2473         (T_BYTE): Define.
2474         (T_WORD): Define.
2475         (T_DWORD): Define.
2476         (T_QWORD): Define.
2477         (T_XWORD): Define.
2478         (T_SHORT): Define.
2479         (T_OFFSET): Define.
2480         (T_PTR): Define.
2481         (T_ID): Define.
2482         (intel_match_token): New function.
2483         (intel_get_token): New function.
2484         (intel_putback_token): New function.
2485         (intel_expr): New function.
2486         (intel_e05): New function.
2487         (intel_e05_1): New function.
2488         (intel_e06): New function.
2489         (intel_e06_1): New function.
2490         (intel_e09): New function.
2491         (intel_e09_1): New function.
2492         (intel_e10): New function.
2493         (intel_e10_1): New function.
2494         (intel_e11): New function.
2496 2000-10-20  Jakub Jelinek  <jakub@redhat.com>
2498         * config/tc-sparc.c (sparc_ip): Fix a bug which caused v9_arg_p
2499         instructions to loose any special insn->architecture mask.
2501         * config/tc-sparc.c (v9a_asr_table): Add v9b ASRs.
2502         (sparc_md_end, sparc_arch_types, sparc_arch,
2503         sparc_elf_final_processing): Handle v8plusb and v9b architectures.
2504         (sparc_ip): Handle siam mode operands. Support v9b ASRs (and
2505         request v9b architecture if they are used).
2507 2000-10-18  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
2509         * config/tc-m68k.c: Fix the previous misapplied patch.
2511 2000-10-18  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
2513         * config/tc-m68k.h (RELAX_RELOC_*): New definitions for both
2514         BFD_ASSEMBLER and !BFD_ASSEMBLER.
2515         * config/tc-m68k.c (md_convert_frag_1): Use them instead of
2516         BFD_RELOC_*.
2518 2000-10-17  Kazu Hirata  <kazu@hxi.com>
2520         * debug.c: Fix formatting.
2521         * depend.c: Likewise.
2522         * dwarf2dbg.c: Likewise.
2523         * dwarf2dbg.h: Likewise.
2524         * ecoff.c: Likewise.
2525         * expr.c: Likewise.
2526         * expr.h: Likewise.
2527         * flonum-konst.c: Likewise.
2528         * frags.h: Likewise.
2530 2000-10-17  Chandrakala Chavva  <cchavva@redhat.com>
2532         * as.c: New option OPTION_TARGET_HELP. Prints all target specific
2533         options.
2534         * doc/as.texinfo: Added notes about this new option.
2536 2000-10-16  Hans-Peter Nilsson  <hp@bitrange.com>
2538         * config/tc-sh.c (JREG): Remove.
2539         (md_convert_frag): Remove #if 0:d code using JREG.
2541 2000-10-15  Diego Novillo  <dnovillo@cygnus.com>
2543         * config/tc-i386.c (i386_operand_modifier): Only match
2544         modifiers SHORT and FLAT if they are followed by a space.
2545         (parse_register): When `allow_naked_reg' is set, do not confuse
2546         identifiers that start with a register name with a register.
2548 2000-10-12  Kazu Hirata  <kazu@hxi.com>
2550         * app.c: Fix formatting.
2551         * as.c: Likewise.
2552         * as.h: Likewise.
2553         * bit_fix.h: Likewise.
2554         * cgen.c: Likewise.
2555         * cgen.h: Likewise.
2556         * cond.c: Likewise.
2558 2000-10-11  Alan Modra  <alan@linuxcare.com.au>
2560         * config/obj-elf.c (elf_frob_symbol): Revert 2000-10-07 change.
2562 2000-10-07  Alan Modra  <alan@linuxcare.com.au>
2564         * config/tc-hppa.c (md_apply_fix): Remove plainly wrong assert.
2565         Re-arrange function a little and improve error message.
2567         * write.c (write_relocs): Fix a comment.
2569         * config/obj-elf.c (elf_frob_symbol): Make section syms global on
2570         link-once sections.
2572 2000-10-05  Jim Wilson  <wilson@cygnus.com>
2574         * config/tc-ia64.c (resources_match): Handle IA64_RS_PRr.
2576 2000-10-05  Alan Modra  <alan@linuxcare.com.au>
2578         * config/tc-i386.c: Delete some useless comments, reformat others.
2580         * config/tc-i386.h (TC_FIX_ADJUSTABLE): Add check to cover
2581         non-global syms in linkonce sections.
2583 2000-10-04  Ralf Baechle  <ralf@gnu.org>
2585         * config/tc-ia64.c (operand_match): Don't use // style comments.
2586         * config/tc-i370.c: Likewise.
2588 2000-09-29  Hans-Peter Nilsson  <hp@axis.com>
2590         Changes to handle varying register prefix and user symbol prefix.
2591         * config/tc-cris.c (SYNTAX_RELAX_REG_PREFIX,
2592         SYNTAX_ENFORCE_REG_PREFIX, SYNTAX_USER_SYM_LEADING_UNDERSCORE,
2593         SYNTAX_USER_SYM_NO_LEADING_UNDERSCORE, REGISTER_PREFIX_CHAR): New.
2594         (s_syntax, cris_force_reg_prefix, cris_relax_reg_prefix,
2595         cris_sym_leading_underscore, cris_sym_no_leading_underscore): New.
2596         (demand_register_prefix): New variable.
2597         (md_pseudo_table): New pseudo ".syntax".
2598         (md_longopts): New options --no-underscore and --underscore.
2599         (cris_target_format): Return elf32-us-cris or elf32-cris depending
2600         on symbols_have_leading_underscore.
2601         (get_gen_reg): Accept or require REGISTER_PREFIX_CHAR.
2602         (get_spec_reg): Ditto.
2603         (cris_number_to_imm) <case BFD_RELOC_VTABLE_ENTRY>: Remove FIXME.
2604         Fix formatting.
2605         (md_parse_option) <case 'h' 'H'>: Deprecate; add reference to
2606         --help.
2607         <case OPTION_NO_US, case OPTION_US>: New.
2608         (md_show_usage): Be brief and reformat to match continuation of
2609         --help.
2610         * po/gas.pot: Regenerate.
2612 2000-09-28  Alan Modra  <alan@linuxcare.com.au>
2614         * config/tc-hppa.c (hppa_force_relocation): If OBJ_SOM, don't
2615         force relocs for 12 bit branches.
2616         (md_apply_fix): Similarly, adjust logic here.
2618 2000-09-28  Alan Modra  <alan@linuxcare.com.au>
2620         * config/tc-hppa.c (md_apply_fix): Add fmt assertion.  Don't
2621         adjust for external and weak syms as we will use a reloc.  Allow
2622         for +8 offset when calculating limits of branches.
2623         (hppa_fix_adjustable): Undo 2000-09-23 change.
2624         (hppa_force_relocation): Likewise.  Add fx_addsy assertion.
2625         Correct distance calculation.
2626         (tc_gen_reloc): Print the file name and line number if we can't
2627         handle a fixup.
2629         From John David Anglin <dave@hiauly1.hia.nrc.ca>
2630         * config/tc-hppa.c (nonzero_dibits): Define.
2631         (arg_reloc_stub_needed): Check each arg and return value
2632         separately for zero case.
2633         (pa_align): Declare argument `bytes'.
2635 2000-09-25  Kazu Hirata  <kazu@hxi.com>
2637         * config/tc-cris.c: Fix formatting.
2638         * config/tc-d10v.h: Likewise.
2639         * config/tc-d30v.c: Likewise.
2640         * config/tc-d30v.h: Likewise.
2641         * config/tc-fr30.c: Likewise.
2642         * config/tc-fr30.h: Likewise.
2643         * config/tc-m68k.c: Likewise.
2644         * config/tc-m68k.h: Likewise.
2645         * config/tc-pj.h: Likewise.
2646         * config/tc-ppc.c: Likewise.
2647         * config/tc-ppc.h: Likewise.
2648         * config/tc-sh.c: Likewise.
2649         * config/tc-sh.h: Likewise.
2650         * config/tc-sparc.c: Likewise.
2651         * config/tc-v850.h: Likewise.
2652         * config/tc-vax.h: Likewise.
2653         * config/tc-w65.h: Likewise.
2654         * config/tc-z8k.h: Likewise.
2656 2000-09-23  Alan Modra  <alan@linuxcare.com.au>
2658         * config/tc-hppa.c (hppa_fix_adjustable): Do the external and weak
2659         checks only for ELF.
2660         (hppa_force_relocation): Likewise.
2662 2000-09-22  Jim Wilson  <wilson@cygnus.com>
2664         * config/tc-ia64.c (dv_sem): Add "stop".
2665         (specify_resource, case IA64_RS_PR): Only handles regs 1 to 15 now.
2666         (specify_resource, case IA64_RS_PRr): New for regs 16 to 62.
2667         (specify_resource, case IA64_RS_PR63): Reorder (note == 7) test to
2668         match above.
2669         (mark_resources): Check IA64_RS_PRr.
2671 2000-09-22  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
2673         * config/tc-m68k.c (md_relax_table, m68k_ip, md_convert_frag_1,
2674         md_estimate_size_before_relax): Redesign and clean up the
2675         relaxation mechanism.
2677 2000-09-21  Kazu Hirata  <kazu@hxi.com>
2679         * config/tc-ns32k.c: Fix formatting.
2680         * config/tc-ns32k.h: Likewise.
2682 2000-09-20  Kazu Hirata  <kazu@hxi.com>
2684         * config/tc-m32r.c: Fix formatting.
2685         * config/tc-m32r.h: Likewise.
2686         * config/tc-m68851.h: Likewise.
2687         * config/tc-m68hc11.c: Likewise.
2688         * config/tc-m68hc11.h: Likewise.
2689         * config/tc-m88k.c: Likewise.
2690         * config/tc-mcore.c: Likewise.
2691         * config/tc-mcore.h: Likewise.
2692         * config/tc-mips.c: Likewise.
2693         * config/tc-mips.h: Likewise.
2694         * config/tc-mn10200.h: Likewise.
2695         * config/tc-mn10300.h: Likewise.
2696         * config/tc-tahoe.c: Likewise.
2697         * config/tc-tahoe.h: Likewise.
2699 2000-09-19  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
2701         * config/tc-vax.c (synthetic_votstrs): Remove jbssi and jbcci.
2702         Likewise in relaxation description comments.
2704 2000-09-18  Alan Modra  <alan@linuxcare.com.au>
2706         * config/tc-hppa.h (TC_FORCE_RELOCATION_SECTION): Allow
2707         subtraction of two syms without emitting a relocation.
2709         From  David Huggins-Daines  <dhd@linuxcare.com>
2710         * config/tc-hppa.c (hppa_force_relocation): Force relocations for
2711         global or weak symbols.
2713 2000-09-15  Kazu Hirata  <kazu@hxi.com>
2715         * config/tc-h8300.h: Fix formatting.
2716         * config/tc-h8500.c: Likewise.
2717         * config/tc-h8500.h: Likewise.
2718         * config/tc-hppa.h: Likewise.
2719         * config/tc-i370.h: Likewise.
2720         * config/tc-i386.h: Likewise.
2721         * config/tc-i860.c: Likewise.
2722         * config/tc-i860.h: Likewise.
2723         * config/tc-i960.h: Likewise.
2724         * config/tc-ia64.c: Likewise.
2725         * config/tc-ia64.h: Likewise.
2727 2000-09-14  Kazu Hirata  <kazu@hxi.com>
2729         * config/tc-a29k.c: Fix formatting.
2730         * config/tc-alpha.c: Likewise.
2731         * config/tc-arc.c: Likewise.
2732         * config/tc-arc.h: Likewise.
2733         * config/tc-arm.c: Likewise.
2734         * config/tc-arm.h: Likewise.
2735         * config/tc-avr.c: Likewise.
2736         * config/tc-avr.h: Likewise.
2737         * config/tc-tic30.c: Likewise.
2738         * config/tc-tic30.h: Likewise.
2739         * config/tc-tic54x.c: Likewise.
2740         * config/tc-tic54x.h: Likewise.
2741         * config/tc-tic80.c: Likewise.
2742         * config/tc-tic80.h: Likewise.
2744 2000-09-14  Timothy Wall  <twall@cygnus.com>
2746         * config/tc-ia64.c (specify_resource): For PR%/PR63, note types of
2747         parallel comparisons for later use.
2748         (struct rsrc): Add parallel comparison type.
2749         (resources_match): Skip special cases of PR usage (non-conflicting
2750         parallel compares).
2752 2000-09-13  Kazu Hirata  <kazu@hxi.com>
2754         * config/obj-ecoff.c: Fix formatting.
2755         * config/obj-elf.c: Likewise.
2756         * config/obj-elf.h: Likewise.
2757         * config/obj-evax.h: Likewise.
2758         * config/obj-generic.h: Likewise.
2759         * config/obj-hp300.c: Likewise.
2760         * config/obj-hp300.h: Likewise.
2761         * config/obj-ieee.h: Likewise.
2762         * config/obj-vms.c: Likewise.
2763         * config/obj-vms.h: Likewise.
2765 2000-09-13  Anders Norlander  <anorland@acc.umu.se>
2767         * config/tc-mips.c (md_begin): Recognize 4Kc, 4Km and 4Kp processors.
2768         (md_parse_option): Ditto.
2769         (md_longopts): Add -mips32 option.
2770         (md_show_usage): Document new options.
2771         (mips_ip): Assemble sdbbp 20 bit 'm' args for MIPS32.
2772         (mips_ip): Assemble mfc0 with a sub-selection code.
2773         (validate_mips_insn): Handle 'H' (OP_*_SEL) and 'm' (OP_*_CODE20).
2774         (mips_cpu_to_str): New function.
2775         (mips_ip): Use mips_cpu_to_str instead of printing numeric cpu value.
2776         Use CPU_* defines instead of hardcoded numbers.
2778         * doc/as.texinfo: Document new options.
2779         * doc/c-mips.texi: Ditto.
2781 2000-09-12  Kazu Hirata  <kazu@hxi.com>
2783         * as.h: Fix formatting.
2784         * asintl.h: Likewise.
2785         * bit_fix.h: Likewise.
2786         * config/obj-aout.c: Likewise.
2787         * config/obj-aout.h: Likewise.
2788         * config/obj-bout.c: Likewise.
2789         * config/obj-bout.h: Likewise.
2790         * config/obj-coff.c: Likewise.
2791         * config/obj-coff.h: Likewise.
2792         * dwarf2dbg.h: Likewise.
2793         * expr.h: Likewise.
2794         * flonum.h: Likewise.
2795         * frags.h: Likewise.
2796         * itbl-ops.h: Likewise.
2797         * macro.h: Likewise.
2798         * read.h: Likewise.
2799         * sb.h: Likewise.
2800         * struc-symbol.h: Likewise.
2801         * subsegs.h: Likewise.
2802         * symbols.h: Likewise.
2803         * tc.h: Likewise.
2804         * write.h: Likewise.
2806 2000-09-11  Kazu Hirata  <kazu@hxi.com>
2808         * bignum-copy.c: Fix formatting.
2809         * config/tc-i370.c: Likewise.
2810         * config/tc-i960.c: Likewise.
2811         * config/tc-m68k.c: Likewise.
2812         * ehopt.c: Likewise.
2813         * flonum-copy.c: Likewise.
2814         * flonum-konst.c: Likewise.
2815         * flonum-mult.c: Likewise.
2816         * literal.c: Likewise.
2817         * read.c: Likewise.
2818         * sb.c: Likewise.
2819         * stabs.c: Likewise.
2820         * subsegs.c: Likewise.
2822 2000-09-09  Philip Blundell  <philb@gnu.org>
2824         * configure.in (arm*-*-uclinux*): New target.
2825         * configure: Regenerate.
2827 2000-09-09  Kazu Hirata  <kazu@hxi.com>
2829         * input-file.c: Fix formatting.
2830         * itbl-ops.c: Likewise.
2831         * messages.c: Likewise.
2833 2000-09-08  Philip Blundell  <philb@gnu.org>
2835         * config/tc-arm.c (md_apply_fix3): Correct handling of ADRL when
2836         offset is negative.
2838 2000-09-07  H.J. Lu  <hjl@gnu.org>
2840         * configure.in (AC_ISC_POSIX): Put after AC_CANONICAL_SYSTEM.
2841         * configure: Rebuild.
2843 2000-09-07  Kazu Hirata  <kazu@hxi.com>
2845         * atof-generic.c: Fix formatting.
2846         * config/tc-mips.c: Likewise.
2847         * config/tc-vax.c: Likewise.
2848         * input-scrub.c: Likewise.
2850 2000-09-07  Alexandre Oliva  <aoliva@redhat.com>
2852         * config/tc-sh.h (TARGET_FORMAT): Use sh-linux targets.
2853         * configure.in (sh-*-linux*): Added.
2854         * configure: Rebuilt.
2856 2000-09-06  Kazu Hirata  <kazu@hxi.com>
2858         * config/tc-hppa.c: Fix formatting.
2860         * ecoff.c: Fix formatting.
2862 2000-09-06  Alexandre Oliva  <aoliva@redhat.com>
2864         * configure: Rebuilt with new libtool.m4.
2866 2000-09-05  Kazu Hirata  <kazu@hxi.com>
2868         * cgen.c: Fix formatting.
2869         * config/tc-ia64.c: Likewise.
2871 2000-09-05  Nick Clifton  <nickc@redhat.com>
2873         * aclocal.m4: Regenerate.
2874         * config.in: Regenerate.
2875         * configure: Regenerate.
2876         * po/gas.pot: Regenerate.
2878 2000-09-05  Hans-Peter Nilsson  <hp@axis.com>
2880         * config/tc-cris.c: Correct comment typos.
2882 2000-09-05  Eric Christopher  <echristo@cygnus.com>
2884         * config/tc-mn10300.c: Cleanup.
2885         (md_pcrel_from): Enable.
2887 2000-09-05  Alan Modra  <alan@linuxcare.com.au>
2889         * expr.c (operand): Fix a comment typo.
2890         * write.c (write_relocs): Fix a signed/unsigned warning.
2892         * config/tc-hppa.c (fudge_reg_expressions): New
2893         (hppa_force_reg_syms_absolute): New.
2894         (pa_equ): Allow reg_section expressions.
2895         * config/tc-hppa.c (md_optimize_expr): Define.
2896         (hppa_force_reg_syms_absolute): Prototype.
2898         * config/tc-hppa.c (pa_11_fp_reg_struct): Delete.
2899         (pa_parse_number): Pass in arg to select fp reg parsing.
2900         Return 1 to indicate format checks pass.  If strict, then only
2901         accept a register or register symbol.  Return value in...
2902         (pa_number): New static for pa_parse_number.
2903         (FP_REG_BASE): Define.
2904         (FP_REG_RSEL): Define.
2905         (pre_defined_registers): Apply FP_REG_BASE and FP_REG_RSEL as
2906         appropriate.  White space changes.
2907         (need_pa11_opcode): Don't bother passing any params, get them from
2908         globals instead.
2909         (pa_ip): Modify all calls to pa_parse_number and need_pa11_opcode.
2910         Remove extraneous check in case 'Q'.
2911         (pa_equ): Modify call to pa_parse_number to do strict parsing. If
2912         reg, set section of resulting symbol to reg_section.
2913         (pa_parse_space_stmt): Modify call to pa_parse_number.
2914         (pa_space): Likewise.
2916         * config/tc-hppa.c: (md_apply_fix): Handle vtable relocs.
2917         (hppa_force_relocation): Handle vtable relocs.
2918         (pa_vtable_entry): New.
2919         (pa_vtable_inherit): New.
2920         (md_pseudo_table): Add entries for vtable pseudos.
2921         (hppa_fix_adjustable): Reject reduction of R_PARISC_GNU_VTINHERIT
2922         and R_PARISC_GNU_VTENTRY relocs.  Reject reduction of relocs
2923         against weak syms.
2924         (tc_gen_reloc): Remove ELF_ARG_RELOC_INSN code.
2925         (pa_type_args): Don't call symbol_get_bfdsym multiple times.
2926         Set STT_PARISC_MILLICODE for OBJ_ELF when encountering a
2927         millicode import.
2928         * config/obj-elf.c (obj_elf_type): Allow md_elf_symbol_type to
2929         specify a symbol type.
2931         * config/tc-hppa.h: Reorganize file a little, grouping OBJ_ELF
2932         dependent things together.
2933         (md_elf_symbol_type): Define.
2935         * config/tc-hppa.c (fix_new_hppa): Elide "$PIC_pcrel$0" pseudo
2936         symbol.
2937         * config/tc-hppa.h (tc_frob_symbol): Elide "$PIC_pcrel$0" here too.
2939         * config/obj-elf.h (obj_elf_vtable_inherit): Declare.
2940         (obj_elf_vtable_entry): Declare.
2942         * config/obj-elf.c (obj_elf_vtable_inherit): Return struct fix *
2943         and export function.
2944         (obj_elf_vtable_entry): Similarly.
2945         (elf_pseudo_table): Fix the damage with a cast.
2947 2000-09-03  Richard Henderson  <rth@cygnus.com>
2949         * config/tc-ia64.c (emit_one_bundle): Stop collecting insns
2950         for template selection when a label is needed.
2952 2000-09-02  Kazu Hirata  <kazu@hxi.com>
2954         * config/tc-ia64.c: Fix formatting.
2956 2000-09-02  Nick Clifton  <nickc@redhat.com>
2958         * configure.in: Increase version number to 2.10.91.
2959         * configure: Regenerate.
2960         * aclocal.m4: Regenerate.
2961         * config.in: Regenerate.
2962         * po/gas.pot: Regenerate.
2963         * Makefile.in: Regenerate.
2965 2000-09-01  Alexandre Oliva  <aoliva@redhat.com>
2967         * config/tc-sh.h [OBJ_ELF] (TC_FIX_ADJUSTABLE): Define.
2968         * config/tc-sh.c (md_apply_fix): Map 32-bit relocations that
2969         become PC-relative to BFD_RELOC_32_PCREL.  Reject 16- or 8-bit
2970         similar relocs.
2971         (sh_obj_adjustable): Return 1 for PC-relative offsets used in
2972         branches.
2974 2000-09-01  Niibe Yutaka  <gniibe@m17n.org>, Kaz Kojima  <kkojima@rr.iij4u.or.jp>, Alexandre Oliva  <aoliva@redhat.com>
2976         * config/tc-sh.h (DIFF_EXPR_OK, GLOBAL_OFFSET_TABLE_NAME,
2977         TC_RELOC_GLOBAL_OFFSET_TABLE, TC_RELOC_RTSYM_LOC_FIXUP): Define.
2978         * config/tc-sh.c (sh_elf_cons, sh_elf_suffix): New functions.
2979         [OBJ_ELF] (md_pseudo_table) <long, int, word, short>: Use them.
2980         (GOT_symbol): New variable.
2981         (md_undefined_symbol): Set it.
2983 2000-09-01  Richard Henderson  <rth@cygnus.com>
2985         * config/tc-ia64.c (match): Don't inline.
2986         (extra_goodness): New.
2987         (md_begin): Prefer nop.f and nop.b for best_template.
2989 2000-08-31  Kazu Hirata  <kazu@hxi.com>
2991         * as.c: Fix formatting.
2992         * cond.c: Likewise.
2993         * frags.c: Likewise.
2994         * macro.c: Likewise.
2996 2000-08-31  Eric Christopher  <echristo@cygnus.com>
2998         * config/tc-mn10300.c:  Cleanup and fix warnings.
2999         (md_pseudo_table): Add initializers.
3000         (md_show_usage): Cleanup.
3001         (md_parse_option): Fix warnings.
3002         (md_undefined_symbol): Fix warnings.
3003         (md_conver_frag): Fix warnings.
3004         (tc_gen_reloc): Fix warnings.
3005         (md_apply_fix3): Fix warnings.
3006         (check_operand): Fix warnings.
3008 2000-08-31  Alexandre Oliva  <aoliva@redhat.com>
3010         * acinclude.m4: Include libtool and gettext macros from the
3011         top level.
3012         * aclocal.m4, configure: Rebuilt.
3014 2000-08-30  Mark Hatle  <mhatle@mvista.com>
3016         * config/tc-ppc.c (md_parse_option): Recognize -m405.
3018 2000-08-31  Kazu Hirata  <kazu@hxi.com>
3020         * listing.c: Fix formatting.
3022 2000-08-29  Kazu Hirata  <kazu@hxi.com>
3024         * app.c: Fix a comment typo.  Fix formatting.
3026 2000-08-25  J. David Anglin  <dave@hiauly1.hia.nrc.ca>
3028         * config/tc-vax.c (md_convert_frag): Correctly calculate the pc relative
3029         offset of the target destination for jmp instructions.
3030         (md_assemble): Change mode to VAX_ABSOLUTE_MODE as per comments.
3032 2000-08-24  Hans-Peter Nilsson  <hp@axis.com>
3034         * NEWS: Mention support for CRIS.
3036 Thu Aug 24 20:41:05 2000  Denis Chertykov  <denisc@overta.ru>
3038         * config/tc-avr.h (TC_IMPLICIT_LCOMM_ALIGNMENT): New macros.
3039         Sets `.lcomm' alignment to zero.
3041 2000-08-23  Alexandre Oliva  <aoliva@redhat.com>
3043         * config/tc-i386.h (OBJ_MAYBE_ELF, OBJ_MAYBE_COFF,
3044         TC_FIX_ADJUSTABLE): Define.
3046 2000-08-23  Jim Wilson  <wilson@cygnus.com>
3048         * config/tc-ia64.c (output_unw_records): Set U & E flags only if
3049         unwind.personality_routine is set.
3051 2000-08-23  H.J. Lu  <hjl@gnu.org>
3053         * write.c (TC_FIX_ADJUSTABLE): Remove the duplicate.
3055 2000-08-23  Alexandre Oliva  <aoliva@redhat.com>
3057         * config/tc-i386.h (TC_FIX_ADJUSTABLE): Do *NOT* define if target
3058         environment is pe.
3060 2000-08-22  H.J. Lu  <hjl@gnu.org>
3062         * config.in (STRICTCOFF): New for strict COFF.
3064         * configure.in: Define STRICTCOFF for i386-*-msdosdjgpp*,
3065         i386-*-go32* and i386-go32-rtems*.
3066         * configure: Rebuilt.
3068         * config/obj-coff.c (obj_coff_endef): Follow the historical
3069         behavior if STRICTCOFF is not defined.
3071         * doc/internals.texi: Document STRICTCOFF.
3073 2000-08-22  Alexandre Oliva  <aoliva@redhat.com>
3075         * write.c (TC_FIX_ADJUSTABLE): Define to 1, if not defined.
3076         (fixup_segment) Use it instead of TC_DONT_FIX_NON_ADJUSTABLE.
3077         * config/tc-i386.h (TC_DONT_FIX_NON_ADJUSTABLE): Remove.
3078         <OBJ_ELF, OBJ_COFF, TE_PE> (TC_FIX_ADJUSTABLE): Define.
3079         * config/tc-arm.h (TC_DONT_FIX_NON_ADJUSTABLE): Remove.
3080         <OBJ_ELF> (TC_FIX_ADJUSTABLE): Define.
3081         * config/tc-i960.h, config/tc-m68k.h, config/tc-v850.h:
3082         Likewise.
3084 2000-08-22  Eric Christopher  <echristo@cygnus.com>
3086         * config/tc-mn10300.c: (md_apply_fix): New function.
3087         (mn10300_force_relocation): New function.
3088         (mn10300_fix_adjustable): New function.
3090         * config/tc-mn10300.h: (TC_FORCE_RELOCATION): Define.
3091         (TC_HANDLES_FX_DONE): Define.
3092         (obj_fix_adjustable): Define.
3093         (MD_APPLY_FIX3): Define.
3094         (TC_LINKRELAX_FIXUP): Define.
3096         * write.c: (TC_LINKRELAX_FIXUP):  Define if not
3097         previously defined.
3098         (fixup_segment): Use TC_LINKRELAX_FIXUP.
3100         * doc/internals.texi: Document TC_LINKRELAX_FIXUP.
3102 2000-08-21  Jason Eckhardt  <jle@cygnus.com>
3104         * config/tc-i860.c (md_apply_fix3): Do not insert the immediate
3105         if the fixup resulted in a relocation.
3107 2000-08-18  Nick Clifton  <nickc@redhat.com>
3109         * config/tc-arm.c (decode_shift): Replace as_tsktsk with as_warn.
3110         Make reference to first element of shift_names explicit.
3112 2000-08-18  Alexandre Oliva  <aoliva@redhat.com>
3114         * write.c (fixup_segment) [TC_DONT_FIX_NON_ADJUSTABLE]: Use
3115         obj_fix_adjustable() and tc_fix_adjustable() to tell whether to
3116         add a symbol's address.  Removed all target-specific #ifdefs that
3117         used to accomplished the same.
3118         * config/tc-v850.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
3119         * config/tc-m68k.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
3120         * config/tc-arm.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
3121         * config/tc-i960.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
3122         * config/tc-i386.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
3124 2000-08-17  Kazu Hirata  <kazu@hxi.com>
3126         * dwarf2dbg.c: Fix formatting.
3128 2000-08-17  Nick Clifton  <nickc@redhat.com>
3130         * config/tc-arm.c (decode_shift): Allow illegal shifts by zero
3131         to be recoded as logical shift lefts by zero.
3133 2000-08-16  Jim Wilson  <wilson@cygnus.com>
3135         * config/tc-ia64.c (specify_resource, case IA64_RS_GR): Handle
3136         postincrement modified registers.  Handle IA64_OPND_R3_2 addl
3137         source registers.
3138         (note_register_values): Handle IA64_OPND_R3_2 operands.
3140 2000-08-16  Jason Eckhardt  <jle@cygnus.com>
3142         * config/tc-i860.c (md_operand): Silly typo fixed.
3144 2000-08-16  Nick Clifton  <nickc@redhat.com>
3146         * config/tc-arm.c (struct asm_shift): Delete.
3147         (shift[]): Delete.
3148         (enum asm_shift_index): New.
3149         (struct asm_shift_properties): New.
3150         (struct asm_shift_name): New.
3151         (shift_properties[]); New.
3152         (shift_names[]); New.
3154         (decode_shift): Use new structures.
3155         Issue a warning is "ROR #0" is used.
3156         Issue a warning if "ASR #0" or "LSR #0" is used.
3158         (md_begin): Initialise arm_shift_hsh table from new
3159         asm_shift_name array.
3161 2000-08-16  Jakub Jelinek  <jakub@redhat.com>
3163         * config/tc-sparc.c: Kill all warnings.
3164         (md_parse_option): Set -32/-64 for -xarch=, allow all -A archs
3165         in -xarch= as well.
3166         (md_show_usage): Update usage text.
3168 2000-08-16  Nick Clifton  <nickc@redhat.com>
3170         * config/tc-arm.c (do_bx): Warn about "bx px" not being very
3171         useful.
3173 2000-08-15  Will Cohen  <wcohen@redhat.com>
3175         * config/tc-sh.h (DWARF2_LINE_MIN_INSN_LENGTH): Defined.
3177         * config/tc-sh.c (md_assemble): Changed so debug_type
3178         test performed for ppi_assemble
3179         * config/tc-sh.c: Included dwarf2dbg.h.
3180         (debug_line): Defined.
3181         (md_assemble): Generates dwarf2 line info.
3182         (sh_finalize): New function.  Finalize dwarf2 info.
3183         (assemble_ppi): Returns size of code generated.
3184         (build_Mytes): Returns size of code generated.
3185         (md_pseudo_table): Added "file" and "loc" psuedo ops.
3186         * config/tc-sh.h (md_end): Defined.
3187         (sh_finalize): Declared.
3189 2000-08-15  Alexandre Oliva  <aoliva@redhat.com>
3191         * config/tc-sh.c (md_apply_fix) [BFD_RELOC_32, BFD_RELOC_16]: Use
3192         md_number_to_chars.
3194 2000-08-14  Nick Clifton  <nickc@redhat.com>
3196         * config/tc-arm.c (do_bx): Allow "bx pc".
3198 2000-08-14  Jim Wilson  <wilson@cygnus.com>
3200         * config/tc-ia64.c (md_longopts): Add -mconstant-gp and -mauto-pic.
3201         (md_parse_option):  Add OPTION_MCONSTANT_GP and OPTION_MAUTO_PIC.
3202         (md_begin): Change assignment to md.flag to OR in the new bit.
3204 2000-08-14  Mark Elbrecht  <snowball3@bigfoot.com>
3206         * config/obj-coff.c (obj_coff_endef) [BFD_ASSEMBLER]: Set the debug
3207         flag for storage types C_ARG, C_REGPARM, C_FIELD, C_MOS, C_MOE,
3208         C_MOU, and C_EOS.
3210 2000-08-14  Jason Eckhardt  <jle@cygnus.com>
3212         * NEWS: Mention i860 support.
3214 Mon Aug 14 11:49:12 2000  Jeffrey A Law  (law@cygnus.com)
3216         * config/tc-mn10300.h (DWARF2_LINE_MIN_INSN_LENGTH): Define.
3218 2000-08-14  Andreas Schwab  <schwab@suse.de>
3220         * doc/c-arm.texi (ARM Directives): Fix warnings from makeinfo.
3222 2000-08-11  Andreas Schwab  <schwab@suse.de>
3224         * doc/c-i860.texi (Opcodes for i860): Remove braces from @item
3225         argument.
3227 2000-08-11  Kazu Hirata  <kazu@hxi.com>
3229         * expr.c: Fix formatting.
3230         * config/obj-bout.c: Likewise.
3232 2000-08-10  Jason Eckhardt  <jle@cygnus.com>
3234         * doc/c-i860.texi: Flesh out the i860 section more.
3236 2000-08-10  Kazu Hirata  <kazu@hxi.com>
3238         * symbols.c: Fix formatting.
3239         * expr.c: Likewise.
3241 Wed Aug  9 16:28:21 EDT 2000    Diego Novillo <dnovillo@cygnus.com>
3243         * config/tc-i386.c (md_assemble): Skip suffix check if the opcode
3244         modifier has the IgnoreSize bit set.
3246 2000-08-09  Alan Modra  <alan@linuxcare.com.au>
3248         From  Rodney Brown  <RodneyBrown@mynd.com>
3249         * configure.in: Use elf on Unixware 7 (i586-sco-sysv5uw7.1.0)
3250         * configure: Regenerate.
3252 2000-08-09  Kazu Hirata  <kazu@hxi.com>
3254         * hash.c: Fix formatting.
3255         * gasp.c: Likewise.
3257 2000-08-08  Jason Eckhardt  <jle@cygnus.com>
3259         * config/tc-i860.h: Rework completely for BFD_ASSEMBLER.
3260         (i860_fix_info): New enum.
3261         (MD_APPLY_FIX3): Define.
3262         (WORKING_DOT_WORD): Define.
3263         (TC_HANDLES_FX_DONE): Define.
3264         (DIFF_EXPR_OK): Define.
3265         (LISTING_HEADER): Define.
3266         (TARGET_FORMAT): Select target format based on endian flag.
3267         (TARGET_BYTES_BIG_ENDIAN): Default to little endian.
3268         (target_big_endian): Add external declaration.
3270         * config/tc-i860.c: All existing code reworked completely. Other
3271         new code shown below.
3272         (SYNTAX_SVR4): Define.
3273         (target_warn_expand): New variable.
3274         (md_shortopts): Declare and define (-Qy, -Qn, and -V options).
3275         (md_longopts): Declare and define with new options (-EL, -EB,
3276         and -mwarn-expand).
3277         (md_show_usage): New function.
3278         (md_operand): New function.
3279         (obtain_reloc_for_imm16): New function.
3280         (md_apply_fix3): New function.
3281         (tc_gen_reloc): New function.
3283 2000-08-08  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
3285         * config/tc-m68hc11.c (build_jump_insn): Make sure the
3286         2 bytes of the jump address are in the same frag.
3287         (find): Accept 68hc12 register indirect modes.
3289         * NEWS: Mention 68HC11 & 68HC12 support.
3291 2000-08-07  Richard Henderson  <rth@cygnus.com>
3293         * config/tc-ia64.c (unwind): Add prologue_mask member.
3294         (dot_vframe): Elide psp_gr record if it overlaps prologue_gr.
3295         (dot_save): Likewise for pfs_gr, rp_gr, and preds_gr.
3296         (dot_body): Clear unwind.prologue_mask.
3297         (dot_prologue): Set it.  Accept a register second argument.
3299 2000-08-07  Kazu Hirata  <kazu@hxi.com>
3301         * config/atof-ieee.c: Fix formatting.
3302         * config/atof-tahoe.c: Likewise.
3304 2000-08-06  Nick Clifton  <nickc@cygnus.com>
3306         * config/tc-sparc.c (md_begin): Fix typo in recent formatting
3307         work.
3309         * doc/as.texinfo (Pseudo Ops): Update to include descriptions
3310         of .popsection, .previous, .pushsection, .subsection,
3311         .version, .vtable_entry, .vtable_inherit and .weak.
3313 2000-08-05  Kazu Hirata  <kazu@hxi.com>
3315         * config/tc-cris.c: Fix formatting.
3316         * config/tc-i386.c: Likewise.
3317         * config/tc-sparc.c (sparc_ip): Simplify the code.
3319 2000-08-04  Kazu Hirata  <kazu@hxi.com>
3321         * config/tc-cris.c: Rearrange code for readability.
3322         * config/tc-d10v.c: Fix formatting.
3323         * config/tc-m32r.c: Likewise.
3324         * config/tc-sparc.c: Likewise.
3326 2000-08-02  Jim Wilson  <wilson@cygnus.com>
3328         * config/tc-ia64.c (emit_one_bundle): Call ia64_free_opcode
3329         before ia64_find_opcode.
3330         (md_assemble): Likewise.
3332 2000-08-01  Nick Clifton  <nickc@cygnus.com>
3334         * config/tc-arm.c (do_mrs): Fix skip of 'cpsr_all' flag.
3335         Undo some formatting fixes.
3337 2000-08-01  Kazu Hirata  <kazu@hxi.com>
3339         * config/obj-som.c: Fix formatting.
3340         * config/obj-ieee.c: Likewise.
3341         * config/tc-arm.c: Likewise.
3342         * config/tc-v850.c: Likewise.
3344 2000-08-01  Nick Clifton  <nickc@redhat.com>
3346         * doc/c-m68k.texi (section M680x0 Options): Turn into a table
3347         index by command line option.
3349 2000-08-01  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
3351         * doc/c-m68k.texi (@cindex @samp{--pcrel}): Rewrite option description.
3352         (@node M68K-Branch): Rewrite to match the reality.
3354 2000-07-31  Jason Eckhardt  <jle@cygnus.com>
3356         * doc/c-i860.texi: New file.
3357         * doc/Makefile.am (CPU_DOCS): Add c-i860.texi.
3358         * doc/Makefile.in: Regenerate.
3359         * doc/all.texi: Add I860 as relevant architecture.
3360         * doc/as.texinfo: Include i860 dependent file c-i860.texi.
3362 2000-07-31  Kazu Hirata  <kazu@hxi.com>
3364         * config/tc-d30v.c: Fix formatting.
3366 2000-07-31  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
3368         * config/tc-m68k.c (flag_keep_pcrel, OPTION_PCREL): Add --pcrel option.
3369         (md_convert_frag_1, md_estimate_size_before_relax): When making DBcc
3370         long emit a long branch if available instead of an absolute jump, never
3371         emit absolute jumps for anything with --pcrel.
3373         * doc/c-m68k.texi: Document new command line option.
3375 2000-07-29  Marek Michalkiewicz  <marekm@linux.org.pl>
3377         * config/tc-avr.c: Use PARAMS macro in function declarations.
3378         Don't declare md_pcrel_from_section (already in tc-avr.h).
3379         (avr_operands): Use AVR_UNDEF_P and AVR_SKIP_P macros.
3380         (avr_operand): Don't set (unsigned) op_mask to -1.
3382 2000-07-28  Jason Eckhardt  <jle@cygnus.com>
3384         * configure.in: Add bits for i860-stardent-{sysv4, elf}*.
3385         * configure: Regenerated.
3386         * config/obj-elf.c (obj_elf_type): Recognize a fifth type
3387         of operand to the .type directive (.e.g, "type").
3389 2000-07-28  Alan Modra  <alan@linuxcare.com.au>
3391         * as.h (warn_comment, found_comment, found_comment_file): Declare.
3392         * app.c (do_scrub_chars): Record where first comment found.
3393         * read.c (read_a_source_file): Init found_comment on entry, and
3394         notify whether comments found on exit.
3395         * config/tc-hppa.c (md_shortopts): Add "c".
3396         (md_longopts): Add warn-comment.
3397         (md_parse_option): Handle it.
3398         (md_show_usage): Show available options.
3399         * config/tc-hppa.h (WARN_COMMENTS): Define if TE_LINUX
3401 Thu Jul 27 11:25:01 2000  Andrew Cagney  <cagney@b1.cygnus.com>
3403         * config/tc-mn10300.c (md_convert_frag): Fix printfs.
3404         (tc_gen_reloc): Add cast when assigning bfd_abs_symbol to
3405         sym_ptr_ptr
3406         (md_estimate_size_before_relax): Don't fall off end of function.
3408 2000-07-27  Kazu Hirata  <kazu@hxi.com>
3410         * config/tc-avr.c: Fix formatting.
3411         * config/tc-ns32k.c: Likewise.
3413 2000-07-27  Alan Modra  <alan@linuxcare.com.au>
3415         * config/tc-d10v.c (find_opcode): Remove extraneous `='.
3417 2000-07-27  Kazu Hirata  <kazu@hxi.com>
3419         * config/tc-d10v.c: Fix formatting.
3420         * config/tc-z8k.c: Likewise.
3421         * config/tc-sparc.c: Likewise.
3423 2000-07-26  Dave Brolley  <brolley@redhat.com>
3425         * cgen.c (queue_fixup): Declare opinfo.
3426         (gas_cgen_parse_operand): Mark unused parameters with ATTRIBUTE_UNUSED.
3427         (gas_cgen_md_operand): Ditto.
3428         (gas_cgen_md_apply_fix3): Ditto.
3430 2000-07-24  Mark Elbrecht  <snowball3@bigfoot.com>
3432         * config/obj-coff.c (obj_frob_symbol): Don't merge
3433         labels. Don't merge if the symbol isn't constant. Return
3434         immediately if a symbol is merged.
3436 2000-07-22  Alan Modra  <alan@linuxcare.com.au>
3438         * frags.c (frag_align): Correct absolute section alignment.
3440 2000-07-20  DJ Delorie  <dj@redhat.com>
3442         * config/obj-coff.c (obj_frob_symbol): revert previous change,
3443         it breaks linking against DLLs.
3445 2000-07-20  Hans-Peter Nilsson  <hp@axis.com>
3447         * configure.in: Add CRIS support.
3448         * configure: Regenerate.
3449         * Makefile.am: (CPU_TYPES): Add cris.
3450         (CPU_OBJ_VALID) [aout]: Add cris.
3451         (MULTI_CPU_TYPES): Add cris.
3452         (MULTI_CPU_OBJ_VALID) [aout]: Add cris.
3453         [coff]: Only i386 and mips are valid.
3454         (TARGET_CPU_CFILES): Add config/tc-cris.c.
3455         (TARGET_CPU_HFILES): Add config/tc-cris.h.
3456         (MULTI_CFILES): Add config/e-crisaout.c and config/e-criself.c.
3457         Regenerate dependencies.
3458         * Makefile.in: Regenerate.
3459         * aclocal.m4: Regenerate.
3460         * as.c: Declare crisaout, criself.
3461         * config/tc-cris.h, config/tc-cris.c: New.
3462         * config/e-criself.c, config/e-crisaout.c: New.
3463         * po/POTFILES.in, po/gas.pot: Regenerate.
3465 2000-07-20  Kazu Hirata  <kazu@hxi.com>
3467         * read.c: Fix formatting.
3468         * write.c: Fix formatting.
3470 2000-07-19  H.J. Lu  <hjl@gnu.org>
3472         * sb.c: Include <stdlib.h> if exists for abort ().
3474 2000-07-19  Alan Modra  <alan@linuxcare.com.au>
3476         * config/tc-hppa.c (hppa_fix_adjustable): Correct LR%/RR% comment.
3477         (arg_reloc_stub_needed): #ifdef OBJ_SOM, not #ifdef SOM.
3478         (pa_type_args): Same here.
3480 2000-07-17  Mark Elbrecht  <snowball3@bigfoot.com>
3482         * config/obj-coff.c (obj_frob_symbol): Don't merge labels. Don't
3483         merge if the symbol isn't constant. Don't call S_SET_EXTERNAL if
3484         the storage class is already set.
3486 2000-07-17  Kazu Hirata  <kazu@hxi.com>
3488         * config/tc-m68hc11.c: Fix formatting.
3489         * config/tc-mn10200.c: Likewise.
3490         * config/tc-mn10300.c: Likewise.
3491         * config/tc-pj.c: Likewise.
3492         * config/tc-tic80.c: Likewise.
3493         * config/tc-w65.c: Likewise.
3495 2000-07-17  Frank Ch. Eigler  <fche@redhat.com>
3497         * expr.c (operand): Permit %bin literals if LITERAL_PREFIXPERCENT_BIN
3498         is defined.
3500 2000-07-15  Ian Lance Taylor  <ian@zembu.com>
3502         * doc/c-mips.texi (MIPS Opts): Remove erroneous space after
3503         @code.
3505 2000-07-15  Alan Modra  <alan@linuxcare.com.au>
3507         * config/tc-hppa.c (hppa_fix_adjustable): Use the same checks for
3508         ELF as are used for SOM (except the 32-bit reloc one) to decide
3509         whether a symbol can be reduced to a section symbol.  Expand on
3510         the comment for symbols involved in LR% and RR% expressions.
3512 2000-07-14  Nick Clifton  <nickc@cygnus.com>
3514         * config/tc-mips.c (mips_disable_float_construction): New
3515         static variable.  Set to true if doubles should not be
3516         constructed by loading two single width fp registers with
3517         halves of the value.
3518         (mips_ip): Test mips_disable_float_construction.
3519         (md_longopts): Add command line switches --construct-floats
3520         and --no-construct-floats.
3521         (md_parse_option): Parse new command line options.
3522         (md_show_usage): Describe new command line options.
3524         * doc/c-mips.texi: Document new command line options.
3526 2000-07-13  Koundinya K  <kk@ddeorg.soft.net>
3528         * configure.in: Remove the test /usr/dde for mips-*-sysv4*MP*
3529         * configure: Regenerate.
3531 2000-07-13  Hans-Peter Nilsson  <hp@axis.com>
3533         * configure.in (DEFAULT_EMULATION setting): Revert part of
3534         2000-07-01 change that set te_multi=multi unless set to tmips.
3535         * configure: Regenerate.
3537 2000-07-12  Mark Elbrecht  <snowball3@bigfoot.com>
3539         * config/obj-coff.c (coff_frob_section): Add padding to the last
3540         section when aligning it increases its size.
3542 2000-07-11  Kazu Hirata  <kazu@hxi.com>
3544         * config/tc-tic54x.c: Fix formatting.
3546 2000-07-10  Kazu Hirata  <kazu@hxi.com>
3548         * config/tc-h8500.c: Fix formatting.
3549         * config/tc-tic54x.c: Fix formatting.
3551 2000-07-10  Alan Modra  <alan@linuxcare.com.au>
3553         * config/tc-hppa.c (md_apply_fix): Check fmt 12 and 22 pc-rel
3554         displacements correctly.
3556         * read.h (s_abort): Add ATTRIBUTE_NORETURN.
3558 2000-07-10  Ryan Bradetich  <rbradetich@uswest.net>
3560         * hash.c (hash_insert): Add cast to obstruct_alloc to fix
3561         warning.
3562         (hash_jam): Ditto.
3564 2000-07-09  Alan Modra  <alan@linuxcare.com.au>
3566         From  David Huggins-Daines  <dhd@linuxcare.com>
3567         * config/te-hppalinux64.h: Add a new emulation.
3568         * configure.in (emulations): Add configure bits to support the
3569         64-bit Linux/parisc target.
3570         * configure: Regenerate.
3572         * config/tc-hppa.c (md_parse_option): Support `-V' for ELF.
3573         (md_shortopts): Add `V' for ELF.
3575         * config/tc-hppa.c (arg_reloc_stub_needed): Define as zero except
3576         when SOM or ELF_ARG_RELOC are defined.
3577         (pa_type_args): Only set symbol_arg_reloc_info when SOM or
3578         ELF_ARG_RELOC are defined.
3579         (pa_stringer_aux): Don't pa_check_current_space_and_subspace here..
3580         (pa_stringer): ..Do it here instead.  Fix comment typos.
3581         (hppa_force_relocation): Cast enums to int before comparing with
3582         ints.
3584         From  Ryan Bradetich  <rbradetich@uswest.net>
3585         * config/tc-hppa.c: Removed unneeded libbfd.h to fix macro
3586         redifinition warning.
3587         (md_apply_fix): Added cast from enum to int for fixP->fx_r_type.
3588         (hppa_force_relocation): ditto
3589         (md_apply_fix): Added cast to buf to fix warnings.
3591         * config/tc-hppa.h (pa_define_label, parse_cons_expression_hppa,
3592         cons_fix_new_hppa, hppa_force_relocation): Prototype.
3594         * config/tc-hppa.c (reloc_type): It's an enum for OBJ_ELF.
3595         (R_N0SEL, R_N1SEL): Define only for OBJ_SOM.
3596         (tc_gen_reloc): Make `code' a reloc_type and `codes' a
3597         reloc_type** to avoid warnings in switch.
3598         (md_apply_fix): Make insn, val signed.  Zap buf_wd and read insn a
3599         little earlier instead.
3601         * config/tc-hppa.c (symbol_arg_reloc_info): Define for both som
3602         and elf.
3603         (pa_type_args): Use symbol_arg_reloc_info.
3604         (struct pa_it): Make arg_reloc unsigned int.
3605         (struct hppa_fix_struct): Likewise for fx_arg_reloc.
3606         (pa_text, pa_data, pa_comm): Don't compile for TE_LINUX.
3607         (pa_code): Delete.  pa_text duplicates this function.
3608         (md_pseudo_table): Call obj_elf_text for ".code" if TE_LINUX.
3609         (fix_new_hppa): Argument offset is offsetT, arg_reloc is unsigned
3610         int.
3611         (cons_fix_new_hppa): Actually change selector to e_fsel when
3612         warning about assuming so.
3613         (tc_gen_reloc): More example elf arg reloc code.
3614         (md_apply_fix): Use arg_reloc_stub_needed for elf too.
3615         (hppa_force_relocation): Likewise.
3617         * config/tc-hppa.h: Use TARGET_ARCH_SIZE to select target include
3618         files.
3619         (pa_end_of_source): Prototype.
3620         (hppa_fix_adjustable): Prototype.
3621         (LABELS_WITHOUT_COLONS): Move it..
3622         * config/te-hppa.h: To here.
3624         * config/te-hppa64.h: New file.
3626         * config/tc-hppa.c: Use TARGET_ARCH_SIZE to select target reloc
3627         type.
3628         (md_apply_fix): Pass stdoutput to bfd_hppa_insn2fmt.  Handle
3629         format -10, -16, 16 relocs.
3630         (hppa_elf_mark_end_of_function): Test for null
3631         last_call_info->start_symbol
3633         * config/tc-hppa.c (pa_ip): In case 'V', pass `strict' to
3634         CHECK_FIELD, not INSERT_FIELD_AND_CONTINUE.  Don't pass opcode to
3635         re_assesmble_* functions.  Delete extraneous statements.  Fix
3636         typos in comments.
3637         (md_apply_fix): Compare against 1048575 in case 21.  Don't pass
3638         insn to re_assemble_*.
3640 2000-07-08  Ulf Carlsson  <ulfc@engr.sgi.com>
3642         * doc/internals.texi (Expressions): Fix typo.
3644 2000-07-08  Kazu Hirata  <kazu@hxi.com>
3646         * config/tc-sh.c: Fix formatting.
3647         * config/tc-tic54x.c: Fix formatting.
3648         * depend.c: Fix formatting.
3649         * flonum-konst.c: Likewise.
3650         * flonum-mult.c: Likewise.
3652 2000-07-07  Kazu Hirata <kazu@hxi.com>
3654         * config/tc-sh.c: Fix comments.
3655         * config/obj-vms.c: Fix comments.
3656         * config/tc-a29k.c: Likewise.
3657         * config/tc-alpha.c: Likewise.
3658         * config/tc-h8300.c: Likewise.
3659         * config/tc-h8500.c: Likewise.
3660         * config/tc-i370.c: Likewise.
3661         * config/tc-ia64.c: Likewise.
3662         * config/tc-m68hc11.c: Likewise.
3663         * config/tc-m68k.c: Likewise.
3664         * config/tc-mips.c: Likewise.
3665         * config/tc-ns32k.c: Likewise.
3666         * config/tc-ppc.c: Likewise.
3667         * config/tc-z8k.c: Likewise.
3669 2000-07-06  Mark Elbrecht  <snowball3@bigfoot.com>
3671         * config/obj-coff.c (TC_COFF_SECTION_DEFAULT_ATTRIBUTES): New.
3672         Default to '(SEC_LOAD | SEC_DATA)'.
3673         (obj_coff_section) [BFD_ASSEMBLER]: Use it.
3675         * doc/internals.texi (CPU Backend): Describe
3676         TC_COFF_SECTION_DEFAULT_ATTRIBUTES.
3678 Thu Jul  6 17:20:58 2000  Andrew Cagney  <cagney@b1.cygnus.com>
3680         * as.c (parse_args): NULL terminate the long option list.
3682 Tue Jul  4 14:08:28 2000  Andrew Cagney  <cagney@b1.cygnus.com>
3684         * config/tc-d30v.h: Include "write.h" for fixS.
3685         (d30v_start_line, md_pcrel_from_section): Add function prototypes.
3687 2000-07-05  Nick Clifton  <nickc@cygnus.com>
3689         * config/tc-d30v.c (write_2_short): Further changes to warning
3690         messages produced when combining EITHER_BUT_PREFER_MU attributed
3691         opcodes.
3693 2000-07-05  DJ Delorie  <dj@redhat.com>
3695         * MAINTAINERS: new
3697 2000-07-04  Alexandre Oliva  <aoliva@redhat.com>
3699         * config/tc-arm.c (psrs): Accept combinations of flags.
3701 2000-07-03  Marek Michalkiewicz  <marekm@linux.org.pl>
3703         * config/tc-avr.c: Change _ () to _() around all strings marked
3704         for translation (exception from the usual coding style).
3705         (avr_opt): New struct variable, how the new switches are set.
3706         (OPTION_MMCU): Define as 'm' and actually use.
3707         (md_longopts): Add -mall-opcodes, -mno-skip-bug, -mno-wrap.
3708         (show_mcu_list): New function, display the list of known MCUs.
3709         (md_show_usage): Document the new switches.  Call show_mcu_list.
3710         (avr_set_arch): Change 'm' to OPTION_MMCU.
3711         (md_parse_option): Call show_mcu_list if unknown MCU specified.
3712         Handle the new switches.
3713         (avr_operands): Disable warnings for undefined combinations of
3714         operands if -mall-opcodes.  Disable warnings for skipping two-word
3715         instructions if enhanced core or -mno-skip-bug.
3716         (avr_operand): Accept all addressing modes on avr1 if -mall-opcodes.
3717         (md_apply_fix3): Reject 8K wrap if >8K or -mno-wrap.
3718         (md_assemble): Accept opcodes not supported by MCU if -mall-opcodes.
3719         (avr_ldi_expression): Warn about implicit lo8().
3720         * config/tc-avr.h (md_pcrel_from_section): Add prototype.
3722 2000-07-01  Koundinya K  <kk@ddeorg.soft.net>
3724         * configure.in: Add entry for mips-*-sysv4*MP*
3725         * configure: Rebuild
3726         * config/tc-mips.c (mips_target_format): Return elf32-tradbigmips or
3727         elf32-tradlittlemips for traditional mips targets.
3728         * config/tc-mips.c (md_estimate_size_before_relax): Duplicate the
3729         test for Link Once sections as in adjust_reloc_syms.
3730         * config/te-tmips.h: New file for traditional mips targets. Define
3731         TE_TMIPS.
3733 2000-06-29 Mark Elbrecht <snowball3@bigfoot.com>
3735         * config/obj-coff.c (obj_coff_setcion) [BFD_ASSEMBLER]: If the
3736         flags argument is not present, don't change an existing section's
3737         section's attributes. If the flags argument is present, warn if the
3738         attributes don't match the section's current attributes. When
3739         long section names are supported, set SEC_LINK_ONCE and
3740         SEC_LINK_DUPLICATES_DISCARD for a new .gnu.linkonce section.
3742 Thu Jun 29 21:30:00 2000  Hans-Peter Nilsson  <hp@axis.com>
3744         * config/obj-aout.c (obj_aout_type): Do not ignore for undefined
3745         symbols; create them.
3747 2000-06-29 Mark Elbrecht <snowball3@bigfoot.com>
3749         * write.c (set_segment_vma): New: Set vma and lma for a segment.
3750         (write_object_file) [BFD_ASSEMBLER && OBJ_COFF && TE_GO32]: Use it.
3752 2000-06-27  Aldy Hernandez  <aldyh@redhat.com>
3754         * config/tc-mips.c (mips_ip): handle "(foo-.-4)" type of
3755         expressions.  Ignore the problem when handling 16 bit signed
3756         immediates, because the assembler will take care of the relocation
3757         later.
3759 2000-06-27  Nick Clifton  <nickc@cygnus.com>
3761         * config/tc-d30v.c (write_2_short): Do not allow opcodes with
3762         the EITHER_BUT_PREFER_MU attribute to be combined into a reverse
3763         sequential order, and emit warning messages if the input source
3764         code contains constructs like that, or parallel constructs
3765         containing such opcodes.
3767 2000-06-26  Marek Michalkiewicz  <marekm@linux.org.pl>
3769         * config/tc-avr.c (mcu_types): Rename avr4 to avr5, add avr4.
3770         Add more MCU types for avr4 and avr5.  Replace at94k{10,20,40}
3771         with just at94k.  Change AVR_ISA_85xx back to AVR_ISA_2xxx.
3772         (md_show_usage): Update usage message.
3773         (md_parse_option): Allow redefinition of MCU type within the
3774         same avr[1-5] bfd machine type.  Show both old and new MCU type
3775         in the error message.
3776         (md_apply_fix3): Support 8K wrap if AVR_ISA_MEGA is not set.
3777         Simplify 8K wrap code.
3779 2000-06-25  Kazu Hirata  <kazu@hxi.com>
3781         * config/obj-aout.c: Remove all uses of DEFUN.
3782         * config/obj-ieee.c: Likewise.
3783         * config/tc-sh.c: Fix comment typos.
3784         * config/tc-tahoe.c: Likewise.
3785         * config/tc-vax.c: Likewise.
3786         * config/tc-w65.c: Likewise.
3787         * config/tc-z8k.c: Likewise.
3788         * config/tc-h8300.c (build_bytes): Assemble ldmac correctly.
3790 2000-06-24  DJ Delorie  <dj@cygnus.com>
3792         * config/tc-i386.c (md_estimate_size_before_relax): Revert
3793         more changes from Sept 1999
3794         (tc_i386_fix_adjustable): ditto
3795         (md_apply_fix3): ditto
3797 2000-06-24  Frank Ch. Eigler  <fche@redhat.com>
3799         * cgen.c (expr_jmp_buf_p): New validity flag for expr_jmp_buf.
3800         (gas_cgen_parse_operand): Set it around expression() call.
3801         (gas_cgen_md_operand): Test for it before longjmp().
3803 2000-06-24  Kazu Hirata  <kazu@hxi.com>
3805         * config/tc-h8500.c: Remove all uses of DEFUN.
3806         * config/tc-sh.c: Likewise.
3807         * config/tc-w65.c: Likewise.
3808         * config/tc-z8k.c: Likewise.
3810         * config/tc-h8500.c: Fix typos in comments.
3812 2000-06-23  Frank Ch. Eigler  <fche@redhat.com>
3814         * expr.c (operand): Permit $hex literals if LITERAL_PREFIXDOLLAR_HEX
3815         is defined.
3817 2000-06-23  matthew green  <mrg@redhat.com>
3819         * expr.c (operand): Do not as_bad() if RELAX_PAREN_GROUPING is
3820         defined.  Fix error message for `[' grouping.
3822 2000-06-22  Kazu Hirata  <kazu@hxi.com>
3824         * config/tc-h8300.c: Fix formatting and comment typos.
3826 2000-06-22  Timothy Wall  <twall@cygnus.com>
3828         * config/tc-ia64.c (note_register_values): Move premature QP
3829         notation clearing into the appropriate place.
3831 2000-06-22  Alan Modra  <alan@linuxcare.com.au>
3833         * dep-in.sed: Escape literal `.'s on patterns.  Trim off `../'
3834         first before anything else.  Add bin-bugs.h, emul.h and progress.h
3835         Sort list of files as for $(OBJS) in Makefile.am.
3837         * Makefile.am (DEP): grep for leading `/' in DEPA, and fail if we
3838         find one.  Remake dependencies.
3839         ($(OBJS)): Add bin-bugs.h, emul.h, and progress.h  Sort the list.
3840         * Makefile.in: Regenerate.
3841         * doc/Makefile.in: Regenerate.
3843         * config/tc-i386.c (i386_displacement): Don't assume a constant
3844         displacement is necessarily 16 bits when in 16 bit code mode.
3845         (md_assemble): Instead size the displacement here after we know
3846         for sure that a .code16gcc operand hasn't automatically added
3847         operand size prefixes.
3849 2000-06-21  H.J. Lu  <hjl@gnu.org>
3851         * Makefile.am: Rebuild dependency.
3852         * Makefile.in: Rebuild.
3854 2000-06-21  Kazu Hirata  <kazu@hxi.com>
3856         * config/tc-h8300.c (parse_reg): Make the function static.
3857         (parse_exp): Likewise.
3859 2000-06-20  DJ Delorie  <dj@cygnus.com>
3861         * config/tc-i386.c (tc_i386_fix_adjustable): Revert change from
3862         Sept 1999; RVA relocs need to be treated more like DIR32 relocs
3863         for cygwin import libraries to work properly.
3865 2000-06-20  H.J. Lu  <hjl@gnu.org>
3867         * Makefile.am: Rebuild dependency.
3868         * Makefile.in: Rebuild.
3869         * configure: Likewise.
3870         * doc/Makefile.in: Likewise.
3872 2000-06-20  Timothy Wall  <twall@cygnus.com>
3874         * doc/internals.texi (CPU backend): Add @itemx for
3875         TC_START_LABEL_WITHOUT_COLON.
3876         * doc/c-tic54x.texi: New.
3877         * doc/as.texinfo: Add tic54x features and include primary tic54x
3878         documentation file.
3879         * doc/all.texi: Add C54X.
3880         * doc/Makefile.am (CPU_DOCS): Add c-tic54x.texi.
3881         * doc/Makefile.in: Regenerate.
3882         * configure.in: Add tic54x and define LIBM for tic54x.
3883         * configure: Regenrate.
3884         * config/tc-tic54x.[ch]: New.
3885         * config/obj-coff.h: Add tic54x.
3886         * Makefile.am: (CPU_TYPES): Add tic54x.
3887         (TARGET_CPU_CFILES): Add 'tc-tic54x.c'.
3888         (TARGET_CPU_HFILES): Add 'tc-tic54x.h'.
3889         (as_new_LDADD): Add $(LIBM).
3890         * Makefile.in: Regenerate.
3892 2000-06-18  Stephane Carrez  <stcarrez@worldnet.fr>
3894         * doc/Makefile.am (CPU_DOCS): Added 68hc11 file.
3895         * doc/c-m68hc11.texi: Document 68HC11 and 68HC12 port.
3896         * doc/as.texinfo: Likewise.
3898         * configure, Makefile.in: Regenerate.
3899         * configure.in (emulations): Recognize m6811 and m6812.
3900         * Makefile.am (CPU_TYPES, TARGET_CPU_CFILES, TARGET_CPU_HFILES):
3901         Added files for 68hc11 and 68hc12 assembler.
3902         * config/tc-m68hc11.c: Assembler for 68hc11 and 68hc12.
3903         * config/tc-m68hc11.h: Header definition for that assembler.
3905 2000-06-18  Nick Clifton  <nickc@redhat.com>
3907         * symbols.c (resolve_symbol_value): Use bfd_octets_per_byte
3908         instead of OCTETS_PER_BYTE.
3910         * config/tc-v850.c: Fix compile time warnings.
3911         * config/tc-ppc.c: Fix compile time warnings.
3913 2000-06-18  H.J. Lu <hjl@gnu.org>
3915         * configure.in: Don't emulate i386-pc-pe-coff with i386coff.
3916         * configure: Rebuild.
3918 2000-06-17 Mark Elbrecht <snowball3@bigfoot.com>
3920         * config/obj-coff.c (obj_coff_weak): Typo fix: Change BFD_ASSEMLER
3921         to BFD_ASSEMBLER.
3923 2000-06-16  Nick Clifton  <nickc@cygnus.com>
3925         * config/tc-mips.c (md_parse_option): Accept RM5200,RM5230,
3926         RM5231, RM5261, RM5721 and RM7000 as r5000 cpu variants.
3928         * doc/c-mips.texi: Document newly accepted cpu variants.
3930 2000-06-15  Ulf Carlsson  <ulfc@engr.sgi.com>
3932         * config/tc-mips.h: Remove definition of ONLY_STANDARD_ESCAPES.
3934 2000-06-13  Ulf Carlsson  <ulfc@engr.sgi.com>
3936         * macro.c (getstring): Make it possible to escape the quote
3937         character.
3939 Tue Jun 13 20:58:28 2000  Catherine Moore <clm@redhat.com>
3941         * config/tc-hppa.c (pa_export): Weak symbols can be global.
3943 2000-06-13  H.J. Lu  <hjl@gnu.org>
3945         * configure: Regenerate.
3947 2000-06-09  Alan Modra  <alan@linuxcare.com.au>
3949         * app.c (do_scrub_begin): Don't default lex[';'] as a line
3950         separator.
3951         * doc/internals.texi (line_separator_chars): Semicolon is no
3952         longer a default.  Mention null and newline as defaults.
3954         * read.c (is_end_of_line): Remove ifdef TC_HPPA.
3956         * config/tc-i386.h (line_separator_chars): Explicitly mention `;'
3957         * config/tc-i860.h (line_separator_chars): Likewise.
3958         * config/tc-h8300.c (line_separator_chars): Likewise.
3959         * config/tc-i960.c (line_separator_chars): Likewise.
3960         * config/tc-m68k.c (line_separator_chars): Likewise.
3961         * config/tc-mips.c (line_separator_chars): Likewise.
3962         * config/tc-ns32k.c (line_separator_chars): Likewise.
3963         * config/tc-sparc.c (line_separator_chars): Likewise.
3964         * config/tc-vax.c (line_separator_chars): Likewise.
3966         * config/tc-h8300.c (comment_chars): Use string initialiser.
3967         * config/tc-i960.c (line_comment_chars): Likewise.
3968         * config/tc-z8k.c (comment_chars, line_comment_chars,
3969         line_separator_chars): Likewise.
3971         * config/tc-arm.c (line_separator_chars): Always use `;', not just
3972         for TE_LINUX.
3974 2000-06-08  Nick Clifton  <nickc@cygnus.com>
3976         * config/tc-arm.c (cons_fix_new_arm): Assign correct reloc value
3977         for size 1 fixes.
3979 2000-06-08  David O'Brien  <obrien@FreeBSD.org>
3981         * configure.in (VERSION): Update to show this is the CVS mainline.
3983 2000-06-08  Matthew Jacob  <mjacob@feral.com>
3985         * config/tc-alpha.c (md_undefined_symbol): Properly understand that
3986         $at is the integer register $r28, vs. both $r28 and the floating
3987         point register $f28.
3989 2000-06-08  James E. Wilson  <wilson@cygnus.com>
3991         * config/tc-ia64.c (generate_unwind_image): Call ia64_flush_insns.
3992         (dot_endp): Don't call ia64_flush_insns.
3993         (emit_one_bundle): Don't delete prologue/body records from
3994         unwind_record list in first loop.  Rewrite second loop to account for
3995         this.
3997 2000-06-07  David Mosberger  <davidm@hpl.hp.com>
3999         * config/tc-ia64.c: Add missing prototypes.
4000         (generate_unwind_image): Cast argument to output_unw_records call.
4002 Wed Jun  7 22:44:14 2000  Denis Chertykov  <denisc@overta.ru>
4004         * config/tc-avr.c (avr_operand): fix the formatting of the comment.
4006 Wed Jun  7 21:26:15 2000  Denis Chertykov  <denisc@overta.ru>
4008         * config/tc-avr.c (AVR_ISA_???): moved to include/opcode/avr.h
4009         (REGISTER_P): likewise.
4010         (avr_opcodes): uses include/opcode/avr.h
4011         (avr_operand): enable ld r,Z or st r,Z for at90s1200.
4013 2000-06-04  Alan Modra  <alan@linuxcare.com.au>
4015         * read.c (is_end_of_line): No ';' for TC_HPPA.  Add missing
4016         initializers too.
4018 2000-06-03  H.J. Lu  <hjl@gnu.org>
4020         * read.c (is_end_of_line): Put back `;'.
4022 2000-06-03  Alan Modra  <alan@linuxcare.com.au>
4024         * config/tc-i386.c (md_shortopts): Remove 'm', add 'q' to non-elf.
4026 2000-06-01  Alan Modra  <alan@linuxcare.com.au>
4028         * expr.c (operand): Test is_end_of_line outside switch to catch
4029         line separator chars that are also operators.
4030         (operator): Return O_illegal for line separator chars.
4032         * read.c (is_end_of_line): Use 1 instead of 99.  Don't set `;'
4033         entry (or `!' entry for TC_HPPA).
4035         * config/tc-arm.c (my_get_float_expression): Cast to unsigned char
4036         before indexing is_end_of_line.  Remove redundant check for '\0'.
4037         (fp_op2): Likewise.
4038         * config/tc-h8500.c (md_assemble): Likewise.
4039         * config/tc-mcore.c (md_assemble): Likewise.
4040         * config/tc-tic30.c (tic30_find_parallel_insn): Likewise.
4041         (md_atof): Likewise
4043         * config/tc-m88k.c (s_bss): Cast to unsigned char before indexing
4044         is_end_of_line.
4045         * config/tc-mcore.c (mcore_cons): Likewise.
4046         (mcore_float_cons): Likewise.
4047         (mcore_stringer): Likewise.
4048         * config/tc-tic30.c (tic30_find_parallel_insn): Likewise.
4050 2000-06-01  Scott Bambrough <scottb@netwinder.org>
4052         * config/tc-arm.c (do_mrs): Allow SPSR_BIT to be set correctly.
4054 2000-05-29  Nick Clifton  <nickc@cygnus.com>
4056         * config/tc-sh.c: Fix compile time warning messages.
4058         * config/tc-mips.c: Fix compile time warning messages.
4060 2000-05-29  Philip Blundell  <philb@gnu.org>
4062         * doc/as.texinfo: Update copyright dates.
4063         (Local Labels): Delete misplaced mention of ARM.
4064         * NEWS: Mention ARM ELF support.
4066 2000-05-27  Alexandre Oliva  <aoliva@cygnus.com>
4068         * config/tc-mn10300.c (md_assemble): Copy size to real_size before
4069         it is modified, and use the real_size to compute the frag address
4070         for dwarf2 line info.
4072 2000-05-27  Alan Modra  <alan@linuxcare.com.au>
4074         * Makefile.am (DEP, DEP1, dep, dep-in, dep-am): Use a better sed
4075         line-matching scheme to cope with automake moving variables around.
4076         ($(TARG_CPU_O)): Remove dependency on TARG_CPU_DEP_@target_cpu_type@
4077         * Makefile.in: Regenerate.
4079 2000-05-26  Jakub Jelinek  <jakub@redhat.com>
4081         * config/tc-sparc.c (sparc_relax): New.
4082         (md_longopts): Add -relax and -no-relax options.
4083         (md_parse_options, md_show_usage): Likewise.
4084         (md_apply_fix3): Optimize tail call into branch always if possible.
4086 Thu May  4 15:27:07 2000  Donald Lindsay  <dlindsay@cygnus.com>
4088         * config/tc-d10v.c (write_2_short, parallel_ok, md_assemble,
4089         d10v_cleanup) implement Mitsubishi's newly explained branch-packing
4090         rules, with warning when a GAS statement specifies a packing that
4091         will result in an instruction being squashed.
4092         Added typdef packing_type and enumerals, changed various integer
4093         literals to use the enumerals.
4095 2000-05-24  David Mosberger  <davidm@hpl.hp.com>
4097         * config/tc-ia64.c (dot_restorereg_p): New function.
4098         (md_pseudo_table): Add restorereg.p.
4099         (output_X3_format): Fix typo: record type should be UNW_X3, not UNW_X1.
4100         (output_X4_format): Fix typo: record type should be UNW_X4, not UNW_X2.
4102         * config/tc-ia64.h (unw_record_type): Add unwabi.
4103         (unw_r_record): Rename member MASK to GRMASK.  Add sub-structure
4104         called MASK with members for imask, and the masks produced by
4105         fr_mem, gr_mem, br_mem, and frgr_mem.
4106         (unw_p_record): Add members ABI and CONTEXT.
4107         (unw_x_record): Add member AB.
4108         * config/tc-ia64.c (enum reg_symbol): Add REG_PSP and REG_PRIUNAT
4109         as pseudo-register for use during unwind info generation.
4110         (AR_PFS, AR_LC): New macros.
4111         (enum pseudo_type): Add PSEUDO_FUNC_REG to permit declaring registers
4112         whose names start with an at sign (as in "@priunat").
4113         (pseudo_func): Add "svr4", "hpux", "nt" constants and "priunat"
4114         register.
4115         (unwind_list, unwind_tail, current_unwind_entry, proc_start,
4116         proc_end, unwind_info, personality_routine): Consolidate into
4117         "unwind" structure to reduce offset-table use.  Add member
4118         NEXT_SLOT_NUMBER to track the slot number for the next instruction
4119         to be emitted.
4120         (output_R1_format, output_R3_format, output_P3_format,
4121         output_P6_format): Initialize R with zero to reduce compiler warnings.
4122         (output_P7_format): Ditto.  Add `default' branch to switch
4123         statement to reduce compiler warnings.
4124         (output_P8_format, output_B1_format, output_B4_format): Ditto.
4125         (output_P4_format): Rename 2nd & 3rd arg to IMASK and IMASK_SIZE.
4126         (format_ab_reg): Rename from format_a_b_reg.  Merge A and B args
4127         into single argument.
4128         (output_X1_format, output_X3_format): Initialize R with zero to reduce
4129         compiler warnings.  Merge A and B args into single argument.
4130         (output_X2_format, output_X4_format): Remove unused variable R.  Merge
4131         A and B args into single argument.
4132         (free_record): Removed (wasn't used).
4133         (free_list_records): Also free imasks in prologue records.
4134         (output_prologue, output_prologue_gr): Initialize mask bits to zero.
4135         (output_spill_mask): Remove.
4136         (output_unwabi): New function.
4137         (output_epilogue, output_label_state, output_copy_state): Call
4138         alloc_record.
4139         (output_spill_psprel, output_spill_sprel, output_spill_psprel_p,
4140         output_spill_sprel_p, output_spill_reg, output_spill_reg_p): Add AB
4141         argument.
4142         (process_one_record): New locals FR_MASK and GR_MASK.  Ignore
4143         gr_mem, fr_mem, br_mem, and frgr_mem records and instead emit them
4144         as part of handling the prologue records.  Emit region's imask if
4145         we have one.  Handle unwabi, epilogue, label_state, copy_state,
4146         spill_psprel, spill_sprel, spill_reg, spill_psprel_p,
4147         spill_sprel_p, and spill_reg_p records.
4148         (set_imask, count_bits, slot_index): New function.
4149         (fixup_unw_records): Fix region size computation.  Handle
4150         epilogue, spill_reg, spill_sprel, spill_psprel, spill_reg_p,
4151         spill_sprel_p, and spill_psprel_p records.  Merge mask bits of
4152         frgr_mem, fr_mem, gr_mem, br_mem on a per-region basis and
4153         set_imask accordingly.  Update imask for gr_gr, and br_gr records.
4154         (convert_expr_to_ab_reg, convert_expr_to_xy_reg): New function.
4155         (dot_save): Use manifest constants for applicaton registers.
4156         Handle REG_PR and REG_PRIUNAT.
4157         (dot_restore): Don't just ignore it.
4158         (dot_restorereg): New function..
4159         (generate_unwind_image): Ensure unwind info is a multiple of eight
4160         bytes, not just four bytes.
4161         (dot_handlerdata, dot_unwentry): Demand empty rest of line.
4162         (dot_altrp): Don't just ignore it.
4163         (dot_savemem): New function.  Replaces dot_savesp() and
4164         dot_savepsp().  Use manifest constants for applicaton registers.
4165         Handle REG_PR and REG_PRIUNAT.
4166         (dot_savef): Simplify.
4167         (dot_saveb): Support generation of br_gr.
4168         (dot_spillreg, dot_spillmem, dot_spillreg_p, dot_spillmem_p,
4169          dot_label_state, dot_copy_state): New function.
4170         (dot_unwabi): Don't just ignore it.
4171         (md_pseudo_table): Add restorereg, spillreg, spillsp, spillpsp,
4172         spillreg.p, spillsp.p, spillpsp, label_state, copy_state,
4173         unwabi, vframesp, and vframepsp.  Fix typo alprp->altrp.
4174         (emit_one_bundle): Set slot number for prologue/body records
4175         *before* emitting the first insn.
4176         (emit_one_bundle): Set UNWIND.NEXT_SLOT_NUMBER.
4177         (md_begin): Declare "psp" pseudo-register.
4178         (md_operand): Handle PSEUDO_FUNC_REG.  Fix printing of error message
4179         so we don't get segfault.
4180         (output_psp_sprel): Output sp/psp relative offsets as 4-byte word
4181         counts as required per SW Conventions manual
4182         (output_rp_psprel, output_rp_sprel, output_pfs_psprel,output_pfs_sprel,
4183         output_preds_psprel, output_preds_sprel, output_spill_base,
4184         output_unat_psprel, output_unat_sprel, output_lc_psprel,
4185         output_lc_sprel, output_fpsr_psprel, output_fpsr_sprel,
4186         output_priunat_psprel, output_priunat_sprel, output_bsp_psprel,
4187         output_bsp_sprel, output_bspstore_psprel, output_bspstore_sprel,
4188         output_rnat_psprel, output_rnat_sprel, output_spill_psprel,
4189         output_spill_sprel, output_spill_psprel_p, output_spill_sprel_p):Ditto.
4190         (dot_vframe): Implement.
4191         (dot_vframesp, dot_vframepsp): New function.
4193 Tue May 23 00:57:05 2000  Hans-Peter Nilsson  <hp@axis.com>
4195         * configure.in (i386-*-freebsd a.out entry): Quote properly.
4196         * configure: Regenerate.
4198 2000-05-23  Alan Modra  <alan@linuxcare.com.au>
4200         * config/tc-i386.c (md_assemble): Pass jump reloc in fr_var...
4201         (md_estimate_size_before_relax): so we can use it here instead of
4202         old kludges.  Localise vars to blocks.  Comment.
4204         * frags.c (frag_new): Update fr_var comments.
4205         * frags.h (struct frag): Ditto.
4207 2000-05-22  Richard Henderson  <rth@cygnus.com>
4209         * config/tc-ia64.c (FUNC_PC_RELATIVE): New.
4210         (pseudo_func): Add pcrel.
4211         (operand_match):  Handle IA64_OPND_TGT64.
4212         (build_insn): Likewise.
4213         (md_begin): Initialize pseudo_func[FUNC_PC_RELATIVE].
4214         (ia64_gen_real_reloc_type): Handle FUNC_PC_RELATIVE.
4215         (fix_insn): Handle all three 64-bit relocation types.
4217 Mon May 22 22:43:32 2000  Hans-Peter Nilsson  <hp@axis.com>
4219         * obj.h (struct format_ops): New members begin, app_file,
4220         s_set_other, s_set_desc, s_get_type, s_set_type,
4221         separate_stab_sections, init_stab_section.
4223         * config/obj-multi.h: Update GPL notice to v2.
4224         (obj_begin): New.
4225         (obj_app_file): New.
4226         (S_SET_SIZE): Test s_set_size for NULL before calling.
4227         (S_SET_ALIGN): Similar for s_set_align.
4228         (S_SET_OTHER): New.
4229         (S_SET_DESC): New.
4230         (S_GET_TYPE): New.
4231         (S_SET_TYPE): New.
4232         (SEPARATE_STAB_SECTIONS): New.
4233         (INIT_STAB_SECTION): New.
4234         (EMIT_SECTION_SYMBOLS): New.
4235         (AOUT_STABS) [OBJ_MAYBE_AOUT]: Define.
4237         * config/obj-elf.h: Update GPL notice to v2.
4238         Mention that this file is included from obj-multi.h.
4239         (obj_begin): Wrap definition in ifndef.
4240         (elf_file_symbol): Constify declaration.
4241         (obj_app_file): Ditto.
4242         (SEPARATE_STAB_SECTIONS, INIT_STAB_SECTION, OBJ_PROCESS_STAB):
4243         Wrap in ifndef SEPARATE_STAB_SECTIONS.
4245         * config/obj-elf.c (elf_s_set_other): New.
4246         (elf_file_symbol): Constify argument.
4247         (elf_separate_stab_sections): New.
4248         (elf_init_stab_section): New.
4249         (elf_format_ops): Add new members.  Remove comma at end.
4251         * config/obj-ecoff.c (ecoff_separate_stab_sections): New.
4252         (ecoff_format_ops): Add new fields.  Remove comma at end.
4253         Mention inconsistency for emit_section_symbols.
4255         * config/obj-coff.h (c_dot_file_symbol): Constify declaration.
4257         * config/obj-coff.c (c_dot_file_symbol): Constify argument.
4258         (coff_separate_stab_sections): New.
4259         (coff_format_ops): Add new members.
4261         * config/obj-aout.c (obj_aout_sec_sym_ok_for_reloc): New.
4262         (obj_aout_s_set_other): New.
4263         (obj_aout_s_set_desc): New.
4264         (obj_aout_s_get_type): New.
4265         (obj_aout_s_set_type): New.
4266         (obj_aout_separate_stab_sections): New.
4267         (aout_format_ops): New members added.  Use obj_aout_process_stab,
4268         not 0.  Use obj_aout_sec_sym_ok_for_reloc, not 0.
4269         (obj_aout_frob_symbol): Add ATTRIBUTE_UNUSED to args as
4270         appropriate.
4271         (obj_aout_line, obj_aout_weak, obj_aout_type): Ditto.
4273 2000-05-22  Alan Modra  <alan@linuxcare.com.au>
4275         * config/tc-i386.c (tc_i386_fix_adjustable): Prevent adjustment
4276         for OBJ_MAYBE_ELF too.  Use S_IS_EXTERNAL instead of S_IS_EXTERN.
4277         (md_estimate_size_before_relax): Ensure jumps to weak and
4278         externally visible symbols are relocatable.
4280 Sat May 20 16:41:55 2000  Hans-Peter Nilsson  <hp@axis.com>
4282         * stabs.c (aout_process_stab): Make global.
4283         (s_desc): Add ATTRIBUTE_UNUSED to args as appropriate.
4284         * read.h (aout_process_stab): Declare.
4286         * configure.in (EMULATIONS) [i386aout, i386coff, i386elf]:
4287         Generalize to *aout, *coff *elf.
4288         * configure: Regenerated.
4290         * doc/internals.texi (Object format backend): Say
4291         SEPARATE_STAB_SECTIONS needs to be nonzero, not just defined.
4293         * Makefile.am (TARG_ENV_HFILES): Delete te-multi.h.
4294         * Makefile.in: Regenerated.
4296 2000-05-19  Catherine Moore  <clm@cygnus.com>
4298         * cgen.h (GAS_CGEN_MAX_FIXUPS): Check if already defined.
4300 2000-05-18  Alan Modra  <alan@linuxcare.com.au>
4302         * config/tc-hppa.c (md_apply_fix): Mask out immediate bits of
4303         instruction to reflect change in re_assemble_*.
4305 Thu May 18 10:52:14 2000  Jeffrey A Law  (law@cygnus.com)
4307         * configure.in (hppa-*-hpux11*): If the cpu is hppa*64*, then
4308         build PA64 ELF tools.
4309         * configure: Rebuilt.
4311 2000-05-17  Alan Modra  <alan@linuxcare.com.au>
4313         * Makefile.am: Regenerate dependencies.
4314         * Makefile.in: Regenerate.
4316 2000-05-15  Nick Clifton  <nickc@cygnus.com>
4318         * config/tc-arm.c (struct asm_psr): Add boolean field
4319         distinguishing between CSPR and SPSR.  Rename 'number' field
4320         to 'field'.
4321         (psrs): Rearrange contents to match new asm_psr structure.
4322         (arm_psr_parse): Move next to psr_required_here.  Make it
4323         return an asm_psr structure.
4324         (psr_required_here): Use asm_psr structure returned by
4325         arm_psr_parse.
4326         (do_msr): Reorganise to allow psr_required_here to be called
4327         only once.
4328         (md_undefined_name): Mark 'name' parameter as unused, since
4329         the COFF target does not use it.
4331 2000-05-14  David O'Brien  <obrien@FreeBSD.org>
4333         * config/te-386bsd.h:  Clean up comments to adhere to the GNU coding
4334         standards.
4335         * config/te-aux.h:  Likewise.
4336         * config/te-dpx2.h:  Likewise.
4337         * config/te-go32.h:  Likewise.
4338         * config/te-hp300.h:  Likewise.
4339         * config/te-hppa.h:  Likewise.
4340         * config/te-i386aix.h:  Likewise.
4341         * config/te-ic960.h:  Likewise.
4342         * config/te-interix.h:  Likewise.
4343         * config/te-nbsd532.h:  Likewise.
4344         * config/te-pc532mach.h:  Likewise.
4345         * config/te-ppcnw.h:  Likewise.
4346         * config/te-psos.h:  Likewise.
4347         * config/te-sparcaout.h:  Likewise.
4348         * config/te-sun3.h:  Likewise.
4349         * config/te-sysv32.h:  Likewise.
4351 2000-05-14  Alan Modra  <alan@linuxcare.com.au>
4353         * config/tc-h8300.c (do_a_fix_imm): Don't rely on `short' being 16
4354         bits.  Instead explicitly mask and sign extend.  Do the 8 bit mask
4355         and sign extend without an if statement.
4356         (build_bytes): Likewise.
4358 2000-05-14  Kazu Hirata  <kazu@hxi.com>
4360         * config/tc-h8300.c (do_a_fix_imm): Output a reloc for no
4361         X_add_symbol L_32 case.
4363 2000-05-14  David O'Brien  <obrien@FreeBSD.org>
4365         * config/te-freebsd.h: New file.
4367 2000-05-13  Alan Modra  <alan@linuxcare.com.au>
4369         * asintl.h (gettext, dgettext, dcgettext, textdomain,
4370         bindtextdomain): Replace defines with those from intl/libgettext.h
4371         to quieten gcc warnings.
4373         * NEWS: Mention x86 .arch and -q.
4375         * config/tc-i386.c (quiet_warnings): New.
4376         (md_assemble): Use quiet_warnings.
4377         (md_parse_option): Set quiet_warnings from -q.
4378         (md_show_usage): Mention -q, delete -m.
4379         (flag_do_long_jump): Delete.
4380         (md_parse_option): Remove -m.
4381         (md_show_usage): Remove -m.
4382         (md_create_long_jump): Remove useless flag_do_long_jump code.
4384         * as.c (parse_args): In case OPTION_DEFSYM, use a valueT to hold
4385         the symbol value, and use bfd_scan_vma if BFD_ASSEMBLER.
4387 2000-05-13  Alan Modra  <alan@linuxcare.com.au>
4388             Alexander Sokolov <robocop@netlink.ru>
4390         * doc/c-i386.texi (i386-Arch): New section.
4391         (i386-Syntax): Mention .intel_syntax and .att_syntax.
4393         * config/tc-i386.c (cpu_arch_name, cpu_arch_flags): New.
4394         (smallest_imm_type): Use smallest opcode for shift by one if cpu
4395         architecture has been given and is not 486.
4396         (set_cpu_arch): New.
4397         (md_pseudo_table): Add .arch.
4398         (md_assemble): Warn if cpu architecture has been given and an
4399         unsupported instruction.
4401         * config/tc-i386.h (SMALLEST_DISP_TYPE): Delete.
4402         Move operand_types bit defines after relevant template field.
4403         (template): Add cpu_flags.
4404         (Cpu*): Define.
4405         (arch_entry): New.
4407 2000-05-12  Alexandre Oliva  <aoliva@cygnus.com>
4409         * config/tc-mn10300.h (md_end): Define.
4410         (mn10300_finalize): Declare.
4411         * config/tc-mn10300.c: Include dwarf2dbg.h.
4412         (debug_line): Define.
4413         (md_assemble): Generate dwarf2 line info.
4414         (mn10300_finalize): New function.  Finalize dwarf2 info.
4416 2000-05-11  Ulf Carlsson  <ulfc@engr.sgi.com>
4418         * config/tc-mips.c (md_estimate_size_before_relax): Use the
4419         external version of the relocation for weak symbols.
4421 2000-05-08  David Mosberger  <davidm@hpl.hp.com>
4423         * config/tc-ia64.c (output_P7_format, case mem_stack_f): Output fixed
4424         frame size in units of 16 bytes, as required per SW Conventions manual.
4425         (output_unw_records): Output info-block header as a dword to get
4426         byte-order right.
4428 2000-05-08  Alan Modra  <alan@linuxcare.com.au>
4430         * as.h: #include "file", not <file> on files from ../include.
4431         (as_abort, as_fatal): Add ATTRIBUTE_NORETURN.
4432         * config/tc-m68k.c (m68k_ip): Fix signed/unsigned warnings.
4433         (md_convert_frag): Add ATTRIBUTE_UNUSED.
4434         (tc_coff_symbol_emit_hook): Ditto.
4435         (OPTCOUNT): Cast to int to avoid compiler warning.
4436         (md_begin): Fix signed/unsigned warnings.
4438 2000-05-08  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
4440         * config/tc-m68k.c (md_convert_frag_1): Abort if we end up in the
4441         ABRANCH LONG case for a conditional branch on a 68000.
4442         (md_estimate_size_before_relax): Likewise.  Also handle
4443         flag_short_refs correctly for ABRANCH, BCC68000, and DBCC.
4444         (m68k-ip: case ABSL): Relax absolute references to 16-bit
4445         PC-relative on all CPUs.
4446         (md_estimate_size_before_relax): Likewise.
4448 2000-05-04  Alan Modra  <alan@linuxcare.com.au>
4450         * as.c (parse_args): Just mention current year in printed
4451         copyright message.
4453 2000-05-03  J.T. Conklin  <jtc@redback.com>
4455         * config/tc-ppc.c (pre_defined_registers): Add entries for vector
4456         unit registers.
4457         (md_parse_option): Recognize -m7400.
4459 2000-05-03  Ian Lance Taylor  <ian@zembu.com>
4461         * config/atof-ieee.c (gen_to_words): When adding carry back in,
4462         don't permit lp to become less than the words array.
4464 2000-05-03  Rodney Brown  <RodneyBrown@pmsc.com>
4466         config/tc-mcore.c (md_apply_fix3): BFD_RELOC_MCORE_PCREL_IMM11BY2
4467         Fix little-endian case.
4469 2000-05-03  David O'Brien  <obrien@NUXI.com>
4471         * as.c (parse_args): Update copyright.
4473 2000-05-03  Mark Elbrecht  <snowball3@bigfoot.com>
4475         * gas/config/tc-i386.h (SUB_SEGMENT_ALIGN): If TE_GO32, return 4
4476         for the .bss section too.
4478 2000-05-02  Alan Modra  <alan@linuxcare.com.au>
4480         * configure.in: Set em=linux for hppa-*-linux.
4481         * configure: Regenerate.
4482         * doc/Makefile.in: Regenerate with correct automake.
4484         * frags.c (frag_grow): Sanity check chunk_size.
4486         * config/obj-elf.h: #include "bfd.h" not <bfd.h>
4487         * config/obj-som.h: Likewise.
4488         * config/obj-ieee.h: Likewise.
4490         * config/tc-hppa.h: Test BFD_ARCH_SIZE, not BFD64.
4492         * config/tc-hppa.c (log2): Only compile when OBJ_SOM.
4493         (md_pseudo_table): Fully initialise OBJ_ELF cases.
4494         (fix_new_hppa): Add ATTRIBUTE_UNUSED to args as appropriate.
4495         (pa_ip): low_sign_unext now returns via function value.  Use
4496         re_assemble_* instead of dis_assemble_* and
4497         INSERT_FIELD_AND_CONTINUE combination.  Don't call sign_unext
4498         unnecessarily.
4499         (md_convert_frag): Add ATTRIBUTE_UNUSED to args as appropriate.
4500         (md_section_align, md_parse_option, md_show_usage,
4501         md_undefined_symbol, pa_align, pa_block, pa_brtab, pa_try,
4502         pa_callinfo, pa_code, pa_comm, pa_end, pa_enter, pa_entry,
4503         pa_exit, pa_export, pa_import, pa_label, pa_leave, pa_level,
4504         pa_origin, pa_param, pa_proc, pa_procend, pa_space, pa_spnum,
4505         pa_version, pa_compiler, pa_copyright, pa_data, pa_fill, pa_lsym,
4506         pa_text): Likewise.
4507         (md_apply_fix): Change type of new_val to offsetT.  Delete w1, w2,
4508         w, resulti.  Add insn, val.  Move bfd_get_32 and bfd_put_32
4509         outside of switch.  Correct mask and shifting errors in case 10
4510         and case -11.  In case 21, compare against signed range to suit
4511         hppa_field_adjust changes.  In case 12, use re_assemble_12.  In
4512         case 17 and case 22, use offsetT variable to properly check range.
4513         Use re_assemble_* here too.
4514         (evaluate_absolute): Change type of value to offsetT.  Call
4515         hppa_field_adjust to do the work for us.
4516         (pa_parse_cmpb_64_cmpltr): Delete save_s.
4517         (pa_parse_cmpib_64_cmpltr): Ditto.
4518         (pa_build_unwind_subspace): Delete unused var subseg.  Change type
4519         of i to unsigned int.
4520         (pa_type_args): Conditionally declare symbol if OBJ_SOM.
4521         (pa_end_of_source): Return type is void.
4523 Mon May  1 08:54:23 2000  Catherine Moore  <clm@cygnus.com>
4525         * macro.c (macro_expand_body): Don't prepend macro number with zeroes.
4527 Mon May  1 14:19:39 2000  Denis Chertykov  <denisc@overta.ru>
4529         * config/tc-avr.c: ATTRIBUTE_UNUSED added to the necessary places.
4530         More comments added.
4531         (md_begin): Removed "construct symbols for each register name".
4532         Because register names conflicts with GCC generated function
4533         names.
4534         (avr_operand): Now constant numbers can be used as a register
4535         identifiers (0 as r0, 31 as r31).
4536         (md_assemble): use skip_space () before parsing instruction
4537         operands.
4539 2000-05-01  Alan Modra  <alan@linuxcare.com.au>
4541         * configure.in: Set bfd_gas=yes on i386-*-pe and i386-*-nt* to
4542         ensure all pe targets use bfd.  Remove unnecessary bfd_gas=yes on
4543         arm-*-netbsd* and arm-*-wince as this is set for all arm*.
4544         * configure: Regenerate.
4546 2000-04-29  Andreas Jaeger  <aj@suse.de>
4548         * as.h: Correctly check GCC version.
4550 2000-04-26  David O'Brien  <obrien@FreeBSD.org>
4552         * doc/as.1: Fix unbalanced brackets.
4554         * config/tc-i386.c (comment_chars): Don't use '/' as comment start if
4555         TE_FreeBSD.
4556         (line_comment_chars): Set to '/' if TE_FreeBSD.
4558 Tue Apr 25 11:02:02 2000  Jeffrey A Law  (law@cygnus.com)
4560         * configure.in: Configury support for PA64 (currently disabled).
4561         * configure: Rebuilt.
4563 2000-04-25  Machida Hiroyuki  <machida@sm.sony.co.jp>
4565         * config/tc-mips.c (s_change_sec): Use record_alignment, not
4566         bfd_set_section_alignment.
4568 2000-04-25  Alan Modra  <alan@linuxcare.com.au>
4570         * config/tc-i386.c (offset_in_range): Ensure shift counts are less
4571         than 32.
4573 2000-04-24  Nick Clifton  <nickc@cygnus.com>
4575         * doc/c-arm.texi (ARM Directives): Document behaviour of .align 0.
4576         * doc/as.texinfo (Align): Include arm and strongarm in list of
4577         targets that have the second form of the behaviour of the .align
4578         directive.
4580 2000-04-24  Mark Klein <mklein@dis.com>
4582         * config/obj-som.c: Terminate obj_pseudo_table.
4584 Mon Apr 24 15:21:11 2000  Clinton Popetz  <cpopetz@cygnus.com>
4586         * as.c (parse_args): Allow md_parse_option to override -a listing
4587         option.
4588         * config/obj-coff.c (add_lineno): Change type of offset parameter
4589         from "int" to "bfd_vma."
4590         * config/tc-ppc.c (md_pseudo_table): Add "llong" and "machine."
4591         (ppc_mach, ppc_subseg_align, ppc_target_format): New.
4592         (ppc_change_csect): Align correctly for XCOFF64.
4593         (ppc_machine): New function, which discards "ppc_machine" line.
4594         (ppc_tc): Cons for 8 when code is 64 bit.
4595         (md_apply_fix3): Don't check operand->insert.  Handle 64 bit
4596         relocations.
4597         (md_parse_option): Handle -a64 and -a32.
4598         (ppc_xcoff64): New.
4599         * config/tc-ppc.h (TARGET_MACH): Define.
4600         (TARGET_FORMAT): Move to function.
4601         (SUB_SEGMENT_ALIGN): Use ppc_subseg_align.
4603 Sun Apr 23 16:45:45 2000  Denis Chertykov  <denisc@overta.ru>
4605         * config/tc-avr.c: New AVR_ISA_ defined.
4606         (md_assemble): Handle opcodes with optional operands (lpm,elpm).
4607         (avr_operand): Handle 'a', 'v' and 'z' constraint letters needed
4608         for `fmul', `movw' and `lpm R,Z' instructions.
4609         (avr_operands): Warn if current opcode is a two-word instruction
4610         and previous opcode was cpse/sbic/sbis/sbrc/sbrs.
4611         (avr_opcodes): New commands added.
4612         (REGISTER_P): Check 'a' and 'v' constraint letters.
4613         (mcu_types): New MCU added.
4615 2000-04-22  Timothy Wall  <twall@cygnus.com>
4617         * config/tc-ia64.c (pseudo_func[]): Add new "nat" entry equivalent
4618         to "natval".
4619         (operand_match): Conditionally insert default bit values for IMMU9.
4621 2000-04-14  Matthew Green  <mrg@cygnus.com>
4623         * configure.in: Add NetBSD/sparc ELF and NetBSD/sparc64 support.
4624         * configure: Rebuilt.
4626 Fri Apr 21 14:29:43 2000  Jeffrey A Law  (law@cygnus.com)
4627                           Jason Eckhardt  <jle@cygnus.com>
4629         * config/tc-hppa.c (md_apply_fix): Handle new PA2.0 formats.
4631         * config/tc-hppa.c (CHECK_ALIGN): New macro.
4632         Added handling of new operand types l,y,&,fe,fE,fx.
4634 Fri Apr 21 13:20:53 2000  Richard Henderson  <rth@cygnus.com>
4635                           David Mosberger  <davidm@hpl.hp.com>
4636                           Timothy Wall <twall@cygnus.com>
4637                           Andrew MacLeod  <amacleod@cygnus.com>
4638                           Jim Wilson  <wilson@cygnus.com>
4640         * Makefile.am (CPU_TYPES): Add ia64.
4641         (TARGET_CPU_CFILES): Add config/tc-ia64.c.
4642         (TARGET_CPU_HFILES): Add config/tc-ia64.h.
4643         * Makefile.in: Rebuild.
4644         * app.c (do_scrub_chars): Handle DOUBLESLASH_COMMENTS.
4645         * configure: Rebuild.
4646         * configure.in: Recognize ia64 as cpu type.  Set bfd_gas.
4647         (ia64-*-elf*, ia64-*-linux-gnu*): New targets.
4648         * expr.c (expr): Handle md_optimize_expr.
4649         * read.c (LEX_HASH): Add comment.
4650         * config/tc-ia64.c, config/tc-ia64.h: New files.
4652 2000-04-21  Richard Henderson  <rth@cygnus.com>
4654         * config/tc-d30v.c (write_2_short): Disregard opcode1->ecc when
4655         bundling a non-delayed branch type instruction.
4657 2000-04-20  Alexandre Oliva  <aoliva@cygnus.com>
4659         * config/tc-mn10300.c (HAVE_AM30): Define.
4660         (md_assemble): Use it.
4662 2000-04-19  Alan Modra  <alan@linuxcare.com.au>
4664         * config/obj-elf.c (obj_elf_change_section): Check for changed
4665         section attributes.
4667         * Makefile.am: (CPU_MULTI_VALID): Remove.
4668         (MULTI_CPU_TYPES): Define.
4669         (MULTI_CPU_OBJ_VALID): Define.
4670         (DEPTC): Use the above.
4671         (DEPOBJ): Same here.
4672         (DEP2): And here.
4673         Regenerate dependencies.
4674         * Makefile.in: Regenerate.
4676 2000-04-19  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
4678         * Makefile.am (YACC, LEX): Get them from configure.
4680 2000-04-18  H.J. Lu  (hjl@gnu.org)
4682         * config/tc-i386.c (offset_in_range): Use addressT instead of
4683         bfd_vma for non-bfd assemblers.
4685 2000-04-17  Alan Modra  <alan@linuxcare.com.au>
4687         * config/tc-i386.c (offset_in_range): Sign extend val so BFD64
4688         doesn't give spurious errors.
4690 2000-04-14  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
4692         * as.h (SEEK_SET): Define if undefined.
4694 2000-04-13  Alan Modra  <alan@linuxcare.com.au>
4696         * config/tc-arm.c (md_apply_fix3): Don't use UL suffix on
4697         constants, and don't assume offsetT is 32 bits.
4699 2000-04-12  Andrew Cagney  <cagney@b1.cygnus.com>
4701         * config/tc-d10v.h: Include "write.h" to get definition of fixS.
4702         (md_pcrel_from_section): Add prototype.
4703         (d10v_fix_adjustable): Add prototype.
4704         (d10v_force_relocation): Replace 'struct fix' with 'fixS'.
4706         * config/tc-d10v.c (md_apply_fix3): Add paren around &&.
4708 2000-04-12  Nick Clifton  <nickc@cygnus.com>
4710         * config/tc-d10v.c (find_opcode): Correctly calculate position of
4711         symbol in frag chain.
4713 2000-04-10  Alan Modra  <alan@linuxcare.com.au>
4715         * config/tc-i386.c (fits_in_signed_byte): Change arg to offsetT.
4716         (fits_in_unsigned_byte, fits_in_unsigned_word): Ditto.
4717         (fits_in_signed_word, smallest_imm_type): Ditto.
4718         (md_assemble): Use an offsetT var to hold offsetT values, not a
4719         long.
4720         (offset_in_range): New.
4721         (md_assemble): Use it.
4722         (md_convert_frag): Change type of target_address, opcode_address,
4723         and displacement_from_opcode_start to offsetT.
4724         (md_create_short_jump): Change type of offset to offsetT.
4725         (md_create_long_jump): Ditto.
4726         (md_apply_fix3): Use -4, not 0xfffffffc for BFD_RELOC_386_PLT32.
4727         (md_chars_to_number): Remove.
4728         (output_invalid): Remove duplicate prototype.
4730 2000-04-09  Nick Clifton  <nickc@cygnus.com>
4732         * Makefile.am (CPU_TYPES): Add 'avr'.
4733         (TARGET_CPU_CFILES): Add 'tc-avr.c'.
4734         (TARGET_CPU_HFILES): Add 'tc-avr.h'.
4736         * Makefile.in: Regenerate.
4738         * doc/as.texinfo: Add M32R documentation.
4740 Fri Apr  7 15:56:57 2000  Andrew Cagney  <cagney@b1.cygnus.com>
4742         * configure.in (WARN_CFLAGS): Set to -W -Wall by default.  Add
4743         --enable-build-warnings option.
4744         * Makefile.am (AM_CFLAGS, WARN_CFLAGS): Add definitions.
4745         * Makefile.in, configure: Re-generate.
4747 2000-04-07  Nick Clifton  <nickc@cygnus.com>
4749         * config/tc-arm.c (md_apply_fix3): Treat BFD_RELOC_ARM_PCREL_BLX
4750         in the same way as BFD_RELOC_ARM_PCREL_BRANCH, and
4751         BFD_RELOC_THUMB_PCREL_BLX lie BFD_RELOC_THUMB_PCREL_BRANCH.
4752         (tc_gen_reloc): Accept BFD_RELOC_{ARM|THUMB}_PCREL_BLX.
4753         (arm_force_relocation): Force relocations for
4754         BFD_RELOC_{ARM|THUMB}_PCREL_BLX as well.
4756 Wed Apr  5 22:26:32 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
4758         * config/tc-sh.c (get_operands): There's no third operand if the
4759         first operand is an immediate.
4761 Wed Apr  5 22:07:19 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
4763         * config/tc-sh.c (immediate): Delete.
4764         (sh_operand_info): Add immediate member.
4765         (parse_reg): Use A_PC for pc.
4766         (parse_exp): Add second argument 'op'.  All callers changed.
4767         (parse_at): Expect pc to be coded as A_PC.
4768         Use immediate field in *op.
4769         (insert): Add fourth argument 'op'.  All callers changed.
4770         (build_relax): Add second argument 'op'.  All callers changed.
4771         (insert_loop_bounds): New function.
4772         (build_Mytes): Remove DISP_4.
4773         Split IMM_[48]{,BY[24]} into IMM[01]_[48]{,BY[24]}.  Add REPEAT.
4774         (assemble_ppi): Use immediate field in *operand.
4775         (sh_force_relocation): Handle BFD_RELOC_SH_LOOP_{START,END}.
4776         (md_apply_fix): Likewise.
4777         (tc_gen_reloc): Likewise.  Check for a pcrel BFD_RELOC_SH_LABEL.
4779 Wed Apr  5 06:35:45 2000  Alexandre Oliva  <oliva@lsd.ic.unicamp.br>
4781         * config/tc-sparc.c (sparc_ip): Avoid string pasting.
4783 Tue Apr  4 19:27:50 2000  Hans-Peter Nilsson  <hp@axis.com>
4785         * internals.texi (CPU backend): Document
4786         TC_CHECK_ADJUSTED_BROKEN_DOT_WORD.
4788 2000-04-04  Alan Modra  <alan@linuxcare.com.au>
4790         * po/gas.pot: Regenerate.
4792         * as.c (show_usage): Restore translated part of bug string.
4793         * gasp.c (show_usage): Likewise.
4795         * Makefile.am (MKDEP): Use gcc -MM rather than ../mkdep.
4796         (DEP): Quote when passing vars to sub-make.  Use "mv -f" rather
4797         than move-if-change.
4798         (DEP1): Modify for "gcc -MM".
4799         (DEPTC): Likewise.
4800         (DEPOBJ): Likewise.
4801         (DEP2): Likewise.
4802         (CLEANFILES): Add DEPTCA, DEPOBJA, DEP2a, DEPA.
4803         Update dependencies.
4804         * Makefile.in: Regenerate.
4806 2000-04-03  Alexandre Oliva  <aoliva@cygnus.com>
4808         * config/tc-mn10300.c (md_pseudo_table): Use constant names.
4809         (md_begin): Likewise.
4810         (HAVE_AM33): New macro.
4811         (md_assemble): Use it.  Match r_regs and xr_regs only if
4812         HAVE_AM33.
4814 2000-04-03  Alan Modra  <alan@linuxcare.com.au>
4816         * as.h: #include "bin-bugs.h"
4817         * as.c (show_usage): Use REPORT_BUGS_TO.
4818         * gasp.c: #include "bin-bugs.h"
4819         (show_usage): Use REPORT_BUGS_TO.
4821         * config/tc-sparc.c (md_show_usage): Add a trailing newline.
4823 Mon Apr  3 13:56:03 2000  Hans-Peter Nilsson  <hp@axis.com>
4825         * write.c (write_object_file) [! WORKING_DOT_WORD]: If defined,
4826         call TC_CHECK_ADJUSTED_BROKEN_DOT_WORD for each word after
4827         adjustments.
4829 2000-04-03  Alan Modra  <alan@linuxcare.com.au>
4831         * config/tc-i386.c (i386_immediate): Don't assume a constant
4832         immediate is necessarily 16 bits when in 16 bit code mode.
4833         (md_assemble): Instead set guess_suffix here after we have checked
4834         registers.
4836 2000-04-02  Richard Henderson  <rth@cygnus.com>
4838         * config/tc-d30v.c (check_range): Allow signed or unsigned 32-bit
4839         quantities.  Correct right shift sign extension.
4840         (build_insn): Make `number' unsigned long.  Mask top 6 bits of
4841         32-bit value when shifting into place.
4843 2000-04-01  Ian Lance Taylor  <ian@zembu.com>
4845         * app.c: Add ATTRIBUTE_UNUSED as needed.
4846         * config/tc-ppc.c: Likewise.
4847         (ppc_size): Make unsigned long.
4848         (ppc_insert_operand): Add casts to avoid warnings.
4850 2000-03-31  Nick Clifton  <nickc@cygnus.com>
4852         * config/tc-d10v.h (md_flush_pending_output): Define.
4854 2000-03-29  Nick Clifton  <nickc@cygnus.com>
4856         * config/tc-sh.h (SEG_NAME): New macro: return the name of a
4857         segment.  Works for both BFD_ASSEMBLER and others.
4858         (SUB_SEGMENT_ALIGN): Use SEG_NAME.
4860 2000-03-29  Nick Clifton <nickc@cygnus.com
4862         * config/tc-arm.c (tinsns): Add "bal" instruction pattern.
4864 2000-03-28  Alan Modra  <alan@linuxcare.com.au>
4866         * listing.c (LISTING_LHS_WIDTH): Default depends on
4867         LISTING_WORD_SIZE.
4868         (LISTING_LHS_WIDTH_SECOND): Default to LISTING_LHS_WIDTH.
4870 2000-03-27  Ian Lance Taylor  <ian@zembu.com>
4872         * config/tc-sh.c (md_show_usage): Use backslash before newline in
4873         string literal.
4875 2000-03-27  Alan Modra  <alan@linuxcare.com.au>
4877         * config/tc-avr.h (TC_HANDLES_FX_DONE): Define.
4879         * config/tc-avr.c (mcu_types): Add missing initialiser.
4880         (md_pcrel_from_section): Add prototype.
4881         (avr_operand): Remove redundant test of unsigned < 0.
4882         (avr_cons_fix_new): Ensure exp_mod_pm zero on function exit.
4884 2000-03-27  Denis Chertykov  <denisc@overta.ru>
4886         * config/tc-avr.c: New file for AVR support.
4887         * config/tc-avr.h: Likewise.
4888         * configure.in: Add AVR support.
4889         * configure: Regenerate.
4891 2000-03-26  Timothy Wall <twall@cygnus.com>
4893         * gasp.c (macro_op): Add new argument to check_macro call.
4894         Macro structure definitions moved to macro.h
4895         * sb.h:  Add argument to prototype for input_scrub_include_sb.
4896         * input-scrub.c (input_scrub_include_sb): Allow disabling of sb
4897         nesting checks with an additional flag.
4898         (struct input_save): Add flag to indicate whether current sb
4899         should be checked for proper macro/conditional nesting.
4900         (input_scrub_push/pop): Save/restore nest check flag.
4901         (input_scrub_next_buffer): Ditto.  Also call end of macro hook if
4902         defined.
4903         * macro.c (check_macro):  Allow caller to retrieve parsed macro
4904         information if a pointer is provided.  This information may be
4905         used by the new macro hooks.
4906         * macro.h: Update prototype for check_macro.  Macro struct
4907         definitions moved here from macro.c/gasp.c.
4908         * read.c (read_a_source_file): Add parameter to check_macro call,
4909         and pass macro info to the macro hook, if defined.
4910         (input_scrub_insert_line): New.  Allow insertion of a line of
4911         characters into the input stream.
4912         (input_scrub_insert_file): New.  Allow insertion of an arbitrary
4913         file into the input stream.
4914         (s_include): Use input_scrub_insert_file.
4915         * internals.texi: Document new macro hooks.
4916         * as.h: New prototypes added.
4918 2000-03-26  Alan Modra  <alan@linuxcare.com.au>
4920         * config/tc-i386.c: Don't start any as_bad or as_warn message with
4921         an initial capital letter.
4922         (i386_index_check): Reindent.
4924 2000-03-19  Nick Clifton  <nickc@cygnus.com>
4926         * config/tc-arm.c (md_apply_fix3): Fix bug detecting overflow of pc
4927         relative branches.
4929 2000-03-17 Thomas de Lellis <tdel@windriver.com>
4931         * config/tc-arm.c (do_t_adr): Flag "adr Rd,label"
4932         instruction operand bad if Rd > 7 when generating
4933         thumb instructions. Prevents for example,
4934         "adr r12,label" from silently failing and generating
4935         the wrong instruction.
4937 2000-03-17  Nick Clifton  <nickc@cygnus.com>
4939         * config/tc-arm.c (md_apply_fix3): Handle same-section relocations
4940         that have a destingation >= 0x400000.
4941         Fix compile time warning messages.
4943 Thu Mar 16 23:45:16 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
4945         * config/tc-sh.c (md_begin): When encountering insn that are
4946         not supported by the current arch, only change the name if
4947         its contents are the same as prev_name.
4948         (get_specific): If the the architecture doesn't match, fail.
4950 Thu Mar 16 21:18:13 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
4952         * config/tc-sh.c (IDENT_CHAR): Define.
4953         (parse_reg): Use it instead of isalnum.  Put r[0..7]_bank operand
4954         matching back where it came from.
4956 Thu Mar 16 20:58:10 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
4958         * config/tc-sh.c (md_show_usage): Add description of -dsp.
4960 2000-03-15  Jonathan Larmour  <jlarmour@redhat.co.uk>
4962         * config/tc-sh.c (parse_reg): Match r[0..7]_bank operands before
4963         normal operands.
4965 2000-03-15  Kazu Hirata  <kazu@hxi.com>
4967         * config/tc-h8300.c: Add ATTRIBUTE_UNUSED as appropriate.
4969 Mon Mar 13 22:02:59 2000  Hans-Peter Nilsson  <hp@axis.se>
4971         * expr.c (operand) [case 'f']: When testing if '0f' can start a
4972         floating-point-number, make sure 'f' is in FLT_CHARS.
4974 Sat Mar 11 00:01:39 2000  Hans-Peter Nilsson  <hp@axis.se>
4976         * read.c (TC_IMPLICIT_LCOMM_ALIGNMENT): New default-definition.
4977         (s_lcomm_internal): Use it.
4978         * doc/internals.texi (CPU backend): Document it.
4979         * config/obj-evax.h (TC_IMPLICIT_LCOMM_ALIGNMENT): Set to 2**3
4980         bytes.
4982 2000-03-10  Geoffrey Keating  <geoffk@cygnus.com>
4984         * config/tc-mips.c (mips_ip): Don't put stuff in .rodata
4985         when embedded-pic.
4987         * config/tc-mips.c (SWITCH_TABLE): The ELF embedded-pic
4988         implementation doesn't have special handling for switch
4989         statements.
4990         (macro_build): Allow for code in sections other than .text.
4991         (macro): Likewise.
4992         (mips_ip): Likewise.
4993         (md_apply_fix): Do pc-relative relocation madness for MIPS ELF.
4994         Don't perform relocs if we will be outputting them.
4995         (tc_gen_reloc): For ELF, just use fx_addnumber for pc-relative
4996         relocations.  Allow BFD_RELOC_16_PCREL_S2 relocs when
4997         embedded-pic.
4999 2000-03-09  Catherine Moore  <clm@cygnus.com>
5001         * config/tc-m32r.c (m32r_fix_adjustable):  Look up the
5002         relocation type based on the entry in the fixup structure.
5003         Put S_IS_EXTERN processing back in.
5005 2000-03-08  H.J. Lu  (hjl@gnu.org)
5007         * Makefile.am (install-exec-tooldir): Depend on
5008         install-exec-bindir for parallel make.
5009         * Makefile.in: Regenerated.
5011 2000-03-06  Nick Clifton  <nickc@cygnus.com>
5013         * config/tc-m32r.c (struct md_longopts): Add -m32r command line
5014         switch.
5015         (md_parse_option): Parse -m32r command line switch - disable m32rx
5016         compatability.
5017         (md_show_usage): Document new option.
5019         * doc/Makefile.am (CPU_DOCS): Add c-m32r.texi.
5020         * doc/Makefile.in: Regenerate.
5021         * doc/c-m32r.texi (M32R-Opts): Document new command line switch.
5023 2000-03-02  Michael Meissner  <meissner@redhat.com>
5025         * config/tc-d30v.c (check_range): Remove code that incorrectly
5026         sign extended values where bits < 32.
5028 2000-03-02  H.J. Lu  (hjl@gnu.org)
5030         * configure.in: Support --enable-targets=all on ia32.
5031         * configure: Regenerated.
5033 2000-03-01  Nick Clifton  <nickc@cygnus.com>
5035         * gasp.c (do_align): Remove bogus check of alignment value.
5037 2000-02-27  Thomas de Lellis  <tdel@windriver.com>
5039         * config/obj-elf.c (elf_frob_symbol): Remove code which when
5040         TC_PPC was defined forced the type of a symbol with no other type
5041         to be BSF_OBJECT.
5043 2000-02-27  Hans-Peter Nilsson  <hp@axis.com>
5045         * doc/internals.texi (CPU backend): Mention that
5046         line_separator_chars do not break up comments.  Fix typos for
5047         LEX_AT and LEX_NAME descriptions.  Document operands for
5048         TC_EQUAL_IN_INSN, md_operand and md_section_align.  Correct
5049         description of md_create_short_jump usage.  Document argument for
5050         md_undefined_symbol.
5052 2000-02-27  Jakub Jelinek  <jakub@redhat.com>
5054         * config/tc-sparc.c (OPTION_UNDECLARED_REGS): New option.
5055         (md_parse_option): Handle it.
5056         (md_show_usage): Document it.
5058 2000-02-27  Ian Lance Taylor  <ian@zembu.com>
5060         * config/tc-alpha.c (md_assemble): Accept `1' and `9' in an
5061         opcode, for the instruction `pal19'.  From Andrea Arcangeli
5062         <andrea@suse.de>.
5064 2000-02-26  Alan Modra  <alan@spri.levels.unisa.edu.au>
5066         * config/tc-i386.c (i386_immediate): Move constant operand sizing
5067         from here..
5068         (md_assemble): To here, before template operands are matched.
5069         Also ensure a constant immediate is sign extended when we know the
5070         size is at most 16 bits.  This is to catch cases like "add
5071         $0xffc0,%ax" where we don't know the size, and thus that the
5072         immediate can be represented as Imm8S until after parsing the
5073         register operand.
5074         (i386_displacement): Similarly sign extend 16 bit constant
5075         displacements.
5076         (md_assemble): Relax 16-bit jump constant range check to suit sign
5077         extended displacements.
5079 2000-02-26  Andreas Jaeger  <aj@suse.de>
5081         * doc/c-mips.texi (MIPS Opts): Fix typo in last patch.
5083 2000-02-25  Alan Modra  <alan@spri.levels.unisa.edu.au>
5085         * config/tc-i386.c (md_assemble): Don't swap intersegment jmp and
5086         call operands when intel_syntax.
5087         (intel_float_operand): Return 2 for "fi...".
5088         (i386_operand_modifier): Change "DWORD PTR" test to suit above.
5089         Return SHORT_MNEM_SUFFIX for "WORD PTR" when "fi...".  Revert
5090         earlier "SHORT" change.
5091         (md_assemble): When determining suffix from Regs, exclude
5092         InOutPortReg.
5094 2000-02-24  Nick Clifton  <nickc@cygnus.com>
5096         * configure: Add arm-wince, mips-pe and sh-pe targets.
5097         * configure: Regenerate.
5099         * config/obj-coff.h (COFF_WITH_PE): Define for mips-pe and
5100         sh-pe targets.
5101         (TARGET_FORMAT): Set to "pe-shl" for the sh-pe target and to
5102         "pe-mips" for the mips-pe target.
5104         * config/tc-arm.c (insns): Change displacement encoded in BL
5105         and B instructions if the target port is arm-wince.
5106         (do_ldst): Do not bias the relocation offset if the target
5107         port is arm-wince.
5108         (md_pcrel_from): Add in missing relocation offset bias if the
5109         target os arm-wince.
5111         * config/tc-mips.c (mips_target_format): Support COFF flavour.
5112         (md_begin): Disable -G support for mips-pe target.
5113         (md_apply_fix): Treat BFD_RELOC_RVA reloc as BFD_RELOC_32.
5114         * config/tc-mips.h (USE_GLOBAL_POINTER_OPT): Add support for
5115         COFF flavour.
5117         * config/tc-sh.c (md_begin): sh-pe target is little endian.
5118         * config/tc-sh.h (SUB_SEGMENT_ALIGN): If using a BFD
5119         assembler, just set the alignment to 4.
5121         * config/te-wince-pe.h: New file for WinCE targets.  Define
5122         TE_WINCE.
5124 2000-02-25  Alan Modra  <alan@spri.levels.unisa.edu.au>
5126         * config/tc-i386.c (md_assemble): Swap segments too for intel mode
5127         string instructions.
5128         (i386_operand_modifier): Set i.suffix = WORD_MNEM_SUFFIX for SHORT.
5129         (i386_intel_memory_operand): After finding a segment override,
5130         check again for no `[' before looking for a displacement.  Bomb if
5131         more than one displacement rather than silently discarding the
5132         second and subsequent ones.  Free strings malloc'd by
5133         build_displacement_string.
5135 2000-02-24  Catherine Moore  <clm@cygnus.com>
5137         * config/obj-som.c (obj_pseudo_table): Add "weak".
5138         (obj_som_weak): New routine.
5140 2000-02-24  Alan Modra  <alan@spri.levels.unisa.edu.au>
5142         * config/tc-i386.c (union i386_op): New.
5143         (struct _i386_insn): Delete disps[], imms[], regs[].  Add op[].
5144         Throughout file replace occurences of disps[n], imms[n], regs[n]
5145         with equivalent op[n].disps, op[n].imms, op[n].regs.  Simplify
5146         intel mode operand swapping.  Add assert in regKludge and
5147         fake_zero_displacement code.  Test i.types[n] when outputting
5148         displacements and immediates.  Combine output of Disp16 with
5149         Disp32.
5150         (md_assemble): Don't try to fix broken UNIXWARE_COMPAT opcodes
5151         when in intel mode by (not) reversing fsub and fdiv operands
5152         before the template search.  This fails for single operand
5153         shorthand forms of the instruction, and if UNIXWARE_COMPAT is
5154         undefined.  Instead fix the base_opcode after we've found the
5155         template.  Move base_opcode xor with found_reverse_match from
5156         opcode output code to before this fix so we test for the correct
5157         opcodes.
5158         (md_assemble): Don't use strcmp when deciding to ignore the suffix
5159         check in intel mode.  Instead compare opcodes.
5161         * config/tc-i386.h (TC_RELOC): Delete.
5162         * config/tc-i386.c (TC_RELOC): Delete.  Replace usage of TC_RELOC
5163         with equivalent call to reloc.
5165         * as.h (flag_m68k_mri): Move declaration after target include, and
5166         only declare when TC_M68K defined.  Define as zero otherwise.
5167         (LABELS_WITHOUT_COLONS, NO_PSEUDO_DOT): If undefined, define as 0.
5168         * app.c (scrub_m68k_mri): Declare only when TC_M68K defined.
5169         Define as zero otherwise.
5170         (do_scrub_begin): Use m68k_mri parameter only when TC_M68K defined.
5171         (struct app_save): Declare scrub_m68k_mri only when TC_M68K.
5172         (app_push, app_pop): Save scrub_m68k_mri only when TC_M68K.
5173         (do_scrub_chars): Use LABELS_WITHOUT_COLONS directly rather than
5174         testing whether defined.
5175         * cond.c (ignore_input): Use NO_PSEUDO_DOT directly.
5176         * expr.c (operand): #ifdef unused case labels when TC_M68K undefined.
5177         * read.c: Use LABELS_WITHOUT_COLONS and NO_PSEUDO_DOT directly
5178         rather than testing whether defined.
5179         (s_mri): Set flag_m68k_mri only when TC_M68K defined.
5180         (parse_mri_cons): Declare and use only when TC_M68K.
5181         * config/tc-hppa.h (LABELS_WITHOUT_COLONS): Define as 1.
5182         * config/tc-m68k.h (NO_PSEUDO_DOT): Define as 1.
5183         * config/tc-m88k.h (NO_PSEUDO_DOT): Define as 1.
5185         * NEWS: Mention IBM 370 support.
5187 2000-02-23  Richard Henderson  <rth@cygnus.com>
5189         * config/tc-i386.c (md_assemble): When swapping operands for
5190         intel_syntax, assume everything that's not Imm or Disp is a
5191         register.
5193 2000-02-23  Linas Vepstas <linas@linas.org>
5195         * config/tc-i370.c, config/tc-i370.h: New files.
5196         * Makefile.am: Add support for Linux/IBM 370.
5197         * configure.in: Likewise.
5198         * app.c (do_scrub_begin): Don't lex single quote when TC_I370.
5199         * config/obj-elf.c: Include elf/i370.h
5200         (obj_elf_section): Don't do anything special for flag_mri if TC_I370.
5202         * Makefile.in: Regenerate.
5203         * configure: Regenerate.
5205         * doc/c-i370.texi: New file.
5206         * doc/all.texi: Include it.
5207         * doc/as.texinfo: And here.
5208         * doc/Makefile.am(CPU_DOCS): Add c-i370.texi.
5209         * doc/Makefile.in: Regenerate.
5211 2000-02-19  Michael Meissner  <meissner@redhat.com>
5213         * config/tc-d30v.c (parallel_ok): Use FLAG_NOT_WITH_ADDSUBppp to
5214         determine if an instruction can be used in parallel with an ADDppp
5215         or SUBppp instruction.
5217 2000-02-22  Andrew Haley  <aph@cygnus.com>
5219         * doc/c-mips.texi (MIPS Opts): Document -mgp32 and -mgp64.
5221 2000-02-22  Andrew Haley  <aph@cygnus.com>
5223         * config/tc-mips.c (mips_gp32): New variable.
5224         (macro_build) Use mips_gp32.
5225         (mips_ip): Ditto.
5226         (md_longopts): Add "-mgp32" and "-mgp64".
5227         (md_parse_option): Add OPTION_GP32 and OPTION_GP64.
5229         (OPTION_M7900): Change offset
5230         (OPTION_NO_M7900): Ditto.
5232 2000-02-22  Alexandre Oliva  <oliva@lsd.ic.unicamp.br>
5234         * config/obj-coff.c (add_lineno): Accept non-positive lineno with
5235         warning, and bump it to 1.
5237 2000-02-22  Ian Lance Taylor  <ian@zembu.com>
5239         From Brad Lucier <lucier@math.purdue.edu>:
5240         * dwarf2dbg.c (print_stats): Add cast to force printf argument to
5241         match format.
5243 2000-02-21  Catherine Moore  <clm@cygnus.com>
5245         * config/tc-mips.c (MF_HILO_INSN): Define.
5246         (mips_7000_hilo_fix): Declare.
5247         (append_insn): Conditionally insert nops after an mfhi/mflo insn.
5248         (md_parse_option): Check for 7000_HILO_FIX options.
5249         (OPTION_M7000_HILO_FIX): Define.
5250         (OPTION_NO_M7000_HILO_FIX): Define.
5251         * doc/c-mips.texi (-mfix7000): Describe.
5253 2000-02-21  Alan Modra  <alan@spri.levels.unisa.edu.au>
5255         * listing.c (print_lines): Remove unused variable `end'.
5257         * config/tc-i386.c (md_assemble): Use `reloc()' to select reloc
5258         type for JumpInterSegment output. Use enum bfd_reloc_code_real for
5259         reloc_type when BFD_ASSEMBLER.
5260         (md_estimate_size_before_relax): Use enum bfd_reloc_code_real for
5261         reloc_type when BFD_ASSEMBLER. Move common code out of switch
5262         statement and quell signed vs. unsigned comparison warning.
5264 2000-02-18  Nick Clifton  <nickc@cygnus.com>
5266         * config/tc-d10v.c (find_opcode): Add a symbol's value to
5267         the computed frag offset, rather than overwriting it.
5269 Thu Feb 17 00:11:08 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
5271         * config/tc-sh.c ("elf/sh.h"): Include.
5272         (sh_dsp, valid_arch, reg_x, reg_y, reg_efg): New static variables.
5273         (md.begin): Initialize target_arch.
5274         Only include opcodes in has table that match selected architecture.
5275         (parse_reg): Recognize register names for sh-dsp.
5276         (parse_at): Recognize post-modify addressing.
5277         (get_operands): The leading space is now optional.
5278         (get_specific): Remove FDREG_N support.  Add support for sh-dsp
5279         arguments.  Update valid_arch.
5280         (build_Mytes): Add support for SDT_REG_N.
5281         (find_cooked_opcode): New function, broken out of md_assemble.
5282         (assemble_ppi, sh_elf_final_processing): New functions.
5283         (md_assemble): Use find_cooked_opcode and assemble_ppi.
5284         (md_longopts, md_parse_option): New option: -dsp.
5285         * config/tc-sh.h (elf_tc_final_processing): Define.
5286         (sh_elf_final_processing): Declare.
5288 Fri Feb 11 14:21:51 2000  Jeffrey A Law  (law@cygnus.com)
5290         * config/tc-hppa.c (pa_build_unwind_subspace): Use subseg_new to create
5291         the unwinder subspace.  Save the current seg/subseg before creating
5292         the new seg/subseg.
5294 2000-02-10  Nick Clifton  <nickc@cygnus.com>
5296         * config/tc-mcore.c (INST_BYTE0): Redefine to handle big and
5297         little endian targets.
5298         (INST_BYTE1): Redefine to handle big and little endian
5299         targets.
5300         (cpu_type): New type: Select between M340 and M210.
5301         (parse_psrmod): New function: Parse the PSRCLR and PSRSET
5302         instructions of the M340.
5303         (md_assemble): Add support for the MULSH and OPSR classes of
5304         instructions.
5305         (md_atof): Add support for little endian targets.
5306         (md_parse_option): Add support for -EL, -EB and -mcpu command
5307         line switches.
5308         (md_convert_frag): Add support for little endian targets.
5309         (md_apply_fix3): Add support for little endian targets.
5310         (md_number_to_chars): Add support for little endian targets.
5312 2000-02-10  Timothy Wall  <twall@redhat.com>
5314         * read.c (read_a_source_file): If TC_START_LABEL_WITHOUT_COLON is
5315         defined, use it to verify the symbol just read should be a label.
5317 2000-02-10  Timothy Wall  <twall@redhat.com>
5319         * app.c (do_scrub_chars): Handle "||" for parallel instructions
5320         when DOUBLEBAR_PARALLEL is defined.  Avoid stripping whitespace
5321         around colons when KEEP_WHITE_AROUND_COLON is defined.
5322         * doc/internals.texi (CPU backend): Document DOUBLEBAR_PARALLEL
5323         and KEEP_WHITE_AROUND_COLON.
5325 2000-02-08  Timothy Wall  <twall@redhat.com>
5327         * read.c (s_rept): Call do_repeat, which abstracts the repeat
5328         logic.
5329         (do_repeat): New.  Abstract repeat logic so that a "break" can be
5330         implemented.
5331         (end_repeat): New.  Provide support for a "break" out of the
5332         repeat loop.
5333         * read.h: Add prototypes for new functions.
5335 2000-02-08  Timothy Wall  <twall@redhat.com>
5337         * doc/internals.texi: Document NUMBERS_WITH_SUFFIX macro.
5338         * as.h: Provide a default NUMBERS_WITH_SUFFIX definition (zero).
5339         * expr.c: Handle numbers with suffixes if NUMBERS_WITH_SUFFIX is
5340         non-zero.
5342 2000-02-08  Timothy Wall  <twall@redhat.com>
5344         * read.c: Added elseif to directives table.
5345         * read.h: Added prototype for s_elseif.
5346         * doc/as.texinfo: Added description for elseif.
5347         * cond.c (s_elseif): New function
5349 2000-02-04  Timothy Wall  <twall@redhat.com>
5351         * listing.c (print_lines): Remove conditionals causing bug in
5352         listings.
5354 2000-02-03  Timothy Wall  <twall@cygnus.com>
5356         * as.h: Define OCTETS_PER_BYTE and OCTETS_PER_BYTE_POWER
5357         default values.
5358         * frags.c (frag_new): Calculate fr_fix in octets
5359         (frag_now_fix) Return offset as target address offset (bytes).
5360         (frag_now_fix_octets) New - Return offset in octets (8-bit
5361         quantities).
5362         * frags.h: Added prototype for frag_now_fix_octets().
5363         Distinguish between octets and bytes in field descriptions.
5364         * listing.c (calc_hex): Account for octets vs bytes when
5365         printing addresses/offsets.
5366         (print_lines) Ditto.  Also, if LISTING_WORD_SIZE is not 1, and
5367         target is little-endian, print the octets in a word in big-endian
5368         order so that the display looks like a proper hexadecimal number,
5369         instead of having the octets reversed.
5370         * read.c (do_align): When recording alignment, alignment power
5371         should be in terms of target bytes (minimum addressible unit)
5372         instead of octets.
5373         (do_org) Convert ORG target address (byte) argument into an
5374         octet offset when generating a variable fragment.
5375         * symbols.c (resolve_symbol_value): Symbol final value
5376         converted to a target address offset (bytes) from its octet offset.
5377         * config/obj-coff.c (coff_frob_symbol): Symbol target address
5378         offset (bytes) is adjusted by the frag offset (octets) converted
5379         to bytes.
5380         (coff_frob_section) Section alignment power is in terms of bytes;
5381         convert it to an octet alignment power when calculating size (and
5382         size mask) in octets.  Don't modify the section size in order to
5383         "align" it for TI COFF, since that format has a different method
5384         for storing alignment information.
5386 2000-02-01  Timothy Wall  <twall@cygnus.com>
5388         * stabs.c (generate_asm_file): Escape backslashes in stabs file
5389         entries, matching the way GCC generates them.  If not escaped, the
5390         filename is encoded incorrectly.
5392 2000-01-31  Nick Clifton  <nickc@cygnus.com>
5394         * config/tc-arm.c (reg_table): Add support for ATPCS register
5395         naming conventions.
5397 2000-01-31  Geoff Keating  <geoffk@cygnus.com>
5399         * config/obj-coff.h (OBJ_COPY_SYMBOL_ATTRIBUTES): Don't define if
5400         already defined.
5401         * config/tc-ppc.h [OBJ_XCOFF] (OBJ_COPY_SYMBOL_ATTRIBUTES):
5402         New macro.
5403         * config/tc-ppc.c (ppc_fix_adjustable): Don't look at the frag
5404         of a symbol when we really care about its value.
5406 2000-01-19  Chandra Chavva   <cchavva@cygnus.com>
5408         * config/tc-mcore.c (md_assemble): Give warning message if
5409         operands passes to instruction are more than the spec.
5411 2000-01-27  Thomas de Lellis <tdel@windriver.com>
5413         * config/tc-arm.c (armadjust_symtab): If the assembler is in
5414         Thumb mode but the label seen was not declared as '.thumb_func'
5415         then set the ST_INFO type to STT_ARM_16BIT mode.   This allows
5416         correct disassembly of Thumb code bounded by non function labels.
5418 2000-01-27  Alan Modra  <alan@spri.levels.unisa.edu.au>
5420         * Makefile.am (MULTI_CFILES): Add config/e-i386aout.c
5421         Add dependencies for e-i386aout.o.  Fix 2 comment lines.
5423         * Makefile.in: Same here.
5424         Update copyright.
5426         * configure.in: Set bfd_gas for i386-aout when primary target
5427         is bfd.  Handle i386aout emulation.  Don't use te_file=multi, as
5428         we may need the primary te_file.  Remove incorrect comment.
5430         * configure: Regenerate.
5432         * config/e-i386aout.c: New file.
5434         * as.c (USE_EMULATIONS): Move to before print_version_id.
5435         (struct emulation): Add i386aout.
5436         (show_usage): Split text strings.  Reformat -a text.  Add --em
5437         help.
5438         Update copyright.
5440         * obj.h (struct format_ops): Add s_get_other and s_get_desc.
5441         (aout_format_ops): New.
5442         Update copyright.
5444         * read.c (s_lcomm_internal): Rewrite OBJ_AOUT,OBJ_BOUT
5445         preprocessor conditional and add aout USE_EMULATIONS tests.
5446         (read_a_source_file): Don't pass error strings to printf as
5447         format arg.
5448         Update copyright.
5450         * gasp.c (exp_get_abs): Don't pass error strings to printf as
5451         format arg.
5452         (do_data): Same here.
5453         (process_file): And here.
5454         Update copyright.
5456         * symbols.c (colon): Rewrite "already defined" fatal message
5457         code for aout with USE_EMULATIONS.
5458         Update copyright.
5460         * config/obj-aout.c (OBJ_HEADER): Define.
5461         (obj_pseudo_table): Rename to aout_pseudo_table.  Init all
5462         fields of sentinel.
5463         (obj_aout_frob_symbol): Expand S_GET_DESC, S_GET_TYPE,
5464         S_GET_OTHER, S_SET_TYPE macros since we don't need obj-multi
5465         forms here.
5466         (obj_aout_type): Expand S_SET_OTHER here too.
5467         (obj_read_begin_hook): Remove.
5468         (aout_pop_insert): New.
5469         (obj_aout_s_get_other): New.
5470         (obj_aout_s_get_desc): New.
5471         (aout_format_ops): New.
5472         Update copyright.
5474         * config/obj-aout.h (obj_pop_insert): Define so non-multi usage
5475         gets aout_pseudo_table.
5476         (aout_pseudo_table): Declare.
5477         (obj_read_begin_hook): Define.
5478         Update copyright.
5480         * config/obj-coff.c (obj_pseudo_table): Rename to
5481         coff_pseudo_table.
5482         (coff_pop_insert): Use coff_pseudo_table.
5483         (coff_sec_sym_ok_for_reloc): Remove.
5484         (coff_format_ops): Add 0 entries for s_get_size, s_set_size,
5485         and comment all zero entries and remove #if 0 code.
5486         Update copyright.
5488         * config/obj-coff.h (obj_pop_insert): Define.
5489         (coff_pseudo_table): Declare.
5490         Update copyright.
5492         * config/obj-ecoff.c (ecoff_format_ops): Add 0 entries for
5493         s_get_size, s_set_size.  Comment all zero entries.
5494         Update copyright.
5496         * config/obj-elf.c (elf_s_get_other): New function.
5497         (obj_read_begin_hook): Rename to elf_obj_read_begin_hook.
5498         (obj_symbol_new_hook): Rename to elf_obj_symbol_new_hook.
5499         (elf_format_ops): Add elf_s_get_other, 0 s_get_size entry, and
5500         comment.
5501         (obj_elf_parse_section_letters): Don't pass error strings to
5502         printf as format arg.
5503         Update copyright.
5505         * config/obj-elf.h (ECOFF_DEBUGGING): Define when
5506         OBJ_MAYBE_ECOFF.
5507         (elf_s_get_other): Declare.
5508         (S_GET_OTHER) Define as elf_s_get_other if not already
5509         defined.
5510         (S_SET_OTHER): Only define when not already defined.
5511         (elf_obj_read_begin_hook): Declare.
5512         (obj_read_begin_hook): Define.
5513         (elf_obj_symbol_new_hook): Declare.
5514         (obj_symbol_new_hook): Define.
5515         Update copyright.
5517         * config/obj-multi.h: Add copyright header and protect against
5518         multiple inclusion.  Add * to all function pointers.
5519         (OBJ_HEADER): If defined, include it rather than other defines
5520         in this file.
5521         (obj_frob_file_after_relocs): Test for NULL.
5522         (obj_symbol_new_hook): Here too.
5523         (obj_sec_sym_ok_for_reloc): And here.
5524         (S_GET_OTHER): Define.
5525         (S_GET_DESC): Define.
5526         (ECOFF_DEBUGGING): Remove as it's done in obj-elf.h
5527         (OBJ_MAYBE_ELF): Update comment.
5529         * config/tc-i386.c (i386_immediate): Add OBJ_MAYBE_AOUT to
5530         OBJ_AOUT preprocessor conditional and handle emulation by
5531         testing OUTPUT_FLAVOR.
5532         (i386_displacement): Here too.
5533         (md_section_align): Similarly here.
5534         (i386_target_format): Conditionally compile when more than one
5535         of OBJ_MAYBE_{ELF,COFF,AOUT} defined.  Add aout case.
5536         (i386_immediate): Fix error message for aout BFD_ASSMBLER.
5537         (i386_displacement): Here too.
5538         Update copyright.
5540         * config/tc-i386.h (AOUT_TARGET_FORMAT): Define for each TE_*.
5541         Define TARGET_FORMAT for aout only when not multi.
5542         Update copyright.
5544         * config/te-multi.h: Delete file as it's identical to te-generic.h
5546 2000-01-15  Alan Modra  <alan@spri.levels.unisa.edu.au>
5548         * config/tc-i386.h (DWORD_MNEM_SUFFIX): Delete.
5549         * config/tc-i386.c (DWORD_MNEM_SUFFIX): Rename all occurrences to
5550         LONG_MNEM_SUFFIX.
5552         * config/tc-i386.h (INTEL_DWORD_MNEM_SUFFIX): Rename to
5553         DWORD_MNEM_SUFFIX.
5554         * config/tc-i386.c (INTEL_DWORD_MNEM_SUFFIX): Here too.  Fix some
5555         comments.
5557 2000-01-13  Clinton Popetz  <cpopetz@cygnus.com>
5559         * config/tc-mips.c (mips_do_align): New function.
5560         * config/tc-mips.h (md_do_align): Define.
5562 2000-01-10  Philip Blundell  <philb@gnu.org>
5564         * doc/c-arm.texi (ARM Options): Fix typo.
5565         (ARM-Chars): Correct description of `#'.  Mention  that `;' is a
5566         line separator for Linux.
5567         * doc/as.texinfo (Comments): Mention the ARM.
5569 2000-01-10  Philip Blundell  <pb@futuretv.com>
5571         * configure.in (arm*-*-conix*): New target.
5572         (arm*-*-linux-gnu*): Match instead of arm-*-linux* and
5573         armv*-*-linux-gnu.
5574         * configure: Regenerate.
5576 2000-01-03  Martin v. Loewis  <loewis@informatik.hu-berlin.de>
5578         * config/obj-elf.c (elf_pseudo_table): Define visibility pseudos.
5579         (obj_elf_visibility): New function.
5581         * doc/as.texinfo (Visibility): New node: document visibility
5582         pseudo ops.
5584 For older changes see ChangeLog-9899