* config/tc-m68hc11.c (build_jump_insn): Allocate worst case storage
[external/binutils.git] / gas / ChangeLog
1 2001-11-01  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
2
3         * config/tc-m68hc11.c (build_jump_insn): Allocate worst case storage
4         for bra/bsr and use frag_variant(), this ensure that the possible
5         16-bit BFD_RELOC_16 will be in the same frag.
6
7 2001-10-31  Chris Demetriou  <cgd@broadcom.com>
8
9         * config/tc-mips.c (HAVE_32BIT_ADDRESSES): If compiling embedded
10         PIC code, assume pointers the same size as GPRs.
11         (macro): In M_LA_AB handling for embedded PIC code, support
12         "la $treg,foo-bar($breg)".  In load/store handling
13         (label ld_st) support "<op> $treg,<sym>-<local_sym>($breg)"
14         which is used by the compiler for switch statements.
15         In load/store double multi-instruction macro handling
16         (label ldd_std) add a comment that no special handling
17         is currently done for embedded PIC.
18         (mips_ip): In 'o' (16-bit offset) case, only accept 16
19         bit offsets.
20
21 2001-10-31  Richard Earnshaw  <rearnsha@arm.com>
22
23         General cleanup of feature definitions.
24         * tc-arm.c (ARM_EXT_LONGMUL, ARM_EXT_HALFWORD, ARM_EXT_THUMB): Delete.
25         (ARM_2UP, ARM_ALL, ARM_3UP, ARM_6UP): Delete.
26         (FPU_CORE, FPU_FPA10, FPA_FPA11, FPU_ALL, FPA_MEMMULTI): Delete.
27         (ARM_EXT_V{1,2,2S,3,3M,4,4T,5T,5ExP}): New defines.
28         (ARM_EXT_V{5,5E}): Synchronize with above.
29         (ARM_ARCH_V*): Define a complete set in terms of above features.
30         (ARM_{1,2,3,250,6,7,8,9,STRONG}): Define in terms of architecture.
31         (FPU_FPA_EXT_V[12]): Define.
32         (FPU_ARCH_FPE, FPU_ARCH_FPA): Define in terms of above.
33         (FPU_ANY): Define.
34         (FPU_DEFAULT): Default to FPA.
35         (CPU_DEFAULT): For XScale, this is now just ARM_ARCH_XSCALE; for
36         Thumb, this is now ARM_ARCH_V5T.
37         (insns): Rework for new feature defines.
38         (tinsns): Likewise.
39         (opcode_select, do_ldst, md_begin, md_parse_option): Likewise.
40
41 2001-10-31  NIIBE Yutaka  <gniibe@m17n.org>
42
43         * configure.in: Handle sh*eb-*-linux* and sh*-*-linux*.
44         * configure: Regenerate.
45         * Makefile.in: Regenerate.
46         * doc/c-sh.texi (SH Options): Added descriptions.
47
48 2001-10-30  Hans-Peter Nilsson  <hp@bitrange.com>
49
50         * configure.in: Update for MMIX port.
51         * Makefile.am: Ditto.  Regenerate dependencies.
52         * Makefile.in: Regenerate.
53         * configure: Regenerate.
54         * config/tc-mmix.h, config/tc-mmix.c: New files.
55         * doc/Makefile.am (CPU_DOCS): Add c-mmix.texi
56         * doc/Makefile.in: Regenerate.
57         * doc/all.texi: @set MMIX.
58         * doc/as.texinfo: Ditto.  Add MMIX gas manpage option overview.
59         Include c-mmix.texi.
60         * doc/c-mmix.texi: New file.
61
62 2001-10-24  Chris Demetriou  <cgd@broadcom.com>
63
64         * config/tc-mips.c (hilo_interlocks, cop_interlocks): Make
65         these evaluate to true if mips_arch indicates SB-1.
66
67 2001-10-23  Alan Modra  <amodra@bigpond.net.au>
68
69         * as.c (parse_args): Print the date as well for --version.
70
71 2001-10-20  Chris Demetriou  <cgd@broadcom.com>
72
73         * config/tc-mips.c (md_show_usage): Print "sb1" for Broadcom
74         SB-1 CPU for consistency.
75         (mips_cpu_info_table): Tweak comment about SB-1.
76
77 2001-10-20  H.J. Lu  <hjl@gnu.org>
78
79         * config/tc-arm.c (do_c_shift): Use ISDIGIT instead of isdigit.
80         (cirrus_parse_offset): Likewise.
81
82 2001-10-19  Nick Clifton  <nickc@cambridge.redhat.com>
83
84         * config/tc-arm.c: Restore line_comment_chars.
85
86 2001-10-18  Nick Clifton  <nickc@cambridge.redhat.com>
87
88         * config/tc-arm.c (comment_chars): Remove semi-colon accidentally
89         added to the list.
90
91 2001-10-18  Hans-Peter Nilsson  <hp@bitrange.com>
92
93         * write.c (fixup_segment): Handle fixups for SEC_MERGE sections as
94         for undefined symbols.
95
96 2001-10-17  Chris Demetriou  <cgd@broadcom.com>
97
98         * doc/as.texinfo (MIPS ISA options):  Added accidentally
99         omitted "-mips64" option to list of options.
100
101 2001-10-17  matthew green  <mrg@redhat.com>
102
103         * config/tc-ppc.c (md_show_usage): Add missing -maltivec, -m7400,
104         -m7410, -m7450 and -m7455 options.
105
106 2001-10-17  Alan Modra  <amodra@bigpond.net.au>
107
108         * config/tc-ppc.c (PPC_HA, PPC_HIGHERA, PPC_HIGHESTA): Simplify.
109         (ppc_size): Select PPC_OPCODE_64 if 64 bit.
110         (md_begin): Don't set ppc_size here.
111         (ppc_target_format): Test ppc_size as well as BFD_DEFAULT_TARGET_SIZE.
112         (md_shortopts): Constify.
113         (md_longopts): Likewise.
114         (md_longopts_size): Likewise.
115         (ppc_elf_suffix): Only allow 64-bit relocs when ppc_size specifies
116         64-bit opcodes.
117         (ppc_machine): Explain why this function is a nop.
118
119 2001-10-17  Alan Modra  <amodra@bigpond.net.au>
120
121         * bit_fix.h: Comment typo fix.
122         * config/tc-mips.c: Likewise.
123         * config/tc-sh.c: Likewise.
124         * config/tc-arc.c (arc_code_symbol): Remove unnecessary test.
125
126         * configure.in (MIPS_STABS_ELF): AC_DEFINE in only one place so
127         that autoheader doesn't duplicate config.in entries.
128         (DEFAULT_ARCH): Ditto.
129         * configure: Regenerate.
130         * config.in: Regenerate.
131
132 2001-10-16  Alan Modra  <amodra@bigpond.net.au>
133
134         From Andrew Pines <apines@cosmodog.com>
135         * config/tc-m68k.c (m68k_ip): Correct absolute jmp opcodes.
136
137 2001-10-16  NIIBE Yutaka  <gniibe@m17n.org>,
138             Hans-Peter Nilsson  <hp@bitrange.com>
139
140         * config/tc-sh.c (shl): Remove.
141         (big): New function.
142         (little): Remove shl handling.  Emit error for endian mismatch.
143         (md_show_usage): Add description of -big.
144         (md_parse_option): Handle OPTION_BIG.  Remove shl handling.
145         (OPTION_BIG): Add.
146         (md_pseudo_table): Add .big.
147         (md_longopts): Add -big.
148         (md_begin): Don't set target_big_endian here.
149         * config/tc-sh.h (TARGET_BYTES_BIG_ENDIAN): Remove.
150         (LISTING_HEADER, COFF_MAGIC, TARGET_FORMAT): Use target_big_endian.
151         (shl): Remove.
152         * configure.in (endian): Default is big.
153         (sh-*-pe*): Little endian.
154         (cpu_type): Set sh for target sh*.
155         * configure: Regenerate.
156
157 2001-10-15  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
158
159         * config/tc-mips.c (md_apply_fix): Preliminary handling of NewABI
160         relocations.
161
162 2001-10-13  Nick Clifton  <nickc@cambridge.redhat.com>
163
164         * config/tc-arm.c: Replace CONST with const.
165
166         * cgen.c: Tidy up formatting.
167
168 2001-10-12  matthew green  <mrg@redhat.com>
169
170         * config/tc-ppc.c (md_parse_option): New -m7410, -m7450 and -m7455
171         flags, equivalent to -m7400.  New -maltivec to enable AltiVec
172         instructions.  New -mbook64 and -mbooke/-mbooke32 flags to enable
173         64-bit and 32-bit BookE support, respectively.  Change -m403 and
174         -m405 to set PPC403 option.
175         (md_show_usage): Adjust for new options.
176         * doc/all.texi: Set PPC.
177         * doc/as.texinfo: Add PPC support and pull in c-ppc.texi.
178         * doc/c-ppc.texi: New file.
179         * doc/Makefile.am (CPU_DOCS): Add c-ppc.texi.
180         * doc/Makefile.in: Regenerate.
181
182 2001-10-12  Nick Clifton  <nickc@cambridge.redhat.com>
183
184         * read.c (s_bad_endr): New function.  Issues a warning message
185         about a bad use of the .rept pseudo op.
186         (po_table[]): Add .endr.
187         * read.h: Prototype s_bad_endr.
188
189         * CONTRIBUTORS: Update contact email address.
190
191 2001-10-11  Kazu Hirata  <kazu@hxi.com>
192
193         * config/tc-alpha.c: Fix comment typos.
194         * config/tc-cris.c: Likewise.
195         * config/tc-hppa.c: Likewise.
196         * config/tc-i370.c: Likewise.
197         * config/tc-mips.c: Likewise.
198         * config/tc-mn10200.c: Likewise.
199         * config/tc-mn10300.c: Likewise.
200         * config/tc-sh.c: Likewise.
201         * config/tc-tahoe.c: Likewise.
202         * config/tc-v850.c: Likewise.
203
204 2001-10-11  Kazu Hirata  <kazu@hxi.com>
205
206         * app.c: Fix comment typos.
207         * bit_fix.h: Likewise.
208         * expr.c: Likewise.
209         * itbl-ops.c: Likewise.
210
211 2001-10-11  Nick Clifton  <nickc@cambridge.redhat.com>
212
213         * input-file.c: Include safe-ctype.h.
214         (input_file_open): Use ISSPACE instead of isspace.
215
216 2001-10-10  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
217
218         * config/tc-mips.c (mips_cpreturn_offset): New variable.
219         (mips_cpreturn_register): Likewise.
220         (mips_gp_register): Likewise.
221         (s_cpsetup): New function prototype.
222         (s_cplocal): Likewise.
223         (s_cpreturn): Likewise.
224         (s_gpvalue): Likewise.
225         (mips_pseudo_table): Add .cpsetup, .cplocal, .cpreturn, .gpvalue
226         pseudo-ops.
227         (macro): Don't warn about .cprestore for NewABI.
228         (md_pcrel_from): Code cleanup.
229         (mips_force_relocation): Force output of some NewABI relocations even
230         without a defined symbol.
231         (s_cpload): Ignore .cpload for NewABI.
232         (s_cpsetup): Handle .cpsetup.
233         (s_cplocal): Handle .cplocal.
234         (s_cprestore): Ignore .cprestore for NewABI.
235         (s_cpreturn): Handle .cpreturn.
236         (s_gpvalue): Handle .gpvalue.
237         (s_cpadd): Ignore .cpadd for NewABI.
238         (nopic_need_relax): Take g_switch_value into account as gp
239         optimization.
240         (tc_gen_reloc): Don't handle BFD_RELOC_MIPS_{CALL,GOT}* for NewABI.
241
242 2001-10-10  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
243
244         * config/tc-mips.c (my_getSmallParser): New function prototype.
245         (small_ex_type): Named this enum, more return values for
246         my_getSmallExpression.
247         (mips_ip): Allow SPC and HT between arguments. Handle some NewABI
248         triple relocations. Protect some parts with ifdef OBJ_ELF.
249         (percent_op_match): New struct, lookup table for %some_reloc().
250         (my_getSmallParser): New function, parses nested percent_ops also.
251         (my_getSmallExpression): Rewite to support nested percent_ops.
252
253 2001-10-10  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
254
255         * config/tc-mips.c
256         (load_address): Support both 32- and 64-bit addresses.
257         (macro): Call load_register correctly. Expand 64-bit loads ans stores.
258         (macro2): Call load_address correctly.
259
260 2001-10-09  Christian Groessler <cpg@aladdin.de>
261
262         * config/tc-z8k.c: Include opcodes/z8k-opc.h after bfd.h
263         since z8k-opc.h now uses the PARAMS macro.
264
265 2001-10-09  Aldy Hernandez  <aldyh@redhat.com>
266
267         * config/tc-arm.c: Change MAVERIK to MAVERICK.
268
269 2001-10-09  Alan Modra  <amodra@bigpond.net.au>
270
271         * config/obj-elf.c: Make use of elf_group_name and elf_next_in_group
272         throughout file.
273         (obj_elf_change_section): Rename "group" to "group_name".
274         (obj_elf_section): Likewise.
275         (elf_frob_file): Don't use sec->lineno for SHT_GROUP section to store
276         first member section; Instead use elf_next_in_group.
277
278 2001-10-09  Alan Modra  <amodra@bigpond.net.au>
279
280         * config/obj-elf.c: (obj_elf_change_section): Add "group" param.
281         Set elf_section_data group from it.  Warn if group name changed.
282         (obj_elf_parse_section_letters): Parse 'G' too.
283         (obj_elf_section): Parse group name.
284         (struct group_list): New.
285         (build_group_lists): New function.
286         (elf_frob_file): Create SEC_GROUP section(s).
287
288         * config/obj-elf.c: (elf_copy_symbol_attributes): Zap trailing
289         whitespace.
290
291 2001-10-08  Aldy Hernandez  <aldyh@redhat.com>
292
293         * doc/arm/c-arm.texi (ARM Options): Add arm9e documentation.
294
295         * config/tc-arm.c (ARM_EXT_MAVERIK): New macro.
296         (cirrus_regtype): New enum.
297         (LONGEST_INST): Change to 10.
298         (CIRRUS_MODE1): New.
299         (CIRRUS_MODE2): New.
300         (CIRRUS_MODE3): New.
301         (CIRRUS_MODE4): New.
302         (CIRRUS_MODE5): New.
303         (CIRRUS_MODE6): New.
304         (insns): Add cirrus dsp instructions.
305         (ARM_EXT_MAVERIKSC_REG): New.
306         (cirrus_register): New.
307         (cirrus_mvf_register): New.
308         (cirrus_mvd_register): New.
309         (cirrus_mvfx_register): New.
310         (cirrus_mvdx_register): New.
311         (cirrus_mvax_register): New.
312         (ARM_EXT_MAVERIKsc_register): New.
313         (reg_table): Add cirrus registers.
314         (cirrus_valid_reg): New.
315         (cirrus_reg_required_here): New.
316         (do_c_binops_1): New.
317         (do_c_binops_2): New.
318         (do_c_binops_3): New.
319         (do_c_triple_4): New.
320         (do_c_triple_5): New.
321         (do_c_quad_6): New.
322         (do_c_dspsc_1): New.
323         (do_c_dspsc_2): New.
324         (do_c_shift_1): New.
325         (do_c_shift_2): New.
326         (do_c_ldst_1): New.
327         (do_c_ldst_2): New.
328         (do_c_ldst_3): New.
329         (do_c_ldst_4): New.
330         (do_c_binops): New.
331         (do_c_triple): New.
332         (do_c_quad): New.
333         (do_c_dspsc): New.
334         (do_c_shift): New.
335         (cirrus_parse_offset): New.
336         (do_c_ldst): New.
337         (md_parse_option): Add arm9e.
338         (md_show_usage): Same.
339
340 2001-10-08  Tom Rix <trix@redhat.com>
341
342         * config/tc-ppc (ppc_bf, ppc_biei) : Set first .bi lineno value to 
343         location of next .bf
344         * config/obj-coff.c (coff_frob_symbol) : XCOFF does not use endndx.
345
346 2001-10-07  Alan Modra  <amodra@bigpond.net.au>
347
348         * config/obj-elf.c: Standardize error/warning messages - don't
349         capitalise, no final period or newline, don't say "ignoring" for
350         as_bad messages.  In some cases, change the wording to that used
351         elsewhere for similar messages.
352         (obj_elf_section_name): New function, split out from ..
353         (obj_elf_section): .. here.  Correctly mask off SHF_MERGE if
354         entsize not specified.
355
356 2001-10-05  Jakub Jelinek  <jakub@redhat.com>
357
358         * doc/as.texinfo: Document M and S ELF section flags.
359
360 2001-10-05  Alan Modra  <amodra@bigpond.net.au>
361
362         * subsegs.c (subseg_text_p): Return 0 for absolute section.
363         * read.c (do_align): If in absolute section, warn about and ignore
364         non-zero fill pattern.
365
366 2001-10-05  Alexandre Oliva  <aoliva@redhat.com>
367
368         * config/tc-mn10300.c (tc_gen_reloc): Don't free
369         reloc->sym_ptr_ptr if it's not allocated.
370
371 2001-10-04  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
372
373         * config/tc-mips.c (prev_insn_reloc_type): Make it an array to hold a
374         relocation triple.
375         (prev_insn_fixp): Likewise.
376         (append_insn): Changed prototype to accept a relocation pointer.
377         (imm_reloc): Make it an array.
378         (offset_reloc): Likewise.
379         (md_assemble): Handle triple relocations.
380         (append_insn): Likewise. Add handling for some NewABI relocations.
381         (mips_no_prev_insn): Handle triple relocations.
382         (macro_build): Likewise. Add handling for some NewABI relocations.
383         Move handling for the 'u' case to append_insn().
384         (mips16_macro_build): Handle triple relocations.
385         (macro_build_lui): Likewise. Don't handle _gp_disp as special symbol
386         for NewABI.
387         (mips_ip): Handle triple relocations.
388         (mips16_ip): Likewise.
389         (mips_force_relocation): Force handling of triple relocations
390         without symbols for NewABI.
391         (md_apply_fix): Add handling for some NewABI relocations.
392
393 2001-10-05  Alan Modra  <amodra@bigpond.net.au>
394
395         * config/tc-i386.c (parse_register): If not producing code for
396         x86_64, reject x86_64 register name matches.
397         (md_assemble): Remove now redundant check for x86_64 regs.
398
399 2001-10-04  Alan Modra  <amodra@bigpond.net.au>
400
401         * config/tc-ppc.c (md_assemble <DS relocs>): Test ppc_size as well
402         as BFD_DEFAULT_TARGET_SIZE.
403         (ppc_tc): Likewise.
404         (ppc_is_toc_sym): Likewise.
405         (md_apply_fix3): Likewise.
406
407 2001-10-03  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
408
409         * config/tc-mips.c (mips_64): Remove.
410         (mips_target_format): Move downwards in file, use HAVE_64BIT_OBJECTS
411         in it.
412         (mips_abi_level, mips_abi): New enum.
413         (mips_32bit_abi): Remove.
414         (HAVE*PRS): Use mips_abi instead of mips_32bit_abi.
415         (HAVE_NEWABI): New define.
416         (HAVE_64BIT_OBJECTS): New define.
417         (HAVE_32BIT_ADDRESSES): Don't return true for 64bit objects.
418         (HAVE_64BIT_ADDRESSES): New define, inverse of HAVE_32BIT_ADDRESSES.
419         (support_64bit_objects): New prototype.
420         (md_begin): Use mips_abi instead of mips_32bit_abi. Don't write
421         .reginfo section for n32, use .MIPS.options instead.
422         (support_64bit_objects): New function, code from md_parse_option.
423         (md_longopts): Add -n32 option.
424         (md_parse_option): Use mips_abi instead of mips_32bit_abi/mips64.
425         Add -n32 option. Protect with OBJ_ELF.
426         (s_mipsset): Use mips_abi instead of mips_32bit_abi.
427         (mips_elf_final_processing): Likewise. Don't write .reginfo section
428         for n32, use .MIPS.options instead.
429
430 2001-10-03  Alan Modra  <amodra@bigpond.net.au>
431
432         * po/POTFILES.in: Regenerate.
433         * configure: Regenerate.
434
435 2001-10-02  Alan Modra  <amodra@bigpond.net.au>
436
437         * config/tc-ppc.c (md_apply_fix3 <BFD_RELOC_CTOR>): Make it 64
438         bits if target is 64 bit.
439
440         * doc/as.texinfo (listing): Fix typo.
441
442         * as.c (print_version_id): Use BFD_VERSION_STRING in place of
443         BFD_VERSION.
444         * Makefile.am (Makefile): Depend on bfd/configure.in.
445         Run "make dep-am".
446         * Makefile.in: Regenerate.
447
448 2001-09-30  H.J. Lu  <hjl@gnu.org>
449
450         * config/obj-elf.c (obj_elf_parse_section_letters): Accept "am"
451         and "ams" for compatibility.
452
453 2001-09-30  Hans-Peter Nilsson  <hp@bitrange.com>
454
455         * config/tc-sh.c (md_pcrel_from_section): Transformed from
456         md_pcrel_from.  Handle pc-relativeness against link-time
457         symbol.  Handle relativeness to elsewhere than the fixup.
458         * config/tc-sh.h (MD_PCREL_FROM_SECTION): Define.
459         (md_pcrel_from_section): Prototype.
460
461         * Makefile.am: Update dependencies with "make dep-am".
462         * Makefile.in: Regenerate.
463
464 2001-09-30  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
465
466         * config/tc-m68hc11.c (cmp_opcode): Define prototype.
467         (print_opcode_format, skip_whites): Likewise.
468         (convert_branch, m68hc11_new_insn): Likewise.
469         (build_dbranch_insn, build_indexed_byte): Likewise.
470         (build_reg_mode, find, find_opcode): Likewise.
471         (print_insn_format): Fix call to print_opcode_format.
472         (md_assemble): Fix call to build_dbranch_insn.
473
474 2001-09-27  Nick Clifton  <nickc@cambridge.redhat.com>
475
476         * config/tc-arm.c: Add missing prototypes.
477
478 2001-09-26  Jeff Johnston  <jjohnstn@redhat.com>
479
480         * input-file.c (input_file_open): When reading the
481         first line looking for #NO_APP, prepare for the possibility
482         of finding #APP instead.  Also fix algorithm to allow
483         white-space to follow either #NO_APP or #APP directives.
484
485 2001-09-25  Geoff Berry  <geoff.berry@bops.com>
486
487         * listing.c (buffer_line): Don't write past the end of `line' when
488         EOF is reached.
489
490 2001-09-25  Alexandre Oliva  <aoliva@redhat.com>
491
492         * config/tc-mn10300.c (tc_gen_reloc): Don't emit an *ABS*
493         relocation for differences between symbols in a section other
494         than the one in which the difference is to be placed; apply
495         the relocation instead.
496
497 2001-09-24  Nick Clifton  <nickc@cambridge.redhat.com>
498
499         * config/tc-arc.c: Add missing prototype.
500         (md_atof): Change type to int. Add missing prototype.
501         * config/tc-arc.h: Prototype exported functions.
502
503 2001-09-22  Nick Clifton  <nickc@cambridge.redhat.com>
504
505         * as.c: Add missing function prototype.
506         * config/obj-aout.c: Fix compile time warning.
507
508 2001-09-21  Bruno Haible  <haible@clisp.cons.org>
509
510         * config/tc-openrisc.c: Don't include <ctype.h>.
511
512 2001-09-19  Martin Schwidefsky <schwidefsky@de.ibm.com>
513
514         * gas/config/tc-s390.c: Add option -mwarn-areg-zero.
515
516 2001-09-19  Alan Modra  <amodra@bigpond.net.au>
517
518         * config/tc-i370.c: Fix typo in last change.
519
520 2001-09-19  Nick Clifton  <nickc@cambridge.redhat.com>
521
522         * doc/as.texinfo (Symbol Names): Improve documentation on local
523         labels and add documenation about dollar labels.
524
525 2001-09-18  Bruno Haible  <haible@clisp.cons.org>
526
527         * as.h: Don't include <ctype.h>.
528         * as.c (main): For gettext, also set the LC_CTYPE locate facet.
529         * atof-generic.c: Include "safe-ctype.h" instead of <ctype.h>.
530         (atof_generic): Use ISDIGIT instead of isdigit.
531         * config/m68k-parse.y: Include "safe-ctype.h".
532         (yylex): Use ISDIGIT/ISALNUM instead of isdigit/isalnum.
533         * config/obj-elf.c: Include "safe-ctype.h".
534         (obj_elf_vtable_inherit): Use ISSPACE instead of isspace.
535         * config/obj-vms.c: Include "safe-ctype.h".
536         (Write_VMS_MHD_Records): Use TOUPPER instead of islower/toupper.
537         (VMS_Case_Hack_Symbol): Use ISUPPER/ISLOWER/TOUPPER/TOLOWER
538         instead of isupper/islower/toupper/tolower.
539         * config/tc-a29k.c: Include "safe-ctype.h" instead of <ctype.h>.
540         (insert_sreg): Use TOUPPER instead of islower/toupper.
541         (machine_ip): Use ISALPHA/ISALNUM/ISUPPER/TOLOWER instead of
542         isalpha/isalnum/isupper/tolower.
543         (a29k_unrecognized_line, md_operand): Use ISDIGIT instead of
544         isdigit.
545         * config/tc-alpha.c: Include "safe-ctype.h" instead of <ctype.h>.
546         (md_undefined_symbol, s_alpha_ent): Use ISDIGIT instead of isdigit.
547         * config/tc-arc.c: Include "safe-ctype.h" instead of <ctype.h>.
548         (md_assemble): Use ISSPACE/ISALNUM instead of isspace/isalnum.
549         (arc_extoper): Use TOLOWER instead of isupper/tolower.
550         * config/tc-arm.c: Include "safe-ctype.h" instead of <ctype.h>.
551         (arm_psr_parse): Use ISALPHA instead of isalpha.
552         (accum0_required_here): Use ISALNUM instead of isalnum.
553         (do_ldrd): Use ISSPACE instead of isspace.
554         (decode_shift): Use ISALPHA instead of isalpha.
555         (insert_reg): Use TOUPPER instead of islower/toupper.
556         (arm_reg_parse): Use ISALPHA instead of isalpha.
557         (arm_parse_reloc): Use ISALNUM/ISPUNCT/TOLOWER instead of
558         isalnum/ispunct/tolower.
559         * config/tc-avr.c: Include "safe-ctype.h" instead of <ctype.h>.
560         (md_parse_option): Use TOLOWER instead of tolower.
561         (avr_operand): Use ISDIGIT/TOLOWER instead of isdigit/tolower.
562         * config/tc-cris.c: Include "safe-ctype.h" instead of <ctype.h>.
563         (cris_process_instruction): Use ISLOWER instead of islower.
564         (get_gen_reg): Use ISALNUM/ISDIGIT instead of isalnum/isdigit.
565         (get_spec_reg): Use TOLOWER/ISALNUM instead of isupper/tolower/isalnum.
566         (get_flags): Use ISSPACE instead of isspace.
567         * config/tc-d10v.c: Include "safe-ctype.h" instead of <ctype.h>.
568         (do_assemble): Use TOLOWER instead of tolower.
569         * config/tc-d30v.c: Include "safe-ctype.h" instead of <ctype.h>.
570         (do_assemble): Use TOLOWER instead of tolower.
571         (d30v_start_line): Use ISSPACE instead of isspace.
572         * config/tc-fr30.c: Include "safe-ctype.h" instead of <ctype.h>.
573         (fr30_is_colon_insn): Use TOLOWER instead of tolower.
574         * config/tc-h8300.c: Include "safe-ctype.h" instead of <ctype.h>.
575         (skip_colonthing, get_operand): Use ISDIGIT instead of isdigit.
576         * config/tc-h8500.c: Include "safe-ctype.h" instead of <ctype.h>.
577         (start_label): Use ISALPHA instead of isalpha.
578         * config/tc-hppa.c: Include "safe-ctype.h" instead of <ctype.h>.
579         (pa_ip): Use ISUPPER/ISLOWER/TOLOWER instead of
580         isupper/islower/tolower.
581         (pa_parse_number): Use ISDIGIT instead of isdigit.
582         (pa_chk_field_selector): Use TOLOWER instead of tolower.
583         (pa_stringer): Use ISDIGIT instead of isdigit.
584         * config/tc-i370.c: Include "safe-ctype.h" instead of <ctype.h>.
585         (register_name): Use ISALPHA instead of isalpha.
586         (i370_elf_suffix): Use ISALNUM/TOLOWER instead of
587         isalnum/islower/tolower.
588         (i370_addr_offset): Use ISDIGIT/ISALPHA instead of
589         isdigit/isalpha.
590         (i370_addr_cons): Use ISALPHA/ISXDIGIT instead of
591         isalpha/isxdigit.
592         (md_assemble): Use ISSPACE instead of isspace.
593         * config/tc-i386.c: Include "safe-ctype.h" instead of <ctype.h>.
594         (md_begin): Use ISDIGIT/ISLOWER/ISUPPER/TOLOWER/ISALPHA
595         instead of isdigit/islower/isupper/tolower/isalpha.
596         (output_invalid): Use ISPRINT instead of isprint.
597         * config/tc-i860.c: Include "safe-ctype.h" instead of <ctype.h>.
598         (i860_ip): Use ISLOWER/ISDIGIT instead of islower/isdigit.
599         * config/tc-i960.c: Include "safe-ctype.h" instead of <ctype.h>.
600         (get_args): Use ISALNUM instead of isalnum.
601         * config/tc-ia64.c: Include "safe-ctype.h".
602         (dot_pred_rel): Use TOUPPER/ISDIGIT instead of toupper/isdigit.
603         (ia64_unrecognized_line): Use ISDIGIT instead of isdigit.
604         (ia64_parse_name): Likewise.
605         * config/tc-m32r.c: Include "safe-ctype.h" instead of <ctype.h>.
606         (assemble_two_insns): Use ISSPACE/ISALNUM/ISUPPER/TOLOWER
607         instead of isspace/isalnum/isupper/tolower.
608         * config/tc-m68hc11.c: Include "safe-ctype.h" instead of <ctype.h>.
609         (md_assemble): Use TOLOWER/ISALNUM instead of tolower/isalnum.
610         * config/tc-m68k.c: Include "safe-ctype.h" instead of <ctype.h>.
611         (mklower_table): Remove variable.
612         (mklower): Remove macro.
613         (insert_reg): Use TOUPPER instead of islower/toupper.
614         (md_begin): Remove initialization of mklower_table.
615         (s_reg): Use ISALNUM instead of isalnum.
616         (mri_assemble): Use ISUPPER/TOLOWER instead of isupper/tolower.
617         (parse_mri_condition): Use TOLOWER instead of isupper/tolower.
618         (build_mri_control_operand): Use TOLOWER instead of tolower.
619         (s_mri_else, s_mri_break, s_mri_next, s_mri_for): Likewise.
620         * config/tc-m88k.c: Include "safe-ctype.h" instead of <ctype.h>.
621         (md_assemble): Use ISSPACE instead of isspace.
622         (get_imm16): Use ISALNUM instead of isalnum.
623         (get_cnd): Use ISDIGIT/ISUPPER/TOLOWER instead of
624         isdigit/isupper/tolower.
625         (get_bf_offset_expression): Use ISALPHA/ISUPPER/TOLOWER
626         instead of isalpha/isupper/tolower.
627         (hexval): Use ISDIGIT/ISLOWER/ISUPPER instead of
628         isdigit/islower/isupper.
629         * config/tc-mcore.c: Include "safe-ctype.h" instead of <ctype.h>.
630         (mcore_s_section): Use ISSPACE instead of isspace.
631         (parse_reg): Use ISSPACE/TOLOWER/ISALNUM instead of
632         isspace/tolower/isalnum.
633         (parse_creg): Use ISSPACE/TOLOWER instead of isspace/tolower.
634         (parse_psrmod): Use TOLOWER instead of isascii/tolower.
635         (parse_exp, parse_mem, md_assemble): Use ISSPACE instead of
636         isspace.
637         * config/tc-mips.c: Include "safe-ctype.h" instead of <ctype.h>.
638         (mips_ip): Use ISSPACE/ISDIGIT instead of isspace/isdigit.
639         (mips16_ip): Use ISLOWER/ISDIGIT instead of islower/isdigit.
640         (my_getSmallExpression): Use ISDIGIT/TOLOWER instead of
641         isdigit/tolower.
642         (tc_get_register): Likewise.
643         (get_number): Use ISDIGIT/ISXDIGIT instead of isdigit/isxdigit.
644         (s_mips_ent): Use ISDIGIT instead of isdigit.
645         * config/tc-mn10200.c: Include "safe-ctype.h" instead of <ctype.h>.
646         (md_assemble): Use ISSPACE instead of isspace.
647         * config/tc-mn10300.c: Include "safe-ctype.h" instead of <ctype.h>.
648         (md_assemble): Use ISSPACE instead of isspace.
649         * config/tc-ns32k.c: Don't include <ctype.h>.
650         * config/tc-pdp11.c: Include "safe-ctype.h".
651         (mklower): Remove function.
652         (parse_reg): Use TOLOWER instead of mklower.
653         * config/tc-pj.c: Include "safe-ctype.h".
654         (md_assemble): Use ISSPACE instead of isspace.
655         * config/tc-ppc.c: Include "safe-ctype.h" instead of <ctype.h>.
656         (register_name): Use ISALPHA instead of isalpha.
657         (ppc_elf_suffix): Use ISALNUM/TOLOWER instead of
658         isalnum/islower/tolower.
659         (md_assemble): Use ISSPACE instead of isspace.
660         (ppc_canonicalize_symbol_name): Use ISLOWER/TOUPPER instead of
661         islower/toupper.
662         * config/tc-s390.c: Include "safe-ctype.h" instead of <ctype.h>.
663         (register_name): Use ISALPHA instead of isalpha.
664         (s390_elf_suffix, s390_lit_suffix): Use ISALNUM instead of isalnum.
665         (md_gather_operands, md_assemble, s390_insn): Use ISSPACE instead of
666         isspace.
667         * config/tc-sh.c: Include "safe-ctype.h" instead of <ctype.h>.
668         (sh_elf_suffix): Use ISALNUM/TOLOWER instead of
669         isalnum/islower/tolower.
670         (IDENT_CHAR): Use ISALNUM instead of isalnum.
671         (parse_reg): Use TOLOWER instead of tolower.
672         (find_cooked_opcode): Use TOLOWER instead of isupper/tolower.
673         * config/tc-sparc.c: Include "safe-ctype.h" instead of <ctype.h>.
674         (sparc_ip): Use ISLOWER/ISDIGIT instead of islower/isdigit.
675         (parse_keyword_arg): Use ISALNUM instead of isalnum.
676         * config/tc-tahoe.c: Include "safe-ctype.h".
677         (tahoe_reg_parse): Use ISDIGIT instead of isdigit.
678         (tip_op): Use TOLOWER instead of isupper/tolower.
679         * config/tc-tic30.c: Include "safe-ctype.h".
680         (md_begin): Use ISLOWER/ISDIGIT/ISUPPER/TOLOWER/ISLOWER/
681         ISALPHA instead of islower/isdigit/isupper/tolower/islower/isalpha.
682         (tic30_operand): Use TOLOWER instead of tolower.
683         (tic30_find_parallel_insn): Likewise.
684         (output_invalid): Use ISPRINT instead of isprint.
685         * config/tc-tic54x.c: Include "safe-ctype.h".
686         (tic54x_asg, tic54x_eval): Use ISALPHA instead of isalpha.
687         (lookup_version): Use TOUPPER instead of toupper.
688         (tic54x_var): Use ISALPHA instead of isalpha.
689         (tic54x_mlib): Use ISSPACE instead of isspace.
690         (subsym_iscons): Use TOUPPER instead of toupper.
691         (get_operands): Use ISSPACE instead of isspace.
692         (is_type): Use TOUPPER/ISDIGIT instead of toupper/isdigit.
693         (encode_indirect, encode_operand): Use TOUPPER instead of toupper.
694         (next_line_shows_parallel): Use ISSPACE instead of isspace.
695         (subsym_get_arg, subsym_substitute): Use ISDIGIT instead of isdigit.
696         (tic54x_start_line_hook, md_assemble, tic54x_start_label): Use
697         ISSPACE instead of isspace.
698         * config/tc-tic80.c: Include "safe-ctype.h".
699         (md_assemble): Use ISSPACE instead of isspace.
700         * config/tc-v850.c: Include "safe-ctype.h" instead of <ctype.h>.
701         (system_register_name): Use ISDIGIT instead of isdigit.
702         (md_assemble): Use ISSPACE instead of isspace.
703         * config/tc-vax.c: Include "safe-ctype.h" instead of <ctype.h>.
704         (vax_reg_parse): Use TOLOWER/ISDIGIT instead of
705         isupper/tolower/isdigit.
706         (vip_op): Use TOLOWER instead of isupper/tolower.
707         * config/tc-w65.c: Don't include <ctype.h>.
708         * config/tc-z8k.c: Include "safe-ctype.h" instead of <ctype.h>.
709         (tohex): Use ISDIGIT/ISLOWER instead of isdigit/islower.
710         (whatreg): Use ISDIGIT instead of isdigit.
711         * ecoff.c: Include "safe-ctype.h" instead of <ctype.h>.
712         (ecoff_directive_ent, ecoff_stab): Use ISDIGIT instead of isdigit.
713         * expr.c: Include "safe-ctype.h" instead of <ctype.h>.
714         (integer_constant): Use ISALNUM/TOUPPER instead of
715         isalnum/islower/toupper.
716         (operand): Use TOLOWER instead of isupper/tolower.
717         * gasp.c: Include "safe-ctype.h" instead of <ctype.h>.
718         (sb_strtol, level_0, change_base, doinstr): Use ISDIGIT instead
719         of isdigit.
720         (process_assigns, whatcond): Use TOUPPER instead of toupper.
721         (chartype_init): Use ISALPHA/ISDIGIT instead of isalpha/isdigit.
722         (main): For gettext, also set the LC_CTYPE locate facet.
723         * hash.c: Include "safe-ctype.h".
724         (main): Use TOLOWER instead of isupper/tolower.
725         * itbl-lex.l: Don't include <ctype.h>.
726         * listing.c: Include "safe-ctype.h" instead of <ctype.h>.
727         (listing_newline): Use ISCNTRL instead of isascii/iscntrl. Don't
728         omit non-ASCII characters.
729         (debugging_pseudo): Use ISSPACE instead of isspace.
730         * macro.c: Include "safe-ctype.h" instead of <ctype.h>.
731         (buffer_and_nest): Use ISALNUM instead of isalnum.
732         (get_token): Use ISALPHA/ISALNUM instead of isalpha/isalnum.
733         (define_macro): Use ISUPPER/TOLOWER instead of isupper/tolower.
734         (macro_expand_body): Use ISALNUM/ISDIGIT/ISUPPER/ISALPHA
735         instead of isalnum/isdigit/isupper/isalpha.
736         (check_macro): Use ISALPHA/ISALNUM/ISUPPER/TOLOWER instead
737         of isalpha/isalnum/isupper/tolower.
738         * read.c: Include "safe-ctype.h" instead of <ctype.h>.
739         (read_a_source_file): Use ISUPPER/TOLOWER/ISDIGIT instead of
740         isupper/tolower/isdigit.
741         (s_mri_common): Use ISDIGIT instead of isdigit.
742         (s_mri_sect): Use ISDIGIT/TOUPPER instead of isdigit/toupper.
743         (s_float_space): Use ISALPHA instead of isalpha.
744         (ignore_rest_of_line): Use ISPRINT instead of isprint.
745         (float_cons): Use ISALPHA instead of isalpha.
746         (next_char_of_string): Use ISDIGIT/ISXDIGIT instead of
747         isdigit/isxdigit.
748         * symbols.c: Include "safe-ctype.h" instead of <ctype.h>.
749         (save_symbol_name): Use ISLOWER/TOUPPER instead of
750         islower/toupper.
751         (symbol_find_base): Use TOUPPER instead of islower/toupper.
752         (decode_local_label_name): Use ISDIGIT instead of isdigit.
753
754 2001-09-18  Martin Schwidefsky <schwidefsky@de.ibm.com>
755
756         * tc-s390.c (s390_insn): Add code to cope with 6 byte O_constants
757         in 64 bit mode and make format "e" work.
758
759 2001-09-18  Alan Modra  <amodra@bigpond.net.au>
760
761         * dwarf2dbg.c (dwarf2_directive_file): Avoid signed/unsigned warning.
762
763         * write.c (set_symtab): Update bfd_alloc declaration.  Use a temp
764         var to ensure bfd_alloc arg is the right type.
765         (write_object_file): Cast args of bfd_seek.  Replace bfd_write with
766         bfd_bwrite.
767
768         * config/obj-coff.c: Replace calls to bfd_write with calls to
769         bfd_bwrite.  Cast args of bfd_seek.
770
771         * config/obj-elf.c (obj_elf_change_section): Avoid signed/unsigned
772         warning.
773
774         * config/tc-mn10300.c (set_arch_mach): Make param unsigned.
775
776         * config/tc-tic54x.c (tic54x_mlib): Replace bfd_read call with
777         call to bfd_bread.
778
779 2001-09-15  Hans-Peter Nilsson  <hp@bitrange.com>
780
781         * config/tc-sh.h (sh_force_relocation): Prototype.
782         (struct fix): Forward declare.
783         * config/tc-sh.c (type sh_operand_info): Move to top of file.
784         (cons, s_align_bytes): Remove old-type declarations.
785         (sh_elf_suffix, parse_reg, dot, parse_exp, parse_at, get_operand,
786         get_operands, get_specific, insert, build_relax,
787         insert_loop_bounds, build_Mytes): Prototype.
788         (little): Make static.  Prototype.
789         (check, tc_Nout_fix_to_chars): Delete unused functions.
790
791 2001-09-14  Eric Christopher  <echristo@redhat.com>
792
793         * config/tc-mips.c (md_parse_option): Remove setting mips_64 via
794         -mgp32/mgp64.
795
796 2001-09-14  Kevin Lo <kevlo@openbsd.org>
797
798         * configure.in: Add arm-openbsd target.
799         * configure: Regenerate.
800
801 2001-09-14  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
802
803         * configure.in: Change machine triplets from mips-*-linux-gnu* to
804         mips*-*-linux*.
805
806 2001-09-12  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
807
808         * config/tc-mips.c (append_insn): Don't rightshift BFD_RELOC_16_PCREL.
809
810 2001-09-11  Richard Henderson  <rth@redhat.com>
811
812         * config/tc-alpha.c (alpha_elf_section_letter): New.
813         (alpha_elf_section_flags): New.
814         * config/tc-alpha.h (md_elf_section_letter): New.
815         (md_elf_section_flags): New.
816         * config/tc-ia64.c (ia64_elf_section_letter): New.
817         * config/tc-ia64.h (md_elf_section_letter): New.
818
819 2001-09-11  Jakub Jelinek  <jakub@redhat.com>
820
821         * config/obj-elf.c (obj_elf_parse_section_letters): Use 'M' instead
822         of 'm', 'S' instead of 's'.  Update bad_msg.
823         * config/tc-ppc.c (ppc_section_letter): Update bad_msg.
824         * config/tc-i370.c (i370_sectioN_letter): Update bad_msg.
825
826 2001-09-09  Alan Modra  <amodra@bigpond.net.au>
827
828         * expr.c (expr): Move code setting "retval" to the end of the loop,
829         and rearrange for efficiency.  For "PIC code" subtraction, use
830         "rightseg" rather than recalculating.  For "symbol OP symbol"
831         subtract, set "retval" to absolute_section if symbols in same
832         section.
833         * symbols.c (resolve_symbol_value): Resolve "sym +/- expr" to an
834         O_symbol.  Simplify a +/- b code.  Allow equality and non-equality
835         comparisons on symbols from any section.  Allow other comparison
836         operators as for subtraction.
837         (symbol_equated_reloc_p): New predicate function.
838         * symbols.h (symbol_equated_reloc_p): Declare.
839         * write.c (relax_segment <rs_machine_dependent>): Ensure segment
840         for expression syms is set correctly.
841         (adjust_reloc_syms): Use symbol_equated_reloc_p.
842         (write_relocs): Likewise.
843         (write_object_file): Likewise.
844         * config/tc-mips.c (md_estimate_size_before_relax): Likewise.
845         * config/tc-i386.c (md_assemble <Output jumps>): Don't lose part
846         of a complex expression when setting up frag_var.
847
848 2001-09-07  Richard Henderson  <rth@redhat.com>
849
850         * config/tc-alpha.c (alpha_reloc_op_tag): Replace need_seq with
851         require_seq and allow_seq.  Let !literal omit the sequence number.
852         (tokenize_arguments): Reject sequence numbers of !allow_seq.
853
854 2001-09-08  Jakub Jelinek  <jakub@redhat.com>
855
856         * config/tc-sparc.c (md_apply_fix3): Handle relocs against SEC_MERGE
857         section symbols the same way as externs.
858
859 2001-09-07  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
860
861         * config/tc-mips.c (s_mipsset): Reallow unrestricted use of .set mipsX
862         pseudo-op.
863
864 2001-09-07  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
865
866         * config/tc-mips.c (append_insn): Handle BFD_RELOC_16_PCREL.
867         (macro_build): Use BFD_RELOC_16_PCREL_S2 only for embedded
868         PIC, BFD_RELOC_16_PCREL for the rest.
869         (mips_ip): Likewise.
870         (md_pcrel_from): return the right offset for the differently shifted
871         pcrel relocs.
872         (md_apply_fix): Handle BFD_RELOC_16_PCREL.
873
874 2001-09-05  Richard Henderson  <rth@redhat.com>
875
876         * config/tc-ia64.c (FUNC_IPLT_RELOC): New.
877         (pseudo_func): Add @iplt.
878         (pseudo_opcode): Add data16 and data16.ua.
879         (md_begin): Set iplt pseudo.
880         (ia64_cons_fix_new): Handle 16 byte iplt reloc specially.
881
882 2001-09-04  Richard Henderson  <rth@redhat.com>
883
884         * config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
885         (MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
886         (alpha_macros): Remove occurrences of same.
887         (O_lituse_addr, O_gprel): New.
888         (DUMMY_RELOC_LITUSE_*): New.
889         (s_alpha_ucons, s_alpha_arch): Prototype.
890         (alpha_reloc_op): Construct elements via DEF macro.
891         (ALPHA_RELOC_SEQUENCE_OK): Remove.
892         (struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
893         members to not be literal specific.
894         (next_sequence_num): New.
895         (md_apply_fix3): Cope with missing GPDISP_LO16.  Adjust for
896         added/removed BFD relocations.
897         (alpha_force_relocation, alpha_fix_adjustable): Likewise.
898         (alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
899         (tokenize_arguments): Parse ! relocations properly.
900         (find_macro_match): Delete unused macro argument types.
901         (assemble_insn): Add reloc parameter; emit that instead of the
902         default as appropriate.
903         (get_alpha_reloc_tag): New.  Split from ...
904         (emit_insn): ... here.  Allocate a reloc tag for GPDISP.
905         (assemble_tokens): Don't search macros if user relocation present.
906         Copy reloc sequence number to insn struct.
907         (emit_ldgp): Remove user reloc handling.
908         (load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
909         (emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
910         (emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
911         * config/tc-alpha.h (tc_adjust_symtab): Always define.
912         (struct alpha_fix_tag): Name members less literal specific.
913
914 Tue Sep  4 20:01:19 2001  Jeffrey A Law  (law@cygnus.com)
915
916         * tc-h8300.c (tc_gen_reloc): Give an error if we try to take the
917         address of two symbols in different sections.
918
919 2001-08-31  Eric Christopher  <echristo@redhat.com>
920             Jason Eckhardt  <jle@redhat.com>
921
922         * config/tc-mips.c (mips_cpu_info): Add support for mipsisa32,
923         5kc, and 20kc.  Clean up old entries.
924
925 Fri Aug 31 12:05:13 2001  J"orn Rennecke <amylaar@redhat.com>
926                           Jeff Law <law@redhat.com>
927
928         * config/tc-h8300.c (build_bytes): For OBJ_ELF, make relocation's
929         offset match H8 ELF spec.
930         (md_section_align): Alternate implementation for BFD_ASSEMBLER.
931         (md_apply_fix): Fix argument and return types for BFD_ASSEMBLER.
932
933         * tc-h8300.c (relocation mappings): Remove.  Moved to tc-h8300.h.
934         (build_bytes): Mark fixups for PCrel branches as signed.  For
935         OBJ_ELF, make sure the reloc's offset points to the first byte
936         to be modified.
937         (md_convert_frag): Update definiton based on BFD_ASSEMBLER.
938         * tc-h8300.h (relocation mappings): Add.
939
940 Thu Aug 30 12:05:13 2001  J"orn Rennecke <amylaar@redhat.com>
941
942         * tc-h8300.c (tc_crawl_symbol_chain, tc_headers_hook): Don't
943         define for BFD_ASSEMBLER.
944         (tc_reloc_mangle): Likewise.
945         (tc_gen_reloc): New function for BFD_ASSEMBLER.
946
947 Wed Aug 29 12:49:58 2001  Jeffrey A Law  (law@cygnus.com)
948
949         * config/tc-h8300.c (h8300hmode): Record the machine type
950         if BFD_ASSEMBLER is defined.
951         (h8300smode, md_begin): Similarly.
952
953 2001-08-29  Joel Sherrill <joel@OARcorp.com>
954
955         * configure.in (i[3456]86-*-rtems*, m68*-*-rtems*): Change
956         default from coff to elf.
957         * configure: Regenerate.
958
959 Wed Aug 29 12:05:13 2001  J"orn Rennecke <amylaar@redhat.com>
960
961         * tc-h8300.c: If OBJ_ELF, include elf/h8.h, and define
962         assorted coff relocations to the corresponding elf relocations.
963         * tc-h8300.h (TARGET_ARCH, TARGET_FORMAT): Define appropriately.
964
965         * configure.in: Add case for h8300-*-elf.
966         * configure: Regenerate.
967
968 Wed Aug 29 12:05:13 2001  J"orn Rennecke <amylaar@redhat.com>
969
970         * doc/internals.texi (MD_PCREL_FROM_SECTION): Change
971         documentation to reflect reality.
972
973 2001-08-27  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
974
975         * config/tc-mips.c (load_address): Reflect change to MAX_GPREL_OFFSET.
976         (macro): Reflect change to MAX_GPREL_OFFSET.
977
978 2001-08-27  Torbjorn Granlund  <tege@swox.com>
979             Staffan Ulfberg  <staffanu@swox.se>
980             Linus Nordberg  <linus@swox.se>
981             Alan Modra  <amodra@bigpond.net.au>
982
983         * configure.in: Recognise powerpc*le*, not just powerpcle*.
984         * configure: Regenerate.
985         * config/tc-ppc.c (PPC_LO, PPC_HI, PPC_HA, PPC_HIGHER,
986         PPC_HIGHERA, PPC_HIGHEST, PPC_HIGHESTA, SEX16): New macros.
987         (md_assemble): Use them.
988         (ppc_machine): Support stub for ELF64 as well as XCOFF.
989         (md_pseudo_table): Add "llong", "quad".
990         (md_parse_option): Match default_cpu of powerpc*.
991         (ppc_arch): Likewise.
992         (ppc_subseg_align): Only for OBJ_XCOFF.
993         (ppc_target_format): Return elf64-powerpc strings for 64 bit ELF.
994         (md_begin): Select PPC_OPCODE_64 for 64 bit.
995         (ppc_insert_operand): Don't bother testing 'file' before calling
996         as_bad_where.  Use as_bad_where for operand->insert errors.
997         (mapping): Add ELF64 relocation modifiers.
998         (ppc_elf_suffix): Replace symbol on BFD_RELOC_PPC64_TOC reloc
999         expressions with abs_symbol.
1000         (ppc_elf_cons): Correct offset for little endian targets.
1001         (ppc_elf_frob_symbol): New.
1002         (md_assemble): Add support for 64 bit ELF relocs.
1003         (ppc_tc): Ensure 8 byte alignment when 64 bit.
1004         (ppc_is_toc_sym): Only define for OBJ_XCOFF and OBJ_ELF.  Match
1005         ".toc" section for 64 bit ELF.
1006         (ppc_fix_adjustable): New.  Macro body moved from tc-ppc.h.
1007         (md_apply_fix3): Silence warning with ATTRIBUTE_UNUSED.  Only do
1008         the ppc_is_toc_sym check for OBJ_XCOFF and OBJ_ELF.  For 64 bit,
1009         use BFD_RELOC_PPC64_TOC16_DS instead of BFD_RELOC_PPC_TOC16.
1010         Expand on comments, error message.  Add support for 64 bit relocs,
1011         and use PPC_HI etc. macros.
1012         * config/tc-ppc.h (MAX_MEM_FOR_RS_ALIGN_CODE): Define.
1013         (HANDLE_ALIGN): Define to generate nops in code sections rather
1014         than zeros.
1015         (TC_FORCE_RELOCATION): Force for BFD_RELOC_PPC64_TOC.
1016         (ELF_TC_SPECIAL_SECTIONS): Add 64 bit ELF sections.
1017         (tc_fix_adjustable): Move body of macro to tc-ppc.c.
1018         (ppc_fix_adjustable): Declare.
1019         (tc_frob_symbol): Define.
1020         (ppc_elf_frob_symbol): Declare.
1021
1022 2001-08-26  Andreas Jaeger  <aj@suse.de>
1023
1024         * config/tc-s390.c: Add missing prototypes
1025         (md_gather_operands): Make static.
1026
1027 2001-08-26  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
1028
1029         * config/tc-mips.h (MAX_GPREL_OFFSET): Change it to the maximum
1030         allowed value, not the word beyond maximum.
1031         * config/tc-mips.c (macro_build_lui): Code cleanup.
1032         (macro): Reflect change to MAX_GPREL_OFFSET.
1033         (mips_ip): Check explicitly against S_EX_NONE.
1034         (my_get_SmallExpression): parse for %gp_rel, not %gprel.
1035         (md_apply_fix): Code cleanup.
1036
1037 2001-08-24  Andreas Jaeger  <aj@suse.de>
1038
1039         * config/tc-ppc.h: Fix prototype declaration.
1040
1041 2001-08-23  Jakub Jelinek  <jakub@redhat.com>
1042
1043         * config/tc-ia64.c (dot_endp): Set function symbol sizes.
1044         * config/obj-elf.c (obj_elf_size): When size is constant, free
1045         and clear symbol_get_obj(sym)->size if any.
1046
1047 2001-08-21  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
1048
1049         * config/tc-mips.c (md_begin): Warn about incompatibility between
1050         -march=FOO and -mipsN option, continue with default ISA.
1051
1052 2001-08-21  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
1053
1054         * config/tc-mips.c (md_parse_option): #ifdef the
1055         traditional/non-traditional names as it is done in mips_target_format.
1056
1057 2001-08-20  Richard Henderson  <rth@redhat.com>
1058
1059         * config/tc-alpha.h (MD_APPLY_FIX3): Define.
1060         * config/tc-alpha.c (md_apply_fix3): Rename from md_apply_fix;
1061         use seg parameter instead of now_seg.
1062
1063 2001-08-18  H.J. Lu  <hjl@gnu.org>
1064
1065         * config/tc-mips.c (show): Add the missing prototype.
1066
1067 2001-08-18  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
1068
1069         * config/tc-mips.c (S_EX_*): New enum for my_getSmallExpression()
1070         return values.
1071         (mips_ip): Use the new return values instead of characters. Add
1072         support for %higher and %highest.
1073         (LP): Remove.
1074         (RP): Remove.
1075         (my_getSmallExpression): Make parsing case insensitive and more
1076         reliable. Add support for %higher and %highest. Further support to
1077         parse %gprel and %neg is implemented but currently deactivated.
1078
1079 2001-08-17  Alan Modra  <amodra@bigpond.net.au>
1080
1081         * ecoff.c (ecoff_frob_symbol): Remove casts from bfd_get_gp_size.
1082         (ecoff_build_symbols): Likewise.
1083         * read.c (s_lcomm_internal): Fix signed/unsigned warning.
1084
1085 2001-08-16  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
1086
1087         * config/tc-mips.c (mips_elf_final_processing): Set elf header flags
1088         for n32 ABI if appropriate.
1089
1090 2001-08-16  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
1091
1092         * config/tc-mips.c (cons_fix_new_mips): Remove.
1093         * config/tc-mips.h (TC_CONS_FIX_NEW): Remove.
1094         (cons_fix_new_mips): Remove.
1095
1096 2001-08-14  Jeff Johnston  <jjohnstn@redhat.com>
1097
1098         * expr.c (operand)[LITERAL_PREFIXDOLLAR_HEX]: Treat $L as
1099         a label, not a hex constant.
1100
1101 2001-08-13  Nick Clifton  <nickc@cambridge.redhat.com>
1102
1103         * config/tc-v850.h: Add missing prototypes.
1104
1105 2001-08-12  Martin Schwidefsky  <schwidefsky@de.ibm.com>
1106
1107         * config/tc-s390.c (s390_elf_cons): Correct fixups for PLT
1108         relocations.
1109
1110 2001-08-12  TAKAI Kousuke  <takai@vlsi.kuee.kyoto-u.ac.jp>
1111
1112         * config/tc-sparc.c (cons_fix_new_sparc): Move
1113         `sparc_no_align_cons = 0;' to...
1114         (s_uacons): ...here so that sparc_no_align_cons will get
1115         cleared properly.
1116
1117 2001-08-11  Kazu Hirata  <kazu@hxi.com>
1118
1119         * config/tc-mips.c: Fix a comment typo.
1120
1121 2001-08-10  Richard Sandiford  <rsandifo@redhat.com>
1122
1123         * config/tc-mips.c (move_register): New function.
1124         (macro_build): Remove OPCODE_IS_MEMBER's gp32 argument.
1125         (mips_ip): Likewise.
1126         (macro2): Use move_register rather than macro_build for moves.
1127         (mips16_macro): Likewise.
1128         (macro): Likewise.  Handle M_MOVE.
1129
1130 2001-08-10  Andreas Jaeger  <aj@suse.de>
1131
1132         * configure.in: Add -Wstrict-prototypes and -Wmissing-prototypes
1133         to build warnings.
1134         * configure: Regenerate.
1135
1136 2001-08-10  Alan Modra  <amodra@bigpond.net.au>
1137
1138         * as.h (alloca): Don't declare if __GNUC__.  Remove an old comment.
1139         Comment indentation of #pragma.
1140         * macro.c (alloca): Likewise.
1141
1142         * config/tc-ppc.c: Revert 2001-08-08.
1143
1144 2001-08-09  Alan Modra  <amodra@bigpond.net.au>
1145
1146         * symbols.c: Add missing prototypes.
1147         * config/e-i386elf.c: Likewise.
1148         * config/e-i386coff.c: Likewise.
1149         * config/e-i386aout.c: Likewise.
1150         * config/obj-coff.c: Likewise.
1151         (def_symbol_in_progress, stack): Move definition.
1152         * config/obj-elf.c: Add missing prototypes.
1153         (obj_elf_change_section): Make static.
1154         (obj_elf_parse_section_letters): Likewise.
1155         (obj_elf_section_word): Likewise.
1156         (obj_elf_section_type): Likewise.
1157
1158 2001-08-08  Alan Modra  <amodra@bigpond.net.au>
1159
1160         From 1999-10-25  Torbjorn Granlund  <tege@swox.com>
1161         * config/tc-ppc.c (md_apply_fix3): Replace haphazard code for
1162         determining reloc type with code reading operands->reloc field.
1163
1164 2001-08-08  Alan Modra  <amodra@bigpond.net.au>
1165
1166         * config/obj-elf.c (elf_copy_symbol_attributes): Make it a global
1167         function, and expand old obj-elf.h OBJ_COPY_SYMBOL_ATTRIBUTES here.
1168         * config/obj-elf.h (elf_copy_symbol_attributes): Declare.
1169         (OBJ_COPY_SYMBOL_ATTRIBUTES): Call elf_copy_symbol_attributes.
1170
1171         * output-file.c (output_file_create): Don't try to open a second
1172         time as it's unnecessary.  FOPEN_W was undefined too.
1173
1174 2001-08-07  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
1175
1176         * config/tc-mips.c (macro_build): Replace magic constants by defines.
1177         (mips_ip): Likewise. Typo.
1178
1179 2001-08-04  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
1180
1181         * config/tc-mips.c (mips_abi_string): Initialize with NULL instead
1182         of 0.
1183         (RELAX_ENCODE): Replace bfd_vma by valueT.
1184         (load_address): Formatting.
1185         (macro): Likewise. Code cleanup. Typo.
1186         (macro2): Formatting.
1187         (md_parse_option): Typo.
1188         (s_mipsset): Reorder cases to look nicer.
1189         (md_estimate_size_before_relax): Formatting. Code cleanup.
1190         (mips_elf_final_processing): Check against NULL instead of 0.
1191         (md_obj_end): Remove ugly `' in message string.
1192         (s_mips_ent): Remove ugly `' in message string.
1193
1194 2001-07-30  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
1195
1196         * config/tc-mips.c (md_begin): Take -mcpu value into account even when
1197         -mipsX is specified. Make both -mcpu/-march and -mcpu/-mtune pairs
1198         mutually exclusive (if they are different).
1199         (md_parse_option): Warn if an -march/-mtune/-mcpu/-m<cpu> option is
1200         set more than once.
1201
1202 2001-08-03  Richard Sandiford  <rsandifo@redhat.com>
1203
1204         * config/tc-mips.c (md_apply_fix): Don't subtract the symbol value
1205         from GPREL addends.
1206
1207 2001-08-02  Richard Sandiford  <rsandifo@redhat.com>
1208
1209         * doc/c-mips.tex (-mgp32, -mfp32): Added -mfp32, unified with -mgp32.
1210         * config/tc-mips.c (mips_fp32, mips_32bit_abi): New static variables.
1211         (md_long_opts): Add -mfp32 option.
1212         (md_parse_option): Handle it.  Set mips_32bit_abi given -mabi=32.
1213         (md_show_usage): Show usage for -mfp32 and -mgp32.
1214         (HAVE_32BIT_GPRS, HAVE_32BIT_FPRS): New macros.
1215         (HAVE_64BIT_GPRS, HAVE_64BIT_FPRS): New macros, inverse of the above.
1216         (HAVE_32BIT_ADDRESSES): New macro.
1217         (load_register): Use HAVE_32BIT_GPRS to determine the register width.
1218         (load_address): Use HAVE_32BIT_ADDRESSES to determine the address size.
1219         (s_cprestore, s_cpadd): Likewise.
1220         (macro): Use HAVE_32BIT_GPRS to determine the width of registers
1221         used in branch and M_LI_D macros.  Use HAVE_64BIT_FPRS to determine
1222         the width registers used in M_LI_DD macros.  Use HAVE_32BIT_ADDRESSES
1223         to determine the width of addresses in load, store and jump macros.
1224         (macro2): Use HAVE_32BIT_GPRS to determine the width of registers
1225         used in set instructions; do not check the address size for them.
1226         Use HAVE_32BIT_ADDRESSES to determine the width of addresses in
1227         unaligned load and store macros.
1228         (mips_ip): Use the new macros to check the width of a register when
1229         processing float constants.  Force a constant into memory if it is
1230         destined for an FPR and the FPRs are wider than the GPRs.  Warn about
1231         odd FPR numbers if HAVE_32BIT_FPRS.  Use HAVE_32BIT_GPRS rather
1232         than mips_gp32 to select synthetic instructions.
1233         (macro_build): Use HAVE_32BIT_GPRS rather than mips_gp32 to select
1234         synthetic instructions.
1235
1236 2001-08-01  Christian Groessler <cpg@aladdin.de>
1237
1238         * config/tc-z8k.c (parse_reg): If a string starts with "r", "rl",
1239         "rh", "rr", "rq", or "sp" then don't automatically assume
1240         it's a register name.  Check whether there is a number
1241         following.
1242
1243 2001-08-01  Alan Modra  <amodra@bigpond.net.au>
1244
1245         * config/tc-i386.c (lex_got): Match lower case relocation tokens.
1246         Don't allocate more space than necessary for the input line copy.
1247
1248 2001-08-01  Alan Modra  <amodra@bigpond.net.au>
1249
1250         * read.c: Standardize error/warning messages - don't capitalise, no
1251         final period or newline, don't say "ignored" or "zero assumed" for
1252         as_bad messages.  In some cases, change the wording to that used
1253         elsewhere for similar messages.
1254         * app.c: Likewise.
1255         * as.c: Likewise.
1256         * atof-generic.c: Likewise.
1257         * cgen.c: Likewise.
1258         * cond.c: Likewise.
1259         * depend.c: Likewise.
1260         * dwarf2dbg.c: Likewise.
1261         * ecoff.c: Likewise.
1262         * expr.c: Likewise.
1263         * frags.c: Likewise.
1264         * input-file.c: Likewise.
1265         * input-scrub.c: Likewise.
1266         * listing.c: Likewise.
1267         * output-file.c: Likewise.
1268         * stabs.c: Likewise.
1269         * subsegs.c: Likewise.
1270         * symbols.c: Likewise.
1271         * write.c: Likewise.
1272         * ecoff.c (ecoff_directive_end): Test for missing name by
1273         comparing input line pointers rather than reading string.
1274         (ecoff_directive_ent): Likewise.
1275         * read.c (s_set): Likewise.
1276         (s_align): Report a warning rather than an error for
1277         alignment too large.
1278         (s_comm): Check for missing symbol name.
1279         (s_lcomm_internal): Likewise.
1280         (s_lsym): Likewise.
1281         (s_globl): Use is_end_of_line instead of looking for '\n'.
1282         (s_lcomm_internal): Likewise.
1283         (ignore_rest_of_line): Report a warning rather than an error.
1284
1285 2001-07-31  Geoffrey Keating  <geoffk@redhat.com>
1286
1287         * config/tc-ppc.c (ppc_elf_validate_fix): It's OK to have
1288         any kind of relocation against a not-loaded section.
1289
1290 2001-07-30  Alan Modra  <amodra@bigpond.net.au>
1291
1292         * config/obj-elf.c (obj_elf_symver): Temporarily modify lex_type
1293         to include '@' in symbol names when parsing versioned symbols
1294         rather than calling get_symbol_end multiple times.
1295         * config/tc-i370.c (register_name): Format fixes.  Don't call
1296         get_symbol_end after parsing number.
1297         * config/tc-mn10200.c (data_register_name): Format fixes.  Hoist
1298         code out of conditional.
1299         (address_register_name): Likewise.
1300         (other_register_name): Likewise.
1301         * config/tc-mn10300.c (r_register_name): Likewise.
1302         (xr_register_name): Likewise.
1303         (data_register_name): Likewise.
1304         (address_register_name): Likewise.
1305         (other_register_name): Likewise.
1306         * config/tc-ppc.c (register_name): Likewise.
1307         * config/tc-s390.c (register_name): Likewise.
1308
1309 2001-07-27  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
1310
1311         * config/tc-m68hc11.c (md_estimate_size_before_relax): Fix bsr
1312         and bra relax: update fragP->fr_fix after the fixup.
1313
1314 2001-07-27  Tracy Kuhrt  <Tracy.Kuhrt@microchip.com>
1315
1316         * read.c (s_set): Check for missing symbol name.
1317
1318 2001-07-26  Alan Modra  <amodra@bigpond.net.au>
1319
1320         * write.c (relax_segment <rs_space>): Account for fr_fix.
1321
1322 2001-07-25  H.J. Lu  <hjl@gnu.org>
1323
1324         * config/tc-mips.c (md_estimate_size_before_relax): Make sure
1325         we treat weak like extern only for ELF.
1326         (mips_fix_adjustable): Make sure we don't adjust extern/weak
1327         symbols only for ELF.
1328
1329 2001-07-25  Chris Demetriou  <cgd@broadcom.com>
1330
1331         * config/tc-mips.c: Fix spelling error in comment.
1332
1333 2001-07-25  Dave Brolley  <brolley@redhat.com>
1334
1335         * app.c (LEX_IS_PARALLEL_SEPARATOR): New macro.
1336         (IS_PARALLEL_SEPARATOR): New macro.
1337         (do_scrub_begin): Set up characters in tc_parallel_separator_chars
1338         as LEX_IS_PARALLEL_SEPARATOR, if it is defined.
1339         (do_scrub_chars): Handle LEX_PARALLEL_SEPARATOR chars like
1340         LEX_LINE_SEPARATOR except that we go to state 1 (as if the label has
1341         been seen).
1342
1343 2001-07-24  Alan Modra  <amodra@bigpond.net.au>
1344
1345         * Makefile.am (DEP_FLAGS): Define, add -DOBJ_MAYBE_ELF.
1346         (DEP1, DEPTC, DEPOBJ, DEP2): Use it.
1347         Update dependencies with "make dep-am".
1348         * Makefile.in: Regenerate.
1349         * doc/Makefile.in: Regenerate.
1350
1351 2001-07-23  Kazu Hirata  <kazu@hxi.com>
1352
1353         * config/tc-alpha.h: Fix formatting.
1354         * config/tc-arc.c: Likewise.
1355         * config/tc-d10v.h: Likewise.
1356         * config/tc-hppa.c: Likewise.
1357         * config/tc-i370.c: Likewise.
1358         * config/tc-i386.h: Likewise.
1359         * config/tc-i960.h: Likewise.
1360         * config/tc-ia64.c: Likewise.
1361         * config/tc-ia64.h: Likewise.
1362         * config/tc-m32r.c: Likewise.
1363         * config/tc-m68k.c: Likewise.
1364         * config/tc-m88k.c: Likewise.
1365         * config/tc-ns32k.c: Likewise.
1366         * config/tc-pdp11.c: Likewise.
1367         * config/tc-pj.h: Likewise.
1368         * config/tc-s390.c: Likewise.
1369         * config/tc-sparc.c: Likewise.
1370         * config/tc-sparc.h: Likewise.
1371         * config/tc-tic80.c: Likewise.
1372         * config/tc-w65.h: Likewise.
1373
1374 2001-07-23  Alan Modra  <amodra@bigpond.net.au>
1375
1376         * symbols.c (S_GET_VALUE): Don't treat O_constant and local
1377         symbols specially.  Always resolve, adding fr_address to value.
1378         * write.c (write_object_file): Don't add fr_address to sym values.
1379         (relax_frag): Likewise.
1380         (relax_segment): Likewise.
1381         * config/obj-ieee.c (do_symbols): Likewise.
1382         * config/tc-cris.c (md_convert_frag): Likewise.
1383         * config/tc-fr30.c (md_convert_frag): Likewise.
1384         * config/tc-i386.c (md_convert_frag): Likewise.
1385         * config/tc-m32r.c (md_convert_frag): Likewise.
1386         * config/tc-m68hc11.c (md_convert_frag): Likewise.
1387         * config/tc-mcore.c (md_convert_frag): Likewise.
1388         * config/tc-mips.c (mips16_extended_frag): Likewise.
1389         * config/tc-ns32k.c (md_convert_frag): Likewise.
1390         * config/tc-m68k.c (md_convert_frag_1): Likewise.
1391         (BRANCHBWL, BRABSJUNC, BRABSJCOND, BRANCHBW, FBRANCH, DBCCLBR,
1392         DBCCABSJ, PCREL1632, PCINDEX, ABSTOPCREL): Decrement.
1393         (md_relax_table): Remove first four entries.  Format.
1394         (md_estimate_size_before_relax): Remove old_fix.  Don't bother
1395         setting fr_var.  Simplify byte branch checks.
1396
1397 2001-07-23  Alan Modra  <amodra@bigpond.net.au>
1398
1399         * config/tc-hppa.c (pa_parse_nonneg_cmpsub_cmpltr): Remove
1400         "isbranch" param as all calls have it set.
1401         (pa_parse_neg_cmpsub_cmpltr): Likewise.
1402         (pa_parse_nonneg_add_cmpltr): Likewise.  Remember result of
1403         strcasecmp in "nullify" var.
1404         (pa_parse_neg_add_cmpltr): Likewise.
1405         (pa_ip): Don't "save_s" unnecessarily.  Update calls to above
1406         functions.  Don't print wrong conditions in error messages.
1407
1408 2001-07-23  Andreas Jaeger  <aj@suse.de>
1409
1410         * config/tc-s390.c (s390_force_relocation): Removed.
1411
1412         * config/tc-s390.h: Remove double declaration of
1413         TC_FORCE_RELOCATION.
1414
1415 2001-07-22  H.J. Lu <hjl@gnu.org>
1416
1417         * config/tc-mips.c (s_mips_end): Remove unused variables.
1418         (s_mips_frame): Add ATTRIBUTE_UNUSED.
1419
1420 2001-07-17  Andreas Schwab  <schwab@suse.de>
1421
1422         * config/tc-m68k.c (md_pseudo_table) [OBJ_ELF]: Add .file and
1423         .loc.
1424         (md_assemble) [OBJ_ELF]: Call dwarf2_emit_insn before emitting
1425         insn.
1426         * config/tc-m68k.h (DWARF2_LINE_MIN_INSN_LENGTH): Define.
1427
1428 2001-07-17  matthew green  <mrg@eterna.com.au>
1429
1430         * config/tc-i386.c (comment_chars): Don't use '/' as comment start if
1431         TE_NetBSD.
1432         (line_comment_chars): Set to '/' if TE_NetBSD.
1433
1434 2001-07-14  matthew green  <mrg@eterna.com.au>
1435
1436         * configure.in (i386-*-netbsdelf*): New target.
1437         * configure: Regenerate.
1438
1439 2001-07-10  Mark Elbrecht  <snowball3@softhome.net>
1440
1441         * config/obj-coff.c (coff_frob_symbol): Don't merge if the storage
1442         class of the non-debug symbol is C_NULL.
1443
1444 2001-07-10  Anders Norlander <anorland@synergenix.se>
1445
1446         * doc/as.texinfo (Incbin): Fix grammatical errors.
1447
1448 2001-07-10  Nick Clifton  <nickc@cambridge.redhat.com>
1449
1450         * depend.c: Use FOPEN_.. macros in calls to fopen().
1451         * input-file.c: As above.
1452         * itbl-ops.c: As above.
1453         * listing.c: As above.
1454         * output-file.c: As above.
1455         * read.c: As above.
1456
1457 2001-07-08  Anders Norlander <anorland@synergenix.se>
1458
1459         * read.c (s_incbin): New .incbin function.
1460         * read.c (potable): Add "incbin" pseudo-op.
1461         * read.h: Add s_incbin prototype.
1462         * doc/as.texinfo (incbin): Document .incbin pseudo-op.
1463         * NEWS: Mention new feature.
1464
1465 2001-07-07  Nick Clifton  <nickc@cambridge.redhat.com>
1466
1467         * ecoff.c (add_file): Only set debug_type to DEBUG_NONE if it is
1468         DEBUG_UNSPECIFIED.
1469
1470 2001-07-06  John Healy  <jhealy@redhat.com>
1471
1472         * cgen.c (gas_cgen_save_fixups): Modified to allow more than one
1473         set of fixups to be stored.
1474         (gas_cgen_restore_fixups): Modified to allow the fixup chain to be
1475         restored to be chosen from any that are saved.
1476         (gas_cgen_swap_fixups): Modified to allow the current set of
1477         fixups to be swapped with any other set that has been saved.
1478         (gas_cgen_initialize_saved_fixups_array): New routine.
1479         * cgen.h: Modifed prototypes for gas_cgen_save_fixups,
1480         gas_cgen_restore_fixups, and gas_cgen_swap_fixups.  Added definitions
1481         or MAX_SAVED_FIXUP_CHAINS.
1482         * config/tc-m32r.c (assemble_two_insns): Changed calls to fixup
1483         store, swap and restore fuctions to reflect the new interface.
1484
1485 2001-07-06  Nick Clifton  <nickc@cambridge.redhat.com>
1486
1487         * config/tc-m68k.c (md_estimate_size_before_relax): Catch and
1488         ignore empty, ineffectual alignment frags when deciding if a
1489         branch can be short.
1490
1491 2001-07-05  Steve Ellcey  <sje@cup.hp.com>
1492
1493         * config/tc-ia64.c (special_section): Add SPECIAL_SECTION_INIT_ARRAY
1494         and SPECIAL_SECTION_FINI_ARRAY.
1495         (special_section_name): Add .init_array and .fini_array.
1496         (md_pseudo_table): Add init_array and fini_array.
1497         (md): Add pointer_size and pointer_size_shift fields.
1498         (setup_unwind_header): New static function.
1499         (output_unw_records): Modify to use setup_unwind_header.
1500         (generate_unwind_image, dot_endp): Modify to use md.pointer_size and
1501         md.pointer_size_shift.
1502         (md_begin): Initialize md.pointer_size and md.pointer_size_shift.
1503
1504 2001-07-05  Ben Elliston  <bje@redhat.com>
1505
1506         * README (Supported platforms): m88k no longer suffers bitrot.
1507
1508         * config/tc-m88k.c (md_pseudo_table): Remove redundant "global".
1509
1510 2001-07-05  Alan Modra  <amodra@bigpond.net.au>
1511
1512         * struc-symbol.h (struct local_symbol): Rename lsy_offset to
1513         lsy_value.  Correct typos in comments.
1514         * symbols.c (local_symbol_make): Update for name change.
1515         (local_symbol_convert): Likewise.
1516         (colon): Likewise.
1517         (S_GET_VALUE): Likewise.
1518         (S_SET_VALUE): Likewise.
1519         (print_symbol_value_1): Likewise.
1520         (resolve_symbol_value): Likewise.  Don't divide local sym values
1521         by OCTETS_PER_BYTE twice.
1522
1523 2001-07-04  Jim Wilson  <wilson@redhat.com>
1524
1525         * config/tc-ia64.c (md_pseudo_table): Add 2byte, 4byte, and 8byte.
1526
1527         * config/tc-ia64.c (is_conditional_branch): Rewrite to exclude mod
1528         sched branches.
1529
1530 2001-07-05  Ben Elliston  <bje@redhat.com>
1531
1532         * read.c (s_fill): Correct spelling error in comments.
1533
1534         * doc/c-m88k.texi: New file.
1535         * doc/Makefile.am (CPU_DOCS): Add c-m88k.texi.
1536         * doc/Makefile.in: Regenerate.
1537         * doc/all.texi: Set M880X0.
1538         * doc/as.texinfo: Hook in m88k-dependent documentation.
1539
1540 2001-07-04  Eric Christopher  <echristo@redhat.com>
1541
1542         * doc/c-mips.texi (MIPS Opts): Document 12000 as valid cpu.
1543
1544         * config/tc-mips.c (mips_cpu_info_table): Add rm5200, rm5231, rm5261,
1545         and rm5721 as valid cpu strings.
1546         (md_show_usage): Add rm5200, rm5231, rm5261, rm5721.
1547
1548 2001-07-04  Richard Sandiford  <rsandifo@redhat.com>
1549
1550         * config/tc-mips.c (md_apply_fix): Prevent addend from becoming zero
1551         if it's expected to be non-zero.
1552
1553 2001-07-03  Nick Clifton  <nickc@cambridge.redhat.com>
1554
1555         * config/tc-sh.c (sh_frob_section): Replace symbol_get_frag() with
1556         fscan->fx_frag.
1557
1558         * write.c (TC_FINALIZE_SYMS_BEFORE_SIZE_SEG): Default to 1.
1559         (write_object_file): Set finalize_syms to
1560         TC_FINALIZE_SYMS_BEFORE_SIZE_SEG just before size_segs is
1561         called.
1562
1563         * doc/internals.texi; Document
1564         TC_FINALIZE_SYMS_BEFORE_SIZE_SEG.
1565
1566 2001-07-02  Alan Modra  <amodra@bigpond.net.au>
1567
1568         * config/tc-ppc.c: Formatting fixes.
1569
1570 2001-07-01  Ben Elliston  <bje@redhat.com>
1571
1572         * config/tc-m88k.c: Back out warning fixes from 2001-06-24, as
1573         they cause some subtle breakage.  Will fix them again later.
1574
1575 2001-06-28  Nick Clifton  <nickc@cambridge.redhat.com>
1576
1577         * config/obj-coff.c (obj_coff_ln): Treat a .ln directive
1578         outside of a function as a .appline directive.
1579
1580 2001-06-28  Eric Christopher <echristo@redhat.com>
1581             H.J. Lu  <hjl@gnu.org>
1582
1583         * config/tc-mips.c (mips_arch): New. Use mips_arch instead
1584         of mips_cpu for the ISA selection.
1585         (md_longopts): Add OPTION_MARCH and OPTION_MTUNE.
1586         (md_parse_option): Handle OPTION_MARCH and OPTION_MTUNE.
1587         (mips_tune): New.  Use mips_tune for scheduling and optimization
1588         issues.
1589         (append_insn): Use mips_tune and mips_arch.
1590         (macro_build): Ditto.
1591         (mips_ip): Ditto.
1592         (md_begin): Handle mips_arch, mips_tune and mips_cpu.  For
1593         backwards compatability mips_cpu generates arch and tune.
1594         (md_show_usage): Document new behavior.
1595
1596         * doc/c-mips.texi (MIPS Opts): Document -march and -mtune.
1597         Deprecate -mcpu.
1598
1599         * NEWS: Update.
1600
1601 2001-06-27  Nick Clifton  <nickc@cambridge.redhat.com>
1602
1603         * write.c (write_object_file): Do not set finalize_syms until
1604         after the segments have been sized.  Some backends may still
1605         need to access the syms's frags in order to adjust relaxed
1606         frags.
1607
1608         * config/tc-arm.c (do_ldst): Use MVN to build simple inverted
1609         constants.
1610
1611 2001-06-27  Alan Modra  <amodra@bigpond.net.au>
1612
1613         * write.c (fixup_segment <Difference of 2 syms same seg>): Don't
1614         subtract MD_PCREL_FROM_SECTION for 68k.
1615         (fixup_segment <Difference of 2 syms different seg>): Only fudge
1616         by adding MD_PCREL_FROM_SECTION for 68k or if not already pcrel.
1617
1618 2001-06-27  Tracy A. Kuhrt  <Tracy.Kuhrt@microchip.com>
1619
1620         * write.c (fixup_segment <Difference of 2 syms same seg>): If
1621         pcrel, subtract MD_PCREL_FROM_SECTION value.
1622
1623 2001-06-24  Ben Elliston  <bje@redhat.com>
1624
1625         * stabs.c (generate_asm_file): Make local variable `len' a size_t.
1626
1627 2001-06-24  Jakub Jelinek  <jakub@redhat.com>
1628
1629         * config/tc-alpha.c (tc_gen_reloc): Handle relocs against SEC_MERGE
1630         section symbols the same way as externs.
1631
1632 2001-06-24  Ben Elliston  <bje@redhat.com>
1633
1634         * config/tc-m88k.c (md_number_to_imm): Remove; unused since 1993.
1635         (emit_relocations): Ditto.
1636         (s_bss): Ditto.
1637         (md_begin): Reformat comments to conform to the GNU standards.
1638         (md_assemble): Ditto.
1639
1640         * config/tc-m88k.c (get_reg): Adjust type of `reg_prefix' to char.
1641         (md_parse_option): Mark parameters as unused.
1642         (md_show_usage): Ditto.
1643         (calcop): Adjust type of `reg_prefix' to char.
1644         (get_reg): Ditto.
1645         (getval): Adjust type of local `c' to char.
1646         (md_create_short_jump): Mark from_addr, to_addr params as unused.
1647         (md_create_long_jump): Ditto.
1648         (md_estimate_size_before_relax): Mark parameters as unused.
1649
1650         * config/tc-m88k.c (md_pseudo_table): Properly terminate the table
1651         to allay a possible compiler warning.
1652
1653 2001-06-22  Nick Clifton  <nickc@cambridge.redhat.com>
1654
1655         * doc/internals.texi (CPU backend): Document md_atof.
1656
1657 2001-06-22  Matthew Wilcox  <willy@ldl.fc.hp.com>
1658
1659         * config/tc-hppa.c (pre_defined_registers): Add %mrp (millicode
1660         return pointer) alias for %r2 or %r31, depending on 32 or 64 bit
1661         architecture.
1662
1663 2001-06-21  Philip Blundell  <philb@gnu.org>
1664
1665         * config/tc-arm.c (cplong_flag): Rename to long_flag.  All uses
1666         updated.
1667         (insns): Remove entry for adrl.  Add long_flag for adr.
1668         (do_adr): Handle `l' suffix.
1669         (do_adrl): Delete.
1670
1671 2001-06-21  Alan Modra  <amodra@bigpond.net.au>
1672
1673         * config/tc-hppa.c (CHECK_FIELD_WHERE): Define.
1674         (md_apply_fix): Use it here.  Replace printf with equivalent
1675         as_bad_where.
1676         (tc_gen_reloc): Use as_bad_where instead of as_bad.
1677         (md_apply_fix): Here too.
1678         * config/tc-i386.c (tc_gen_reloc): Use as_bad_where instead of as_bad.
1679         * config/tc-m68k.c (tc_gen_reloc): Likewise.
1680         (md_convert_frag_1): Likewise.
1681
1682 2000-06-20  Tom Rix <trix@redhat.com>
1683
1684         * config/tc-ppc.c (ppc_comm): Change default alignment to 4 bytes.
1685
1686 2001-06-18  H.J. Lu <hjl@gnu.org>
1687
1688         * doc/Makefile.am (info): Depend on $(MANS).
1689         (as.1): Remove the prefix `$(srcdir)/'.
1690         * doc/Makefile.in: Regenerated.
1691
1692         * as.1: Removed.
1693
1694 2001-06-18  Philip Blundell  <philb@gnu.org>
1695
1696         * config/tc-arm.c (do_msr): Remove restriction on usage of
1697         immediate operands.
1698
1699 2001-06-19  Alan Modra  <amodra@bigpond.net.au>
1700
1701         * dwarf2dbg.c (dwarf2_finish): Output file info even when no
1702         line info.
1703
1704 2001-06-13  Philip Blundell  <philb@gnu.org>
1705
1706         * config/tc-arm.c (thumb_shift): Improve wording of error message.
1707         (do_t_arit): Likewise.
1708
1709 2001-06-13  Nick Clifton  <nickc@cambridge.redhat.com>
1710
1711         * config/tc-sh.c (md_pseudo_table): Only intercept the .file and
1712         .loc pseudos if the dfwarf2 functions are available.
1713         (md_assemble): Only call dwarf2_emit_insn if it is available.
1714
1715         * expr.c: Fix typo in comment.
1716
1717 2001-06-12  Nick Clifton  <nickc@cambridge.redhat.com>
1718
1719         * doc/as.texinfo (Infix Ops): Document that comparison and
1720         combiner operators can be used as infix operators.
1721
1722 2001-06-12  Peter Jakubek <pjak@snafu.de>
1723
1724         * config/tc-m68k.c (parse_mri_control_operand): Fix handling
1725         of AND/OR.
1726         (swap_mri_condition): Add HS (alias fo CC) and LO (alias for CS).
1727         (reverse_mri_condition): Likewise.
1728         (swap_mri_condition): Issue warning for conditions that can not be
1729         swapped.
1730         (build_mri_control_operand): Fix order of operands (swapped).
1731         (build_mri_control_operand): Allow upper case extension in structured
1732         control directives.
1733         (s_mri_else): Likewise.
1734         (s_mri_next): Likewise.
1735         (s_mri_for): Likewise.
1736         (s_mri_if): Fix handling comment ('*') in mri mode.
1737         (s_mri_while): Likewise.
1738         * macro.c (macro_expand): Allow macro invocation with empty
1739         extension.
1740
1741 2001-06-12  Nick Clifton  <nickc@cambridge.redhat.com>
1742
1743         * config/tc-arm.c: Fix test for overlow of literal pool.
1744
1745 2001-06-11  H.J. Lu  <hjl@gnu.org>
1746
1747         * NEWS: Updated for the new -n option for the MIPS assembler.
1748
1749         * config/tc-mips.c (md_show_usage): Add -n.
1750
1751         * doc/as.texinfo: Document the new -n option.
1752         * doc/c-mips.texi: Likewise.
1753         * doc/as.1: Regenerated.
1754
1755 2001-06-10  Alan Modra  <amodra@bigpond.net.au>
1756
1757         * config/obj-coff.c (obj_coff_section): Formatting fix.
1758
1759         * config/tc-i386.c (md_assemble): Accept branch hints as ",pt" and
1760         ",pn".
1761
1762 2001-06-08  H.J. Lu  <hjl@gnu.org>
1763
1764         * config/tc-mips.c (warn_nops): New variable. Set to 0 to
1765         disable warning about all NOPS that the assembler generates.
1766         (macro): Warn NOPS generated only if warn_nops is not 0.
1767         (md_shortopts): Add `n'.
1768         (md_parse_option): Set warn_nops to 1 for `n'.
1769
1770 2001-06-08  H.J. Lu  <hjl@gnu.org>
1771
1772         * config/tc-mips.c (mips_ip): Properly handle illegal operands.
1773
1774 2001-06-08  H.J. Lu  <hjl@gnu.org>
1775
1776         * config/tc-mips.c (md_apply_fix): Don't adjust common
1777         extern/weak symbols for ELF.
1778         (md_estimate_size_before_relax): Treat weak like extern for
1779         ELF.
1780         (mips_fix_adjustable): Don't adjust extern/weak symbols for
1781         ELF.
1782
1783 2001-06-08  Alan Modra  <amodra@bigpond.net.au>
1784
1785         * Makefile.am: 'som' is not wrongly spelled 'some'.
1786         * Makefile.in: Regenerate.
1787
1788         * config/tc-mips.c (mips16_mark_labels): Reduce number of calls to
1789         S_GET_VALUE by using a temp.
1790         (append_insn): Likewise, and for S_SET_VALUE too.
1791         (mips_emit_delays): Likewise.
1792         (my_getExpression): Likewise.
1793         (md_apply_fix): Likewise.  Use "valueT" rather than "long" for "value".
1794         (mips16_extended_frag): Remove code concerned with avoiding
1795         locking in a frag address now that symbols are not finalized until
1796         relaxation is complete.  Cater for first relaxation pass having
1797         bogus addresses.  Use relax_marker to reliably determine whether a
1798         symbol frag has been reached on the current pass.
1799
1800 2001-06-07  H.J. Lu  <hjl@gnu.org>
1801
1802         * configure.in: Move "mips-*-linux-gnu*" before "mips-*-gnu*".
1803         * configure: Regenerate.
1804
1805 2001-06-07  H.J. Lu  <hjl@gnu.org>
1806
1807         * configure.in: Use MIPS_STABS_ELF for Linux/mips and remove
1808         ecoff emulation.
1809         * configure: Regenerate.
1810
1811 2001-06-07  H.J. Lu  <hjl@gnu.org>
1812
1813         * config/tc-mips.c (mips_pseudo_table): Add "extern" if
1814         MIPS_STABS_ELF is defined.
1815
1816 2001-06-06  Nick Clifton  <nickc@cambridge.redhat.com>
1817
1818         * as.c (show_usage): Remove L from listing options.  It is not a
1819         generic option.
1820
1821 2001-06-06  Christian Groessler <cpg@aladdin.de>
1822
1823         * config/tc-z8k.c: Removed many warnings by removing unused
1824         variables and tagging unused parameters as such.
1825         (md_begin): Fixed a typo (","instead of ";").
1826         (struct ctrl_table): Add parentheses to initialize array
1827         correctly.
1828         (struct flag_table): Likewise.
1829         (struct intr_table): Likewise.
1830         (struct table): Likewise.
1831         (check_operand): "#if 0"'ed since it doesn't seem to be used.
1832
1833 2001-06-06  Peter Jakubek <pjak@snafu.de>
1834
1835         * config/tc-m68k.c (md_show_usage): Add all supported ColdFire
1836         options to list (e.g. m5206e, m5307, m5407).
1837
1838 2001-06-06  Martin Schwidefsky <schwidefsky@de.ibm.com>
1839
1840         * config/tc-s390.h (TC_FORCE_RELOCATION): Always emit relocations
1841         BFD_RELOC_VTABLE_INHERIT and BFD_RELOC_VTABLE_ENTRY.
1842
1843 2001-06-06  Alan Modra  <amodra@bigpond.net.au>
1844
1845         * config/tc-i386.c (md_assemble): Handle Pentium4 branch hints.
1846         <JumpByte, JumpDword insn output>: Remove dead code.
1847
1848 2001-06-06  Tracy Kuhrt <Tracy.Kuhrt@microchip.com>
1849
1850         * as.c (parse_args): Correct option name "listing-lhs-width2".
1851
1852 2001-06-05  Nick Clifton  <nickc@cambridge.redhat.com>
1853
1854         * symbols.c (S_SET_EXTERNAL): Do not override a section symbol's
1855         status.
1856
1857 2001-05-30  Richard Henderson  <rth@redhat.com>
1858
1859         * read.c (emit_leb128_expr): Call md_cons_align.
1860
1861 2001-05-28  Jeff Sturm  <jsturm@one-point.com>
1862
1863         * config/tc-sparc.c (md_apply_fix3): Handle BFD_RELOC_SPARC_UA16,
1864         BFD_RELOC_SPARC_UA32 and BFD_RELOC_SPARC_UA64.
1865         (tc_gen_reloc): Likewise.
1866         (sparc_cons_align): Don't clear sparc_no_align_cons.
1867         (cons_fix_new_sparc): Substitute BFD_RELOC_SPARC_UA{16|32|64} for
1868         BFD_RELOC_{16|32|64} iff sparc_no_align_cons is set.
1869
1870 2001-05-27  Alan Modra  <amodra@one.net.au>
1871
1872         * write.c (relax_segment <rs_space>): Check the section of a
1873         symbol to determine whether it is absolute rather than comparing
1874         its frag against zero_address_frag as listings play tricks with
1875         frags.
1876
1877         * config/tc-m68k.c (md_assemble): Ensure variable part of frag is
1878         allocated in the same chunk as the fixed part.
1879
1880 2001-05-26  Alan Modra  <amodra@one.net.au>
1881
1882         * write.c (relax_segment <rs_space>): Calculate growth using
1883         addresses before stretch.  Prevent repeated error messages.
1884         From Peter Jakubek  <pjak@snafu.de>
1885         Use as_bad_where and as_warn_where to pinpoint errors.
1886
1887 2001-05-25  Alan Modra  <amodra@one.net.au>
1888
1889         * symbols.c (resolve_symbol_value): Always set segment, even when
1890         not finalizing symbol value.
1891
1892         * config/obj-ieee.c (write_object_file): Set finalize_syms.
1893         * config/obj-coff.c (write_object_file): Likewise.
1894         * (size_section): Remove rs_space assert as fr_symbol is no longer
1895         removed.
1896         (fill_section): Likewise.
1897
1898         * configure.in: Replace linuxoldld with linux*oldld.
1899         * configure: Regenerate.
1900
1901         From 2.11 branch 2001-03-30  Richard Henderson  <rth@redhat.com>
1902         * config/tc-i386.c (md_convert_frag): Don't die on local symbols
1903         that have been finalized.
1904
1905         * symbols.c (resolve_symbol_value): Clear sy_resolving before
1906         taking exit_dont_set_value.
1907
1908         * write.c (relax_segment <rs_space>): Don't zap fr_symbol when
1909         relaxing.
1910
1911 2000-05-24  Tom Rix <trix@redhat.com>
1912
1913         * config/obj-coff.c (add_lineno): xcoff allows negative line
1914         numbers
1915         * config/tc-ppc.c (ppc_stabx): fix generated symbol
1916
1917 2001-05-24  Alan Modra  <amodra@one.net.au>
1918
1919         * write.c (write_object_file): Set finalize_syms = 1 before
1920         size_seg is called.
1921
1922 2001-05-23  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
1923
1924         * config/tc-mips.c (ISA_HAS_64BIT_REGS): Add ISA_MIPS64 as 64 bit
1925         architecture, remove erraneous ISA_MIPS32.
1926         (md_show_usage): Add MIPS r12k support.
1927         (mips_cpu_info_table): Add MIPS r12k support.
1928
1929 2001-05-22  Alan Modra  <amodra@one.net.au>
1930
1931         * config/tc-arc.c (md_assemble): Use is_end_of_line instead of
1932         testing for NULs.
1933
1934         * symbols.c (resolve_symbol_value): Remove "finalize" param,
1935         instead use finalize_syms directly.  Don't treat expressions
1936         specially with regard to finalize_syms.  Update calls to self.
1937         (resolve_local_symbol): Update call to resolve_symbol_value.
1938         (S_GET_VALUE): Likewise.  Return resolve_symbol_value if
1939         !finalize_syms.
1940         * symbols.h (resolve_symbol_value): Update prototype.
1941         * config/obj-aout.c (obj_crawl_symbol_chain): Update call
1942         to resolve_symbol_value.
1943         * config/obj-bout.c (obj_crawl_symbol_chain): Likewise.
1944         * config/obj-coff.c (do_relocs_for): Likewise.
1945         (yank_symbols): Likewise.
1946         (fixup_segment): Likewise.
1947         * config/obj-vms.c (obj_crawl_symbol_chain): Likewise.
1948         * config/tc-mips.c (md_convert_frag): Likewise.
1949         * config/tc-ppc.c (ppc_frob_symbol): Likewise.
1950         (ppc_fix_adjustable): Likewise.
1951         * dwarf2dbg.c (dwarf2dbg_estimate_size_before_relax): Likewise.
1952         (dwarf2dbg_convert_frag): Likewise.
1953         * ehopt.c (eh_frame_estimate_size_before_relax): Likewise.
1954         (eh_frame_convert_frag): Likewise.
1955         * expr.c (make_expr_symbol): Likewise.
1956         * write.c (adjust_reloc_syms): Likewise.
1957         (write_object_file): Likewise.
1958         (relax_segment): Likewise.
1959         (fixup_segment): Likewise.
1960         (finalize_syms): Init to zero, and update comment.
1961         (write_object_file): Set finalize_syms to 1 rather than 2.
1962         * doc/internals.texi (sy_value): Mention finalize_syms.
1963         (S_GET_VALUE): Remove restriction on when S_GET_VALUE can be called.
1964
1965         * config/tc-m68k.c (relaxable_symbol): Only treat external symbols
1966         as relaxable if embedded system, make weak syms non-relaxable.
1967         Move definition..
1968         (tc_m68k_fix_adjustable): ..so it can be used here.
1969         (md_apply_fix_2): Sign extend without conditional.
1970
1971         * config/tc-v850.c: Update copyright.
1972
1973 2001-05-16  Jeff Johnston  <jjohnstn@redhat.com>
1974
1975         * cgen.c (gas_cgen_tc_gen_reloc): Changed error message when
1976         howto entry is not found.
1977
1978 2001-05-15  Alexandre Oliva  <aoliva@redhat.com>
1979
1980         * config/tc-mn10300.c (mn10300_force_relocation): Don't
1981         optimize differences between symbols in code sections to
1982         constants.
1983         (mn10300_fix_adjustable): Don't adjust to section+offset
1984         relocations pointing at symbols in code sections.
1985
1986 2001-05-16  Alan Modra  <amodra@one.net.au>
1987
1988         * config/tc-arc.c (md_assemble): Correct dwarf2_emit_insn param
1989         for 8 byte insns.
1990         * config/tc-i386.c (md_assemble): Call dwarf2_emit_insn before
1991         opcodes are output rather than after.  Delete insn_size.
1992         * config/tc-v850.c (md_assemble): Similarly, but delete
1993         total_insn_size.
1994
1995 2001-05-14  Richard Henderson  <rth@redhat.com>
1996
1997         * ehopt.c (eh_frame_convert_frag): Fix missed subtype adjustment
1998         last change.
1999
2000 2001-05-14  Richard Henderson  <rth@redhat.com>
2001
2002         * ehopt.c (get_cie_info): Rename from eh_frame_code_alignment;
2003         also collect whether to expect an FDE augmentation.
2004         (check_eh_frame): Rewrite as a state machine.  Track where in
2005         an FDE we are located, skip any augmentation.
2006         (eh_frame_estimate_size_before_relax): Get code alignment from
2007         the fragment subtype.
2008         (eh_frame_relax_frag, eh_frame_convert_frag): Likewise.
2009         * read.c (emit_leb128_expr): Call check_eh_frame.
2010
2011 2001-05-14  Alexandre Oliva  <aoliva@redhat.com>
2012
2013         * config/tc-mn10300.c (md_assemble): Anchor dwarf2 line info
2014         before a relaxable insns.
2015
2016 2001-05-13  Alexandre Oliva  <aoliva@redhat.com>
2017
2018         * config/tc-mn10300.c (tc_gen_reloc): Don't reject differences
2019         between symbols if the base symbol is in the current section;
2020         emit a PC-relative relocation instead.
2021
2022 2001-05-12  Peter Targett  <peter.targett@arccores.com>
2023
2024         * config/tc-arc.c: Update copyright and tidy source comments.
2025         (md_pseudo_table): Add directive .cpu back as an alias for
2026         .option.  Add .file and .line for dwarf2 support.
2027         (arc_mach_type): Make bfd_mach_arc_6 default.
2028         (md_longopts): Add entry 'pre-v6' representing old command line
2029         option when assembling for 'arc5' core versions.
2030         (md_parse_option): Make OPTION_ARC same as OPTION_ARC6, for new
2031         default behaviour.
2032         (arc_code_symbol): Make symbol value for @h30 fixup expression
2033         equal to O_constant.
2034         (md_assemble): Call dwarf2_emit_insn.
2035         Include "dwarf2dbg2.h".  Formatting fixes throughout file.
2036         * config/tc-arc.h (DWARF2_LINE_MIN_INSN_LENGTH): Define.
2037         * doc/c-arc.texi (ARC_CORE_DEFAULT): Update to new default.
2038
2039 2001-05-11  Jakub Jelinek  <jakub@redhat.com>
2040
2041         * config/tc-ia64.c (special_linkonce_name): New.
2042         (make_unw_section): Map .gnu.linkonce.t.FOO text section into
2043         .gnu.linkonce.ia64unw{,i}.FOO.
2044         (ia64_elf_section_type): Handle .gnu.linkonce.ia64unw{,i}.FOO.
2045         (dot_endp): Add comment about it.
2046
2047 2001-05-11  Nick Clifton  <nickc@cambridge.redhat.com>
2048
2049         * config/tc-arm.c (arm_handle_align): When truncating an aligned
2050         block, ensure that the low order bits of the alignment are
2051         preserved.
2052
2053 2001-05-10  Alan Modra  <amodra@one.net.au>
2054
2055         * config/obj-vms.c (obj_crawl_symbol_chain): Don't take address of
2056         symbol_next.
2057
2058         * config/tc-fr30.c (md_estimate_size_before_relax): Return size of
2059         current variable part of frag.
2060         * config/tc-m32r.c (md_estimate_size_before_relax): Likewise.
2061         * config/tc-openrisc.c (md_estimate_size_before_relax): Likewise.
2062         * config/tc-m68hc11.c (RELAX_STATE): Define.
2063         (RELAX_LENGTH): Define.
2064         (md_estimate_size_before_relax): Handle non-relaxable cases
2065         separately from relaxable cases for clarity, and return correct
2066         size for multi-pass relaxation.
2067         * config/tc-tahoe.c (RELAX_LENGTH): Correct.
2068         (md_estimate_size_before_relax): As for tc-m68hc11.c.
2069         (md_convert_frag): Remove "length_code".
2070         * config/tc-vax.c (RELAX_STATE): Define.
2071         (RELAX_LENGTH): Define.
2072         (md_relax_table): Add missing entry.
2073         (md_estimate_size_before_relax): As for tc-m68hc11.c.
2074         (md_convert_frag): Remove "length_code".
2075         * config/tc-ns32k.c (md_estimate_size_before_relax): Simplify and
2076         don't bother setting fr_var.  Return correct size for multi-pass
2077         relaxation.
2078         * config/tc-v850.c (md_estimate_size_before_relax): Rewrite.
2079         (md_convert_frag): Don't bother clearing fr_var.
2080         (md_pseudo_table): Correct initialization.
2081         * config/tc-h8500.c (md_convert_frag): Don't bother clearing fr_var.
2082         (md_estimate_size_before_relax): No need to set fr_var.
2083         * config/tc-mcore.c (md_convert_frag): Don't bother clearing fr_var.
2084         (md_estimate_size_before_relax): No need to set fr_var.
2085
2086 2001-05-09  Richard Henderson  <rth@redhat.com>
2087
2088         * config/tc-ia64.c (generate_unwind_image): Align the fragment
2089         beginning a function's unwind info block.
2090
2091 2001-05-09  Alexandre Oliva  <aoliva@redhat.com>
2092
2093         * config/tc-mn10300.c (md_apply_fix3): Accept PC-relative relocs.
2094
2095 2001-05-08  Andreas Schwab  <schwab@suse.de>
2096
2097         * config/tc-m68k.c: Instead of replacing -1 by 64 in assignment to
2098         fx_pcrel_adjust explicitly sign extend when reading it.
2099
2100 2001-05-08  Alan Modra  <amodra@one.net.au>
2101
2102         * config/tc-m68k.c (md_estimate_size_before_relax): Set fr_var
2103         from md_relax_table, and combine some switch cases.
2104
2105 2001-05-06  Alexandre Oliva  <aoliva@redhat.com>
2106
2107         * config/tc-mn10300.c (md_assemble): Subtract operand->shift
2108         from offset in non-pcrel operands too.
2109
2110 2001-05-06  Nick Clifton  <nickc@cambridge.redhat.com>
2111
2112         * config/tc-arm.h (MAX_MEM_FOR_RS_ALIGN_CODE): Define.
2113         * config/tc-arm.c (arm_handle_align): Do not insert more than
2114         MAX_MEM_FOR_RS_ALIGN_CODE bytes.
2115         (arm_frag_align_code): Use MAX_MEM_FOR_RS_ALIGN_CODE.
2116
2117 2001-05-03  Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
2118
2119         * Makefile.am (TARG_ENV_HFILES): Add te-hppa64.h and te-hppalinux64.h.
2120         Run "make dep-am".
2121         * Makefile.in: Regenerate.
2122         * configure.in: Remove duplicate mips-*-ecoff* entry.
2123         * configure: Regenerate.
2124
2125         * config/obj-ecoff.c (obj_pseudo_table): Fix terminating entry.
2126         (n_names): Cast away type mismatch.
2127         (ecoff_sec_sym_ok_for_reloc): Add unused attribute.
2128         (obj_ecoff_frob_symbol): Likewise.
2129         * ecoff.c: (add_file): Add unused attribute.
2130         (ecoff_directive_begin): Likewise.
2131         (ecoff_directive_bend): Likewise.
2132         (ecoff_directive_def): Likewise.
2133         (ecoff_directive_dim): Likewise.
2134         (ecoff_directive_scl): Likewise.
2135         (ecoff_directive_size): Likewise.
2136         (ecoff_directive_type): Likewise.
2137         (ecoff_directive_tag): Likewise.
2138         (ecoff_directive_val): Likewise.
2139         (ecoff_directive_endef): Likewise.
2140         (ecoff_directive_end): Likewise.
2141         (ecoff_directive_ent): Likewise.
2142         (ecoff_directive_extern): Likewise.
2143         (ecoff_directive_file): Likewise.
2144         (ecoff_directive_fmask): Likewise.
2145         (ecoff_directive_frame): Likewise.
2146         (ecoff_directive_mask): Likewise.
2147         (ecoff_directive_loc): Likewise.
2148         (mark_stabs): Likewise.
2149         (ecoff_stab):  Likewise.
2150         (ecoff_frob_symbol): Cast away type mismatch.
2151         (ecoff_padding_adjust): Likewise.
2152         (ecoff_build_symbols): Likewise.
2153         (ecoff_build_procs): Likewise.
2154         (ecoff_build_aux): Likewise.
2155         (ecoff_build_strings): Likewise.
2156         (ecoff_build_fdr): Likewise.
2157         (ecoff_build_debug): Likewise.
2158         * itbl-ops.c (itbl_assemble): Variable initialization.
2159
2160 2001-05-03  Alan Modra  <amodra@one.net.au>
2161
2162         * config/tc-i386.c (i386_displacement): Call as_bad for bad GOTOFF
2163         expressions rather than triggering an assert.
2164
2165 2001-05-02  Johan Rydberg  <jrydberg@opencores.org>
2166
2167         * config/tc-openrisc.c: New file.
2168         * config/tc-openrisc.h: Likewise.
2169
2170         * Makefile.am: Add OpenRISC target.
2171         * Makefile.in: Regenerated.
2172
2173         * configure.in (openrisc-*-*): Add target.
2174         * configure: Regenerated.
2175
2176 2001-05-02  Nick Clifton  <nickc@cambridge.redhat.com>
2177
2178         * config/tc-arm.c (arm_frag_align_code): Change error message to
2179         more explanatory version.
2180
2181 2001-04-29  Keith M Wesolowski <wesolows@foobazco.org>
2182
2183         * config/tc-mips.c (md_parse_option): Also accept
2184         elf64-tradbigmips and elf64-tradlittlemips for OPTION_64.
2185
2186 2001-04-27  David Mosberger  <davidm@hpl.hp.com>
2187
2188         * config/tc-ia64.c (dot_spillmem_p): Fix output_spill_?sprel_p()
2189         argument passing order: predicate goes last, not first.
2190
2191 2001-04-27  Sean McNeil <sean@mcneil.com>
2192
2193         * configure.in: Add arm-vxworks.
2194         * configure: Regenerate.
2195
2196 2001-04-26  Nick Clifton  <nickc@cambridge.redhat.com>
2197
2198         * config/tc-arm.c (arm_handle_align): New Function:  Generate
2199         no-op filled alignment frags.
2200         (arm_frag_align_code): New Function: Create a code alignment frag.
2201         (arm_init_frag): New Function: Initialse the target dependent
2202         parts of a frag.
2203
2204         * config/tc-arm.h (TC_FRAG_TYPE): Define.
2205         (TC_FRAG_INIT): Define.
2206         (HANDLE_ALIGN): Define.
2207         (md_do_align): Define.
2208
2209 2001-04-25  Nick Clifton  <nickc@cambridge.redhat.com>
2210
2211         * config/obj-coff.c (do_linenos_for): Check to see if the filename
2212         symbol has been initialised before extracting its symbol index.
2213
2214 2001-04-24  H.J. Lu  <hjl@gnu.org>
2215
2216         * configure: Regenerated with the right version of autoconf.
2217
2218 2001-04-24  Christian Groessler  <cpg@aladdin.de>
2219
2220         * config/tc-z8k.c (build_bytes): 12 and 16 bit displacements now
2221         generate R_CALLR and R_REL16 relocations
2222
2223 2000-04-20  Jason Eckhardt  <jle@redhat.com>
2224
2225         * config/tc-d10v.h (tc_frob_label): Update the symbol's frag
2226         since frag_now can change after d10v_cleanup is called.
2227
2228 2001-04-16  David O'Brien  <obrien@FreeBSD.org>
2229
2230         * configure.in: Add the em type for FreeBSD targets.
2231         * configure: Regenerate.
2232
2233 2001-04-14  Alexandre Oliva  <aoliva@redhat.com>
2234
2235         * struc-symbol.h (struct local_symbol): New TC_LOCAL_SYMFIELD_TYPE.
2236         * symbols.c (local_symbol_convert): Call TC_LOCAL_SYMFIELD_CONVERT.
2237
2238         * config/tc-mn10300.c (md_assemble): Simplify offset adjustment of
2239         pc-relative relocations not placed at the end of the instruction.
2240
2241 2001-04-13  Jim Wilson  <wilson@redhat.com>
2242
2243         * tc-ia64.c (is_conditional_branch): Return true for br, brl, and br.
2244         excluding br.i.
2245
2246 2001-04-13  Jakub Jelinek  <jakub@redhat.com>
2247
2248         * config/obj-elf.c (obj_elf_change_section): Add entsize argument,
2249         handle SHF_MERGE and SHF_STRINGS.
2250         (obj_elf_parse_section_letters): Set SHF_MERGE and SHF_STRINGS.
2251         (obj_elf_section): Allow additional argument specifying entity size.
2252         * write.c (adjust_reloc_syms): Keep relocations against local symbols
2253         in SEC_MERGE sections.
2254
2255 2001-04-12  Jason Merrill  <jason_merrill@redhat.com>
2256
2257         * dwarf2dbg.c (process_entries): Don't optimize redundant line notes.
2258
2259 2001-04-12  Alexandre Oliva  <aoliva@redhat.com>
2260
2261         * expr.c (operand): Pass &c to md_parse_name().
2262         * config/tc-ia64.h, config/tc-ppc.h, config/tc-tic54x.h: Adjust.
2263
2264 2001-04-07  Steven J. Hill  <sjhill@cotw.com>
2265
2266         * config/tc-mips.c: Support ELF64 for traditional MIPS targets.
2267
2268         * Makefile.am: (TARG_ENV_HFILES): Add tc-mips.h.
2269         * Makefile.in: Regenerated.
2270
2271         * configure.in: Use traditional MIPS targets for Linux/MIPS.
2272         * configure: Regenerated.
2273
2274 2001-04-06  Alexandre Oliva  <aoliva@redhat.com>
2275
2276         * config/tc-mn10300.c (xr_registers): Added `pc'.
2277
2278 2001-04-05  Alan Modra  <alan@linuxcare.com.au>
2279
2280         * configure.in: Add h8500-*-coff and h8500-*-rtems targets.
2281         * configure: Regenerate.
2282
2283         * config/tc-h8500.c (md_estimate_size_before_relax): Add missing
2284         cases, and always return size based on current fr_subtype.
2285         (md_begin): Move initialization of md_relax_table..
2286         (md_relax_table): ..to static initializer.  Set rlx_length for
2287         UNDEF_WORD_DISP cases.
2288         * config/tc-w65.c (md_estimate_size_before_relax): Likewise.
2289         (md_begin): Likewise.
2290         (md_relax_table): Likewise.
2291         * config/tc-mcore.c (md_estimate_size_before_relax): Likewise.
2292         (md_relax_table): Set rlx_length for UNDEF_WORD_DISP cases.
2293         Set rlx_backward and rlx_forward to zero for unused states.
2294         * config/tc-sh.c (md_estimate_size_before_relax): Likewise.
2295         (md_relax_table): Set rlx_length for UNDEF_WORD_DISP cases.
2296         (UNCOND12, UNCOND32): Remove duplicate defines.
2297
2298 2001-04-04  Hans-Peter Nilsson  <hp@axis.com>
2299
2300         * config/tc-cris.c (md_estimate_size_before_relax) <case
2301         ENCODE_RELAX (STATE_CONDITIONAL_BRANCH, STATE_UNDF)>: Don't emit
2302         32-bit branch, just set fragP->fr_subtype.  Set fragP->fr_var.
2303         <all cases>: Always set fragP->fr_var using md_cris_relax_table.
2304         Add cases to cover all relax states.
2305         (cris_insn_first_word_frag): New.
2306         (md_assemble): Call cris_insn_first_word_frag to get the first
2307         frag in an insn, not frag_more.  Don't call dwarf2_emit_insn at
2308         end.  Drop variable insn_size.
2309         (gen_bdap): Call cris_insn_first_word_frag, not frag_more.
2310         (cris_sym_leading_underscore): Wrap first as_bad parameter in _().
2311         (cris_sym_no_leading_underscore, s_cris_file, s_cris_loc): Ditto.
2312
2313         * write.c (write_object_file): Reset broken word state before
2314         calling relax_seg.
2315
2316 2001-03-31  Alan Modra  <alan@linuxcare.com.au>
2317
2318         * listing.c (listing_listing): Enable listing on EDICT_NOLIST_NEXT
2319         for one line if not already enabled.
2320         * cond.c (s_elseif): Correct conditional assembly listing.
2321         (s_else): Likewise.
2322
2323         * cond.c (s_endif): Correct handling of "if .. elseif .." trees.
2324         Don't abort on NULL current_cframe.
2325
2326 2001-03-30  Alan Modra  <alan@linuxcare.com.au>
2327
2328         * dwarf2dbg.c (dwarf2_directive_file): Fix warnings.
2329         (dwarf2dbg_convert_frag): Pass `finalize_syms' to resolve_symbol_value.
2330         * config/obj-aout.c (obj_crawl_symbol_chain): Likewise.
2331         * config/obj-bout.c (obj_crawl_symbol_chain): Likewise.
2332         * config/obj-coff.c (do_relocs_for): Likewise.
2333         (yank_symbols): Likewise.
2334         (fixup_segment): Likewise.
2335         * config/tc-ppc.c (ppc_frob_symbol): Likewise.
2336         (ppc_fix_adjustable): Likewise.
2337         * config/tc-mips.c (md_convert_frag): Likewise.
2338         * config/obj-vms.c (obj_crawl_symbol_chain): Likewise.
2339         * ehopt.c (eh_frame_convert_frag): Likewise.
2340         * expr.c (make_expr_symbol): Likewise.
2341
2342         * frags.h (struct frag): Add last_fr_address.  Reorder fields for
2343         better packing.
2344         * symbols.c (resolve_symbol_value): Don't fix expression values
2345         until relaxation is complete.
2346         (resolve_local_symbol): Pass `finalize_syms' to resolve_symbol_value.
2347         (S_GET_VALUE): Likewise, and return unresolved expression value.
2348         * write.c (finalize_syms): New.
2349         (relax_and_size_seg): Split into..
2350         (relax_seg): New function, returns 1 if anything changed..
2351         (size_seg): And the remainder of relax_and_size_seg.
2352         (fixup_segment): Arrange for final resolution of sym values.
2353         (adjust_reloc_syms): Likewise.
2354         (write_object_file): Likewise, and repeatedly call relax_seg until
2355         nothing more changes.
2356         (relax_segment): Return 1 if anything changed.  Use correct types
2357         for rs_org `target' and `after'.
2358         * write.h (finalize_syms): Declare.
2359         (relax_segment): Update prototype.
2360
2361         * config/tc-sh.c (md_estimate_size_before_relax): Add extra
2362         do-nothing cases to switch to avoid abort on a second relaxation
2363         pass, and tidy code a little.
2364         * config/tc-cris.c (md_estimate_size_before_relax): Likewise.
2365         * config/tc-h8500.c (md_estimate_size_before_relax): Likewise.
2366         * config/tc-w65.c (md_estimate_size_before_relax): Likewise.
2367         * config/tc-i386.c (UNCOND_JUMP, COND_JUMP, COND_JUMP86): Decrement.
2368         (md_relax_table): Remove first four unused entries.  Increment
2369         rlx_length by one throughout table, and update comments to suit.
2370         (md_estimate_size_before_relax): Return size of current variable
2371         part of frag to reflect reality when relaxing more than once.
2372         * config/tc-mcore.c (COND12, UNCD12): Rename to DISP12 throughout.
2373         (COND32, UNCD32): Rename to DISP32 throughout.
2374         (UNDEF_WORD_DISP): Renumber to 3.
2375         (md_estimate_size_before_relax): Add extra do-nothing cases.
2376         * config/tc-mn10200.c (md_estimate_size_before_relax): Rewrite.
2377         * config/tc-mn10300.c (md_estimate_size_before_relax): Rewrite.
2378         * config/tc-ns32k.c (md_estimate_size_before_relax): Add cases to
2379         handle word and dword branches.
2380
2381 2001-03-29  Hans-Peter Nilsson  <hp@axis.com>
2382
2383         * config/tc-cris.h (tc_fix_adjustable): Allow only
2384         BFD_RELOC_CRIS_32_GOTREL of the PIC relocs.
2385         * config/tc-cris.c (cris_get_pic_suffix): Correct reloc type in
2386         example in comment to valid type.
2387
2388 2001-03-28  H.J. Lu  <hjl@gnu.org>
2389
2390         * read.c (equals): Set to local for COFF only if it hasn't been
2391         defined before.
2392
2393 2001-03-28  Alan Modra  <alan@linuxcare.com.au>
2394
2395         * config/tc-hppa.c (DEFAULT_LEVEL): Define.
2396         (md_begin): Use it when setting default architecture.
2397
2398 2001-03-27  Nick Papadonis  <nick@coelacanth.com>
2399
2400         * read.c (equals): (for COFF) default symbols to being local.
2401
2402 2001-03-27  Hans-Peter Nilsson  <hp@axis.com>
2403
2404         * configure.in (cris-*-*): Change default emulation to criself.
2405         (cris-*-*aout*): New rule.
2406         * configure: Regenerate.
2407
2408 2001-03-26  Martin Schwidefsky  <schwidefsky@de.ibm.com>
2409
2410         * config/tc-s390.c (tc_s390_fix_adjustable): Add test for
2411         BFD_RELOC_390_GOTENT.
2412         * config/tc-s390.h (TC_RELOC_RTSYM_LOC_FIXUP): Add test for
2413         BFD_RELOC_390_GOTENT.
2414
2415 2001-03-26  Nick Clifton  <nickc@redhat.com>
2416
2417         * config/tc-s390.h (TC_FORCE_RELOCATION): Define.
2418         * config/tc-s390.c (s390_force_relocation): New function: Force
2419         relocations for VTINHERIT relocs.
2420
2421 2001-03-23  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
2422
2423         * doc/as.texinfo: Put @c man begin to generate the as man page.
2424         When generating man, define all the variables. Re-organize some
2425         options to obtain better indentation of man page.
2426         * doc/Makefile.am (MANCONF, TEXI2POD, POD2MAN): New variable.
2427         (as.1): Build from as.texinfo.
2428         * doc/Makefile.in: Regenerate.Index: binutils/Makefile.am
2429
2430 2001-03-25  Alan Modra  <alan@linuxcare.com.au>
2431
2432         * config/tc-i386.c (i386_scale): Accept an absolute expression for
2433         scale factor, and return the end of the expression.
2434         (i386_operand): Modify for above.
2435
2436 2001-03-23  Nick Clifton  <nickc@redhat.com>
2437
2438         * doc/as.texinfo: Document --listing-XXX command line switches.
2439         Explain why listings behave differently when -pipe is used.
2440
2441 2001-03-23  Richard Sandiford  <rsandifo@redhat.com>
2442
2443         * write.c (fix_new_exp): Print an error if passed a register.
2444
2445 2001-03-23  Hans-Peter Nilsson  <hp@axis.com>
2446
2447         * config/tc-cris.c: Tweak attribution.  Fix typos.  PIC support.
2448         (PIC_SUFFIX_CHAR): New macro.
2449         (cris_get_pic_suffix, cris_get_pic_reloc_size): New functions.
2450         (pic): New variable.
2451         (md_longopts): New option --pic.
2452         (OPTION_PIC): Define.
2453         (md_estimate_size_before_relax): Tweak longish comment.
2454         (md_create_long_jump): Make the long jumps generate ADD.D offset,PC.
2455         (md_assemble): Handle a PIC relocation on prefix and normal
2456         instruction operands.
2457         <output_instruction.insn_type == CRIS_INSN_BRANCH>: Handle
2458         "complex" operand expressions.  Call frag_more outside
2459         gen_cond_branch_32 parameter list.
2460         (cris_process_instruction): Handle PIC relocs on parsed
2461         operand expressions.  Validize PIC reloc sizes.
2462         (get_autoinc_prefix_or_indir_op): Handle PIC suffix.
2463         (gen_bdap): Handle "complex" operand expressions.
2464         (gen_cond_branch_32): Use as_warn_where, not as_warn.  Use
2465         ADD.D offset,PC as jump instruction if generating PIC.  Generate
2466         error instead of crashing on complex expressions.
2467         (cris_number_to_imm): Add segT parameter.  All callers changed.
2468         Use segT parameter, not now_seg, for segment of fixup.  Handle
2469         PCREL relocations but check that they are fully resolved.
2470         (md_parse_option): Handle OPTION_PIC.
2471         (tc_gen_reloc): Handle PIC relocs.
2472         (md_show_usage): Update for --pic.
2473         (md_apply_fix3): Renamed from md_apply_fix.
2474         (md_pcrel_from): Accept emitting PCREL relocs when ELF.
2475         (md_cris_force_relocation): Force relocation for PIC relocs.
2476
2477         * config/tc-cris.h: Tweak attribution.
2478         (MD_APPLY_FIX3): Define.
2479         (IS_CRIS_PIC_RELOC): New macro.
2480         (TC_RELOC_RTSYM_LOC_FIXUP): Define.
2481         (tc_fix_adjustable): Don't adjust a globally visible symbol when
2482         generating ELF.
2483         (tc_frob_symbol): Avoid emitting undefined symbols.
2484
2485 2001-03-20  Alan Modra  <alan@linuxcare.com.au>
2486
2487         * frags.h (struct frag): Add relax_marker.
2488         * write.c (is_dnrange): Delete.
2489         (relax_frag): Use correct types for `aim', `target', `address'.
2490         Delete `offset', `was_address'.  Test `relax_marker' instead of
2491         using fragile (and slow) address test.
2492         (relax_segment): Init and flip `relax_marker'.
2493
2494 2001-03-19  Alan Modra  <alan@linuxcare.com.au>
2495
2496         * config/tc-i386.c (md_assemble <REGISTER_WARNINGS>): Correct
2497         used register name.
2498
2499 2001-03-18  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
2500
2501         * config/tc-m68hc11.c (md_pseudo_table): Recognize xrefb to comply
2502         with 'Motorola specification for assembly language input standard'.
2503
2504 2001-03-17  Richard Henderson  <rth@redhat.com>
2505
2506         * dwarf2dbg.c (user_filenum, user_filenum_allocated): Remove.
2507         (dwarf2_directive_loc): Don't use them.
2508         (dwarf2_directive_file): Reject duplicate file definitions.
2509         (get_filenum): Zero allocated memory.
2510         (out_file_list): Complain about missing file definitions.
2511
2512 2001-03-17  Alan Modra  <alan@linuxcare.com.au>
2513
2514         * read.c (do_org): Handle complex expressions.
2515         * cgen.c (gas_cgen_finish_insn): Likewise.
2516
2517 2001-03-15  David Mosberger  <davidm@hpl.hp.com>
2518
2519         * config/tc-ia64.c (md): New member keep_pending_output.
2520         (ia64_flush_pending_output): Flush only if md.keep_pending_output
2521         is not set.
2522         (dot_xdata): Turn on md.keep_pending_output for the duration of
2523         this function.
2524         (dot_xfloat_cons): Ditto.
2525         (dot_xstringer): Ditto.
2526         (dot_xdata_ua): Ditto.
2527         (dot_xfloat_cons_ua): Ditto.
2528
2529 2001-03-15  Jim Wilson  <wilson@redhat.com>
2530
2531         * config/tc-ia64.c (ia64_unrecognized_line, case '['): Add local
2532         label support.
2533
2534 2001-03-15  Alexandre Oliva  <aoliva@redhat.com>
2535
2536         * config/tc-sh.c (parse_reg): Match capital MACH and MACL.
2537
2538 2001-03-15  DJ Delorie  <dj@redhat.com>
2539
2540         * stabs.c (s_stab_generic): Don't corrupt the notes obstack by
2541         blindly freeing string if it isn't at the top of the obstack.
2542
2543 2001-03-13  Alan Modra  <alan@linuxcare.com.au>
2544
2545         * config/tc-i386.c (RELOC_ENUM): Define.  Use throughout file.
2546         (NUM_FLAG_CODE): Define.
2547         (lex_got): New function.
2548         (got_reloc): New global var.
2549         (x86_cons_fix_new): New function.
2550         (x86_cons): New function.
2551         (i386_immediate): Use lex_got here, replacing inline code.  Change
2552         "ignoring junk.." error message to "junk.."
2553         (i386_displacement): Likewise.
2554         * config/tc-i386.h (TC_PARSE_CONS_EXPRESSION): Define.
2555         (x86_cons): Declare.
2556         (TC_CONS_FIX_NEW): Define.
2557         (x86_cons_fix_new): Declare.
2558
2559 2001-03-12  Nick Clifton  <nickc@redhat.com>
2560
2561         * config/tc-arm.c (md_begin): Always set machine type based on
2562         cpu_variant.
2563
2564 2001-03-07  Alan Modra  <alan@linuxcare.com.au>
2565
2566         * config/tc-i386.c (struct _i386_insn): Rename disp_reloc to reloc.
2567         (md_assemble) <smallest displacement>: Use correct field of i.op[]
2568         union.
2569         <JumpInterSegment output>: Use correct i.disp_reloc[].
2570         <immediate output>: Likewise.
2571
2572 2001-03-06  Nick Clifton  <nickc@redhat.com>
2573
2574         * config/tc-arm.c (md_apply_fix3): Clear bit zero of offset in
2575         BLX(1) instruction.
2576
2577 2001-03-06  Igor Shevlyakov  <igor@windriver.com>
2578
2579         * config/tc-m68k.c : Add 5407 to archs[] table.
2580         (HAVE_LONG_BRANCH): Add mcf5407.
2581         (select_control_regs): Recognize 5407.
2582
2583 2001-03-02  Dave Brolley  <brolley@redhat.com>
2584
2585         * config/tc-m32r.c (expand_debug_syms): Call frag_align_code rather
2586         than m32r_do_align.
2587
2588 2001-03-02  Richard Sandiford  <rsandifo@redhat.com>
2589
2590         * config/atof-ieee.c (TC_LARGEST_EXPONENT_IS_NORMAL): New macro.
2591         (gen_to_words): Print warnings if NaNs are found and the target CPU
2592         does not support them.  Allow largest exponent to be used in normal
2593         numbers if TC_LARGEST_EXPONENT_IS_NORMAL evaluates to true.
2594
2595 2001-02-28  Andreas Jaeger  <aj@suse.de>, Bo Thorsen  <bo@suse.de>
2596
2597         * config/tc-i386.c (tc_gen_reloc): Remove ugly hack which is not needed
2598         anymore since we use bfd_elf_generic_reloc now.
2599         (md_apply_fix3): Only apply hack for partial_inplace if not using RELA.
2600
2601 2001-02-27  Alan Modra  <alan@linuxcare.com.au>
2602
2603         * configure.in (BFD_VERSION): New.
2604         (AM_INIT_AUTOMAKE): Use $BFD_VERSION.
2605         * configure: Regenerate.
2606         * Makefile.am: Run "make dep-am"
2607         * Makefile.in: Regenerate.
2608         * doc/Makefile.in: Regenerate.
2609
2610 2001-02-26  Mark Elbrecht  <snowball3@bigfoot.com>
2611
2612         * config/obj-coff.c [BFD_ASSEMBLER] (obj_coff_section): Set
2613         SEC_NEVER_LOAD when the 'n' flag is used.
2614         Add SEC_NEVER_LOAD to matchflags.
2615
2616 2001-02-24  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
2617
2618         * symbols.c (decode_local_label_name): Initialize message_format
2619         only when an error is reported (perf pb due to I18N).
2620
2621 2001-02-23  H.J. Lu  <hjl@gnu.org>
2622
2623         * dwarf2dbg.c (dwarf2_directive_file): Call s_app_file (0) if
2624         BFD_ASSEMBLER is not defined.
2625
2626 2001-02-23  Richard Sandiford  <rsandifo@redhat.com>
2627
2628         * config/tc-mn10300.c (md_apply_fix3): Don't mark a fixup as
2629         done if it's against a symbol.
2630
2631 2001-02-22  Timothy Wall  <twall@cygnus.com>
2632
2633         * config/tc-ia64.c (ia64_target_format): Return ia64-aix-specific
2634         target formats if applicable.
2635         * config/te-ia64aix.h: New.  Configuration for AIX5 on IA-64.
2636         * Makefile.am (TARG_ENV_HFILES): Added config/te-ia64aix.h.
2637         * Makefile.in: Regenerated.
2638         * configure.in: Added configuration for ia64-*-aix*.
2639         * configure: Regenerated.
2640
2641 2001-02-21  David Mosberger  <davidm@hpl.hp.com>
2642
2643         * config/tc-ia64.c (enum operand_match_result): New type.
2644         (operand_match): Change return type to operand_match_result.
2645         Fix all returns appropriately, adding support for returning the
2646         out-of-range result.
2647         (parse_operands): New locals result, error_pos, out_of_range_pos,
2648         curr_out_of_range_pos.  Rewrite operand matching loop to give better
2649         error messages.
2650
2651 2001-02-21  David Mosberger  <davidm@hpl.hp.com>
2652
2653         * config/tc-ia64.c (struct unwind): Add member "prologue_count".
2654         (dot_proc): Clear unwind.prologue_count to zero.
2655         (dot_prologue): Increment unwind.prologue_count.
2656         (dot_restore): If second operand is omitted, use
2657         unwind.prologue_count -1 for "ecount" (# of additional regions to
2658         pop).  Decrement unwind.prologue_count by number of regions
2659         popped.
2660
2661 2001-02-21  Nick Clifton  <nickc@redhat.com>
2662
2663         * doc/as.texinfo (Section): Note that some flags to the COFF
2664         version of .section remove attributes rather than setting them.
2665
2666 2001-02-20  Kazu Hirata  <kazu@hxi.com>
2667
2668         * config/tc-pdp11.c: Fix formatting.
2669         * config/tc-pdp11.h: Likewise.
2670
2671 2001-02-20  Bo Thorsen  <bo@suse.de>
2672
2673         * config/tc-i386.c (tc_i386_fix_adjustable): Fix GOTPCREL GOT
2674         entry.
2675
2676 2001-02-18  David O'Brien  <obrien@FreeBSD.org>
2677
2678         * configure.in (cpu_type, arch): Add a generic FreeBSD specification as
2679         all FreeBSD platforms should look the same at this level.
2680         * configure: Rebuilt.
2681         * config/tc-i386.c: Add support for old FreeBSD a.out hosts.
2682
2683 2001-02-18  lars brinkhoff  <lars@nocrew.org>
2684
2685         * Makefile.am: Add PDP-11 target.
2686         * configure.in: Likewise.
2687         * config/tc-pdp11.c: New file.
2688         * config/tc-pdp11.h: New file.
2689         * doc/Makefile.am: Add PDP-11 documentation.
2690         * doc/all.texi: Likewise.
2691         * doc/as.texinfo: Likewise.
2692         * doc/c-pdp11.texi: New file.
2693
2694 2001-02-16  matthew green  <mrg@redhat.com>
2695
2696         * cgen.c (gas_cgen_md_apply_fix3): Support BFD_RELOC_64.
2697
2698 2001-02-13  Jim Wilson  <wilson@redhat.com>
2699
2700         * config/tc-ia64.c (operand_match, case TAG13): Make a BFD_RELOC_UNUSED
2701         reloc instead of a 0 reloc.
2702         (md_apply_fix3): Check for BFD_RELOC_UNUSED instead of 0, and mark it
2703         as done.
2704         * config/tc-ia64.h (TC_RELOC_RTSYM_LOC_FIXUP): Likewise.
2705
2706 2001-02-13  Ian Lance Taylor  <ian@zembu.com>
2707
2708         * write.c (is_dnrange): Stop as soon as the address becomes
2709         larger.
2710         (relax_frag): Add segment parameter.  Only call symbol_get_frag
2711         once.  Only call is_dnrange if the symbol is in the same segment,
2712         and the symbol address is larger.
2713         (relax_segment): Pass segment to md_relax_frag and relax_frag.
2714         * write.h (relax_frag): Update declaration.
2715         * config/tc-fr30.c (fr30_relax_frag): Add segment parameter.  Pass
2716         it to relax_frag.
2717         * config/tc-m32r.c (m32r_relax_frag): Likewise.
2718         * config/tc-m32r.h (md_relax_frag): Add segment parameter.
2719         (m32r_relax_frag): Update declaration.
2720         * config/tc-mips.h (md_relax_frag): Add segment parameter.
2721         * config/tc-tic54x.h (md_relax_frag): Likewise.
2722         * doc/internals.texi (CPU backend): Update documentation for
2723         md_relax_frag.
2724
2725 2001-02-13  Alan Modra  <alan@linuxcare.com.au>
2726
2727         * doc/c-i386.texi (i386-Arch): Add "jumps"/"nojumps" blurb.
2728         Mention effect of < 386 architectures on jump promotion.
2729         (i386-Jumps): xref above.  Don't assume long disp is 32 bits.
2730
2731         * config/tc-i386.c (no_cond_jump_promotion): New.
2732         (set_cpu_arch): Parse "jumps" arch modifier.
2733         (insn_size): Modify usage comment.
2734         (ENCODE_RELAX_STATE): Reformat and protect macro arg.
2735         (SIZE_FROM_RELAX_STATE): Rename to DISP_SIZE_FROM_RELAX_STATE.
2736         (TYPE_FROM_RELAX_STATE): New define.
2737         (UNCOND_JUMP, COND_JUMP): Renumber.
2738         (md_relax_table): Reorder to suit.
2739         (COND_JUMP86): New define.
2740         (md_relax_table): Handle COND_JUMP86 cases. Add a few comments.
2741         (md_assemble): Create frag var for jumps of max size, encode relax
2742         state for COND_JUMP86.
2743         (md_estimate_size_before_relax): Handle COND_JUMP86 cases, and
2744         leave conditional jumps small if no_cond_jump_promotion.
2745         (md_convert_frag): Likewise.
2746
2747         * expr.c (operator): Don't bump input_line_pointer for two char
2748         operators.  Instead return operator size via new param num_chars.
2749         (expr): Use above to parse multi-char operators correctly.
2750
2751 Mon Feb 12 17:45:50 CET 2001  Jan Hubicka  <jh@suse.cz>
2752
2753         * config/tc-i386.c (i386_displacement): Fix handling of
2754         BFD_RELOC_X86_64_GOTPCREL.
2755         (i386_validate_fix): Likewise.
2756
2757 2001-02-12  Philip Blundell  <pb@futuretv.com>
2758
2759         * config/tc-arm.c (do_ldst): Improve warnings for unpredictable
2760         ldrt/strt instructions.
2761
2762 2001-02-11  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
2763
2764         * config/tc-mips.c (macro): For M_LA_AB emit a
2765         BFD_RELOC_MIPS_CALL16 relocation or a
2766         BFD_RELOC_MIPS_CALL_HI16/BFD_RELOC_MIPS_CALL_LO16 pair instead of
2767         BFD_RELOC_MIPS_GOT16 and
2768         BFD_RELOC_MIPS_GOT_HI16/BFD_RELOC_MIPS_GOT_LO16, respectively for
2769         loading the jump register when generating SVR4_PIC code.
2770
2771 2001-02-10  Chris Demetriou  <cgd@broadcom.com>
2772
2773         * configure.in: Make 'mipself' and 'mipsecoff' emulations
2774         map to MIPS-specific files, as they used to do before the
2775         change on 2000-05-21.
2776         * configure: Regerate.
2777
2778 2001-02-10  Chris Demetriou  <cgd@broadcom.com>
2779
2780         * config/tc-mips.c (md_parse_option): Don't try to compile
2781         ELF-only option code if not ELF.
2782
2783 2001-02-08  David Mosberger  <davidm@hpl.hp.com>
2784
2785         * config/tc-ia64.h (md_elf_section_type): New macro.
2786         (ELF_TC_SPECIAL_SECTIONS): Drop .IA_64.unwind and .IA_64.unwind_info
2787         (they're now handled via ia64_elf_section_type.
2788
2789         * config/tc-ia64.c (unwind): New members saved_text_seg,
2790         saved_text_subseg, and force_unwind_entry.
2791         (optimize_unw_records): New function to optimize away unnecessary
2792         unwind directives.
2793         (ia64_elf_section_type): New function.
2794         (output_unw_records): Generate unwind info only if the size is
2795         non-zero or if it's forced for some other reason (e.g.,
2796         handlerdata or a personality routine).
2797         (generate_unwind_image): Don't switch back to previous
2798         section---stay inside the unwind info section instead so that
2799         handlerdata that may follow goes into the right place.
2800         (dot_handlerdata): Force generation of unwind entry and save the
2801         current active text segment before generating unwind image.
2802         (dot_unwentry): Force generation of unwind entry.
2803         (dot_personality): Ditto.
2804         (dot_endp): Generate unwind table entry only if there is
2805         some unwind info or the unwind entry was forced.
2806
2807         * config/tc-ia64.c (make_unw_section_name): New macro to form
2808         unwind section name.
2809         (generate_unwind_image): Add "text_name" argument.  Use it to
2810         form unwind section name.
2811         (dot_handlerdata): Determine current segment (section) name and
2812         pass it to generate_unwind_image().
2813         (dot_endp): Determine current segment (section) name and use
2814         it to determine the appropriate unwind section name.
2815         (ia64_md_do_align): Add missing ATTRIBUTE_UNUSED declarations to
2816         n, fill, and max arguments.
2817
2818 2001-02-09  Schwidefsky  <schwidefsky@de.ibm.com>
2819
2820         * Makefile.am: Add linux target for S/390.
2821         * configure.in: Likewise.
2822         * config/tc-s390.c: New file.
2823         * config/tc-s390.h: New file.
2824
2825 2001-02-09  Alexandre Oliva  <aoliva@redhat.com>
2826
2827         * config/tc-sh.c (md_pseudo_table): Add uaquad.  Use s_uacons for
2828         2byte, 4byte and 8byte.
2829
2830 2001-02-08  Alan Modra  <alan@linuxcare.com.au>
2831
2832         * config/tc-hppa.c (pa_build_unwind_subspace): Don't call
2833         md_number_to_chars with size > sizeof (valueT).
2834
2835 2001-02-06  H.J. Lu  <hjl@gnu.org>
2836
2837         * config/tc-ia64.h (TC_RELOC_RTSYM_LOC_FIXUP): Do fixup if
2838         there is no relocation.
2839
2840 2001-02-06  H.J. Lu  <hjl@gnu.org>
2841
2842         * config/tc-ia64.h (TC_RELOC_RTSYM_LOC_FIXUP): New. Defined.
2843
2844         * config/tc-ia64.c (md_parse_option): Only accept the valid
2845         ia64 options on "-axxx".
2846
2847 2001-02-05  Jim Wilson  <wilson@redhat.com>
2848
2849         * config/tc-ia64.c (errata_nop_necessary_p): Return 0 instead of
2850         aborting for invalid operands.
2851
2852 2001-02-06  Alan Modra  <alan@linuxcare.com.au>
2853
2854         * config/tc-hppa.c (fix_new_hppa): Pass in unwind directly rather
2855         than via pointer.  Update all callers.
2856         (UNWIND_LOW32): Define.
2857         (UNWIND_HIGH32): Define.
2858         (pa_build_unwind_subspace): Use the above macros instead of dumping
2859         bitfields directly.  Call frag_more once rather than multiple times.
2860         (md_assemble): Use UNWIND_LOW32.
2861         (pa_entry): Likewise
2862         (pa_procend): Likewise.
2863         (process_exit): Use UNWIND_HIGH32.
2864
2865 2001-02-04  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
2866
2867         * config/tc-m68hc11.h (LISTING_HEADER): Use m68hc11_listing_header
2868         function to select the header according to the cpu.
2869         (md_after_pass_hook, md_do_align): Remove.
2870         (md_cleanup, m68hc11_cleanup): Remove.
2871         (md_pcrel_from_section): Declare.
2872         * config/tc-m68hc11.c (build_dbranch_insn): Remove insn_size.
2873         (build_jump_insn, build_insn): Likewise.
2874         (m68hc11_listing_header): New function.
2875         (m68hc11_cleanup): Remove.
2876
2877 2001-02-02  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
2878
2879         * config/tc-m68hc11.c (relaxable_symbol): Relax externally visible
2880         symbols because there is no support for shared libraries and these
2881         symbols can't be overridden (unless they are weak).
2882
2883 2001-02-01  Momchil Velikov  <velco@fadata.bg>
2884
2885         * dwarf2dbg.c (out_debug_abbrev): Terminate the abbreviations
2886         for the compilation unit with a zero byte.
2887
2888 2001-01-30  Alan Modra  <alan@linuxcare.com.au>
2889
2890         * config/tc-hppa.c (pa_ip): Support 12 bit branches to absolute
2891         destinations.  Correct range check for 17 and 22 bit branches.
2892
2893 2001-01-25  Nick Clifton  <nickc@redhat.com>
2894
2895         * config/tc-m68k.c (tc_gen_reloc): Do not abort if tcbit is
2896         still set.  Issue an error message instead.
2897         (md_estimate_size_before_relax): Delete unused variable
2898         'buffer_address'.  Fixup parentheses around if statement.
2899
2900 2001-01-23  Kazu Hirata  <kazu@hxi.com>
2901
2902         * as.c: Fix formatting.
2903         * ehopt.c: Likewise.
2904         * messages.c: Likewise.
2905         * stabs.c: Likewise.
2906         * symbols.c: Likewise.
2907
2908 2001-01-23  Ben Elliston  <bje@redhat.com>
2909
2910         * config/tc-m32r.c (m32r_handle_align): Declare type of fragp.
2911
2912 2001-01-22  Kazu Hirata  <kazu@hxi.com>
2913
2914         * config/tc-alpha.c: Fix formatting.
2915
2916 2001-01-19  Kazu Hirata  <kazu@hxi.com>
2917
2918         * config/tc-alpha.c: Fix formatting.
2919
2920 2001-01-18  Kazu Hirata  <kazu@hxi.com>
2921
2922         * config/tc-alpha.c: Fix formatting.
2923
2924 2001-01-18  Nick Clifton  <nickc@redhat.com>
2925
2926         * config/tc-arm.c (ldm_flags): Remove redundant bit from "fa" and
2927         "da" flags.
2928         (stm_flags): Remove redundant bit from "ed" and "da" flags.
2929
2930 2001-01-18  Alexandre Oliva  <aoliva@redhat.com>
2931
2932         * configure.in (cpu_type, arch): Match i386 too.
2933         * configure: Rebuilt.
2934
2935 2001-01-16  Kazu Hirata  <kazu@hxi.com>
2936
2937         * config/tc-i386.c: Fix formatting.
2938
2939 2001-01-16  Alan Modra  <alan@linuxcare.com.au>
2940
2941         * config/tc-hppa.c (tc_gen_reloc): Use SEGREL32 instead of DIR32
2942         relocs for .PARISC.unwind section.
2943
2944         * config/tc-hppa.c (pa_build_unwind_subspace): Build unwind
2945         depending on section flags, not just for .text.
2946
2947 2001-01-15  Jim Wilson  <wilson@redhat.com>
2948
2949         * config/tc-ia64.c (ia64_flush_insns): Handle unwind directives
2950         not immediately followed by an instruction.
2951
2952 2001-01-15  Kazu Hirata  <kazu@hxi.com>
2953
2954         * config/tc-m68hc11.c: Fix formatting.
2955
2956 2001-01-15  Nick Clifton  <nickc@redhat.com>
2957
2958         * symbols.c (colon): Change 'already defined symbol' from a
2959         fatal error to an ordinary error.  There is no reason why this
2960         error should be fatal.
2961
2962         * message.c (as_fatal): Delete output file, if one has been
2963         created.
2964
2965 2001-01-14  Alan Modra  <alan@linuxcare.com.au>
2966
2967         * config/tc-hppa.h (TARGET_FORMAT): Add hppa-linux variants.
2968
2969 2001-01-14  Kazu Hirata  <kazu@hxi.com>
2970
2971         * config/tc-alpha.c: Fix formatting.
2972         * config/tc-arc.c: Likewise.
2973         * config/tc-arc.h: Likewise.
2974         * config/tc-d10v.c: Likewise.
2975         * config/tc-i370.c: Likewise.
2976         * config/tc-i386.c: Likewise.
2977         * config/tc-i960.c: Likewise.
2978         * config/tc-m68k.c: Likewise.
2979         * config/tc-ppc.c: Likewise.
2980         * config/tc-sparc.c: Likewise.
2981         * config/tc-tahoe.c: Likewise.
2982         * config/tc-vax.c: Likewise.
2983
2984         * config/tc-arc.c: Fix formatting.
2985
2986         * config/tc-arc.c: Fix formatting.
2987
2988 2001-01-14  Alan Modra  <alan@linuxcare.com.au>
2989
2990         * config/tc-hppa.c (pa_build_unwind_subspace): Use SEGREL32 for
2991         both 32 and 64 bit ELF.
2992
2993         * config/tc-hppa.c (pa_ip): Store `a' flag in bit zero of operand
2994         and don't bother storing `m' for "ce" completer.  Tidy handling of
2995         'J' and 'K' operands to suit.  Handle '<' and '>' operands.
2996
2997 Sun Jan 14 00:36:42 MET 2001  Jan Hubicka  <jh@suse.cz>
2998
2999         * config/tc-i386.h (TARGET_MACH): New macro.
3000         (i386_mach): Declare.
3001         * config/tc-i386.c (i386_mach): New function.
3002
3003 2001-01-13  Philip Blundell  <philb@gnu.org>
3004
3005         * doc/as.texinfo: Fix spelling and cross-references.
3006
3007         * doc/c-arm.texi: Fix typos.  Say that `;' is a line separator
3008         character for all systems, not just GNU/Linux.  Make it explicit
3009         that `-k' doesn't affect code generation, just ELF flags.
3010
3011 Sat Jan 13 01:47:35 MET 2001  Jan Hubicka <jh@suse.cz>
3012
3013         * config/tc-i386.c (md_assemble): Check cpu_flags even for nullary
3014         instructions.
3015
3016 2001-01-12  Frank Ch. Eigler  <fche@redhat.com>
3017
3018         * cgen.c (gas_cgen_finish_insn): Call dwarf2_emit_insn.
3019
3020 2001-01-12  Nick Clifton  <nickc@redhat.com>
3021
3022         * as.c (print_args): Update copyright date to 2001.
3023
3024 2001-01-12  Peter Targett  <peter.targett@arccores.com>
3025
3026         * doc/c-arc.texi: New file.
3027         Some sections to be expanded.
3028
3029 2001-01-12  Alan Modra  <alan@linuxcare.com.au>
3030
3031         * config/tc-i386.c (md_longopts): Recognize "--64" only for ELF.
3032         (md_parse_option): Always accept "--32".
3033
3034 2001-01-11  Peter Targett  <peter.targett@arccores.com>
3035
3036         * as.h (TC_ARC): Ensure struc-symbol.h included.
3037         * as.c (dwarf2dbg.h): Include to remove implicit declaration
3038         warnings.
3039         * struc-symbol.h (SYMBOLS_NEED_BACKPOINTERS): Define.
3040         (TARGET_SYMBOL_FIELDS) added.
3041
3042         * doc/Makefile.am (CPU_DOCS): Added c-arc.texi.
3043         * doc/c-arc.texi: New file.
3044         Some sections to be expanded.
3045         * doc/as.texinfo: Update command-line options.
3046         Removed outdated text for ARC dependant features, instead include
3047         text from above file.
3048
3049         * config/obj-elf.h (ELF_TARGET_SYMBOL_FIELDS): Define local flag.
3050         (TARGET_SYMBOL_FIELDS): Alias to previous definition.
3051         (targ-cpu.h) header.
3052         * config/tc-arc.h:
3053         * config/tc-arc.c: New updated configuration for
3054         ARC, including selection of core variants, and extensibility of
3055         instructions, registers etc. through directives.
3056
3057         * config/tc-arc.c (arc_extinst): Minor corrections for
3058         error messages.
3059         (arc_common) Likewise. Make alignment argument optional for local
3060         symbols also, with default of zero.
3061
3062 2001-01-11  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
3063
3064         * config/tc-m68hc11.c (md_estimate_size_before_relax): Fix
3065         STATE_INDEXED_OFFSET when the symbol is undefined (16-bit offset).
3066         (build_indexed_byte): Don't relax indexed byte, use 16-bit offset
3067         and fix_new_exp() instead.
3068         (md_convert_frag): For indexed post byte use the symbol value
3069         rather than the displacement.
3070         (md_relax_table): Fix indexed offset relax.
3071
3072 2001-01-11  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
3073
3074         * config/tc-m68hc11.c (md_estimate_size_before_relax):Don't
3075         relax weak symbols.
3076         (relaxable_symbol): New function.
3077
3078 2001-01-11  Andreas Jaeger  <aj@suse.de>
3079
3080         * config/tc-i386.h (TC_RELOC_GLOBAL_OFFSET_TABLE): Removed, it's
3081         not used anywhere.
3082
3083 2001-01-10  Nick Clifton  <nickc@redhat.com>
3084
3085         * config/tc-arm.c (arm_fix_adjustable): Define for OBJ_COFF.
3086         * config/tc-arm.h (obj_fix_adjustable): Define for OBJ_COFF
3087
3088 2001-01-10  Nick Clifton  <nickc@redhat.com>
3089
3090         * symbols.c (DOLLAR_LABEL_CHAR): New constant - the magic
3091         character used to dollar local symbols.
3092         (LOCAL_LABEL_CHAR): New constant - the magic character used to
3093         local label symbols.
3094         (dollar_label_name): Use DOLLAR_LABEL_CHAR.
3095         (fb_label_name): Prefix local labels with LOCAL_LABEL_PREFIX,
3096         if defined.
3097         Use LOCAL_LABEL_CHAR.
3098         (decode_local_label_name): Skip LOCAL_LABEL_PREFIX.
3099         Use DOLLAR_LABEL_CHAR and LOCAL_LABEL_CHAR.
3100         (S_IS_LOCAL): Use DOLLAR_LABEL_CHAR and LOCAL_LABEL_CHAR.
3101
3102 2001-01-08  Bo Thorsen  <bo@suse.de>
3103
3104         * config/tc-i386.c (i386_immediate, i386_displacement):
3105         GOTPCREL check fix.
3106
3107 2001-01-07  Ian Lance Taylor  <ian@zembu.com>
3108
3109         * doc/c-i386.texi (i386-Arch): Remove spaces incorrectly inserted
3110         in last change.
3111
3112 2001-01-07  Philip Blundell  <philb@gnu.org>
3113
3114         * doc/as.texinfo (Bug Reporting): Update email address for
3115         reports.
3116         * README: Likewise.
3117
3118 Sat Jan  6 13:33:10 MET 2001  Jan Hubicka  <jh@suse.cz>
3119
3120         * configure.in: Define DEFAULT_ARCH for i386.
3121         * config/tc-i386.c (md_assemble): Return after the error message;
3122         move testing for 64bit operands to proper place.
3123
3124 2001-01-06  Jan Hubicka <jh@suse.cz>, Andreas Jaeger  <aj@suse.de>
3125
3126         * doc/as.texinfo: Document '#' as comment character for i386 and
3127         x86_64. Add AMD x86-64 into menu of machine dependent information.
3128
3129         * doc/c-i386.texi: Document x86_64 extensions.
3130
3131 Fri Jan  5 13:26:42 MET 2001  Jan Hubicka  <jh@suse.cz>
3132
3133         * config/tc-i386.c (md_assemble): Handle third byte of the opcode as prefix.
3134
3135 Thu Jan  4 22:25:26 MET 2001  Jan Hubicka  <jh@suse.cz>
3136
3137         * config/tc-i386.c (cpu_arch): Add Pentium4 and modify sledgehammer entry.
3138         * NEWS: Add note about Pentium4 support.
3139
3140 Wed Jan  3 17:26:32 MET 2001  Jan Hubicka  <jh@suse.cz>
3141
3142         * config/tc-i387.c (pi, pte, pt): Update.
3143         (type_names): Add new types.
3144
3145 Wed Jan  3 16:26:52 MET 2001  Jan Hubicka  <jh@suse.cz>
3146
3147         * config/tc-i386.h (CpuK6, CpuAthlon, CpuSledgehammer, CpuMMX, Cpu3dnow,
3148         CpuUnknown): Renumber
3149         (CpuP4, CpuSSE2): New.
3150         (CpuUnknownFlags): Add CpuP4 and CpuSSE2
3151
3152 2001-01-03  Philip Blundell  <pb@futuretv.com>
3153
3154         * config/tc-alpha.c (alpha_force_relocation): Handle vtable
3155         relocs.
3156         (alpha_fix_adjustable): Likewise.
3157         (md_apply_fix): Likewise.
3158
3159 2000-12-31  H.J. Lu  <hjl@gnu.org>
3160
3161         * listing.c (listing_message): Allocate string only if it is
3162         used.
3163
3164         * configure: Rebuild.
3165
3166 2000-12-31  Hans-Peter Nilsson  <hp@bitrange.com>
3167
3168         * doc/internals.texi (Relaxing with a table) <after relaxation>:
3169         Point out caveats with generating fixups for the opcode in a frag.
3170
3171 Sat Dec 30 19:02:48 MET 2000  Jan Hubicka  <jh@suse.cz>
3172
3173         * configure.in: Add support for x86_64 and x86_64-*-linux-gnu*
3174         * NEWS: Add x86_64.
3175
3176 2000-12-29  H.J. Lu  <hjl@gnu.org>
3177
3178         * listing.c (calc_hex): Print the variable part only if the
3179         fragment type is rs_fill.
3180
3181 2000-12-29  Hans-Peter Nilsson  <hp@bitrange.com>
3182
3183         * doc/internals.texi (tc_conditional_pseudoop,
3184         TC_LINKRELAX_FIXUP): Fix typos.
3185
3186 2000-12-28  Richard Henderson  <rth@redhat.com>
3187
3188         * write.c (subsegs_finish): Fix thinko last change -- don't
3189         "optimize" the alignment == 0 case.
3190
3191 2000-12-28  Richard Henderson  <rth@redhat.com>
3192
3193         * as.h (rs_align_test): New.
3194         * frags.c (NOP_OPCODE): Move default from read.c.
3195         (MAX_MEM_FOR_RS_ALIGN_CODE): New default.
3196         (frag_align_code): New.
3197         * frags.h (frag_align_code): Declare.
3198         * read.c (NOP_OPCODE): Remove.
3199         (do_align): Use frag_align_code.
3200         * write.c (NOP_OPCODE): Remove.
3201         (get_recorded_alignment): New.
3202         (cvt_frag_to_fill): Handle rs_align_test.
3203         (relax_segment): Likewise.
3204         (subsegs_finish): Align last subseg in section to the
3205         section alignment.  Use frag_align_code.
3206         * write.h (get_recorded_alignment): Declare.
3207         * config/obj-coff.c (size_section): Handle rs_align_test.
3208         (fill_section, fixup_mdeps): Likewise.
3209         (write_object_file): Use frag_align_code.
3210
3211         * config/tc-alpha.c (alpha_align): Use frag_align_code.
3212         (alpha_handle_align): New.
3213         * config/tc-alpha.h (HANDLE_ALIGN): New.
3214         (MAX_MEM_FOR_RS_ALIGN_CODE): New.
3215
3216         * config/tc-i386.h (md_do_align): Use frag_align_code.
3217         (MAX_MEM_FOR_RS_ALIGN_CODE): New.
3218
3219         * config/tc-ia64.c (ia64_md_do_align): Don't do code alignment.
3220         (ia64_handle_align): New.
3221         * config/tc-ia64.h (HANDLE_ALIGN): New.
3222         (MAX_MEM_FOR_RS_ALIGN_CODE): New.
3223
3224         * config/tc-m32r.c (m32r_do_align): Remove.
3225         (m32r_handle_align): New.
3226         (fill_insn): Use frag_align_code.
3227         * config/tc-m32r.h (md_do_align): Remove.
3228         (HANDLE_ALIGN, MAX_MEM_FOR_RS_ALIGN_CODE): New.
3229         * config/tc-m88k.c, config/tc-m88k.h: Similarly.
3230         * config/tc-mips.c, config/tc-mips.h: Similarly.
3231
3232         * config/tc-sh.c (sh_cons_align): Use rs_align_test.
3233         (sh_handle_align): Likewise.  Handle rs_align_code.
3234         (sh_do_align): Remove.
3235         * config/tc-sh.h (md_do_align): Remove.
3236         (MAX_MEM_FOR_RS_ALIGN_CODE): New.
3237
3238         * config/tc-sparc.c (sparc_cons_align): Use rs_align_test.
3239         (sparc_handle_align): Likewise.  Handle rs_align_code.
3240         * config/tc-sparc.h (md_do_align): Remove.
3241         (MAX_MEM_FOR_RS_ALIGN_CODE): New.
3242
3243 2000-12-22  DJ Delorie  <dj@redhat.com>
3244
3245         * config/tc-d10v.c (md_assemble): set prev_seg and prev_subseg
3246         when we assemble the first half of a pair.
3247
3248 2000-12-22  H.J. Lu  <hjl@gnu.org>
3249
3250         * config/tc-i386.c (reloc): Update the macro for non-bfd
3251         assembler.
3252         (BFD_RELOC_X86_64_GOTPCREL): Set to 0 for non-bfd assembler.
3253
3254 2000-12-22  H.J. Lu  <hjl@gnu.org>
3255
3256         * dwarf2dbg.c (dwarf2_finish): Remove #if BFD_ASSEMBLER.
3257
3258 Wed Dec 20 14:21:22 MET 2000  Jan Hubicka  <jh@suse.cz>
3259
3260         * config/tc-i386.h (i386_target_format): Define even for ELFs.
3261         (QWORD_MNEM_SUFFIX): New macro.
3262         (CpuK6,CpuAthlon,CpuSledgehammer, Cpu64, CpuNo64, CpuUnknownFlags):
3263         New macros
3264         (CpuMMX,CpuSSE,Cpu3dnow, CpuUnknown): Renumber.
3265         (IgnoreSize, DefaultSize, No_?Suf, FWait, IsString, regKludge, IsPrefix,
3266         ImmExt): Renumber.
3267         (Size64, No_qSuf, NoRex64, Rex64): New macros.
3268         (Reg64, Imm32S, Imm64, Disp32S, Disp64): New macros.
3269         (Imm8, Imm8S, Imm16, Imm32, Imm1, BaseIndex, Disp8, Disp16, Disp32,
3270         InOutPortReg,ShiftCount, Control, Debug, Test, FloatReg, FloatAcc,
3271         SReg2, SReg3, Acc, JumpAbsolute, RegMMX, RegXMM, EsSeg, InvMem):
3272         Renumber.
3273         (Reg, WordReg): Add Reg64.
3274         (Imm): Add Imm32S and Imm64.
3275         (EncImm): New.
3276         (Disp): Add Disp64 and Disp32S.
3277         (AnyMem): Add Disp32S.
3278         (RegRex, RegRex64): New macros.
3279         (rex_byte): New type.
3280         * config/tc-i386.c (set_16bit_code_flag): Kill.
3281         (fits_in_unsigned_long, fits_in_signed_long): New functions.
3282         (reloc): New parameter "signed"; support x86_64.
3283         (set_code_flag): New.
3284         (DEFAULT_ARCH): New macro; default to "i386".
3285         (default_arch): New static variable.
3286         (struct _i386_insn): New fields Operand_PCrel; rex.
3287         (flag_16bit_code): Kill; All tests replaced to "flag_code == CODE_64BIT"
3288         (flag_code): New enum and static variable.
3289         (use_rela_relocations): New static variable.
3290         (flag_code_names): New static variable.
3291         (cpu_arch_flags): Default to CpuUnknownFlags|CpuNo64.
3292         (cpu_arch): Add "sledgehammer"; Add CPUAthlon to Athlon and CpuK6 to
3293         K6 and Athlon.
3294         (i386_align_code): Return plain "nop" for x86_64.
3295         (mode_from_disp_size): Support Disp32S.
3296         (smallest_imm_type): Support Imm32S and Imm64.
3297         (offset_in_range): Support size of 8.
3298         (set_cpu_arch): Do not clobber to Cpu64/CpuNo64.
3299         (md_pseudo_table): Add "code64"; use set_code_flat.
3300         (md_begin): Emit sane error message on hash failure.
3301         (tc_i386_fix_adjustable): Support x86_64 relocations.
3302         (md_assemble): Support QWORD_MNEM_SUFFIX, REX registers,
3303         instructions supported on particular arch just partially,
3304         output of 64bit immediates, handling of Imm32S and Disp32S type.
3305         (i386_immedaite): Support x86_64 relocations; support 64bit constants.
3306         (i386_displacement): Likewise.
3307         (i386_index_check): Cleanup; support 64bit addresses.
3308         (md_apply_fix3): Support x86_64 relocation and rela.
3309         (md_longopts): Add "32" and "64".
3310         (md_parse_option): Add OPTION_32 and OPTION_64.
3311         (i386_target_format): Call even for ELFs; choose between
3312         elf64-x86-64 and elf32-i386.
3313         (i386_validate_fix): Refuse GOTOFF in 64bit mode.
3314         (tc_gen_reloc): Support rela relocations and x86_64.
3315         (intel_e09_1): Support QWORD.
3316
3317 2000-12-15  Diego Novillo  <dnovillo@redhat.com>
3318
3319         * config/tc-i386.c (intel_e09_1): Only flag as a memory operand if
3320         it's not an offset expression.
3321         (intel_e10_1): Ditto. Also, if the operand is an offset expression,
3322         keep the braces '[' and ']' in the output string.
3323         (intel_e11): Ditto. Also remove comparison intel_parser.op_modifier
3324         != FLAT. There is no such op_modifier.
3325
3326 2000-12-14  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
3327
3328         * dwarf2dbg.c: If we don't have <limits.h>, try including <sys/param.h>
3329         if we have it.
3330
3331 2000-12-13  Kazu Hirata  <kazu@hxi.com>
3332
3333         * as.h: Fix formatting.
3334         * cgen.h: Likewise.
3335         * dwarf2dbg.c: Likewise.
3336         * input-scrub.c: Likewise.
3337         * read.h: Likewise.
3338
3339 2000-12-13  Mark Elbrecht  <snowball3@bigfoot.com>
3340
3341         * configure.in (i386-*-msdosdjgpp): Set bfd_gas to yes.
3342         configure: Regenerate.
3343
3344 2000-12-13  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
3345
3346         * dwarf2dbg.c: #include <limits.h> only if it exists.
3347
3348 2000-12-13  Rodney Brown  <RodneyBrown@mynd.com>
3349
3350         * config/tc-hppa.c (pa_ip): Correct CHECK_FIELD typo.
3351         (md_apply_fix): Here too.
3352
3353 2000-12-12  Jim Wilson  <wilson@redhat.com>
3354
3355         * config/tc-ia64.h (ia64_init): Add prototype.
3356
3357 2000-12-12  H.J. Lu  <hjl@gnu.org>
3358
3359         * dwarf2dbg.c: Enabled only if BFD_ASSEMBLER is defined.
3360
3361         * read.h (outputting_stabs_line_debug): Change it to int.
3362         * stabs.c (outputting_stabs_line_debug): Likewise.
3363
3364 2000-12-12  Geoffrey Keating  <geoffk@redhat.com>
3365
3366         * config/obj-bout.c (obj_crawl_symbol_chain): Don't take
3367         the address of a function result.
3368
3369 2000-12-12  Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>
3370
3371         * config/tc-ppc.c (md_pseudo_table): Add .file and .loc.
3372         (md_assemble): Call dwarf2_emit_insn.
3373         (shlib): Fix typo SHILB -> SHLIB.
3374         (md_parse_option): Likewise.
3375         (ppc_elf_validate_fix): Likewise:
3376         * config/tc-ppc.h (DWARF2_LINE_MIN_INSN_LENGTH): New.
3377
3378 2000-12-12  Nick Clifton  <nickc@redhat.com>
3379
3380         * cgen.h: Fix formatting.
3381         * input-scrub.c: Fix formatting.
3382         * macro.c: Fix formatting.
3383         * config/tc-mips.c: Fix formatting.
3384         * doc/c-mips.texi: Fix formatting.
3385
3386 Mon Dec 11 14:35:42 MET 2000  Jan hubicka  <jh@suse.cz>
3387
3388         * config/tc-i386.c (md_assemble): Refuse 's' and 'l' suffixes in the intel
3389         mode; convert 'd' suffix to 's' or 'l'; remove all DWORD_MNEM_SUFFIX
3390         references.
3391         (intel_e09_1): Convert QWORD to 'l' suffix for FP operations; refuse
3392         otherwise.
3393         * config/tc-i386.h (DWORD_MNEM_SUFFIX): Kill.
3394         (No_dSuf): Kill.
3395
3396         * i386.h (*_Suf): Remove No_dSuf.
3397         (d_suf, wld_Suf,sld_Suf, sldx_Suf, bwld_Suf, d_FP, sld_FP, sldx_FP)
3398         Remove.
3399         (i386_optab): Remove 'd' in the suffixes.
3400
3401 2000-12-06  Mark Elbrecht  <snowball3@bigfoot.com>
3402
3403         * config/tc-i386.c (T_SHORT): Undefine before defining.
3404
3405 2000-12-05  Kazu Hirata  <kazu@hxi.com>
3406
3407         * config/tc-mips.c: Fix formatting.
3408
3409 2000-12-04  Matthew Hiller  <hiller@redhat.com>
3410
3411         * config/tc-d10v.c (flag_allow_gstabs_packing): New variable.
3412         (md_longopts): New options --gstabs-packing, --no-gstabs-packing.
3413         (md_show_usage): Ditto.
3414         (md_parse_option): Ditto.
3415         (d10v_cleanup): Writes pending instruction only if
3416         ! outputting_stabs_line_debug || ! flag_allow_gstabs_packing.
3417         Fix compile time warning messages.
3418
3419         * doc/c-d10v.texi: Documents new options.
3420
3421 2000-12-04  Matthew Hiller  <hiller@redhat.com>
3422
3423         * stabs.c (outputting_stabs_line_debug): New variable.
3424         (stabs_generate_asm_lineno): Set outputting_stabs_line_debug at
3425         function entry and unset at function exit.
3426
3427         * read.h (outputting_stabs_line_debug): New extern declaration.
3428
3429         * as.c: Include dwarf2dbg.h for definition of dwarf2_finish.
3430
3431         * dwarf2dbg.c: Fix compile time warning messages.
3432
3433 2000-12-03  Kazu Hirata  <kazu@hxi.com>
3434
3435         * config/tc-a29k.c: Fix formatting.
3436         * config/tc-alpha.c: Likewise.
3437         * config/tc-arm.c: Likewise.
3438         * config/tc-cris.c: Likewise.
3439         * config/tc-hppa.c: Likewise.
3440         * config/tc-i370.c: Likewise.
3441         * config/tc-i386.c: Likewise.
3442         * config/tc-i860.c: Likewise.
3443         * config/tc-i960.c: Likewise.
3444         * config/tc-ia64.c: Likewise.
3445         * config/tc-m68hc11.c: Likewise.
3446         * config/tc-m68k.c: Likewise.
3447         * config/tc-m88k.c: Likewise.
3448         * config/tc-pj.c: Likewise.
3449         * config/tc-ppc.c: Likewise.
3450         * config/tc-sh.c: Likewise.
3451         * config/tc-sparc.c: Likewise.
3452         * config/tc-tahoe.c: Likewise.
3453         * config/tc-vax.c: Likewise.
3454
3455 2000-12-01  Chris Demetriou  <cgd@sibyte.com>
3456
3457         * config/tc-mips.c (mips_ip): When calculating offsets,
3458         don't accept as constant the difference between the
3459         addresses of symbols in two different sections.
3460
3461         * config/tc-mips.c (macro_build): Add new 'U' and 'J' operand
3462         specifiers.
3463         (validate_mips_insn): Likewise.  Also, update 'B' operand
3464         specifier to use OP_*_CODE20 constants and delete 'm' operand
3465         specifier.
3466         (mips_ip): Remove 'm' operand specifier, add 'U' and 'J'
3467         operand specifiers.  Change warning generated by 'B' operand
3468         specifier to reflect its new multi-purpose usage.
3469
3470         * config/tc-mips.c (mips_set_options): Use ISA_UNKNOWN rather than
3471         -1, and update comment.
3472         (file_mips_isa): Likewise.
3473         (mips_cpu): Use CPU_UNKNOWN rather than -1, and update comment.
3474         (ISA_HAS_COPROC_DELAYS, ISA_HAS_64BIT_REGS, gpr_interlocks): Use
3475         ISA_* constants rather than hard-coded numbers.
3476         (mips_cpu_info): New structure.
3477         (mips_cpu_info_table): New table describing CPU and ISA names
3478         and numbers.
3479         (mips_cpu_info_from_name, mips_cpu_info_from_isa,
3480         mips_cpu_info_from_cpu): New functions.
3481         (mips_isa_to_str): New function to get string for ISA name.
3482         (mips_cpu_to_str): Convert to use mips_cpu_info_from_cpu, and
3483         return const char *.
3484         (md_begin): Redo CPU and ISA selection logic, using
3485         mips_cpu_info_from_*.  Convert to use ISA_* constants rather
3486         than hard-coded numbers.
3487         (append_insn, mips_emit_delays, macro, macro2): Convert to use
3488         ISA_* constants rather than hard-coded numbers.
3489         (mips_ip): Convert to use mips_isa_to_str to get ISA name.
3490         (md_longopts): Delete OPTION_NO_MIPS32.
3491         (md_parse_option): Convert to use ISA_* constants rather than
3492         hard-coded numbers.  Make OPTIONS_MIPS32 case treat MIPS32
3493         as an ISA.  Delete OPTION_NO_MIPS32 case.  Convert OPTION_MCPU
3494         to use strcasecmp to recognize "default" and to use
3495         mips_cpu_info_from_name to get CPU numbers from argument.
3496         (md_show_usage): Move -mips32 so it's with the rest of the ISA
3497         flags.  Change 4Kc, 4Kp and 4Km CPU entries to just be
3498         mips32-4k.
3499         (s_mipsset): Accept ISA value 32.
3500         * doc/as.texinfo: Clean up MIPS options summary slightly,
3501         remove -no-mips32.  Add note about -mips4 and -mips32
3502         specifying those ISA levels.  Delete -mips32 and -no-mips32
3503         cpu flag descriptions.
3504         * doc/c-mips.texi: Add -mips32 to list of ISA switches.  Clean
3505         up the supported CPU switch list, and replace 4Kc, 4Km, and
3506         4Kp entries with a single mips32-4k entry.  Note that you can
3507         use ".set mips32".
3508
3509         * config/tc-mips.c (ISA_HAS_64BIT_REGS): Add checks for ISA_MIPS5 and
3510         ISA_MIPS64.
3511         (md_longopts, OPTION_MIPS5, OPTION_MIPS64): Add options for
3512         -mips5 and -mips64.
3513         (md_parse_option): Add cases for OPTION_MIPS5 and
3514         OPTION_MIPS64.
3515         (md_show_usage): Mention -mips5 and -mips64 arguments.
3516         (s_mipsset): Add cases for MIPS5 and MIPS64.
3517         (mips_cpu_info_table): Add entries for MIPS5 and MIPS64 ISAs
3518         and pseudo-CPUs.
3519         * doc/as.texinfo: Mention -mips5 and -mips64 options
3520         and their meanings.
3521         * doc/c-mips.texi: Likewise.  Also update introduction
3522         and ".set" usage information.
3523
3524         * config/tc-mips.c (md_show_usage): Add "sb1" to the
3525         CPU list.
3526         (mips_cpu_info_table): Add SB-1 entries.
3527         * doc/c-mips.texi: Add "sb1" to the list of CPUs
3528         known to the -mcpu option.
3529
3530         * doc/as.texinfo: Correct description of MIPS -mcpu
3531         option, by copying some of the text from doc/c-mips.texi.
3532
3533 2000-12-01  Joel Sherrill  <joel@OARcorp.com>
3534
3535         * configure.in (arm-*-rtems*, a29k-*rtems*, h8300-*-rtems*):
3536         New targets.
3537         (sparc*-*-rtemself*, sparc*-*-rtemsaout*): New targets.
3538         (sparc*-*-rtems*): Switched from a.out to ELF.
3539         * configure: Regenerate.
3540         * config.in: Regenerate.
3541         * Makefile.in: Regenerate.
3542         * aclocal.m4: Regenerate.
3543         * po/gas.pot: Regenerate.
3544
3545 2000-11-30  Philip Blundell  <pb@futuretv.com>
3546
3547         * config/obj-coff.c (obj_coff_weak): Use S_SET_WEAK if it exists,
3548         even in non BFD_ASSEMBLER case.
3549
3550 2000-11-30  Diego Novillo  <dnovillo@redhat.com>
3551
3552         * config/tc-i386.c (md_assemble): Swap i.disp_relocs when using intel
3553         syntax.
3554
3555 2000-11-29  Richard Henderson  <rth@redhat.com>
3556
3557         * dwarf2dbg.c: Rewrite from scratch.  Queue all debugging output
3558         until dwarf2_finish; use relaxation to get cross-fragment offsets;
3559         thread multiple subsegments properly; handle multiple code
3560         sections properly; emit proper compilation unit info for assembler
3561         generated debugging.
3562
3563         * as.h (enum _relax_state): Add rs_dwarf2dbg.
3564         * dwarf2dbg.h (struct dwarf2_line_info): Remove filename.
3565         (dwarf2dbg_estimate_size_before_relax): Declare.
3566         (dwarf2dbg_relax_frag, dwarf2dbg_convert_frag): Declare.
3567         * write.c: Include dwarf2dbg.h.
3568         (cvt_frag_to_fill): Handle rs_dwarf2dbg.
3569         (relax_segment): Likewise.
3570
3571 2000-11-28  Hans-Peter Nilsson  <hp@bitrange.com>
3572
3573         * config/tc-sh.c (md_convert_frag) <undefined symbol, conditional
3574         jump>: Use as_bad_where instead of as_bad.  Tweak error message
3575         accordingly.  Stabilize frag by updating fix part and resetting
3576         variant part.
3577         <undefined symbol, unconditional jump>: Ditto.
3578         (sh_elf_cons): Cast *input_line_pointer to unsigned char when
3579         indexing is_end_of_line[].
3580         (md_assemble): Initialize size to 0.
3581         (md_section_align): Mark parameter seg as unused.
3582         (parse_reg): Parse names case-insensitively.
3583
3584 2000-11-28  Kazu Hirata  <kazu@hxi.com>
3585
3586         * config/obj-aout.h: Fix formatting.
3587         * config/obj-bout.h: Likewise.
3588         * config/obj-coff.c: Likewise.
3589         * config/obj-coff.h: Likewise.
3590         * config/obj-elf.h: Likewise.
3591         * config/obj-som.h: Likewise.
3592         * config/obj-vms.c: Likewise.
3593         * config/obj-vms.h: Likewise.
3594         * config/tc-h8300.h: Likewise.
3595         * config/tc-ns32k.h: Likewise.
3596         * config/tc-sparc.h: Likewise.
3597         * config/tc-tic54x.h: Likewise.
3598         * config/tc-z8k.h: Likewise.
3599
3600 2000-11-28  Nick Clifton  <nickc@redhat.com>
3601
3602         * doc/as.1 (COPYING): Mention that the GNU Free Documentation
3603         License is present in the sources, but not the output, and
3604         also available from the GNU website.
3605         (GNU Free Documentation License): Comment out this section.
3606
3607 2000-11-28  Hans-Peter Nilsson  <hp@axis.com>
3608
3609         * Makefile.am (CPU_OBJ_VALID): Add case to filter out invalid coff
3610         targets.  Remove i860 from valid a.out targets.
3611         * Makefile.in: Regenerate.
3612
3613         * config/tc-cris.c: Include dwarf2dbg.h.
3614         (md_pseudo_table): Add .file and .loc.
3615         (md_assemble): Call dwarf2_emit_insn if generating ELF.
3616         (s_cris_file, s_cris_loc): New.
3617         * config/tc-cris.h (DWARF2_LINE_MIN_INSN_LENGTH): Define.
3618         * Makefile.am: Regenerate dependencies.
3619         * Makefile.in: Regenerate.
3620
3621 2000-11-28  Alan Modra  <alan@linuxcare.com.au>
3622
3623         * expr.c (STANDARD_MUL_PRECEDENCE): Correct value.
3624         (MRI_MUL_PRECEDENCE): Likewise.
3625         (op_rank): Fix a comment typo.
3626
3627 2000-11-26  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
3628
3629         * config/tc-m68hc11.c (build_indexed_byte): Print the offset in
3630         the error message.
3631         (get_operand): Fix analysis for movw/movb instructions.
3632
3633 2000-11-24  Nick Clifton  <nickc@redhat.com>
3634
3635         * configure.in (xscale-elf): Add target.
3636         (xscale-coff): Add target.
3637         * configure: Regenerate.
3638
3639         * config/tc-arm.c (ARM_EXT_V5E): New ARM architecture
3640         extenstion.
3641         (ARM_EXT_XSCALE): New ARM architecture extension.
3642         (ARM_LONGMUL): Rename to ARM_EXT_LONGMUL.
3643         (ARM_HALFWORD): Rename to ARM_EXT_HALFWORD.
3644         (ARM_THUMB): Rename to ARM_EXT_THUMB.
3645         (ARM_ARCH_V4): Remove processor from architecture.
3646         (ARM_ARCH_3M): New architecutre definition.
3647         (ARM_ARCH_V5TE): New architecutre definition.
3648         (ARM_ARCH_XSCALE): New architecutre definition.
3649         (CPU_DEFAULT): Allow to be defaulted to XScale.
3650         (atpcs): New boolean variable.
3651         (ldr_flags): Support 'd' flag for double word loads.
3652         (str_flags): Support 'd' flag for double word stored.
3653         (do_mia): New function.
3654         (do_mar): New function.
3655         (do_mra): New function.
3656         (do_pld): New function.
3657         (do_ldrd): New function.
3658         (do_blx): New function.
3659         (do_bkpt): New function.
3660         (do_clz): New function.
3661         (do_lstc2): New function.
3662         (do_cdp2): New function.
3663         (do_t_blx): New function.
3664         (do_t_bkpt): New function.
3665         (do_smla): New function.
3666         (do_smlal): New function.
3667         (do_smul): New function.
3668         (do_qadd): New function.
3669         (do_co_reg2c): New function.
3670         (LONGEST_INSN): Redefine to 7.
3671
3672         * doc/c-arm.texi: Document -mxscale, -mmarmv5te and -matpcs
3673         command line switches.
3674
3675 2000-11-22  Jim Wilson  <wilson@redhat.com>
3676
3677         * config/tc-ia64.c (pseudo_func): Add missing initializers.
3678         (struct rsrc): Make line unsigned.
3679         (gr_values): Add missing initializer.
3680         (SLOT_NUM_NOT_SET): Add unsigned cast.
3681         (ia64_elf_section_flags, output_vbyte_mem, count_output, dot_radix,
3682         dot_fframe, dot_vframe, dot_vframesp, dot_vframepsp, dot_save,
3683         dot_restore, dot_restorereg, dot_restorereg_p, dot_handlerdata,
3684         dot_unwentry, dot_altrp, dot_saveg, dot_savef, dot_saveb, dot_savegf,
3685         dot_spill, dot_spillreg, dot_spillreg_p, dot_label_state,
3686         dot_copy_state, dot_unwabi, dot_personality, dot_proc, dot_body,
3687         dot_prologue, dot_endp, dot_regstk, dot_psr, dot_alias, dot_ln,
3688         dot_reg_val, dot_entry, dot_mem_offset, ia64_init, mark_resource,
3689         md_undefined_symbol, md_apply_fix3, tc_gen_reloc, ia64_md_do_align):
3690         Add ATTRIBUTE_UNUSED to unused parameters.
3691         (convert_expr_to_ab_reg): Add parens.
3692         (convert_expr_to_xy_reg): Add parens.  Comment out >= REG_GR test.
3693         (dot_prologue): Initialize grsave when declared.
3694         (md_pseudo_table): Add missing initializers.
3695         (operand_match): Add casts to bfd_vma.
3696         (emit_one_bundle): Delete unused local prev.  Make required_template
3697         unsigned.
3698         (specify_resource): Cast i to unsigned.
3699         (note_register_values): Use fprintf_vma.
3700         (print_dependency): Likewise.
3701
3702 2000-11-21  Jim Wilson  <wilson@redhat.com>
3703
3704         * config/tc-ia64.c (generate_unwind_image): Call record_alignment
3705         for unwind info section.
3706         (dot_endp): Likewise for unwind section.
3707
3708         * config/tc-ia64.c (emit_one_bundle): Pass size of 8 not 4 to
3709         fix_new_exp.
3710
3711 2000-11-21  Jakub Jelinek  <jakub@redhat.com>
3712
3713         * config/tc-sparc.c (md_pseudo_table): Add .file and .loc.
3714         (output_insn): Call dwarf2_emit_insn.
3715         * config/tc-sparc.h (DWARF2_LINE_MIN_INSN_LENGTH): New.
3716
3717 2000-11-17  Richard Henderson  <rth@redhat.com>
3718
3719         * ehopt.c (eh_frame_code_alignment): New arg `in_seg', update all
3720         callers.  Don't switch segments.  Expect CIE == -1 in .debug_frame.
3721         (check_eh_frame): Handle .eh_frame and .debug_frame concurrently.
3722
3723 2000-11-17  Nick Clifton  <nickc@redhat.com>
3724
3725         * config/tc-arm.c (md_pseudo_table): Add support for .line and
3726         .file pseudo ops.
3727
3728 2000-11-17  Richard Henderson  <rth@redhat.com>
3729
3730         * config/tc-i386.c (md_pseudo_table): Add .file and .loc.
3731
3732 2000-11-17  Richard Henderson  <rth@redhat.com>
3733
3734         * dwarf2dbg.c (dwarf2_gen_line_info): Early out for no line number.
3735         * config/obj-elf.h (ECOFF_DEBUGGING) [TC_ALPHA]: Adjust for
3736         tri-state definition of alpha_flag_mdebug.
3737         * config/tc-alpha.c (alpha_flag_mdebug): Init to -1.
3738         (s_alpha_file): Store first .file directive.
3739         (s_alpha_stab): New.
3740         (md_pseudo_table): Add stabs and stabn.
3741
3742 2000-11-17  Richard Henderson  <rth@redhat.com>
3743
3744         * config/tc-i386.c (md_assemble): Call dwarf2_emit_insn.
3745
3746 2000-11-17  Richard Henderson  <rth@redhat.com>
3747
3748         * as.c (debug_type): Init to DEBUG_UNSPECIFIED.
3749         (main): Call dwarf2_finish.
3750         * as.h (debug_type): Clarify documentation of the meaning
3751         of this variable.
3752         * dwarf2dbg.c (DWARF2_LINE_MIN_INSN_LENGTH): Default to 1.
3753         (print_stats): Fix parenthesis problem.
3754         (now_subseg_size): New.
3755         (dwarf2_finish): Use it.  If DEBUG_DWARF2, emit bits for .debug_info.
3756         (dwarf2_directive_file): Don't set debug_type.
3757         (dwarf2_where): Honor DEBUG_DWARF2 first.
3758         (dwarf2_emit_insn): Renamed from dwarf2_generate_asm_lineno;
3759         do nothing if not emitting dwarf2 debug info, or no work.
3760         * dwarf2dbg.h (dwarf2_emit_insn): Update.
3761         * ecoff.c (add_file): Turn on DEBUG_ECOFF only if DEBUG_UNSPECIFIED.
3762         (ecoff_new_file): Likewise.
3763         * read.c (generate_lineno_debug): Kill ecoff hackery.  Update
3764         commentary wrt dwarf2.
3765
3766         * config/tc-alpha.c (alpha_adjust_symtab_relocs): Add
3767         ATTRIBUTE_UNUSED as needed.
3768         (emit_insn): Call dwarf2_emit_insn.
3769         (s_alpha_file): New.
3770         (s_alpha_loc): New.
3771         (s_alpha_coff_wrapper): Don't handle them.
3772         (md_pseudo_table): Update for .file and .loc.
3773         * config/tc-alpha.h (DWARF2_LINE_MIN_INSN_LENGTH): New.
3774
3775         * config/tc-arm.c (output_inst): Update for dwarf2_emit_insn;
3776         don't protect with debug_type.
3777         * config/tc-hppa.c (md_assemble): Likewise.
3778         * config/tc-m68hc11.c (m68hc11_new_insn): Likewise.
3779         * config/tc-mn10300.c (md_assemble): Likewise.
3780         * config/tc-sh.c (md_assemble): Likewise.
3781         * config/tc-v850.c (md_assemble): Likewise.
3782
3783         * config/tc-arm.c (arm_end_of_source): Remove.
3784         * config/tc-hppa.c (pa_end_of_source): Remove.
3785         * config/tc-m68hc11.c (m68hc11_end_of_source): Remove.
3786         * config/tc-mn10300.c (mn10300_finalize): Remove.
3787         * config/tc-sh.c (sh_finalize): Remove.
3788         * config/tc-v850.c (sh_finalize): Remove.
3789
3790         * config/tc-arm.h (md_end): Remove.
3791         * config/tc-hppa.h (md_end): Remove.
3792         (DWARF2_LINE_MIN_INSN_LENGTH): New.
3793         * config/tc-m68hc11.h (md_end): Remove.
3794         * config/tc-mn10300.h (md_end): Remove.
3795         * config/tc-sh.h (md_end): Remove.
3796         * config/tc-v850.h (md_end): Remove.
3797
3798         * config/tc-ia64.c (emit_one_bundle): Don't protect
3799         dwarf2 bits with debug_type.
3800         (md_assemble): Likewise.
3801         (ia64_end_of_source): Don't call dwarf2_finish.
3802
3803 2000-11-16  Jim Wilson  <wilson@redhat.com>
3804
3805         * config/tc-ia64.c (errata_nop_necessary_p): Abort if general regno
3806         >= 128 instead of > 128.  Abort if predicate regno is >= 64 instead of
3807         > 16.
3808
3809 2000-11-16  H.J. Lu  <hjl@gnu.org>
3810
3811         * config/obj-elf.c (obj_elf_symver): Don't check the missing
3812         version name.
3813
3814 2000-11-15  Kazu Hirata  <kazu@hxi.com>
3815
3816         * config/tc-tic30.c: Fix formatting.
3817         * config/tc-tic80.c: Likewise.
3818         * config/tc-v850.c: Likewise.
3819         * config/tc-vax.c: Likewise.
3820         * config/tc-w65.c: Likewise.
3821         * config/tc-z8k.c: Likewise.
3822
3823 2000-11-14  DJ Delorie  <dj@redhat.com>
3824
3825         * config/tc-v850.c: Support dwarf2.
3826         * config/tc-v850.h: Ditto.
3827
3828         * config/tc-v850.c (cons_fix_new_v850): Don't rely on
3829         parse_cons_expression_v850 to initialize hold_cons_reloc.
3830
3831 2000-11-15  Bernd Schmidt  <bernds@redhat.com>
3832
3833         * config/tc-ia64.c (struct md): New entries LAST_GROUPS, GROUP_IDX.
3834         (errata_nops_necessary_p): New function.
3835         (emit_one_bundle): Call it.  Update the GROUP_IDX field in struct
3836         md.
3837
3838 2000-11-14  Jim Wilson  <wilson@redhat.com>
3839
3840         * config/tc-ia64.c (ia64_target_format): If EF_IA_64_BE not set, then
3841         return little endian bfd formats.
3842
3843 2000-11-14  Kazu Hirata  <kazu@hxi.com>
3844
3845         * config/aout_gnu.h: Fix formatting.
3846         * config/atof-vax.c: Likewise.
3847         * config/m68k-parse.h: Likewise.
3848         * config/m88k-opcode.h: Likewise.
3849         * config/obj-elf.c: Likewise.
3850         * config/tc-arm.c: Likewise.
3851         * config/tc-cris.c: Likewise.
3852         * config/tc-i386.c: Likewise.
3853         * config/tc-ia64.c: Likewise.
3854         * config/tc-mn10300.c: Likewise.
3855         * config/te-386bsd.h: Likewise.
3856         * config/te-hppa.h: Likewise.
3857         * config/te-nbsd.h: Likewise.
3858         * config/te-ppcnw.h: Likewise.
3859         * config/te-sparcaout.h: Likewise.
3860         * config/te-tmips.h: Likewise.
3861         * config/vax-inst.h: Likewise.
3862         * config/vms-conf.h: Likewise.
3863
3864 2000-11-14  Jakub Jelinek  <jakub@redhat.com>
3865
3866         * config/tc-alpha.c (s_alpha_prologue): Preserve visibility bits.
3867
3868 2000-11-13  H.J. Lu  <hjl@gnu.org>
3869
3870         * config/obj-elf.c (elf_frob_symbol): Support
3871         ".symver name,name2@@@nodename".
3872         (elf_frob_file_before_adjust): Likewise.
3873
3874         * doc/as.texinfo: Updated for ".symver name,name2@@@nodename"
3875         and ".symver name,name2@@@nodename".
3876         Fix a typo.
3877
3878 2000-11-12  H.J. Lu  (hjl@gnu.org)
3879
3880         * config/obj-elf.c (obj_elf_symver): Check missing version
3881         name.
3882
3883 2000-11-12  H.J. Lu  (hjl@gnu.org)
3884
3885         * dwarf2dbg.c (dwarf2_generate_asm_lineno): Use addressT
3886         instead of bfd_vma for non-bfd assemblers.
3887
3888 2000-11-09  Kazu Hirata  <kazu@hxi.com>
3889
3890         * itbl-ops.c: Fix comment typos.
3891
3892 2000-11-08  Jim Wilson  <wilson@redhat.com>
3893
3894         * config/tc-ia64.c (struct unw_rec_list): Add slot_frag field.
3895         (struct unwind): Add next_slot_frag field.
3896         (slot_index): New parameters slot_frag and first_frag.  Add code
3897         to add in frag sizes when different.  Add comments.
3898         (fixup_unw_records): New locals first_frag and last_frag.  Pass new
3899         arguments to slot_index.
3900         (emit_one_bundle): Set slot_frag field.  Set next_slot_number after
3901         loop end.  Set next_slot_frag field.
3902
3903 2000-11-07  H.J. Lu  <hjl@gnu.org>
3904
3905         * doc/as.texinfo (.symver): Updated for versioned symbol
3906         reference.
3907
3908         * obj.h (format_ops): Add the frob_file_before_adjust field.
3909
3910         * config/obj-aout.c (aout_format_ops): Set the
3911         frob_file_before_adjust field to 0.
3912         * config/obj-coff.c (coff_format_ops): Likewise.
3913         * config/obj-ecoff.c (ecoff_format_ops): Likewise.
3914
3915         * config/obj-elf.c (obj_elf_symver): Allow duplicated version
3916         name.
3917         (elf_frob_file_before_adjust): New function to remove unneeded
3918         versioned symbols from the symbol table.
3919         (elf_format_ops): Set the frob_file_before_adjust field to
3920         elf_frob_file_before_adjust.
3921
3922         * config/obj-elf.h (obj_frob_file_before_adjust): Defined if
3923         not defined.
3924
3925         * config/obj-multi.h (obj_frob_file_before_adjust): Defined.
3926
3927 2000-11-07  Peter Targett  <peter.targett@arccores.com>
3928
3929         * config/tc-arc.h: Avoid warnings for LITTLE_ENDIAN and
3930         BIG_ENDIAN macros.
3931         * config/tc-arc.c: Use S_IS_LOCAL to test local symbols.
3932         Fix compile time warning messages.
3933
3934 2000-11-07  Nick Clifton  <nickc@redhat.com>
3935
3936         * stabs.c (generate_asm_file): Increase length of xmalloc'ed
3937         buffer in order to avoid buffer overflows.
3938
3939 2000-11-06  Steve Ellcey <sje@cup.hp.com>
3940
3941         * config/tc-ia64.c (md_shortopts, md_parse_option, md_show_usage):
3942         Change M to m for -milp32 or -mlp64 to match gcc.
3943         (dot_endp): Use bytes_per_address instead of 8.
3944         (emit_one_bundle): Use number_to_chars_littleendian instead of
3945         md_number_to_chars.
3946         (fix_insn): Likewise.
3947         (ia64_init): New function.
3948         (ia64_target_format): New function.
3949         (md_begin): Set endianness, arch, and machine as appropriate.
3950         * config/tc-ia64.h: (TARGET_BYTES_BIG_ENDIAN, md_number_to_chars):
3951         Make these macros depend on TE_HPUX macro.
3952         (TARGET_FORMAT): Define.
3953         (HOST_SPECIAL_INIT): Define.
3954         * config/te-hpux.h: New file.
3955         * configure.in: Add "ia64-*-hpux*" target to configure.
3956         * configure: Regenerate.
3957
3958 2000-11-06  Kazu Hirata  <kazu@hxi.com>
3959
3960         * as.c: Fix formatting.
3961         * dwarf2dbg.c: Likewise.
3962         * input-file.c: Likewise.
3963         * input-file.h: Likewise.
3964         * input-scrub.c: Likewise.
3965         * itbl-ops.c: Likewise.
3966         * listing.c: Likewise.
3967         * macro.h: Likewise.
3968         * messages.c: Likewise.
3969         * read.c: Likewise.
3970         * subsegs.c: Likewise.
3971         * subsegs.h: Likewise.
3972         * write.c: Likewise.
3973
3974 2000-11-06  Nick Clifton  <nickc@redhat.com>
3975
3976         * doc/as.texinfo: Add GNU Free Documentation License.
3977         * doc/gasp.texi:  Add GNU Free Documentation License.
3978         * doc/as.1:  Add GNU Free Documentation License.
3979
3980 2000-11-05  Nick Clifton  <nickc@redhat.com>
3981
3982         * config/tc-arm.c: Add include of "dwarf2dbg.h"
3983
3984 2000-11-02  Per Lundberg  <plundis@chaosdev.org>
3985
3986         * configure.in: Recognise i[3456]86-chaosdev-storm-chaos.
3987         * configure: Regenerate.
3988
3989 2000-11-01  Nick Clifton  <nickc@redhat.com>
3990
3991         * read.c (original_case_string): New global variable.
3992         (read_a_source_file): Copy opcode string into
3993         original_case_string if clobbering the case of the opcode.
3994         * read.h: Export the definition of original_case_string.
3995         * config/tc-arm.c (md_assembler): When parsing a .req
3996         directive use the original opcode string, not the case
3997         clobbered version.
3998
3999 2000-11-02  Nick Clifton  <nickc@redhat.com>
4000
4001         * config/tc-mn10300.c (debug_line): Remove this static
4002         variable.
4003         (md_assemble): Call dwarf2_generate_asm_lineno instead of
4004         dwarf2_where and dwarf2_gen_line_info.
4005
4006 2000-11-02  Theo Honohan  <th@futuretv.com>
4007
4008         * config/tc-arm.c (do_msr): Improve error message.
4009
4010 2000-10-31  Eric Christopher  <echristo@redhat.com>
4011
4012         * config/tc-mn10300.c (md_apply_fix3): Use valuep if fully resolved
4013         or pc-relative, else use fx_offset.
4014
4015 2000-10-31  Jim Wilson  <wilson@redhat.com>
4016
4017         * config/tc-ia64.c (struct md): New field tag_fixups.
4018         (ia64_flush_insns): Handle tag_fixups.  Error if dangling
4019         qualifying predicate.
4020         (emit_one_bundle): Delete spurious multiplication by one.  Handle
4021         tag_fixups.
4022         (ia64_start_line): Error if dangling qualifying predicate.
4023         (defining_tag): New static variable.
4024         (ia64_unrecognized_line, case '['): Parse tags.
4025         (ia64_frob_label): Create tag_fixups.
4026         (md_assemble): Reset md.qp.X_op after using it.
4027
4028 2000-10-31  Kaz Kojima <kkojima@rr.iij4u.or.jp>
4029
4030         * config/tc-sh.c (md_apply_fix [BFD_RELOC_SH_PCDISP12BY2]): Allow 4094.
4031
4032 2000-10-31  Bernd Schmidt  <bernds@redhat.co.uk>
4033
4034         * config/tc-ia64.c (extra_goodness): Only prefer F in slot 1 and B in slot 2.
4035
4036 2000-10-30  Kazu Hirata  <kazu@hxi.com>
4037
4038         * expr.c: Fix formatting.
4039         * flonum-copy.c: Likewise.
4040         * flonum.h: Likewise.
4041         * gasp.c: Likewise.
4042         * hash.c: Likewise.
4043
4044 2000-10-30  Hans-Peter Nilsson  <hp@bitrange.com>
4045
4046         * as.h (OPTION_MD_BASE): Bump to 190.
4047         * as.c (parse_args) <std_longopts>: Add comment about the need to
4048         check OPTION_MD_BASE in as.h.
4049
4050         * config/tc-sh.c (md_apply_fix): For ELF, do not "adjust back" VAL
4051         for weak symbols.
4052
4053 2000-10-27  Nick Clifton  <nickc@redhat.com>
4054
4055         * configure.in (emulations): Add m68hc12.
4056         * configure: Regenerate.
4057         * po/gas.pot: Regenerate.
4058
4059 2000-10-27  Aldy Hernandez  <aldyh@redhat.com>
4060
4061         * config/tc-arm.c (psrs): Remove lowercase versions of spsr* and
4062         cpsr*.
4063         (arm_psr_parse): Handle lowercase CPSR and SPSR.
4064
4065 2000-10-25  Nick Clifton  <nickc@redhat.com>
4066
4067         * dwarf2out.c (dwarf2_generate_asm_lineno): New function: Generate
4068         a DWARF2 line number information sequence.
4069
4070         *dwarf2out.h: Add prototype for dwarf2_generate_asm_lineno.
4071
4072         * read.c (generate_lineno_debug): Update comment describing why
4073         DWARF2 line number debug information is not generated
4074         automatically by this function.
4075
4076         * doc/as.texinfo: Note that --gdwarf2 only works on some targets,
4077         not all.
4078
4079         * config/tc-arm.h (md_end): Define.
4080         (DWARF2_LINE_MIN_INSN_LENGTH): Define.
4081
4082         * config/tc-arm.c (output_inst): Call dwarf2_generate_asm_lineno
4083         if generating DWARF2 line numbers.
4084         (arm_end_of_source): New function.  Call dwarf2_finish if
4085         necessary.
4086
4087         * config/tc-hppa.c (md_assemble): Use dwarf2_generate_asm_lineno.
4088         * config/tc-m68hc11.c (m68hc11_new_insn): Use dwarf2_generate_asm_lineno.
4089         * config/tc-sh.c (md_assemble): Use dwarf2_generate_asm_lineno.
4090
4091 2000-10-25  Diego Novillo  <dnovillo@cygnus.com>
4092
4093         * config/tc-i386.c: Fix prototype declarations for functions taking no
4094         arguments.
4095
4096 2000-10-24  Diego Novillo  <dnovillo@cygnus.com>
4097
4098         * config/tc-i386.c (i386_operand_modifier): Remove.
4099         (build_displacement_string): Remove.
4100         (i386_parse_seg): Remove.
4101         (i386_intel_memory_operand): Remove.
4102         (i386_intel_operand): Re-write using recursive descent parser based
4103         on MASM documentation.
4104         (struct intel_parser_s): New structure.
4105         (intel_parser): New static variable.
4106         (struct intel_token): New structure.
4107         (cur_token, prev_token): New static variables.
4108         (T_NIL): Define.
4109         (T_CONST): Define.
4110         (T_REG): Define.
4111         (T_BYTE): Define.
4112         (T_WORD): Define.
4113         (T_DWORD): Define.
4114         (T_QWORD): Define.
4115         (T_XWORD): Define.
4116         (T_SHORT): Define.
4117         (T_OFFSET): Define.
4118         (T_PTR): Define.
4119         (T_ID): Define.
4120         (intel_match_token): New function.
4121         (intel_get_token): New function.
4122         (intel_putback_token): New function.
4123         (intel_expr): New function.
4124         (intel_e05): New function.
4125         (intel_e05_1): New function.
4126         (intel_e06): New function.
4127         (intel_e06_1): New function.
4128         (intel_e09): New function.
4129         (intel_e09_1): New function.
4130         (intel_e10): New function.
4131         (intel_e10_1): New function.
4132         (intel_e11): New function.
4133
4134 2000-10-20  Jakub Jelinek  <jakub@redhat.com>
4135
4136         * config/tc-sparc.c (sparc_ip): Fix a bug which caused v9_arg_p
4137         instructions to loose any special insn->architecture mask.
4138
4139         * config/tc-sparc.c (v9a_asr_table): Add v9b ASRs.
4140         (sparc_md_end, sparc_arch_types, sparc_arch,
4141         sparc_elf_final_processing): Handle v8plusb and v9b architectures.
4142         (sparc_ip): Handle siam mode operands. Support v9b ASRs (and
4143         request v9b architecture if they are used).
4144
4145 2000-10-18  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
4146
4147         * config/tc-m68k.c: Fix the previous misapplied patch.
4148
4149 2000-10-18  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
4150
4151         * config/tc-m68k.h (RELAX_RELOC_*): New definitions for both
4152         BFD_ASSEMBLER and !BFD_ASSEMBLER.
4153         * config/tc-m68k.c (md_convert_frag_1): Use them instead of
4154         BFD_RELOC_*.
4155
4156 2000-10-17  Kazu Hirata  <kazu@hxi.com>
4157
4158         * debug.c: Fix formatting.
4159         * depend.c: Likewise.
4160         * dwarf2dbg.c: Likewise.
4161         * dwarf2dbg.h: Likewise.
4162         * ecoff.c: Likewise.
4163         * expr.c: Likewise.
4164         * expr.h: Likewise.
4165         * flonum-konst.c: Likewise.
4166         * frags.h: Likewise.
4167
4168 2000-10-17  Chandrakala Chavva  <cchavva@redhat.com>
4169
4170         * as.c: New option OPTION_TARGET_HELP. Prints all target specific
4171         options.
4172         * doc/as.texinfo: Added notes about this new option.
4173
4174 2000-10-16  Hans-Peter Nilsson  <hp@bitrange.com>
4175
4176         * config/tc-sh.c (JREG): Remove.
4177         (md_convert_frag): Remove #if 0:d code using JREG.
4178
4179 2000-10-15  Diego Novillo  <dnovillo@cygnus.com>
4180
4181         * config/tc-i386.c (i386_operand_modifier): Only match
4182         modifiers SHORT and FLAT if they are followed by a space.
4183         (parse_register): When `allow_naked_reg' is set, do not confuse
4184         identifiers that start with a register name with a register.
4185
4186 2000-10-12  Kazu Hirata  <kazu@hxi.com>
4187
4188         * app.c: Fix formatting.
4189         * as.c: Likewise.
4190         * as.h: Likewise.
4191         * bit_fix.h: Likewise.
4192         * cgen.c: Likewise.
4193         * cgen.h: Likewise.
4194         * cond.c: Likewise.
4195
4196 2000-10-11  Alan Modra  <alan@linuxcare.com.au>
4197
4198         * config/obj-elf.c (elf_frob_symbol): Revert 2000-10-07 change.
4199
4200 2000-10-07  Alan Modra  <alan@linuxcare.com.au>
4201
4202         * config/tc-hppa.c (md_apply_fix): Remove plainly wrong assert.
4203         Re-arrange function a little and improve error message.
4204
4205         * write.c (write_relocs): Fix a comment.
4206
4207         * config/obj-elf.c (elf_frob_symbol): Make section syms global on
4208         link-once sections.
4209
4210 2000-10-05  Jim Wilson  <wilson@cygnus.com>
4211
4212         * config/tc-ia64.c (resources_match): Handle IA64_RS_PRr.
4213
4214 2000-10-05  Alan Modra  <alan@linuxcare.com.au>
4215
4216         * config/tc-i386.c: Delete some useless comments, reformat others.
4217
4218         * config/tc-i386.h (TC_FIX_ADJUSTABLE): Add check to cover
4219         non-global syms in linkonce sections.
4220
4221 2000-10-04  Ralf Baechle  <ralf@gnu.org>
4222
4223         * config/tc-ia64.c (operand_match): Don't use // style comments.
4224         * config/tc-i370.c: Likewise.
4225
4226 2000-09-29  Hans-Peter Nilsson  <hp@axis.com>
4227
4228         Changes to handle varying register prefix and user symbol prefix.
4229         * config/tc-cris.c (SYNTAX_RELAX_REG_PREFIX,
4230         SYNTAX_ENFORCE_REG_PREFIX, SYNTAX_USER_SYM_LEADING_UNDERSCORE,
4231         SYNTAX_USER_SYM_NO_LEADING_UNDERSCORE, REGISTER_PREFIX_CHAR): New.
4232         (s_syntax, cris_force_reg_prefix, cris_relax_reg_prefix,
4233         cris_sym_leading_underscore, cris_sym_no_leading_underscore): New.
4234         (demand_register_prefix): New variable.
4235         (md_pseudo_table): New pseudo ".syntax".
4236         (md_longopts): New options --no-underscore and --underscore.
4237         (cris_target_format): Return elf32-us-cris or elf32-cris depending
4238         on symbols_have_leading_underscore.
4239         (get_gen_reg): Accept or require REGISTER_PREFIX_CHAR.
4240         (get_spec_reg): Ditto.
4241         (cris_number_to_imm) <case BFD_RELOC_VTABLE_ENTRY>: Remove FIXME.
4242         Fix formatting.
4243         (md_parse_option) <case 'h' 'H'>: Deprecate; add reference to
4244         --help.
4245         <case OPTION_NO_US, case OPTION_US>: New.
4246         (md_show_usage): Be brief and reformat to match continuation of
4247         --help.
4248         * po/gas.pot: Regenerate.
4249
4250 2000-09-28  Alan Modra  <alan@linuxcare.com.au>
4251
4252         * config/tc-hppa.c (hppa_force_relocation): If OBJ_SOM, don't
4253         force relocs for 12 bit branches.
4254         (md_apply_fix): Similarly, adjust logic here.
4255
4256 2000-09-28  Alan Modra  <alan@linuxcare.com.au>
4257
4258         * config/tc-hppa.c (md_apply_fix): Add fmt assertion.  Don't
4259         adjust for external and weak syms as we will use a reloc.  Allow
4260         for +8 offset when calculating limits of branches.
4261         (hppa_fix_adjustable): Undo 2000-09-23 change.
4262         (hppa_force_relocation): Likewise.  Add fx_addsy assertion.
4263         Correct distance calculation.
4264         (tc_gen_reloc): Print the file name and line number if we can't
4265         handle a fixup.
4266
4267         From John David Anglin <dave@hiauly1.hia.nrc.ca>
4268         * config/tc-hppa.c (nonzero_dibits): Define.
4269         (arg_reloc_stub_needed): Check each arg and return value
4270         separately for zero case.
4271         (pa_align): Declare argument `bytes'.
4272
4273 2000-09-25  Kazu Hirata  <kazu@hxi.com>
4274
4275         * config/tc-cris.c: Fix formatting.
4276         * config/tc-d10v.h: Likewise.
4277         * config/tc-d30v.c: Likewise.
4278         * config/tc-d30v.h: Likewise.
4279         * config/tc-fr30.c: Likewise.
4280         * config/tc-fr30.h: Likewise.
4281         * config/tc-m68k.c: Likewise.
4282         * config/tc-m68k.h: Likewise.
4283         * config/tc-pj.h: Likewise.
4284         * config/tc-ppc.c: Likewise.
4285         * config/tc-ppc.h: Likewise.
4286         * config/tc-sh.c: Likewise.
4287         * config/tc-sh.h: Likewise.
4288         * config/tc-sparc.c: Likewise.
4289         * config/tc-v850.h: Likewise.
4290         * config/tc-vax.h: Likewise.
4291         * config/tc-w65.h: Likewise.
4292         * config/tc-z8k.h: Likewise.
4293
4294 2000-09-23  Alan Modra  <alan@linuxcare.com.au>
4295
4296         * config/tc-hppa.c (hppa_fix_adjustable): Do the external and weak
4297         checks only for ELF.
4298         (hppa_force_relocation): Likewise.
4299
4300 2000-09-22  Jim Wilson  <wilson@cygnus.com>
4301
4302         * config/tc-ia64.c (dv_sem): Add "stop".
4303         (specify_resource, case IA64_RS_PR): Only handles regs 1 to 15 now.
4304         (specify_resource, case IA64_RS_PRr): New for regs 16 to 62.
4305         (specify_resource, case IA64_RS_PR63): Reorder (note == 7) test to
4306         match above.
4307         (mark_resources): Check IA64_RS_PRr.
4308
4309 2000-09-22  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
4310
4311         * config/tc-m68k.c (md_relax_table, m68k_ip, md_convert_frag_1,
4312         md_estimate_size_before_relax): Redesign and clean up the
4313         relaxation mechanism.
4314
4315 2000-09-21  Kazu Hirata  <kazu@hxi.com>
4316
4317         * config/tc-ns32k.c: Fix formatting.
4318         * config/tc-ns32k.h: Likewise.
4319
4320 2000-09-20  Kazu Hirata  <kazu@hxi.com>
4321
4322         * config/tc-m32r.c: Fix formatting.
4323         * config/tc-m32r.h: Likewise.
4324         * config/tc-m68851.h: Likewise.
4325         * config/tc-m68hc11.c: Likewise.
4326         * config/tc-m68hc11.h: Likewise.
4327         * config/tc-m88k.c: Likewise.
4328         * config/tc-mcore.c: Likewise.
4329         * config/tc-mcore.h: Likewise.
4330         * config/tc-mips.c: Likewise.
4331         * config/tc-mips.h: Likewise.
4332         * config/tc-mn10200.h: Likewise.
4333         * config/tc-mn10300.h: Likewise.
4334         * config/tc-tahoe.c: Likewise.
4335         * config/tc-tahoe.h: Likewise.
4336
4337 2000-09-19  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
4338
4339         * config/tc-vax.c (synthetic_votstrs): Remove jbssi and jbcci.
4340         Likewise in relaxation description comments.
4341
4342 2000-09-18  Alan Modra  <alan@linuxcare.com.au>
4343
4344         * config/tc-hppa.h (TC_FORCE_RELOCATION_SECTION): Allow
4345         subtraction of two syms without emitting a relocation.
4346
4347         From  David Huggins-Daines  <dhd@linuxcare.com>
4348         * config/tc-hppa.c (hppa_force_relocation): Force relocations for
4349         global or weak symbols.
4350
4351 2000-09-15  Kazu Hirata  <kazu@hxi.com>
4352
4353         * config/tc-h8300.h: Fix formatting.
4354         * config/tc-h8500.c: Likewise.
4355         * config/tc-h8500.h: Likewise.
4356         * config/tc-hppa.h: Likewise.
4357         * config/tc-i370.h: Likewise.
4358         * config/tc-i386.h: Likewise.
4359         * config/tc-i860.c: Likewise.
4360         * config/tc-i860.h: Likewise.
4361         * config/tc-i960.h: Likewise.
4362         * config/tc-ia64.c: Likewise.
4363         * config/tc-ia64.h: Likewise.
4364
4365 2000-09-14  Kazu Hirata  <kazu@hxi.com>
4366
4367         * config/tc-a29k.c: Fix formatting.
4368         * config/tc-alpha.c: Likewise.
4369         * config/tc-arc.c: Likewise.
4370         * config/tc-arc.h: Likewise.
4371         * config/tc-arm.c: Likewise.
4372         * config/tc-arm.h: Likewise.
4373         * config/tc-avr.c: Likewise.
4374         * config/tc-avr.h: Likewise.
4375         * config/tc-tic30.c: Likewise.
4376         * config/tc-tic30.h: Likewise.
4377         * config/tc-tic54x.c: Likewise.
4378         * config/tc-tic54x.h: Likewise.
4379         * config/tc-tic80.c: Likewise.
4380         * config/tc-tic80.h: Likewise.
4381
4382 2000-09-14  Timothy Wall  <twall@cygnus.com>
4383
4384         * config/tc-ia64.c (specify_resource): For PR%/PR63, note types of
4385         parallel comparisons for later use.
4386         (struct rsrc): Add parallel comparison type.
4387         (resources_match): Skip special cases of PR usage (non-conflicting
4388         parallel compares).
4389
4390 2000-09-13  Kazu Hirata  <kazu@hxi.com>
4391
4392         * config/obj-ecoff.c: Fix formatting.
4393         * config/obj-elf.c: Likewise.
4394         * config/obj-elf.h: Likewise.
4395         * config/obj-evax.h: Likewise.
4396         * config/obj-generic.h: Likewise.
4397         * config/obj-hp300.c: Likewise.
4398         * config/obj-hp300.h: Likewise.
4399         * config/obj-ieee.h: Likewise.
4400         * config/obj-vms.c: Likewise.
4401         * config/obj-vms.h: Likewise.
4402
4403 2000-09-13  Anders Norlander  <anorland@acc.umu.se>
4404
4405         * config/tc-mips.c (md_begin): Recognize 4Kc, 4Km and 4Kp processors.
4406         (md_parse_option): Ditto.
4407         (md_longopts): Add -mips32 option.
4408         (md_show_usage): Document new options.
4409         (mips_ip): Assemble sdbbp 20 bit 'm' args for MIPS32.
4410         (mips_ip): Assemble mfc0 with a sub-selection code.
4411         (validate_mips_insn): Handle 'H' (OP_*_SEL) and 'm' (OP_*_CODE20).
4412         (mips_cpu_to_str): New function.
4413         (mips_ip): Use mips_cpu_to_str instead of printing numeric cpu value.
4414         Use CPU_* defines instead of hardcoded numbers.
4415
4416         * doc/as.texinfo: Document new options.
4417         * doc/c-mips.texi: Ditto.
4418
4419 2000-09-12  Kazu Hirata  <kazu@hxi.com>
4420
4421         * as.h: Fix formatting.
4422         * asintl.h: Likewise.
4423         * bit_fix.h: Likewise.
4424         * config/obj-aout.c: Likewise.
4425         * config/obj-aout.h: Likewise.
4426         * config/obj-bout.c: Likewise.
4427         * config/obj-bout.h: Likewise.
4428         * config/obj-coff.c: Likewise.
4429         * config/obj-coff.h: Likewise.
4430         * dwarf2dbg.h: Likewise.
4431         * expr.h: Likewise.
4432         * flonum.h: Likewise.
4433         * frags.h: Likewise.
4434         * itbl-ops.h: Likewise.
4435         * macro.h: Likewise.
4436         * read.h: Likewise.
4437         * sb.h: Likewise.
4438         * struc-symbol.h: Likewise.
4439         * subsegs.h: Likewise.
4440         * symbols.h: Likewise.
4441         * tc.h: Likewise.
4442         * write.h: Likewise.
4443
4444 2000-09-11  Kazu Hirata  <kazu@hxi.com>
4445
4446         * bignum-copy.c: Fix formatting.
4447         * config/tc-i370.c: Likewise.
4448         * config/tc-i960.c: Likewise.
4449         * config/tc-m68k.c: Likewise.
4450         * ehopt.c: Likewise.
4451         * flonum-copy.c: Likewise.
4452         * flonum-konst.c: Likewise.
4453         * flonum-mult.c: Likewise.
4454         * literal.c: Likewise.
4455         * read.c: Likewise.
4456         * sb.c: Likewise.
4457         * stabs.c: Likewise.
4458         * subsegs.c: Likewise.
4459
4460 2000-09-09  Philip Blundell  <philb@gnu.org>
4461
4462         * configure.in (arm*-*-uclinux*): New target.
4463         * configure: Regenerate.
4464
4465 2000-09-09  Kazu Hirata  <kazu@hxi.com>
4466
4467         * input-file.c: Fix formatting.
4468         * itbl-ops.c: Likewise.
4469         * messages.c: Likewise.
4470
4471 2000-09-08  Philip Blundell  <philb@gnu.org>
4472
4473         * config/tc-arm.c (md_apply_fix3): Correct handling of ADRL when
4474         offset is negative.
4475
4476 2000-09-07  H.J. Lu  <hjl@gnu.org>
4477
4478         * configure.in (AC_ISC_POSIX): Put after AC_CANONICAL_SYSTEM.
4479         * configure: Rebuild.
4480
4481 2000-09-07  Kazu Hirata  <kazu@hxi.com>
4482
4483         * atof-generic.c: Fix formatting.
4484         * config/tc-mips.c: Likewise.
4485         * config/tc-vax.c: Likewise.
4486         * input-scrub.c: Likewise.
4487
4488 2000-09-07  Alexandre Oliva  <aoliva@redhat.com>
4489
4490         * config/tc-sh.h (TARGET_FORMAT): Use sh-linux targets.
4491         * configure.in (sh-*-linux*): Added.
4492         * configure: Rebuilt.
4493
4494 2000-09-06  Kazu Hirata  <kazu@hxi.com>
4495
4496         * config/tc-hppa.c: Fix formatting.
4497
4498         * ecoff.c: Fix formatting.
4499
4500 2000-09-06  Alexandre Oliva  <aoliva@redhat.com>
4501
4502         * configure: Rebuilt with new libtool.m4.
4503
4504 2000-09-05  Kazu Hirata  <kazu@hxi.com>
4505
4506         * cgen.c: Fix formatting.
4507         * config/tc-ia64.c: Likewise.
4508
4509 2000-09-05  Nick Clifton  <nickc@redhat.com>
4510
4511         * aclocal.m4: Regenerate.
4512         * config.in: Regenerate.
4513         * configure: Regenerate.
4514         * po/gas.pot: Regenerate.
4515
4516 2000-09-05  Hans-Peter Nilsson  <hp@axis.com>
4517
4518         * config/tc-cris.c: Correct comment typos.
4519
4520 2000-09-05  Eric Christopher  <echristo@cygnus.com>
4521
4522         * config/tc-mn10300.c: Cleanup.
4523         (md_pcrel_from): Enable.
4524
4525 2000-09-05  Alan Modra  <alan@linuxcare.com.au>
4526
4527         * expr.c (operand): Fix a comment typo.
4528         * write.c (write_relocs): Fix a signed/unsigned warning.
4529
4530         * config/tc-hppa.c (fudge_reg_expressions): New
4531         (hppa_force_reg_syms_absolute): New.
4532         (pa_equ): Allow reg_section expressions.
4533         * config/tc-hppa.c (md_optimize_expr): Define.
4534         (hppa_force_reg_syms_absolute): Prototype.
4535
4536         * config/tc-hppa.c (pa_11_fp_reg_struct): Delete.
4537         (pa_parse_number): Pass in arg to select fp reg parsing.
4538         Return 1 to indicate format checks pass.  If strict, then only
4539         accept a register or register symbol.  Return value in...
4540         (pa_number): New static for pa_parse_number.
4541         (FP_REG_BASE): Define.
4542         (FP_REG_RSEL): Define.
4543         (pre_defined_registers): Apply FP_REG_BASE and FP_REG_RSEL as
4544         appropriate.  White space changes.
4545         (need_pa11_opcode): Don't bother passing any params, get them from
4546         globals instead.
4547         (pa_ip): Modify all calls to pa_parse_number and need_pa11_opcode.
4548         Remove extraneous check in case 'Q'.
4549         (pa_equ): Modify call to pa_parse_number to do strict parsing. If
4550         reg, set section of resulting symbol to reg_section.
4551         (pa_parse_space_stmt): Modify call to pa_parse_number.
4552         (pa_space): Likewise.
4553
4554         * config/tc-hppa.c: (md_apply_fix): Handle vtable relocs.
4555         (hppa_force_relocation): Handle vtable relocs.
4556         (pa_vtable_entry): New.
4557         (pa_vtable_inherit): New.
4558         (md_pseudo_table): Add entries for vtable pseudos.
4559         (hppa_fix_adjustable): Reject reduction of R_PARISC_GNU_VTINHERIT
4560         and R_PARISC_GNU_VTENTRY relocs.  Reject reduction of relocs
4561         against weak syms.
4562         (tc_gen_reloc): Remove ELF_ARG_RELOC_INSN code.
4563         (pa_type_args): Don't call symbol_get_bfdsym multiple times.
4564         Set STT_PARISC_MILLICODE for OBJ_ELF when encountering a
4565         millicode import.
4566         * config/obj-elf.c (obj_elf_type): Allow md_elf_symbol_type to
4567         specify a symbol type.
4568
4569         * config/tc-hppa.h: Reorganize file a little, grouping OBJ_ELF
4570         dependent things together.
4571         (md_elf_symbol_type): Define.
4572
4573         * config/tc-hppa.c (fix_new_hppa): Elide "$PIC_pcrel$0" pseudo
4574         symbol.
4575         * config/tc-hppa.h (tc_frob_symbol): Elide "$PIC_pcrel$0" here too.
4576
4577         * config/obj-elf.h (obj_elf_vtable_inherit): Declare.
4578         (obj_elf_vtable_entry): Declare.
4579
4580         * config/obj-elf.c (obj_elf_vtable_inherit): Return struct fix *
4581         and export function.
4582         (obj_elf_vtable_entry): Similarly.
4583         (elf_pseudo_table): Fix the damage with a cast.
4584
4585 2000-09-03  Richard Henderson  <rth@cygnus.com>
4586
4587         * config/tc-ia64.c (emit_one_bundle): Stop collecting insns
4588         for template selection when a label is needed.
4589
4590 2000-09-02  Kazu Hirata  <kazu@hxi.com>
4591
4592         * config/tc-ia64.c: Fix formatting.
4593
4594 2000-09-02  Nick Clifton  <nickc@redhat.com>
4595
4596         * configure.in: Increase version number to 2.10.91.
4597         * configure: Regenerate.
4598         * aclocal.m4: Regenerate.
4599         * config.in: Regenerate.
4600         * po/gas.pot: Regenerate.
4601         * Makefile.in: Regenerate.
4602
4603 2000-09-01  Alexandre Oliva  <aoliva@redhat.com>
4604
4605         * config/tc-sh.h [OBJ_ELF] (TC_FIX_ADJUSTABLE): Define.
4606         * config/tc-sh.c (md_apply_fix): Map 32-bit relocations that
4607         become PC-relative to BFD_RELOC_32_PCREL.  Reject 16- or 8-bit
4608         similar relocs.
4609         (sh_obj_adjustable): Return 1 for PC-relative offsets used in
4610         branches.
4611
4612 2000-09-01  Niibe Yutaka  <gniibe@m17n.org>, Kaz Kojima  <kkojima@rr.iij4u.or.jp>, Alexandre Oliva  <aoliva@redhat.com>
4613
4614         * config/tc-sh.h (DIFF_EXPR_OK, GLOBAL_OFFSET_TABLE_NAME,
4615         TC_RELOC_GLOBAL_OFFSET_TABLE, TC_RELOC_RTSYM_LOC_FIXUP): Define.
4616         * config/tc-sh.c (sh_elf_cons, sh_elf_suffix): New functions.
4617         [OBJ_ELF] (md_pseudo_table) <long, int, word, short>: Use them.
4618         (GOT_symbol): New variable.
4619         (md_undefined_symbol): Set it.
4620
4621 2000-09-01  Richard Henderson  <rth@cygnus.com>
4622
4623         * config/tc-ia64.c (match): Don't inline.
4624         (extra_goodness): New.
4625         (md_begin): Prefer nop.f and nop.b for best_template.
4626
4627 2000-08-31  Kazu Hirata  <kazu@hxi.com>
4628
4629         * as.c: Fix formatting.
4630         * cond.c: Likewise.
4631         * frags.c: Likewise.
4632         * macro.c: Likewise.
4633
4634 2000-08-31  Eric Christopher  <echristo@cygnus.com>
4635
4636         * config/tc-mn10300.c:  Cleanup and fix warnings.
4637         (md_pseudo_table): Add initializers.
4638         (md_show_usage): Cleanup.
4639         (md_parse_option): Fix warnings.
4640         (md_undefined_symbol): Fix warnings.
4641         (md_conver_frag): Fix warnings.
4642         (tc_gen_reloc): Fix warnings.
4643         (md_apply_fix3): Fix warnings.
4644         (check_operand): Fix warnings.
4645
4646 2000-08-31  Alexandre Oliva  <aoliva@redhat.com>
4647
4648         * acinclude.m4: Include libtool and gettext macros from the
4649         top level.
4650         * aclocal.m4, configure: Rebuilt.
4651
4652 2000-08-30  Mark Hatle  <mhatle@mvista.com>
4653
4654         * config/tc-ppc.c (md_parse_option): Recognize -m405.
4655
4656 2000-08-31  Kazu Hirata  <kazu@hxi.com>
4657
4658         * listing.c: Fix formatting.
4659
4660 2000-08-29  Kazu Hirata  <kazu@hxi.com>
4661
4662         * app.c: Fix a comment typo.  Fix formatting.
4663
4664 2000-08-25  J. David Anglin  <dave@hiauly1.hia.nrc.ca>
4665
4666         * config/tc-vax.c (md_convert_frag): Correctly calculate the pc relative
4667         offset of the target destination for jmp instructions.
4668         (md_assemble): Change mode to VAX_ABSOLUTE_MODE as per comments.
4669
4670 2000-08-24  Hans-Peter Nilsson  <hp@axis.com>
4671
4672         * NEWS: Mention support for CRIS.
4673
4674 Thu Aug 24 20:41:05 2000  Denis Chertykov  <denisc@overta.ru>
4675
4676         * config/tc-avr.h (TC_IMPLICIT_LCOMM_ALIGNMENT): New macros.
4677         Sets `.lcomm' alignment to zero.
4678
4679 2000-08-23  Alexandre Oliva  <aoliva@redhat.com>
4680
4681         * config/tc-i386.h (OBJ_MAYBE_ELF, OBJ_MAYBE_COFF,
4682         TC_FIX_ADJUSTABLE): Define.
4683
4684 2000-08-23  Jim Wilson  <wilson@cygnus.com>
4685
4686         * config/tc-ia64.c (output_unw_records): Set U & E flags only if
4687         unwind.personality_routine is set.
4688
4689 2000-08-23  H.J. Lu  <hjl@gnu.org>
4690
4691         * write.c (TC_FIX_ADJUSTABLE): Remove the duplicate.
4692
4693 2000-08-23  Alexandre Oliva  <aoliva@redhat.com>
4694
4695         * config/tc-i386.h (TC_FIX_ADJUSTABLE): Do *NOT* define if target
4696         environment is pe.
4697
4698 2000-08-22  H.J. Lu  <hjl@gnu.org>
4699
4700         * config.in (STRICTCOFF): New for strict COFF.
4701
4702         * configure.in: Define STRICTCOFF for i386-*-msdosdjgpp*,
4703         i386-*-go32* and i386-go32-rtems*.
4704         * configure: Rebuilt.
4705
4706         * config/obj-coff.c (obj_coff_endef): Follow the historical
4707         behavior if STRICTCOFF is not defined.
4708
4709         * doc/internals.texi: Document STRICTCOFF.
4710
4711 2000-08-22  Alexandre Oliva  <aoliva@redhat.com>
4712
4713         * write.c (TC_FIX_ADJUSTABLE): Define to 1, if not defined.
4714         (fixup_segment) Use it instead of TC_DONT_FIX_NON_ADJUSTABLE.
4715         * config/tc-i386.h (TC_DONT_FIX_NON_ADJUSTABLE): Remove.
4716         <OBJ_ELF, OBJ_COFF, TE_PE> (TC_FIX_ADJUSTABLE): Define.
4717         * config/tc-arm.h (TC_DONT_FIX_NON_ADJUSTABLE): Remove.
4718         <OBJ_ELF> (TC_FIX_ADJUSTABLE): Define.
4719         * config/tc-i960.h, config/tc-m68k.h, config/tc-v850.h:
4720         Likewise.
4721
4722 2000-08-22  Eric Christopher  <echristo@cygnus.com>
4723
4724         * config/tc-mn10300.c: (md_apply_fix): New function.
4725         (mn10300_force_relocation): New function.
4726         (mn10300_fix_adjustable): New function.
4727
4728         * config/tc-mn10300.h: (TC_FORCE_RELOCATION): Define.
4729         (TC_HANDLES_FX_DONE): Define.
4730         (obj_fix_adjustable): Define.
4731         (MD_APPLY_FIX3): Define.
4732         (TC_LINKRELAX_FIXUP): Define.
4733
4734         * write.c: (TC_LINKRELAX_FIXUP):  Define if not
4735         previously defined.
4736         (fixup_segment): Use TC_LINKRELAX_FIXUP.
4737
4738         * doc/internals.texi: Document TC_LINKRELAX_FIXUP.
4739
4740 2000-08-21  Jason Eckhardt  <jle@cygnus.com>
4741
4742         * config/tc-i860.c (md_apply_fix3): Do not insert the immediate
4743         if the fixup resulted in a relocation.
4744
4745 2000-08-18  Nick Clifton  <nickc@redhat.com>
4746
4747         * config/tc-arm.c (decode_shift): Replace as_tsktsk with as_warn.
4748         Make reference to first element of shift_names explicit.
4749
4750 2000-08-18  Alexandre Oliva  <aoliva@redhat.com>
4751
4752         * write.c (fixup_segment) [TC_DONT_FIX_NON_ADJUSTABLE]: Use
4753         obj_fix_adjustable() and tc_fix_adjustable() to tell whether to
4754         add a symbol's address.  Removed all target-specific #ifdefs that
4755         used to accomplished the same.
4756         * config/tc-v850.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
4757         * config/tc-m68k.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
4758         * config/tc-arm.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
4759         * config/tc-i960.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
4760         * config/tc-i386.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
4761
4762 2000-08-17  Kazu Hirata  <kazu@hxi.com>
4763
4764         * dwarf2dbg.c: Fix formatting.
4765
4766 2000-08-17  Nick Clifton  <nickc@redhat.com>
4767
4768         * config/tc-arm.c (decode_shift): Allow illegal shifts by zero
4769         to be recoded as logical shift lefts by zero.
4770
4771 2000-08-16  Jim Wilson  <wilson@cygnus.com>
4772
4773         * config/tc-ia64.c (specify_resource, case IA64_RS_GR): Handle
4774         postincrement modified registers.  Handle IA64_OPND_R3_2 addl
4775         source registers.
4776         (note_register_values): Handle IA64_OPND_R3_2 operands.
4777
4778 2000-08-16  Jason Eckhardt  <jle@cygnus.com>
4779
4780         * config/tc-i860.c (md_operand): Silly typo fixed.
4781
4782 2000-08-16  Nick Clifton  <nickc@redhat.com>
4783
4784         * config/tc-arm.c (struct asm_shift): Delete.
4785         (shift[]): Delete.
4786         (enum asm_shift_index): New.
4787         (struct asm_shift_properties): New.
4788         (struct asm_shift_name): New.
4789         (shift_properties[]); New.
4790         (shift_names[]); New.
4791
4792         (decode_shift): Use new structures.
4793         Issue a warning is "ROR #0" is used.
4794         Issue a warning if "ASR #0" or "LSR #0" is used.
4795
4796         (md_begin): Initialise arm_shift_hsh table from new
4797         asm_shift_name array.
4798
4799 2000-08-16  Jakub Jelinek  <jakub@redhat.com>
4800
4801         * config/tc-sparc.c: Kill all warnings.
4802         (md_parse_option): Set -32/-64 for -xarch=, allow all -A archs
4803         in -xarch= as well.
4804         (md_show_usage): Update usage text.
4805
4806 2000-08-16  Nick Clifton  <nickc@redhat.com>
4807
4808         * config/tc-arm.c (do_bx): Warn about "bx px" not being very
4809         useful.
4810
4811 2000-08-15  Will Cohen  <wcohen@redhat.com>
4812
4813         * config/tc-sh.h (DWARF2_LINE_MIN_INSN_LENGTH): Defined.
4814
4815         * config/tc-sh.c (md_assemble): Changed so debug_type
4816         test performed for ppi_assemble
4817         * config/tc-sh.c: Included dwarf2dbg.h.
4818         (debug_line): Defined.
4819         (md_assemble): Generates dwarf2 line info.
4820         (sh_finalize): New function.  Finalize dwarf2 info.
4821         (assemble_ppi): Returns size of code generated.
4822         (build_Mytes): Returns size of code generated.
4823         (md_pseudo_table): Added "file" and "loc" psuedo ops.
4824         * config/tc-sh.h (md_end): Defined.
4825         (sh_finalize): Declared.
4826
4827 2000-08-15  Alexandre Oliva  <aoliva@redhat.com>
4828
4829         * config/tc-sh.c (md_apply_fix) [BFD_RELOC_32, BFD_RELOC_16]: Use
4830         md_number_to_chars.
4831
4832 2000-08-14  Nick Clifton  <nickc@redhat.com>
4833
4834         * config/tc-arm.c (do_bx): Allow "bx pc".
4835
4836 2000-08-14  Jim Wilson  <wilson@cygnus.com>
4837
4838         * config/tc-ia64.c (md_longopts): Add -mconstant-gp and -mauto-pic.
4839         (md_parse_option):  Add OPTION_MCONSTANT_GP and OPTION_MAUTO_PIC.
4840         (md_begin): Change assignment to md.flag to OR in the new bit.
4841
4842 2000-08-14  Mark Elbrecht  <snowball3@bigfoot.com>
4843
4844         * config/obj-coff.c (obj_coff_endef) [BFD_ASSEMBLER]: Set the debug
4845         flag for storage types C_ARG, C_REGPARM, C_FIELD, C_MOS, C_MOE,
4846         C_MOU, and C_EOS.
4847
4848 2000-08-14  Jason Eckhardt  <jle@cygnus.com>
4849
4850         * NEWS: Mention i860 support.
4851
4852 Mon Aug 14 11:49:12 2000  Jeffrey A Law  (law@cygnus.com)
4853
4854         * config/tc-mn10300.h (DWARF2_LINE_MIN_INSN_LENGTH): Define.
4855
4856 2000-08-14  Andreas Schwab  <schwab@suse.de>
4857
4858         * doc/c-arm.texi (ARM Directives): Fix warnings from makeinfo.
4859
4860 2000-08-11  Andreas Schwab  <schwab@suse.de>
4861
4862         * doc/c-i860.texi (Opcodes for i860): Remove braces from @item
4863         argument.
4864
4865 2000-08-11  Kazu Hirata  <kazu@hxi.com>
4866
4867         * expr.c: Fix formatting.
4868         * config/obj-bout.c: Likewise.
4869
4870 2000-08-10  Jason Eckhardt  <jle@cygnus.com>
4871
4872         * doc/c-i860.texi: Flesh out the i860 section more.
4873
4874 2000-08-10  Kazu Hirata  <kazu@hxi.com>
4875
4876         * symbols.c: Fix formatting.
4877         * expr.c: Likewise.
4878
4879 Wed Aug  9 16:28:21 EDT 2000    Diego Novillo <dnovillo@cygnus.com>
4880
4881         * config/tc-i386.c (md_assemble): Skip suffix check if the opcode
4882         modifier has the IgnoreSize bit set.
4883
4884 2000-08-09  Alan Modra  <alan@linuxcare.com.au>
4885
4886         From  Rodney Brown  <RodneyBrown@mynd.com>
4887         * configure.in: Use elf on Unixware 7 (i586-sco-sysv5uw7.1.0)
4888         * configure: Regenerate.
4889
4890 2000-08-09  Kazu Hirata  <kazu@hxi.com>
4891
4892         * hash.c: Fix formatting.
4893         * gasp.c: Likewise.
4894
4895 2000-08-08  Jason Eckhardt  <jle@cygnus.com>
4896
4897         * config/tc-i860.h: Rework completely for BFD_ASSEMBLER.
4898         (i860_fix_info): New enum.
4899         (MD_APPLY_FIX3): Define.
4900         (WORKING_DOT_WORD): Define.
4901         (TC_HANDLES_FX_DONE): Define.
4902         (DIFF_EXPR_OK): Define.
4903         (LISTING_HEADER): Define.
4904         (TARGET_FORMAT): Select target format based on endian flag.
4905         (TARGET_BYTES_BIG_ENDIAN): Default to little endian.
4906         (target_big_endian): Add external declaration.
4907
4908         * config/tc-i860.c: All existing code reworked completely. Other
4909         new code shown below.
4910         (SYNTAX_SVR4): Define.
4911         (target_warn_expand): New variable.
4912         (md_shortopts): Declare and define (-Qy, -Qn, and -V options).
4913         (md_longopts): Declare and define with new options (-EL, -EB,
4914         and -mwarn-expand).
4915         (md_show_usage): New function.
4916         (md_operand): New function.
4917         (obtain_reloc_for_imm16): New function.
4918         (md_apply_fix3): New function.
4919         (tc_gen_reloc): New function.
4920
4921 2000-08-08  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
4922
4923         * config/tc-m68hc11.c (build_jump_insn): Make sure the
4924         2 bytes of the jump address are in the same frag.
4925         (find): Accept 68hc12 register indirect modes.
4926
4927         * NEWS: Mention 68HC11 & 68HC12 support.
4928
4929 2000-08-07  Richard Henderson  <rth@cygnus.com>
4930
4931         * config/tc-ia64.c (unwind): Add prologue_mask member.
4932         (dot_vframe): Elide psp_gr record if it overlaps prologue_gr.
4933         (dot_save): Likewise for pfs_gr, rp_gr, and preds_gr.
4934         (dot_body): Clear unwind.prologue_mask.
4935         (dot_prologue): Set it.  Accept a register second argument.
4936
4937 2000-08-07  Kazu Hirata  <kazu@hxi.com>
4938
4939         * config/atof-ieee.c: Fix formatting.
4940         * config/atof-tahoe.c: Likewise.
4941
4942 2000-08-06  Nick Clifton  <nickc@cygnus.com>
4943
4944         * config/tc-sparc.c (md_begin): Fix typo in recent formatting
4945         work.
4946
4947         * doc/as.texinfo (Pseudo Ops): Update to include descriptions
4948         of .popsection, .previous, .pushsection, .subsection,
4949         .version, .vtable_entry, .vtable_inherit and .weak.
4950
4951 2000-08-05  Kazu Hirata  <kazu@hxi.com>
4952
4953         * config/tc-cris.c: Fix formatting.
4954         * config/tc-i386.c: Likewise.
4955         * config/tc-sparc.c (sparc_ip): Simplify the code.
4956
4957 2000-08-04  Kazu Hirata  <kazu@hxi.com>
4958
4959         * config/tc-cris.c: Rearrange code for readability.
4960         * config/tc-d10v.c: Fix formatting.
4961         * config/tc-m32r.c: Likewise.
4962         * config/tc-sparc.c: Likewise.
4963
4964 2000-08-02  Jim Wilson  <wilson@cygnus.com>
4965
4966         * config/tc-ia64.c (emit_one_bundle): Call ia64_free_opcode
4967         before ia64_find_opcode.
4968         (md_assemble): Likewise.
4969
4970 2000-08-01  Nick Clifton  <nickc@cygnus.com>
4971
4972         * config/tc-arm.c (do_mrs): Fix skip of 'cpsr_all' flag.
4973         Undo some formatting fixes.
4974
4975 2000-08-01  Kazu Hirata  <kazu@hxi.com>
4976
4977         * config/obj-som.c: Fix formatting.
4978         * config/obj-ieee.c: Likewise.
4979         * config/tc-arm.c: Likewise.
4980         * config/tc-v850.c: Likewise.
4981
4982 2000-08-01  Nick Clifton  <nickc@redhat.com>
4983
4984         * doc/c-m68k.texi (section M680x0 Options): Turn into a table
4985         index by command line option.
4986
4987 2000-08-01  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
4988
4989         * doc/c-m68k.texi (@cindex @samp{--pcrel}): Rewrite option description.
4990         (@node M68K-Branch): Rewrite to match the reality.
4991
4992 2000-07-31  Jason Eckhardt  <jle@cygnus.com>
4993
4994         * doc/c-i860.texi: New file.
4995         * doc/Makefile.am (CPU_DOCS): Add c-i860.texi.
4996         * doc/Makefile.in: Regenerate.
4997         * doc/all.texi: Add I860 as relevant architecture.
4998         * doc/as.texinfo: Include i860 dependent file c-i860.texi.
4999
5000 2000-07-31  Kazu Hirata  <kazu@hxi.com>
5001
5002         * config/tc-d30v.c: Fix formatting.
5003
5004 2000-07-31  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
5005
5006         * config/tc-m68k.c (flag_keep_pcrel, OPTION_PCREL): Add --pcrel option.
5007         (md_convert_frag_1, md_estimate_size_before_relax): When making DBcc
5008         long emit a long branch if available instead of an absolute jump, never
5009         emit absolute jumps for anything with --pcrel.
5010
5011         * doc/c-m68k.texi: Document new command line option.
5012
5013 2000-07-29  Marek Michalkiewicz  <marekm@linux.org.pl>
5014
5015         * config/tc-avr.c: Use PARAMS macro in function declarations.
5016         Don't declare md_pcrel_from_section (already in tc-avr.h).
5017         (avr_operands): Use AVR_UNDEF_P and AVR_SKIP_P macros.
5018         (avr_operand): Don't set (unsigned) op_mask to -1.
5019
5020 2000-07-28  Jason Eckhardt  <jle@cygnus.com>
5021
5022         * configure.in: Add bits for i860-stardent-{sysv4, elf}*.
5023         * configure: Regenerated.
5024         * config/obj-elf.c (obj_elf_type): Recognize a fifth type
5025         of operand to the .type directive (.e.g, "type").
5026
5027 2000-07-28  Alan Modra  <alan@linuxcare.com.au>
5028
5029         * as.h (warn_comment, found_comment, found_comment_file): Declare.
5030         * app.c (do_scrub_chars): Record where first comment found.
5031         * read.c (read_a_source_file): Init found_comment on entry, and
5032         notify whether comments found on exit.
5033         * config/tc-hppa.c (md_shortopts): Add "c".
5034         (md_longopts): Add warn-comment.
5035         (md_parse_option): Handle it.
5036         (md_show_usage): Show available options.
5037         * config/tc-hppa.h (WARN_COMMENTS): Define if TE_LINUX
5038
5039 Thu Jul 27 11:25:01 2000  Andrew Cagney  <cagney@b1.cygnus.com>
5040
5041         * config/tc-mn10300.c (md_convert_frag): Fix printfs.
5042         (tc_gen_reloc): Add cast when assigning bfd_abs_symbol to
5043         sym_ptr_ptr
5044         (md_estimate_size_before_relax): Don't fall off end of function.
5045
5046 2000-07-27  Kazu Hirata  <kazu@hxi.com>
5047
5048         * config/tc-avr.c: Fix formatting.
5049         * config/tc-ns32k.c: Likewise.
5050
5051 2000-07-27  Alan Modra  <alan@linuxcare.com.au>
5052
5053         * config/tc-d10v.c (find_opcode): Remove extraneous `='.
5054
5055 2000-07-27  Kazu Hirata  <kazu@hxi.com>
5056
5057         * config/tc-d10v.c: Fix formatting.
5058         * config/tc-z8k.c: Likewise.
5059         * config/tc-sparc.c: Likewise.
5060
5061 2000-07-26  Dave Brolley  <brolley@redhat.com>
5062
5063         * cgen.c (queue_fixup): Declare opinfo.
5064         (gas_cgen_parse_operand): Mark unused parameters with ATTRIBUTE_UNUSED.
5065         (gas_cgen_md_operand): Ditto.
5066         (gas_cgen_md_apply_fix3): Ditto.
5067
5068 2000-07-24  Mark Elbrecht  <snowball3@bigfoot.com>
5069
5070         * config/obj-coff.c (obj_frob_symbol): Don't merge
5071         labels. Don't merge if the symbol isn't constant. Return
5072         immediately if a symbol is merged.
5073
5074 2000-07-22  Alan Modra  <alan@linuxcare.com.au>
5075
5076         * frags.c (frag_align): Correct absolute section alignment.
5077
5078 2000-07-20  DJ Delorie  <dj@redhat.com>
5079
5080         * config/obj-coff.c (obj_frob_symbol): revert previous change,
5081         it breaks linking against DLLs.
5082
5083 2000-07-20  Hans-Peter Nilsson  <hp@axis.com>
5084
5085         * configure.in: Add CRIS support.
5086         * configure: Regenerate.
5087         * Makefile.am: (CPU_TYPES): Add cris.
5088         (CPU_OBJ_VALID) [aout]: Add cris.
5089         (MULTI_CPU_TYPES): Add cris.
5090         (MULTI_CPU_OBJ_VALID) [aout]: Add cris.
5091         [coff]: Only i386 and mips are valid.
5092         (TARGET_CPU_CFILES): Add config/tc-cris.c.
5093         (TARGET_CPU_HFILES): Add config/tc-cris.h.
5094         (MULTI_CFILES): Add config/e-crisaout.c and config/e-criself.c.
5095         Regenerate dependencies.
5096         * Makefile.in: Regenerate.
5097         * aclocal.m4: Regenerate.
5098         * as.c: Declare crisaout, criself.
5099         * config/tc-cris.h, config/tc-cris.c: New.
5100         * config/e-criself.c, config/e-crisaout.c: New.
5101         * po/POTFILES.in, po/gas.pot: Regenerate.
5102
5103 2000-07-20  Kazu Hirata  <kazu@hxi.com>
5104
5105         * read.c: Fix formatting.
5106         * write.c: Fix formatting.
5107
5108 2000-07-19  H.J. Lu  <hjl@gnu.org>
5109
5110         * sb.c: Include <stdlib.h> if exists for abort ().
5111
5112 2000-07-19  Alan Modra  <alan@linuxcare.com.au>
5113
5114         * config/tc-hppa.c (hppa_fix_adjustable): Correct LR%/RR% comment.
5115         (arg_reloc_stub_needed): #ifdef OBJ_SOM, not #ifdef SOM.
5116         (pa_type_args): Same here.
5117
5118 2000-07-17  Mark Elbrecht  <snowball3@bigfoot.com>
5119
5120         * config/obj-coff.c (obj_frob_symbol): Don't merge labels. Don't
5121         merge if the symbol isn't constant. Don't call S_SET_EXTERNAL if
5122         the storage class is already set.
5123
5124 2000-07-17  Kazu Hirata  <kazu@hxi.com>
5125
5126         * config/tc-m68hc11.c: Fix formatting.
5127         * config/tc-mn10200.c: Likewise.
5128         * config/tc-mn10300.c: Likewise.
5129         * config/tc-pj.c: Likewise.
5130         * config/tc-tic80.c: Likewise.
5131         * config/tc-w65.c: Likewise.
5132
5133 2000-07-17  Frank Ch. Eigler  <fche@redhat.com>
5134
5135         * expr.c (operand): Permit %bin literals if LITERAL_PREFIXPERCENT_BIN
5136         is defined.
5137
5138 2000-07-15  Ian Lance Taylor  <ian@zembu.com>
5139
5140         * doc/c-mips.texi (MIPS Opts): Remove erroneous space after
5141         @code.
5142
5143 2000-07-15  Alan Modra  <alan@linuxcare.com.au>
5144
5145         * config/tc-hppa.c (hppa_fix_adjustable): Use the same checks for
5146         ELF as are used for SOM (except the 32-bit reloc one) to decide
5147         whether a symbol can be reduced to a section symbol.  Expand on
5148         the comment for symbols involved in LR% and RR% expressions.
5149
5150 2000-07-14  Nick Clifton  <nickc@cygnus.com>
5151
5152         * config/tc-mips.c (mips_disable_float_construction): New
5153         static variable.  Set to true if doubles should not be
5154         constructed by loading two single width fp registers with
5155         halves of the value.
5156         (mips_ip): Test mips_disable_float_construction.
5157         (md_longopts): Add command line switches --construct-floats
5158         and --no-construct-floats.
5159         (md_parse_option): Parse new command line options.
5160         (md_show_usage): Describe new command line options.
5161
5162         * doc/c-mips.texi: Document new command line options.
5163
5164 2000-07-13  Koundinya K  <kk@ddeorg.soft.net>
5165
5166         * configure.in: Remove the test /usr/dde for mips-*-sysv4*MP*
5167         * configure: Regenerate.
5168
5169 2000-07-13  Hans-Peter Nilsson  <hp@axis.com>
5170
5171         * configure.in (DEFAULT_EMULATION setting): Revert part of
5172         2000-07-01 change that set te_multi=multi unless set to tmips.
5173         * configure: Regenerate.
5174
5175 2000-07-12  Mark Elbrecht  <snowball3@bigfoot.com>
5176
5177         * config/obj-coff.c (coff_frob_section): Add padding to the last
5178         section when aligning it increases its size.
5179
5180 2000-07-11  Kazu Hirata  <kazu@hxi.com>
5181
5182         * config/tc-tic54x.c: Fix formatting.
5183
5184 2000-07-10  Kazu Hirata  <kazu@hxi.com>
5185
5186         * config/tc-h8500.c: Fix formatting.
5187         * config/tc-tic54x.c: Fix formatting.
5188
5189 2000-07-10  Alan Modra  <alan@linuxcare.com.au>
5190
5191         * config/tc-hppa.c (md_apply_fix): Check fmt 12 and 22 pc-rel
5192         displacements correctly.
5193
5194         * read.h (s_abort): Add ATTRIBUTE_NORETURN.
5195
5196 2000-07-10  Ryan Bradetich  <rbradetich@uswest.net>
5197
5198         * hash.c (hash_insert): Add cast to obstruct_alloc to fix
5199         warning.
5200         (hash_jam): Ditto.
5201
5202 2000-07-09  Alan Modra  <alan@linuxcare.com.au>
5203
5204         From  David Huggins-Daines  <dhd@linuxcare.com>
5205         * config/te-hppalinux64.h: Add a new emulation.
5206         * configure.in (emulations): Add configure bits to support the
5207         64-bit Linux/parisc target.
5208         * configure: Regenerate.
5209
5210         * config/tc-hppa.c (md_parse_option): Support `-V' for ELF.
5211         (md_shortopts): Add `V' for ELF.
5212
5213         * config/tc-hppa.c (arg_reloc_stub_needed): Define as zero except
5214         when SOM or ELF_ARG_RELOC are defined.
5215         (pa_type_args): Only set symbol_arg_reloc_info when SOM or
5216         ELF_ARG_RELOC are defined.
5217         (pa_stringer_aux): Don't pa_check_current_space_and_subspace here..
5218         (pa_stringer): ..Do it here instead.  Fix comment typos.
5219         (hppa_force_relocation): Cast enums to int before comparing with
5220         ints.
5221
5222         From  Ryan Bradetich  <rbradetich@uswest.net>
5223         * config/tc-hppa.c: Removed unneeded libbfd.h to fix macro
5224         redifinition warning.
5225         (md_apply_fix): Added cast from enum to int for fixP->fx_r_type.
5226         (hppa_force_relocation): ditto
5227         (md_apply_fix): Added cast to buf to fix warnings.
5228
5229         * config/tc-hppa.h (pa_define_label, parse_cons_expression_hppa,
5230         cons_fix_new_hppa, hppa_force_relocation): Prototype.
5231
5232         * config/tc-hppa.c (reloc_type): It's an enum for OBJ_ELF.
5233         (R_N0SEL, R_N1SEL): Define only for OBJ_SOM.
5234         (tc_gen_reloc): Make `code' a reloc_type and `codes' a
5235         reloc_type** to avoid warnings in switch.
5236         (md_apply_fix): Make insn, val signed.  Zap buf_wd and read insn a
5237         little earlier instead.
5238
5239         * config/tc-hppa.c (symbol_arg_reloc_info): Define for both som
5240         and elf.
5241         (pa_type_args): Use symbol_arg_reloc_info.
5242         (struct pa_it): Make arg_reloc unsigned int.
5243         (struct hppa_fix_struct): Likewise for fx_arg_reloc.
5244         (pa_text, pa_data, pa_comm): Don't compile for TE_LINUX.
5245         (pa_code): Delete.  pa_text duplicates this function.
5246         (md_pseudo_table): Call obj_elf_text for ".code" if TE_LINUX.
5247         (fix_new_hppa): Argument offset is offsetT, arg_reloc is unsigned
5248         int.
5249         (cons_fix_new_hppa): Actually change selector to e_fsel when
5250         warning about assuming so.
5251         (tc_gen_reloc): More example elf arg reloc code.
5252         (md_apply_fix): Use arg_reloc_stub_needed for elf too.
5253         (hppa_force_relocation): Likewise.
5254
5255         * config/tc-hppa.h: Use TARGET_ARCH_SIZE to select target include
5256         files.
5257         (pa_end_of_source): Prototype.
5258         (hppa_fix_adjustable): Prototype.
5259         (LABELS_WITHOUT_COLONS): Move it..
5260         * config/te-hppa.h: To here.
5261
5262         * config/te-hppa64.h: New file.
5263
5264         * config/tc-hppa.c: Use TARGET_ARCH_SIZE to select target reloc
5265         type.
5266         (md_apply_fix): Pass stdoutput to bfd_hppa_insn2fmt.  Handle
5267         format -10, -16, 16 relocs.
5268         (hppa_elf_mark_end_of_function): Test for null
5269         last_call_info->start_symbol
5270
5271         * config/tc-hppa.c (pa_ip): In case 'V', pass `strict' to
5272         CHECK_FIELD, not INSERT_FIELD_AND_CONTINUE.  Don't pass opcode to
5273         re_assesmble_* functions.  Delete extraneous statements.  Fix
5274         typos in comments.
5275         (md_apply_fix): Compare against 1048575 in case 21.  Don't pass
5276         insn to re_assemble_*.
5277
5278 2000-07-08  Ulf Carlsson  <ulfc@engr.sgi.com>
5279
5280         * doc/internals.texi (Expressions): Fix typo.
5281
5282 2000-07-08  Kazu Hirata  <kazu@hxi.com>
5283
5284         * config/tc-sh.c: Fix formatting.
5285         * config/tc-tic54x.c: Fix formatting.
5286         * depend.c: Fix formatting.
5287         * flonum-konst.c: Likewise.
5288         * flonum-mult.c: Likewise.
5289
5290 2000-07-07  Kazu Hirata <kazu@hxi.com>
5291
5292         * config/tc-sh.c: Fix comments.
5293         * config/obj-vms.c: Fix comments.
5294         * config/tc-a29k.c: Likewise.
5295         * config/tc-alpha.c: Likewise.
5296         * config/tc-h8300.c: Likewise.
5297         * config/tc-h8500.c: Likewise.
5298         * config/tc-i370.c: Likewise.
5299         * config/tc-ia64.c: Likewise.
5300         * config/tc-m68hc11.c: Likewise.
5301         * config/tc-m68k.c: Likewise.
5302         * config/tc-mips.c: Likewise.
5303         * config/tc-ns32k.c: Likewise.
5304         * config/tc-ppc.c: Likewise.
5305         * config/tc-z8k.c: Likewise.
5306
5307 2000-07-06  Mark Elbrecht  <snowball3@bigfoot.com>
5308
5309         * config/obj-coff.c (TC_COFF_SECTION_DEFAULT_ATTRIBUTES): New.
5310         Default to '(SEC_LOAD | SEC_DATA)'.
5311         (obj_coff_section) [BFD_ASSEMBLER]: Use it.
5312
5313         * doc/internals.texi (CPU Backend): Describe
5314         TC_COFF_SECTION_DEFAULT_ATTRIBUTES.
5315
5316 Thu Jul  6 17:20:58 2000  Andrew Cagney  <cagney@b1.cygnus.com>
5317
5318         * as.c (parse_args): NULL terminate the long option list.
5319
5320 Tue Jul  4 14:08:28 2000  Andrew Cagney  <cagney@b1.cygnus.com>
5321
5322         * config/tc-d30v.h: Include "write.h" for fixS.
5323         (d30v_start_line, md_pcrel_from_section): Add function prototypes.
5324
5325 2000-07-05  Nick Clifton  <nickc@cygnus.com>
5326
5327         * config/tc-d30v.c (write_2_short): Further changes to warning
5328         messages produced when combining EITHER_BUT_PREFER_MU attributed
5329         opcodes.
5330
5331 2000-07-05  DJ Delorie  <dj@redhat.com>
5332
5333         * MAINTAINERS: new
5334
5335 2000-07-04  Alexandre Oliva  <aoliva@redhat.com>
5336
5337         * config/tc-arm.c (psrs): Accept combinations of flags.
5338
5339 2000-07-03  Marek Michalkiewicz  <marekm@linux.org.pl>
5340
5341         * config/tc-avr.c: Change _ () to _() around all strings marked
5342         for translation (exception from the usual coding style).
5343         (avr_opt): New struct variable, how the new switches are set.
5344         (OPTION_MMCU): Define as 'm' and actually use.
5345         (md_longopts): Add -mall-opcodes, -mno-skip-bug, -mno-wrap.
5346         (show_mcu_list): New function, display the list of known MCUs.
5347         (md_show_usage): Document the new switches.  Call show_mcu_list.
5348         (avr_set_arch): Change 'm' to OPTION_MMCU.
5349         (md_parse_option): Call show_mcu_list if unknown MCU specified.
5350         Handle the new switches.
5351         (avr_operands): Disable warnings for undefined combinations of
5352         operands if -mall-opcodes.  Disable warnings for skipping two-word
5353         instructions if enhanced core or -mno-skip-bug.
5354         (avr_operand): Accept all addressing modes on avr1 if -mall-opcodes.
5355         (md_apply_fix3): Reject 8K wrap if >8K or -mno-wrap.
5356         (md_assemble): Accept opcodes not supported by MCU if -mall-opcodes.
5357         (avr_ldi_expression): Warn about implicit lo8().
5358         * config/tc-avr.h (md_pcrel_from_section): Add prototype.
5359
5360 2000-07-01  Koundinya K  <kk@ddeorg.soft.net>
5361
5362         * configure.in: Add entry for mips-*-sysv4*MP*
5363         * configure: Rebuild
5364         * config/tc-mips.c (mips_target_format): Return elf32-tradbigmips or
5365         elf32-tradlittlemips for traditional mips targets.
5366         * config/tc-mips.c (md_estimate_size_before_relax): Duplicate the
5367         test for Link Once sections as in adjust_reloc_syms.
5368         * config/te-tmips.h: New file for traditional mips targets. Define
5369         TE_TMIPS.
5370
5371 2000-06-29 Mark Elbrecht <snowball3@bigfoot.com>
5372
5373         * config/obj-coff.c (obj_coff_setcion) [BFD_ASSEMBLER]: If the
5374         flags argument is not present, don't change an existing section's
5375         section's attributes. If the flags argument is present, warn if the
5376         attributes don't match the section's current attributes. When
5377         long section names are supported, set SEC_LINK_ONCE and
5378         SEC_LINK_DUPLICATES_DISCARD for a new .gnu.linkonce section.
5379
5380 Thu Jun 29 21:30:00 2000  Hans-Peter Nilsson  <hp@axis.com>
5381
5382         * config/obj-aout.c (obj_aout_type): Do not ignore for undefined
5383         symbols; create them.
5384
5385 2000-06-29 Mark Elbrecht <snowball3@bigfoot.com>
5386
5387         * write.c (set_segment_vma): New: Set vma and lma for a segment.
5388         (write_object_file) [BFD_ASSEMBLER && OBJ_COFF && TE_GO32]: Use it.
5389
5390 2000-06-27  Aldy Hernandez  <aldyh@redhat.com>
5391
5392         * config/tc-mips.c (mips_ip): handle "(foo-.-4)" type of
5393         expressions.  Ignore the problem when handling 16 bit signed
5394         immediates, because the assembler will take care of the relocation
5395         later.
5396
5397 2000-06-27  Nick Clifton  <nickc@cygnus.com>
5398
5399         * config/tc-d30v.c (write_2_short): Do not allow opcodes with
5400         the EITHER_BUT_PREFER_MU attribute to be combined into a reverse
5401         sequential order, and emit warning messages if the input source
5402         code contains constructs like that, or parallel constructs
5403         containing such opcodes.
5404
5405 2000-06-26  Marek Michalkiewicz  <marekm@linux.org.pl>
5406
5407         * config/tc-avr.c (mcu_types): Rename avr4 to avr5, add avr4.
5408         Add more MCU types for avr4 and avr5.  Replace at94k{10,20,40}
5409         with just at94k.  Change AVR_ISA_85xx back to AVR_ISA_2xxx.
5410         (md_show_usage): Update usage message.
5411         (md_parse_option): Allow redefinition of MCU type within the
5412         same avr[1-5] bfd machine type.  Show both old and new MCU type
5413         in the error message.
5414         (md_apply_fix3): Support 8K wrap if AVR_ISA_MEGA is not set.
5415         Simplify 8K wrap code.
5416
5417 2000-06-25  Kazu Hirata  <kazu@hxi.com>
5418
5419         * config/obj-aout.c: Remove all uses of DEFUN.
5420         * config/obj-ieee.c: Likewise.
5421         * config/tc-sh.c: Fix comment typos.
5422         * config/tc-tahoe.c: Likewise.
5423         * config/tc-vax.c: Likewise.
5424         * config/tc-w65.c: Likewise.
5425         * config/tc-z8k.c: Likewise.
5426         * config/tc-h8300.c (build_bytes): Assemble ldmac correctly.
5427
5428 2000-06-24  DJ Delorie  <dj@cygnus.com>
5429
5430         * config/tc-i386.c (md_estimate_size_before_relax): Revert
5431         more changes from Sept 1999
5432         (tc_i386_fix_adjustable): ditto
5433         (md_apply_fix3): ditto
5434
5435 2000-06-24  Frank Ch. Eigler  <fche@redhat.com>
5436
5437         * cgen.c (expr_jmp_buf_p): New validity flag for expr_jmp_buf.
5438         (gas_cgen_parse_operand): Set it around expression() call.
5439         (gas_cgen_md_operand): Test for it before longjmp().
5440
5441 2000-06-24  Kazu Hirata  <kazu@hxi.com>
5442
5443         * config/tc-h8500.c: Remove all uses of DEFUN.
5444         * config/tc-sh.c: Likewise.
5445         * config/tc-w65.c: Likewise.
5446         * config/tc-z8k.c: Likewise.
5447
5448         * config/tc-h8500.c: Fix typos in comments.
5449
5450 2000-06-23  Frank Ch. Eigler  <fche@redhat.com>
5451
5452         * expr.c (operand): Permit $hex literals if LITERAL_PREFIXDOLLAR_HEX
5453         is defined.
5454
5455 2000-06-23  matthew green  <mrg@redhat.com>
5456
5457         * expr.c (operand): Do not as_bad() if RELAX_PAREN_GROUPING is
5458         defined.  Fix error message for `[' grouping.
5459
5460 2000-06-22  Kazu Hirata  <kazu@hxi.com>
5461
5462         * config/tc-h8300.c: Fix formatting and comment typos.
5463
5464 2000-06-22  Timothy Wall  <twall@cygnus.com>
5465
5466         * config/tc-ia64.c (note_register_values): Move premature QP
5467         notation clearing into the appropriate place.
5468
5469 2000-06-22  Alan Modra  <alan@linuxcare.com.au>
5470
5471         * dep-in.sed: Escape literal `.'s on patterns.  Trim off `../'
5472         first before anything else.  Add bin-bugs.h, emul.h and progress.h
5473         Sort list of files as for $(OBJS) in Makefile.am.
5474
5475         * Makefile.am (DEP): grep for leading `/' in DEPA, and fail if we
5476         find one.  Remake dependencies.
5477         ($(OBJS)): Add bin-bugs.h, emul.h, and progress.h  Sort the list.
5478         * Makefile.in: Regenerate.
5479         * doc/Makefile.in: Regenerate.
5480
5481         * config/tc-i386.c (i386_displacement): Don't assume a constant
5482         displacement is necessarily 16 bits when in 16 bit code mode.
5483         (md_assemble): Instead size the displacement here after we know
5484         for sure that a .code16gcc operand hasn't automatically added
5485         operand size prefixes.
5486
5487 2000-06-21  H.J. Lu  <hjl@gnu.org>
5488
5489         * Makefile.am: Rebuild dependency.
5490         * Makefile.in: Rebuild.
5491
5492 2000-06-21  Kazu Hirata  <kazu@hxi.com>
5493
5494         * config/tc-h8300.c (parse_reg): Make the function static.
5495         (parse_exp): Likewise.
5496
5497 2000-06-20  DJ Delorie  <dj@cygnus.com>
5498
5499         * config/tc-i386.c (tc_i386_fix_adjustable): Revert change from
5500         Sept 1999; RVA relocs need to be treated more like DIR32 relocs
5501         for cygwin import libraries to work properly.
5502
5503 2000-06-20  H.J. Lu  <hjl@gnu.org>
5504
5505         * Makefile.am: Rebuild dependency.
5506         * Makefile.in: Rebuild.
5507         * configure: Likewise.
5508         * doc/Makefile.in: Likewise.
5509
5510 2000-06-20  Timothy Wall  <twall@cygnus.com>
5511
5512         * doc/internals.texi (CPU backend): Add @itemx for
5513         TC_START_LABEL_WITHOUT_COLON.
5514         * doc/c-tic54x.texi: New.
5515         * doc/as.texinfo: Add tic54x features and include primary tic54x
5516         documentation file.
5517         * doc/all.texi: Add C54X.
5518         * doc/Makefile.am (CPU_DOCS): Add c-tic54x.texi.
5519         * doc/Makefile.in: Regenerate.
5520         * configure.in: Add tic54x and define LIBM for tic54x.
5521         * configure: Regenrate.
5522         * config/tc-tic54x.[ch]: New.
5523         * config/obj-coff.h: Add tic54x.
5524         * Makefile.am: (CPU_TYPES): Add tic54x.
5525         (TARGET_CPU_CFILES): Add 'tc-tic54x.c'.
5526         (TARGET_CPU_HFILES): Add 'tc-tic54x.h'.
5527         (as_new_LDADD): Add $(LIBM).
5528         * Makefile.in: Regenerate.
5529
5530 2000-06-18  Stephane Carrez  <stcarrez@worldnet.fr>
5531
5532         * doc/Makefile.am (CPU_DOCS): Added 68hc11 file.
5533         * doc/c-m68hc11.texi: Document 68HC11 and 68HC12 port.
5534         * doc/as.texinfo: Likewise.
5535
5536         * configure, Makefile.in: Regenerate.
5537         * configure.in (emulations): Recognize m6811 and m6812.
5538         * Makefile.am (CPU_TYPES, TARGET_CPU_CFILES, TARGET_CPU_HFILES):
5539         Added files for 68hc11 and 68hc12 assembler.
5540         * config/tc-m68hc11.c: Assembler for 68hc11 and 68hc12.
5541         * config/tc-m68hc11.h: Header definition for that assembler.
5542
5543 2000-06-18  Nick Clifton  <nickc@redhat.com>
5544
5545         * symbols.c (resolve_symbol_value): Use bfd_octets_per_byte
5546         instead of OCTETS_PER_BYTE.
5547
5548         * config/tc-v850.c: Fix compile time warnings.
5549         * config/tc-ppc.c: Fix compile time warnings.
5550
5551 2000-06-18  H.J. Lu <hjl@gnu.org>
5552
5553         * configure.in: Don't emulate i386-pc-pe-coff with i386coff.
5554         * configure: Rebuild.
5555
5556 2000-06-17 Mark Elbrecht <snowball3@bigfoot.com>
5557
5558         * config/obj-coff.c (obj_coff_weak): Typo fix: Change BFD_ASSEMLER
5559         to BFD_ASSEMBLER.
5560
5561 2000-06-16  Nick Clifton  <nickc@cygnus.com>
5562
5563         * config/tc-mips.c (md_parse_option): Accept RM5200,RM5230,
5564         RM5231, RM5261, RM5721 and RM7000 as r5000 cpu variants.
5565
5566         * doc/c-mips.texi: Document newly accepted cpu variants.
5567
5568 2000-06-15  Ulf Carlsson  <ulfc@engr.sgi.com>
5569
5570         * config/tc-mips.h: Remove definition of ONLY_STANDARD_ESCAPES.
5571
5572 2000-06-13  Ulf Carlsson  <ulfc@engr.sgi.com>
5573
5574         * macro.c (getstring): Make it possible to escape the quote
5575         character.
5576
5577 Tue Jun 13 20:58:28 2000  Catherine Moore <clm@redhat.com>
5578
5579         * config/tc-hppa.c (pa_export): Weak symbols can be global.
5580
5581 2000-06-13  H.J. Lu  <hjl@gnu.org>
5582
5583         * configure: Regenerate.
5584
5585 2000-06-09  Alan Modra  <alan@linuxcare.com.au>
5586
5587         * app.c (do_scrub_begin): Don't default lex[';'] as a line
5588         separator.
5589         * doc/internals.texi (line_separator_chars): Semicolon is no
5590         longer a default.  Mention null and newline as defaults.
5591
5592         * read.c (is_end_of_line): Remove ifdef TC_HPPA.
5593
5594         * config/tc-i386.h (line_separator_chars): Explicitly mention `;'
5595         * config/tc-i860.h (line_separator_chars): Likewise.
5596         * config/tc-h8300.c (line_separator_chars): Likewise.
5597         * config/tc-i960.c (line_separator_chars): Likewise.
5598         * config/tc-m68k.c (line_separator_chars): Likewise.
5599         * config/tc-mips.c (line_separator_chars): Likewise.
5600         * config/tc-ns32k.c (line_separator_chars): Likewise.
5601         * config/tc-sparc.c (line_separator_chars): Likewise.
5602         * config/tc-vax.c (line_separator_chars): Likewise.
5603
5604         * config/tc-h8300.c (comment_chars): Use string initialiser.
5605         * config/tc-i960.c (line_comment_chars): Likewise.
5606         * config/tc-z8k.c (comment_chars, line_comment_chars,
5607         line_separator_chars): Likewise.
5608
5609         * config/tc-arm.c (line_separator_chars): Always use `;', not just
5610         for TE_LINUX.
5611
5612 2000-06-08  Nick Clifton  <nickc@cygnus.com>
5613
5614         * config/tc-arm.c (cons_fix_new_arm): Assign correct reloc value
5615         for size 1 fixes.
5616
5617 2000-06-08  David O'Brien  <obrien@FreeBSD.org>
5618
5619         * configure.in (VERSION): Update to show this is the CVS mainline.
5620
5621 2000-06-08  Matthew Jacob  <mjacob@feral.com>
5622
5623         * config/tc-alpha.c (md_undefined_symbol): Properly understand that
5624         $at is the integer register $r28, vs. both $r28 and the floating
5625         point register $f28.
5626
5627 2000-06-08  James E. Wilson  <wilson@cygnus.com>
5628
5629         * config/tc-ia64.c (generate_unwind_image): Call ia64_flush_insns.
5630         (dot_endp): Don't call ia64_flush_insns.
5631         (emit_one_bundle): Don't delete prologue/body records from
5632         unwind_record list in first loop.  Rewrite second loop to account for
5633         this.
5634
5635 2000-06-07  David Mosberger  <davidm@hpl.hp.com>
5636
5637         * config/tc-ia64.c: Add missing prototypes.
5638         (generate_unwind_image): Cast argument to output_unw_records call.
5639
5640 Wed Jun  7 22:44:14 2000  Denis Chertykov  <denisc@overta.ru>
5641
5642         * config/tc-avr.c (avr_operand): fix the formatting of the comment.
5643
5644 Wed Jun  7 21:26:15 2000  Denis Chertykov  <denisc@overta.ru>
5645
5646         * config/tc-avr.c (AVR_ISA_???): moved to include/opcode/avr.h
5647         (REGISTER_P): likewise.
5648         (avr_opcodes): uses include/opcode/avr.h
5649         (avr_operand): enable ld r,Z or st r,Z for at90s1200.
5650
5651 2000-06-04  Alan Modra  <alan@linuxcare.com.au>
5652
5653         * read.c (is_end_of_line): No ';' for TC_HPPA.  Add missing
5654         initializers too.
5655
5656 2000-06-03  H.J. Lu  <hjl@gnu.org>
5657
5658         * read.c (is_end_of_line): Put back `;'.
5659
5660 2000-06-03  Alan Modra  <alan@linuxcare.com.au>
5661
5662         * config/tc-i386.c (md_shortopts): Remove 'm', add 'q' to non-elf.
5663
5664 2000-06-01  Alan Modra  <alan@linuxcare.com.au>
5665
5666         * expr.c (operand): Test is_end_of_line outside switch to catch
5667         line separator chars that are also operators.
5668         (operator): Return O_illegal for line separator chars.
5669
5670         * read.c (is_end_of_line): Use 1 instead of 99.  Don't set `;'
5671         entry (or `!' entry for TC_HPPA).
5672
5673         * config/tc-arm.c (my_get_float_expression): Cast to unsigned char
5674         before indexing is_end_of_line.  Remove redundant check for '\0'.
5675         (fp_op2): Likewise.
5676         * config/tc-h8500.c (md_assemble): Likewise.
5677         * config/tc-mcore.c (md_assemble): Likewise.
5678         * config/tc-tic30.c (tic30_find_parallel_insn): Likewise.
5679         (md_atof): Likewise
5680
5681         * config/tc-m88k.c (s_bss): Cast to unsigned char before indexing
5682         is_end_of_line.
5683         * config/tc-mcore.c (mcore_cons): Likewise.
5684         (mcore_float_cons): Likewise.
5685         (mcore_stringer): Likewise.
5686         * config/tc-tic30.c (tic30_find_parallel_insn): Likewise.
5687
5688 2000-06-01  Scott Bambrough <scottb@netwinder.org>
5689
5690         * config/tc-arm.c (do_mrs): Allow SPSR_BIT to be set correctly.
5691
5692 2000-05-29  Nick Clifton  <nickc@cygnus.com>
5693
5694         * config/tc-sh.c: Fix compile time warning messages.
5695
5696         * config/tc-mips.c: Fix compile time warning messages.
5697
5698 2000-05-29  Philip Blundell  <philb@gnu.org>
5699
5700         * doc/as.texinfo: Update copyright dates.
5701         (Local Labels): Delete misplaced mention of ARM.
5702         * NEWS: Mention ARM ELF support.
5703
5704 2000-05-27  Alexandre Oliva  <aoliva@cygnus.com>
5705
5706         * config/tc-mn10300.c (md_assemble): Copy size to real_size before
5707         it is modified, and use the real_size to compute the frag address
5708         for dwarf2 line info.
5709
5710 2000-05-27  Alan Modra  <alan@linuxcare.com.au>
5711
5712         * Makefile.am (DEP, DEP1, dep, dep-in, dep-am): Use a better sed
5713         line-matching scheme to cope with automake moving variables around.
5714         ($(TARG_CPU_O)): Remove dependency on TARG_CPU_DEP_@target_cpu_type@
5715         * Makefile.in: Regenerate.
5716
5717 2000-05-26  Jakub Jelinek  <jakub@redhat.com>
5718
5719         * config/tc-sparc.c (sparc_relax): New.
5720         (md_longopts): Add -relax and -no-relax options.
5721         (md_parse_options, md_show_usage): Likewise.
5722         (md_apply_fix3): Optimize tail call into branch always if possible.
5723
5724 Thu May  4 15:27:07 2000  Donald Lindsay  <dlindsay@cygnus.com>
5725
5726         * config/tc-d10v.c (write_2_short, parallel_ok, md_assemble,
5727         d10v_cleanup) implement Mitsubishi's newly explained branch-packing
5728         rules, with warning when a GAS statement specifies a packing that
5729         will result in an instruction being squashed.
5730         Added typdef packing_type and enumerals, changed various integer
5731         literals to use the enumerals.
5732
5733 2000-05-24  David Mosberger  <davidm@hpl.hp.com>
5734
5735         * config/tc-ia64.c (dot_restorereg_p): New function.
5736         (md_pseudo_table): Add restorereg.p.
5737         (output_X3_format): Fix typo: record type should be UNW_X3, not UNW_X1.
5738         (output_X4_format): Fix typo: record type should be UNW_X4, not UNW_X2.
5739
5740         * config/tc-ia64.h (unw_record_type): Add unwabi.
5741         (unw_r_record): Rename member MASK to GRMASK.  Add sub-structure
5742         called MASK with members for imask, and the masks produced by
5743         fr_mem, gr_mem, br_mem, and frgr_mem.
5744         (unw_p_record): Add members ABI and CONTEXT.
5745         (unw_x_record): Add member AB.
5746         * config/tc-ia64.c (enum reg_symbol): Add REG_PSP and REG_PRIUNAT
5747         as pseudo-register for use during unwind info generation.
5748         (AR_PFS, AR_LC): New macros.
5749         (enum pseudo_type): Add PSEUDO_FUNC_REG to permit declaring registers
5750         whose names start with an at sign (as in "@priunat").
5751         (pseudo_func): Add "svr4", "hpux", "nt" constants and "priunat"
5752         register.
5753         (unwind_list, unwind_tail, current_unwind_entry, proc_start,
5754         proc_end, unwind_info, personality_routine): Consolidate into
5755         "unwind" structure to reduce offset-table use.  Add member
5756         NEXT_SLOT_NUMBER to track the slot number for the next instruction
5757         to be emitted.
5758         (output_R1_format, output_R3_format, output_P3_format,
5759         output_P6_format): Initialize R with zero to reduce compiler warnings.
5760         (output_P7_format): Ditto.  Add `default' branch to switch
5761         statement to reduce compiler warnings.
5762         (output_P8_format, output_B1_format, output_B4_format): Ditto.
5763         (output_P4_format): Rename 2nd & 3rd arg to IMASK and IMASK_SIZE.
5764         (format_ab_reg): Rename from format_a_b_reg.  Merge A and B args
5765         into single argument.
5766         (output_X1_format, output_X3_format): Initialize R with zero to reduce
5767         compiler warnings.  Merge A and B args into single argument.
5768         (output_X2_format, output_X4_format): Remove unused variable R.  Merge
5769         A and B args into single argument.
5770         (free_record): Removed (wasn't used).
5771         (free_list_records): Also free imasks in prologue records.
5772         (output_prologue, output_prologue_gr): Initialize mask bits to zero.
5773         (output_spill_mask): Remove.
5774         (output_unwabi): New function.
5775         (output_epilogue, output_label_state, output_copy_state): Call
5776         alloc_record.
5777         (output_spill_psprel, output_spill_sprel, output_spill_psprel_p,
5778         output_spill_sprel_p, output_spill_reg, output_spill_reg_p): Add AB
5779         argument.
5780         (process_one_record): New locals FR_MASK and GR_MASK.  Ignore
5781         gr_mem, fr_mem, br_mem, and frgr_mem records and instead emit them
5782         as part of handling the prologue records.  Emit region's imask if
5783         we have one.  Handle unwabi, epilogue, label_state, copy_state,
5784         spill_psprel, spill_sprel, spill_reg, spill_psprel_p,
5785         spill_sprel_p, and spill_reg_p records.
5786         (set_imask, count_bits, slot_index): New function.
5787         (fixup_unw_records): Fix region size computation.  Handle
5788         epilogue, spill_reg, spill_sprel, spill_psprel, spill_reg_p,
5789         spill_sprel_p, and spill_psprel_p records.  Merge mask bits of
5790         frgr_mem, fr_mem, gr_mem, br_mem on a per-region basis and
5791         set_imask accordingly.  Update imask for gr_gr, and br_gr records.
5792         (convert_expr_to_ab_reg, convert_expr_to_xy_reg): New function.
5793         (dot_save): Use manifest constants for applicaton registers.
5794         Handle REG_PR and REG_PRIUNAT.
5795         (dot_restore): Don't just ignore it.
5796         (dot_restorereg): New function..
5797         (generate_unwind_image): Ensure unwind info is a multiple of eight
5798         bytes, not just four bytes.
5799         (dot_handlerdata, dot_unwentry): Demand empty rest of line.
5800         (dot_altrp): Don't just ignore it.
5801         (dot_savemem): New function.  Replaces dot_savesp() and
5802         dot_savepsp().  Use manifest constants for applicaton registers.
5803         Handle REG_PR and REG_PRIUNAT.
5804         (dot_savef): Simplify.
5805         (dot_saveb): Support generation of br_gr.
5806         (dot_spillreg, dot_spillmem, dot_spillreg_p, dot_spillmem_p,
5807          dot_label_state, dot_copy_state): New function.
5808         (dot_unwabi): Don't just ignore it.
5809         (md_pseudo_table): Add restorereg, spillreg, spillsp, spillpsp,
5810         spillreg.p, spillsp.p, spillpsp, label_state, copy_state,
5811         unwabi, vframesp, and vframepsp.  Fix typo alprp->altrp.
5812         (emit_one_bundle): Set slot number for prologue/body records
5813         *before* emitting the first insn.
5814         (emit_one_bundle): Set UNWIND.NEXT_SLOT_NUMBER.
5815         (md_begin): Declare "psp" pseudo-register.
5816         (md_operand): Handle PSEUDO_FUNC_REG.  Fix printing of error message
5817         so we don't get segfault.
5818         (output_psp_sprel): Output sp/psp relative offsets as 4-byte word
5819         counts as required per SW Conventions manual
5820         (output_rp_psprel, output_rp_sprel, output_pfs_psprel,output_pfs_sprel,
5821         output_preds_psprel, output_preds_sprel, output_spill_base,
5822         output_unat_psprel, output_unat_sprel, output_lc_psprel,
5823         output_lc_sprel, output_fpsr_psprel, output_fpsr_sprel,
5824         output_priunat_psprel, output_priunat_sprel, output_bsp_psprel,
5825         output_bsp_sprel, output_bspstore_psprel, output_bspstore_sprel,
5826         output_rnat_psprel, output_rnat_sprel, output_spill_psprel,
5827         output_spill_sprel, output_spill_psprel_p, output_spill_sprel_p):Ditto.
5828         (dot_vframe): Implement.
5829         (dot_vframesp, dot_vframepsp): New function.
5830
5831 Tue May 23 00:57:05 2000  Hans-Peter Nilsson  <hp@axis.com>
5832
5833         * configure.in (i386-*-freebsd a.out entry): Quote properly.
5834         * configure: Regenerate.
5835
5836 2000-05-23  Alan Modra  <alan@linuxcare.com.au>
5837
5838         * config/tc-i386.c (md_assemble): Pass jump reloc in fr_var...
5839         (md_estimate_size_before_relax): so we can use it here instead of
5840         old kludges.  Localise vars to blocks.  Comment.
5841
5842         * frags.c (frag_new): Update fr_var comments.
5843         * frags.h (struct frag): Ditto.
5844
5845 2000-05-22  Richard Henderson  <rth@cygnus.com>
5846
5847         * config/tc-ia64.c (FUNC_PC_RELATIVE): New.
5848         (pseudo_func): Add pcrel.
5849         (operand_match):  Handle IA64_OPND_TGT64.
5850         (build_insn): Likewise.
5851         (md_begin): Initialize pseudo_func[FUNC_PC_RELATIVE].
5852         (ia64_gen_real_reloc_type): Handle FUNC_PC_RELATIVE.
5853         (fix_insn): Handle all three 64-bit relocation types.
5854
5855 Mon May 22 22:43:32 2000  Hans-Peter Nilsson  <hp@axis.com>
5856
5857         * obj.h (struct format_ops): New members begin, app_file,
5858         s_set_other, s_set_desc, s_get_type, s_set_type,
5859         separate_stab_sections, init_stab_section.
5860
5861         * config/obj-multi.h: Update GPL notice to v2.
5862         (obj_begin): New.
5863         (obj_app_file): New.
5864         (S_SET_SIZE): Test s_set_size for NULL before calling.
5865         (S_SET_ALIGN): Similar for s_set_align.
5866         (S_SET_OTHER): New.
5867         (S_SET_DESC): New.
5868         (S_GET_TYPE): New.
5869         (S_SET_TYPE): New.
5870         (SEPARATE_STAB_SECTIONS): New.
5871         (INIT_STAB_SECTION): New.
5872         (EMIT_SECTION_SYMBOLS): New.
5873         (AOUT_STABS) [OBJ_MAYBE_AOUT]: Define.
5874
5875         * config/obj-elf.h: Update GPL notice to v2.
5876         Mention that this file is included from obj-multi.h.
5877         (obj_begin): Wrap definition in ifndef.
5878         (elf_file_symbol): Constify declaration.
5879         (obj_app_file): Ditto.
5880         (SEPARATE_STAB_SECTIONS, INIT_STAB_SECTION, OBJ_PROCESS_STAB):
5881         Wrap in ifndef SEPARATE_STAB_SECTIONS.
5882
5883         * config/obj-elf.c (elf_s_set_other): New.
5884         (elf_file_symbol): Constify argument.
5885         (elf_separate_stab_sections): New.
5886         (elf_init_stab_section): New.
5887         (elf_format_ops): Add new members.  Remove comma at end.
5888
5889         * config/obj-ecoff.c (ecoff_separate_stab_sections): New.
5890         (ecoff_format_ops): Add new fields.  Remove comma at end.
5891         Mention inconsistency for emit_section_symbols.
5892
5893         * config/obj-coff.h (c_dot_file_symbol): Constify declaration.
5894
5895         * config/obj-coff.c (c_dot_file_symbol): Constify argument.
5896         (coff_separate_stab_sections): New.
5897         (coff_format_ops): Add new members.
5898
5899         * config/obj-aout.c (obj_aout_sec_sym_ok_for_reloc): New.
5900         (obj_aout_s_set_other): New.
5901         (obj_aout_s_set_desc): New.
5902         (obj_aout_s_get_type): New.
5903         (obj_aout_s_set_type): New.
5904         (obj_aout_separate_stab_sections): New.
5905         (aout_format_ops): New members added.  Use obj_aout_process_stab,
5906         not 0.  Use obj_aout_sec_sym_ok_for_reloc, not 0.
5907         (obj_aout_frob_symbol): Add ATTRIBUTE_UNUSED to args as
5908         appropriate.
5909         (obj_aout_line, obj_aout_weak, obj_aout_type): Ditto.
5910
5911 2000-05-22  Alan Modra  <alan@linuxcare.com.au>
5912
5913         * config/tc-i386.c (tc_i386_fix_adjustable): Prevent adjustment
5914         for OBJ_MAYBE_ELF too.  Use S_IS_EXTERNAL instead of S_IS_EXTERN.
5915         (md_estimate_size_before_relax): Ensure jumps to weak and
5916         externally visible symbols are relocatable.
5917
5918 Sat May 20 16:41:55 2000  Hans-Peter Nilsson  <hp@axis.com>
5919
5920         * stabs.c (aout_process_stab): Make global.
5921         (s_desc): Add ATTRIBUTE_UNUSED to args as appropriate.
5922         * read.h (aout_process_stab): Declare.
5923
5924         * configure.in (EMULATIONS) [i386aout, i386coff, i386elf]:
5925         Generalize to *aout, *coff *elf.
5926         * configure: Regenerated.
5927
5928         * doc/internals.texi (Object format backend): Say
5929         SEPARATE_STAB_SECTIONS needs to be nonzero, not just defined.
5930
5931         * Makefile.am (TARG_ENV_HFILES): Delete te-multi.h.
5932         * Makefile.in: Regenerated.
5933
5934 2000-05-19  Catherine Moore  <clm@cygnus.com>
5935
5936         * cgen.h (GAS_CGEN_MAX_FIXUPS): Check if already defined.
5937
5938 2000-05-18  Alan Modra  <alan@linuxcare.com.au>
5939
5940         * config/tc-hppa.c (md_apply_fix): Mask out immediate bits of
5941         instruction to reflect change in re_assemble_*.
5942
5943 Thu May 18 10:52:14 2000  Jeffrey A Law  (law@cygnus.com)
5944
5945         * configure.in (hppa-*-hpux11*): If the cpu is hppa*64*, then
5946         build PA64 ELF tools.
5947         * configure: Rebuilt.
5948
5949 2000-05-17  Alan Modra  <alan@linuxcare.com.au>
5950
5951         * Makefile.am: Regenerate dependencies.
5952         * Makefile.in: Regenerate.
5953
5954 2000-05-15  Nick Clifton  <nickc@cygnus.com>
5955
5956         * config/tc-arm.c (struct asm_psr): Add boolean field
5957         distinguishing between CSPR and SPSR.  Rename 'number' field
5958         to 'field'.
5959         (psrs): Rearrange contents to match new asm_psr structure.
5960         (arm_psr_parse): Move next to psr_required_here.  Make it
5961         return an asm_psr structure.
5962         (psr_required_here): Use asm_psr structure returned by
5963         arm_psr_parse.
5964         (do_msr): Reorganise to allow psr_required_here to be called
5965         only once.
5966         (md_undefined_name): Mark 'name' parameter as unused, since
5967         the COFF target does not use it.
5968
5969 2000-05-14  David O'Brien  <obrien@FreeBSD.org>
5970
5971         * config/te-386bsd.h:  Clean up comments to adhere to the GNU coding
5972         standards.
5973         * config/te-aux.h:  Likewise.
5974         * config/te-dpx2.h:  Likewise.
5975         * config/te-go32.h:  Likewise.
5976         * config/te-hp300.h:  Likewise.
5977         * config/te-hppa.h:  Likewise.
5978         * config/te-i386aix.h:  Likewise.
5979         * config/te-ic960.h:  Likewise.
5980         * config/te-interix.h:  Likewise.
5981         * config/te-nbsd532.h:  Likewise.
5982         * config/te-pc532mach.h:  Likewise.
5983         * config/te-ppcnw.h:  Likewise.
5984         * config/te-psos.h:  Likewise.
5985         * config/te-sparcaout.h:  Likewise.
5986         * config/te-sun3.h:  Likewise.
5987         * config/te-sysv32.h:  Likewise.
5988
5989 2000-05-14  Alan Modra  <alan@linuxcare.com.au>
5990
5991         * config/tc-h8300.c (do_a_fix_imm): Don't rely on `short' being 16
5992         bits.  Instead explicitly mask and sign extend.  Do the 8 bit mask
5993         and sign extend without an if statement.
5994         (build_bytes): Likewise.
5995
5996 2000-05-14  Kazu Hirata  <kazu@hxi.com>
5997
5998         * config/tc-h8300.c (do_a_fix_imm): Output a reloc for no
5999         X_add_symbol L_32 case.
6000
6001 2000-05-14  David O'Brien  <obrien@FreeBSD.org>
6002
6003         * config/te-freebsd.h: New file.
6004
6005 2000-05-13  Alan Modra  <alan@linuxcare.com.au>
6006
6007         * asintl.h (gettext, dgettext, dcgettext, textdomain,
6008         bindtextdomain): Replace defines with those from intl/libgettext.h
6009         to quieten gcc warnings.
6010
6011         * NEWS: Mention x86 .arch and -q.
6012
6013         * config/tc-i386.c (quiet_warnings): New.
6014         (md_assemble): Use quiet_warnings.
6015         (md_parse_option): Set quiet_warnings from -q.
6016         (md_show_usage): Mention -q, delete -m.
6017         (flag_do_long_jump): Delete.
6018         (md_parse_option): Remove -m.
6019         (md_show_usage): Remove -m.
6020         (md_create_long_jump): Remove useless flag_do_long_jump code.
6021
6022         * as.c (parse_args): In case OPTION_DEFSYM, use a valueT to hold
6023         the symbol value, and use bfd_scan_vma if BFD_ASSEMBLER.
6024
6025 2000-05-13  Alan Modra  <alan@linuxcare.com.au>
6026             Alexander Sokolov <robocop@netlink.ru>
6027
6028         * doc/c-i386.texi (i386-Arch): New section.
6029         (i386-Syntax): Mention .intel_syntax and .att_syntax.
6030
6031         * config/tc-i386.c (cpu_arch_name, cpu_arch_flags): New.
6032         (smallest_imm_type): Use smallest opcode for shift by one if cpu
6033         architecture has been given and is not 486.
6034         (set_cpu_arch): New.
6035         (md_pseudo_table): Add .arch.
6036         (md_assemble): Warn if cpu architecture has been given and an
6037         unsupported instruction.
6038
6039         * config/tc-i386.h (SMALLEST_DISP_TYPE): Delete.
6040         Move operand_types bit defines after relevant template field.
6041         (template): Add cpu_flags.
6042         (Cpu*): Define.
6043         (arch_entry): New.
6044
6045 2000-05-12  Alexandre Oliva  <aoliva@cygnus.com>
6046
6047         * config/tc-mn10300.h (md_end): Define.
6048         (mn10300_finalize): Declare.
6049         * config/tc-mn10300.c: Include dwarf2dbg.h.
6050         (debug_line): Define.
6051         (md_assemble): Generate dwarf2 line info.
6052         (mn10300_finalize): New function.  Finalize dwarf2 info.
6053
6054 2000-05-11  Ulf Carlsson  <ulfc@engr.sgi.com>
6055
6056         * config/tc-mips.c (md_estimate_size_before_relax): Use the
6057         external version of the relocation for weak symbols.
6058
6059 2000-05-08  David Mosberger  <davidm@hpl.hp.com>
6060
6061         * config/tc-ia64.c (output_P7_format, case mem_stack_f): Output fixed
6062         frame size in units of 16 bytes, as required per SW Conventions manual.
6063         (output_unw_records): Output info-block header as a dword to get
6064         byte-order right.
6065
6066 2000-05-08  Alan Modra  <alan@linuxcare.com.au>
6067
6068         * as.h: #include "file", not <file> on files from ../include.
6069         (as_abort, as_fatal): Add ATTRIBUTE_NORETURN.
6070         * config/tc-m68k.c (m68k_ip): Fix signed/unsigned warnings.
6071         (md_convert_frag): Add ATTRIBUTE_UNUSED.
6072         (tc_coff_symbol_emit_hook): Ditto.
6073         (OPTCOUNT): Cast to int to avoid compiler warning.
6074         (md_begin): Fix signed/unsigned warnings.
6075
6076 2000-05-08  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
6077
6078         * config/tc-m68k.c (md_convert_frag_1): Abort if we end up in the
6079         ABRANCH LONG case for a conditional branch on a 68000.
6080         (md_estimate_size_before_relax): Likewise.  Also handle
6081         flag_short_refs correctly for ABRANCH, BCC68000, and DBCC.
6082         (m68k-ip: case ABSL): Relax absolute references to 16-bit
6083         PC-relative on all CPUs.
6084         (md_estimate_size_before_relax): Likewise.
6085
6086 2000-05-04  Alan Modra  <alan@linuxcare.com.au>
6087
6088         * as.c (parse_args): Just mention current year in printed
6089         copyright message.
6090
6091 2000-05-03  J.T. Conklin  <jtc@redback.com>
6092
6093         * config/tc-ppc.c (pre_defined_registers): Add entries for vector
6094         unit registers.
6095         (md_parse_option): Recognize -m7400.
6096
6097 2000-05-03  Ian Lance Taylor  <ian@zembu.com>
6098
6099         * config/atof-ieee.c (gen_to_words): When adding carry back in,
6100         don't permit lp to become less than the words array.
6101
6102 2000-05-03  Rodney Brown  <RodneyBrown@pmsc.com>
6103
6104         config/tc-mcore.c (md_apply_fix3): BFD_RELOC_MCORE_PCREL_IMM11BY2
6105         Fix little-endian case.
6106
6107 2000-05-03  David O'Brien  <obrien@NUXI.com>
6108
6109         * as.c (parse_args): Update copyright.
6110
6111 2000-05-03  Mark Elbrecht  <snowball3@bigfoot.com>
6112
6113         * config/tc-i386.h (SUB_SEGMENT_ALIGN): If TE_GO32, return 4
6114         for the .bss section too.
6115
6116 2000-05-02  Alan Modra  <alan@linuxcare.com.au>
6117
6118         * configure.in: Set em=linux for hppa-*-linux.
6119         * configure: Regenerate.
6120         * doc/Makefile.in: Regenerate with correct automake.
6121
6122         * frags.c (frag_grow): Sanity check chunk_size.
6123
6124         * config/obj-elf.h: #include "bfd.h" not <bfd.h>
6125         * config/obj-som.h: Likewise.
6126         * config/obj-ieee.h: Likewise.
6127
6128         * config/tc-hppa.h: Test BFD_ARCH_SIZE, not BFD64.
6129
6130         * config/tc-hppa.c (log2): Only compile when OBJ_SOM.
6131         (md_pseudo_table): Fully initialise OBJ_ELF cases.
6132         (fix_new_hppa): Add ATTRIBUTE_UNUSED to args as appropriate.
6133         (pa_ip): low_sign_unext now returns via function value.  Use
6134         re_assemble_* instead of dis_assemble_* and
6135         INSERT_FIELD_AND_CONTINUE combination.  Don't call sign_unext
6136         unnecessarily.
6137         (md_convert_frag): Add ATTRIBUTE_UNUSED to args as appropriate.
6138         (md_section_align, md_parse_option, md_show_usage,
6139         md_undefined_symbol, pa_align, pa_block, pa_brtab, pa_try,
6140         pa_callinfo, pa_code, pa_comm, pa_end, pa_enter, pa_entry,
6141         pa_exit, pa_export, pa_import, pa_label, pa_leave, pa_level,
6142         pa_origin, pa_param, pa_proc, pa_procend, pa_space, pa_spnum,
6143         pa_version, pa_compiler, pa_copyright, pa_data, pa_fill, pa_lsym,
6144         pa_text): Likewise.
6145         (md_apply_fix): Change type of new_val to offsetT.  Delete w1, w2,
6146         w, resulti.  Add insn, val.  Move bfd_get_32 and bfd_put_32
6147         outside of switch.  Correct mask and shifting errors in case 10
6148         and case -11.  In case 21, compare against signed range to suit
6149         hppa_field_adjust changes.  In case 12, use re_assemble_12.  In
6150         case 17 and case 22, use offsetT variable to properly check range.
6151         Use re_assemble_* here too.
6152         (evaluate_absolute): Change type of value to offsetT.  Call
6153         hppa_field_adjust to do the work for us.
6154         (pa_parse_cmpb_64_cmpltr): Delete save_s.
6155         (pa_parse_cmpib_64_cmpltr): Ditto.
6156         (pa_build_unwind_subspace): Delete unused var subseg.  Change type
6157         of i to unsigned int.
6158         (pa_type_args): Conditionally declare symbol if OBJ_SOM.
6159         (pa_end_of_source): Return type is void.
6160
6161 Mon May  1 08:54:23 2000  Catherine Moore  <clm@cygnus.com>
6162
6163         * macro.c (macro_expand_body): Don't prepend macro number with zeroes.
6164
6165 Mon May  1 14:19:39 2000  Denis Chertykov  <denisc@overta.ru>
6166
6167         * config/tc-avr.c: ATTRIBUTE_UNUSED added to the necessary places.
6168         More comments added.
6169         (md_begin): Removed "construct symbols for each register name".
6170         Because register names conflicts with GCC generated function
6171         names.
6172         (avr_operand): Now constant numbers can be used as a register
6173         identifiers (0 as r0, 31 as r31).
6174         (md_assemble): use skip_space () before parsing instruction
6175         operands.
6176
6177 2000-05-01  Alan Modra  <alan@linuxcare.com.au>
6178
6179         * configure.in: Set bfd_gas=yes on i386-*-pe and i386-*-nt* to
6180         ensure all pe targets use bfd.  Remove unnecessary bfd_gas=yes on
6181         arm-*-netbsd* and arm-*-wince as this is set for all arm*.
6182         * configure: Regenerate.
6183
6184 2000-04-29  Andreas Jaeger  <aj@suse.de>
6185
6186         * as.h: Correctly check GCC version.
6187
6188 2000-04-26  David O'Brien  <obrien@FreeBSD.org>
6189
6190         * doc/as.1: Fix unbalanced brackets.
6191
6192         * config/tc-i386.c (comment_chars): Don't use '/' as comment start if
6193         TE_FreeBSD.
6194         (line_comment_chars): Set to '/' if TE_FreeBSD.
6195
6196 Tue Apr 25 11:02:02 2000  Jeffrey A Law  (law@cygnus.com)
6197
6198         * configure.in: Configury support for PA64 (currently disabled).
6199         * configure: Rebuilt.
6200
6201 2000-04-25  Machida Hiroyuki  <machida@sm.sony.co.jp>
6202
6203         * config/tc-mips.c (s_change_sec): Use record_alignment, not
6204         bfd_set_section_alignment.
6205
6206 2000-04-25  Alan Modra  <alan@linuxcare.com.au>
6207
6208         * config/tc-i386.c (offset_in_range): Ensure shift counts are less
6209         than 32.
6210
6211 2000-04-24  Nick Clifton  <nickc@cygnus.com>
6212
6213         * doc/c-arm.texi (ARM Directives): Document behaviour of .align 0.
6214         * doc/as.texinfo (Align): Include arm and strongarm in list of
6215         targets that have the second form of the behaviour of the .align
6216         directive.
6217
6218 2000-04-24  Mark Klein <mklein@dis.com>
6219
6220         * config/obj-som.c: Terminate obj_pseudo_table.
6221
6222 Mon Apr 24 15:21:11 2000  Clinton Popetz  <cpopetz@cygnus.com>
6223
6224         * as.c (parse_args): Allow md_parse_option to override -a listing
6225         option.
6226         * config/obj-coff.c (add_lineno): Change type of offset parameter
6227         from "int" to "bfd_vma."
6228         * config/tc-ppc.c (md_pseudo_table): Add "llong" and "machine."
6229         (ppc_mach, ppc_subseg_align, ppc_target_format): New.
6230         (ppc_change_csect): Align correctly for XCOFF64.
6231         (ppc_machine): New function, which discards "ppc_machine" line.
6232         (ppc_tc): Cons for 8 when code is 64 bit.
6233         (md_apply_fix3): Don't check operand->insert.  Handle 64 bit
6234         relocations.
6235         (md_parse_option): Handle -a64 and -a32.
6236         (ppc_xcoff64): New.
6237         * config/tc-ppc.h (TARGET_MACH): Define.
6238         (TARGET_FORMAT): Move to function.
6239         (SUB_SEGMENT_ALIGN): Use ppc_subseg_align.
6240
6241 Sun Apr 23 16:45:45 2000  Denis Chertykov  <denisc@overta.ru>
6242
6243         * config/tc-avr.c: New AVR_ISA_ defined.
6244         (md_assemble): Handle opcodes with optional operands (lpm,elpm).
6245         (avr_operand): Handle 'a', 'v' and 'z' constraint letters needed
6246         for `fmul', `movw' and `lpm R,Z' instructions.
6247         (avr_operands): Warn if current opcode is a two-word instruction
6248         and previous opcode was cpse/sbic/sbis/sbrc/sbrs.
6249         (avr_opcodes): New commands added.
6250         (REGISTER_P): Check 'a' and 'v' constraint letters.
6251         (mcu_types): New MCU added.
6252
6253 2000-04-22  Timothy Wall  <twall@cygnus.com>
6254
6255         * config/tc-ia64.c (pseudo_func[]): Add new "nat" entry equivalent
6256         to "natval".
6257         (operand_match): Conditionally insert default bit values for IMMU9.
6258
6259 2000-04-14  Matthew Green  <mrg@cygnus.com>
6260
6261         * configure.in: Add NetBSD/sparc ELF and NetBSD/sparc64 support.
6262         * configure: Rebuilt.
6263
6264 Fri Apr 21 14:29:43 2000  Jeffrey A Law  (law@cygnus.com)
6265                           Jason Eckhardt  <jle@cygnus.com>
6266
6267         * config/tc-hppa.c (md_apply_fix): Handle new PA2.0 formats.
6268
6269         * config/tc-hppa.c (CHECK_ALIGN): New macro.
6270         Added handling of new operand types l,y,&,fe,fE,fx.
6271
6272 Fri Apr 21 13:20:53 2000  Richard Henderson  <rth@cygnus.com>
6273                           David Mosberger  <davidm@hpl.hp.com>
6274                           Timothy Wall <twall@cygnus.com>
6275                           Andrew MacLeod  <amacleod@cygnus.com>
6276                           Jim Wilson  <wilson@cygnus.com>
6277
6278         * Makefile.am (CPU_TYPES): Add ia64.
6279         (TARGET_CPU_CFILES): Add config/tc-ia64.c.
6280         (TARGET_CPU_HFILES): Add config/tc-ia64.h.
6281         * Makefile.in: Rebuild.
6282         * app.c (do_scrub_chars): Handle DOUBLESLASH_COMMENTS.
6283         * configure: Rebuild.
6284         * configure.in: Recognize ia64 as cpu type.  Set bfd_gas.
6285         (ia64-*-elf*, ia64-*-linux-gnu*): New targets.
6286         * expr.c (expr): Handle md_optimize_expr.
6287         * read.c (LEX_HASH): Add comment.
6288         * config/tc-ia64.c, config/tc-ia64.h: New files.
6289
6290 2000-04-21  Richard Henderson  <rth@cygnus.com>
6291
6292         * config/tc-d30v.c (write_2_short): Disregard opcode1->ecc when
6293         bundling a non-delayed branch type instruction.
6294
6295 2000-04-20  Alexandre Oliva  <aoliva@cygnus.com>
6296
6297         * config/tc-mn10300.c (HAVE_AM30): Define.
6298         (md_assemble): Use it.
6299
6300 2000-04-19  Alan Modra  <alan@linuxcare.com.au>
6301
6302         * config/obj-elf.c (obj_elf_change_section): Check for changed
6303         section attributes.
6304
6305         * Makefile.am: (CPU_MULTI_VALID): Remove.
6306         (MULTI_CPU_TYPES): Define.
6307         (MULTI_CPU_OBJ_VALID): Define.
6308         (DEPTC): Use the above.
6309         (DEPOBJ): Same here.
6310         (DEP2): And here.
6311         Regenerate dependencies.
6312         * Makefile.in: Regenerate.
6313
6314 2000-04-19  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
6315
6316         * Makefile.am (YACC, LEX): Get them from configure.
6317
6318 2000-04-18  H.J. Lu  (hjl@gnu.org)
6319
6320         * config/tc-i386.c (offset_in_range): Use addressT instead of
6321         bfd_vma for non-bfd assemblers.
6322
6323 2000-04-17  Alan Modra  <alan@linuxcare.com.au>
6324
6325         * config/tc-i386.c (offset_in_range): Sign extend val so BFD64
6326         doesn't give spurious errors.
6327
6328 2000-04-14  Michael Sokolov  <msokolov@ivan.Harhan.ORG>
6329
6330         * as.h (SEEK_SET): Define if undefined.
6331
6332 2000-04-13  Alan Modra  <alan@linuxcare.com.au>
6333
6334         * config/tc-arm.c (md_apply_fix3): Don't use UL suffix on
6335         constants, and don't assume offsetT is 32 bits.
6336
6337 2000-04-12  Andrew Cagney  <cagney@b1.cygnus.com>
6338
6339         * config/tc-d10v.h: Include "write.h" to get definition of fixS.
6340         (md_pcrel_from_section): Add prototype.
6341         (d10v_fix_adjustable): Add prototype.
6342         (d10v_force_relocation): Replace 'struct fix' with 'fixS'.
6343
6344         * config/tc-d10v.c (md_apply_fix3): Add paren around &&.
6345
6346 2000-04-12  Nick Clifton  <nickc@cygnus.com>
6347
6348         * config/tc-d10v.c (find_opcode): Correctly calculate position of
6349         symbol in frag chain.
6350
6351 2000-04-10  Alan Modra  <alan@linuxcare.com.au>
6352
6353         * config/tc-i386.c (fits_in_signed_byte): Change arg to offsetT.
6354         (fits_in_unsigned_byte, fits_in_unsigned_word): Ditto.
6355         (fits_in_signed_word, smallest_imm_type): Ditto.
6356         (md_assemble): Use an offsetT var to hold offsetT values, not a
6357         long.
6358         (offset_in_range): New.
6359         (md_assemble): Use it.
6360         (md_convert_frag): Change type of target_address, opcode_address,
6361         and displacement_from_opcode_start to offsetT.
6362         (md_create_short_jump): Change type of offset to offsetT.
6363         (md_create_long_jump): Ditto.
6364         (md_apply_fix3): Use -4, not 0xfffffffc for BFD_RELOC_386_PLT32.
6365         (md_chars_to_number): Remove.
6366         (output_invalid): Remove duplicate prototype.
6367
6368 2000-04-09  Nick Clifton  <nickc@cygnus.com>
6369
6370         * Makefile.am (CPU_TYPES): Add 'avr'.
6371         (TARGET_CPU_CFILES): Add 'tc-avr.c'.
6372         (TARGET_CPU_HFILES): Add 'tc-avr.h'.
6373
6374         * Makefile.in: Regenerate.
6375
6376         * doc/as.texinfo: Add M32R documentation.
6377
6378 Fri Apr  7 15:56:57 2000  Andrew Cagney  <cagney@b1.cygnus.com>
6379
6380         * configure.in (WARN_CFLAGS): Set to -W -Wall by default.  Add
6381         --enable-build-warnings option.
6382         * Makefile.am (AM_CFLAGS, WARN_CFLAGS): Add definitions.
6383         * Makefile.in, configure: Re-generate.
6384
6385 2000-04-07  Nick Clifton  <nickc@cygnus.com>
6386
6387         * config/tc-arm.c (md_apply_fix3): Treat BFD_RELOC_ARM_PCREL_BLX
6388         in the same way as BFD_RELOC_ARM_PCREL_BRANCH, and
6389         BFD_RELOC_THUMB_PCREL_BLX lie BFD_RELOC_THUMB_PCREL_BRANCH.
6390         (tc_gen_reloc): Accept BFD_RELOC_{ARM|THUMB}_PCREL_BLX.
6391         (arm_force_relocation): Force relocations for
6392         BFD_RELOC_{ARM|THUMB}_PCREL_BLX as well.
6393
6394 Wed Apr  5 22:26:32 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
6395
6396         * config/tc-sh.c (get_operands): There's no third operand if the
6397         first operand is an immediate.
6398
6399 Wed Apr  5 22:07:19 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
6400
6401         * config/tc-sh.c (immediate): Delete.
6402         (sh_operand_info): Add immediate member.
6403         (parse_reg): Use A_PC for pc.
6404         (parse_exp): Add second argument 'op'.  All callers changed.
6405         (parse_at): Expect pc to be coded as A_PC.
6406         Use immediate field in *op.
6407         (insert): Add fourth argument 'op'.  All callers changed.
6408         (build_relax): Add second argument 'op'.  All callers changed.
6409         (insert_loop_bounds): New function.
6410         (build_Mytes): Remove DISP_4.
6411         Split IMM_[48]{,BY[24]} into IMM[01]_[48]{,BY[24]}.  Add REPEAT.
6412         (assemble_ppi): Use immediate field in *operand.
6413         (sh_force_relocation): Handle BFD_RELOC_SH_LOOP_{START,END}.
6414         (md_apply_fix): Likewise.
6415         (tc_gen_reloc): Likewise.  Check for a pcrel BFD_RELOC_SH_LABEL.
6416
6417 Wed Apr  5 06:35:45 2000  Alexandre Oliva  <oliva@lsd.ic.unicamp.br>
6418
6419         * config/tc-sparc.c (sparc_ip): Avoid string pasting.
6420
6421 Tue Apr  4 19:27:50 2000  Hans-Peter Nilsson  <hp@axis.com>
6422
6423         * internals.texi (CPU backend): Document
6424         TC_CHECK_ADJUSTED_BROKEN_DOT_WORD.
6425
6426 2000-04-04  Alan Modra  <alan@linuxcare.com.au>
6427
6428         * po/gas.pot: Regenerate.
6429
6430         * as.c (show_usage): Restore translated part of bug string.
6431         * gasp.c (show_usage): Likewise.
6432
6433         * Makefile.am (MKDEP): Use gcc -MM rather than ../mkdep.
6434         (DEP): Quote when passing vars to sub-make.  Use "mv -f" rather
6435         than move-if-change.
6436         (DEP1): Modify for "gcc -MM".
6437         (DEPTC): Likewise.
6438         (DEPOBJ): Likewise.
6439         (DEP2): Likewise.
6440         (CLEANFILES): Add DEPTCA, DEPOBJA, DEP2a, DEPA.
6441         Update dependencies.
6442         * Makefile.in: Regenerate.
6443
6444 2000-04-03  Alexandre Oliva  <aoliva@cygnus.com>
6445
6446         * config/tc-mn10300.c (md_pseudo_table): Use constant names.
6447         (md_begin): Likewise.
6448         (HAVE_AM33): New macro.
6449         (md_assemble): Use it.  Match r_regs and xr_regs only if
6450         HAVE_AM33.
6451
6452 2000-04-03  Alan Modra  <alan@linuxcare.com.au>
6453
6454         * as.h: #include "bin-bugs.h"
6455         * as.c (show_usage): Use REPORT_BUGS_TO.
6456         * gasp.c: #include "bin-bugs.h"
6457         (show_usage): Use REPORT_BUGS_TO.
6458
6459         * config/tc-sparc.c (md_show_usage): Add a trailing newline.
6460
6461 Mon Apr  3 13:56:03 2000  Hans-Peter Nilsson  <hp@axis.com>
6462
6463         * write.c (write_object_file) [! WORKING_DOT_WORD]: If defined,
6464         call TC_CHECK_ADJUSTED_BROKEN_DOT_WORD for each word after
6465         adjustments.
6466
6467 2000-04-03  Alan Modra  <alan@linuxcare.com.au>
6468
6469         * config/tc-i386.c (i386_immediate): Don't assume a constant
6470         immediate is necessarily 16 bits when in 16 bit code mode.
6471         (md_assemble): Instead set guess_suffix here after we have checked
6472         registers.
6473
6474 2000-04-02  Richard Henderson  <rth@cygnus.com>
6475
6476         * config/tc-d30v.c (check_range): Allow signed or unsigned 32-bit
6477         quantities.  Correct right shift sign extension.
6478         (build_insn): Make `number' unsigned long.  Mask top 6 bits of
6479         32-bit value when shifting into place.
6480
6481 2000-04-01  Ian Lance Taylor  <ian@zembu.com>
6482
6483         * app.c: Add ATTRIBUTE_UNUSED as needed.
6484         * config/tc-ppc.c: Likewise.
6485         (ppc_size): Make unsigned long.
6486         (ppc_insert_operand): Add casts to avoid warnings.
6487
6488 2000-03-31  Nick Clifton  <nickc@cygnus.com>
6489
6490         * config/tc-d10v.h (md_flush_pending_output): Define.
6491
6492 2000-03-29  Nick Clifton  <nickc@cygnus.com>
6493
6494         * config/tc-sh.h (SEG_NAME): New macro: return the name of a
6495         segment.  Works for both BFD_ASSEMBLER and others.
6496         (SUB_SEGMENT_ALIGN): Use SEG_NAME.
6497
6498 2000-03-29  Nick Clifton <nickc@cygnus.com
6499
6500         * config/tc-arm.c (tinsns): Add "bal" instruction pattern.
6501
6502 2000-03-28  Alan Modra  <alan@linuxcare.com.au>
6503
6504         * listing.c (LISTING_LHS_WIDTH): Default depends on
6505         LISTING_WORD_SIZE.
6506         (LISTING_LHS_WIDTH_SECOND): Default to LISTING_LHS_WIDTH.
6507
6508 2000-03-27  Ian Lance Taylor  <ian@zembu.com>
6509
6510         * config/tc-sh.c (md_show_usage): Use backslash before newline in
6511         string literal.
6512
6513 2000-03-27  Alan Modra  <alan@linuxcare.com.au>
6514
6515         * config/tc-avr.h (TC_HANDLES_FX_DONE): Define.
6516
6517         * config/tc-avr.c (mcu_types): Add missing initialiser.
6518         (md_pcrel_from_section): Add prototype.
6519         (avr_operand): Remove redundant test of unsigned < 0.
6520         (avr_cons_fix_new): Ensure exp_mod_pm zero on function exit.
6521
6522 2000-03-27  Denis Chertykov  <denisc@overta.ru>
6523
6524         * config/tc-avr.c: New file for AVR support.
6525         * config/tc-avr.h: Likewise.
6526         * configure.in: Add AVR support.
6527         * configure: Regenerate.
6528
6529 2000-03-26  Timothy Wall <twall@cygnus.com>
6530
6531         * gasp.c (macro_op): Add new argument to check_macro call.
6532         Macro structure definitions moved to macro.h
6533         * sb.h:  Add argument to prototype for input_scrub_include_sb.
6534         * input-scrub.c (input_scrub_include_sb): Allow disabling of sb
6535         nesting checks with an additional flag.
6536         (struct input_save): Add flag to indicate whether current sb
6537         should be checked for proper macro/conditional nesting.
6538         (input_scrub_push/pop): Save/restore nest check flag.
6539         (input_scrub_next_buffer): Ditto.  Also call end of macro hook if
6540         defined.
6541         * macro.c (check_macro):  Allow caller to retrieve parsed macro
6542         information if a pointer is provided.  This information may be
6543         used by the new macro hooks.
6544         * macro.h: Update prototype for check_macro.  Macro struct
6545         definitions moved here from macro.c/gasp.c.
6546         * read.c (read_a_source_file): Add parameter to check_macro call,
6547         and pass macro info to the macro hook, if defined.
6548         (input_scrub_insert_line): New.  Allow insertion of a line of
6549         characters into the input stream.
6550         (input_scrub_insert_file): New.  Allow insertion of an arbitrary
6551         file into the input stream.
6552         (s_include): Use input_scrub_insert_file.
6553         * internals.texi: Document new macro hooks.
6554         * as.h: New prototypes added.
6555
6556 2000-03-26  Alan Modra  <alan@linuxcare.com.au>
6557
6558         * config/tc-i386.c: Don't start any as_bad or as_warn message with
6559         an initial capital letter.
6560         (i386_index_check): Reindent.
6561
6562 2000-03-19  Nick Clifton  <nickc@cygnus.com>
6563
6564         * config/tc-arm.c (md_apply_fix3): Fix bug detecting overflow of pc
6565         relative branches.
6566
6567 2000-03-17 Thomas de Lellis <tdel@windriver.com>
6568
6569         * config/tc-arm.c (do_t_adr): Flag "adr Rd,label"
6570         instruction operand bad if Rd > 7 when generating
6571         thumb instructions. Prevents for example,
6572         "adr r12,label" from silently failing and generating
6573         the wrong instruction.
6574
6575 2000-03-17  Nick Clifton  <nickc@cygnus.com>
6576
6577         * config/tc-arm.c (md_apply_fix3): Handle same-section relocations
6578         that have a destingation >= 0x400000.
6579         Fix compile time warning messages.
6580
6581 Thu Mar 16 23:45:16 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
6582
6583         * config/tc-sh.c (md_begin): When encountering insn that are
6584         not supported by the current arch, only change the name if
6585         its contents are the same as prev_name.
6586         (get_specific): If the the architecture doesn't match, fail.
6587
6588 Thu Mar 16 21:18:13 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
6589
6590         * config/tc-sh.c (IDENT_CHAR): Define.
6591         (parse_reg): Use it instead of isalnum.  Put r[0..7]_bank operand
6592         matching back where it came from.
6593
6594 Thu Mar 16 20:58:10 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
6595
6596         * config/tc-sh.c (md_show_usage): Add description of -dsp.
6597
6598 2000-03-15  Jonathan Larmour  <jlarmour@redhat.co.uk>
6599
6600         * config/tc-sh.c (parse_reg): Match r[0..7]_bank operands before
6601         normal operands.
6602
6603 2000-03-15  Kazu Hirata  <kazu@hxi.com>
6604
6605         * config/tc-h8300.c: Add ATTRIBUTE_UNUSED as appropriate.
6606
6607 Mon Mar 13 22:02:59 2000  Hans-Peter Nilsson  <hp@axis.se>
6608
6609         * expr.c (operand) [case 'f']: When testing if '0f' can start a
6610         floating-point-number, make sure 'f' is in FLT_CHARS.
6611
6612 Sat Mar 11 00:01:39 2000  Hans-Peter Nilsson  <hp@axis.se>
6613
6614         * read.c (TC_IMPLICIT_LCOMM_ALIGNMENT): New default-definition.
6615         (s_lcomm_internal): Use it.
6616         * doc/internals.texi (CPU backend): Document it.
6617         * config/obj-evax.h (TC_IMPLICIT_LCOMM_ALIGNMENT): Set to 2**3
6618         bytes.
6619
6620 2000-03-10  Geoffrey Keating  <geoffk@cygnus.com>
6621
6622         * config/tc-mips.c (mips_ip): Don't put stuff in .rodata
6623         when embedded-pic.
6624
6625         * config/tc-mips.c (SWITCH_TABLE): The ELF embedded-pic
6626         implementation doesn't have special handling for switch
6627         statements.
6628         (macro_build): Allow for code in sections other than .text.
6629         (macro): Likewise.
6630         (mips_ip): Likewise.
6631         (md_apply_fix): Do pc-relative relocation madness for MIPS ELF.
6632         Don't perform relocs if we will be outputting them.
6633         (tc_gen_reloc): For ELF, just use fx_addnumber for pc-relative
6634         relocations.  Allow BFD_RELOC_16_PCREL_S2 relocs when
6635         embedded-pic.
6636
6637 2000-03-09  Catherine Moore  <clm@cygnus.com>
6638
6639         * config/tc-m32r.c (m32r_fix_adjustable):  Look up the
6640         relocation type based on the entry in the fixup structure.
6641         Put S_IS_EXTERN processing back in.
6642
6643 2000-03-08  H.J. Lu  (hjl@gnu.org)
6644
6645         * Makefile.am (install-exec-tooldir): Depend on
6646         install-exec-bindir for parallel make.
6647         * Makefile.in: Regenerated.
6648
6649 2000-03-06  Nick Clifton  <nickc@cygnus.com>
6650
6651         * config/tc-m32r.c (struct md_longopts): Add -m32r command line
6652         switch.
6653         (md_parse_option): Parse -m32r command line switch - disable m32rx
6654         compatability.
6655         (md_show_usage): Document new option.
6656
6657         * doc/Makefile.am (CPU_DOCS): Add c-m32r.texi.
6658         * doc/Makefile.in: Regenerate.
6659         * doc/c-m32r.texi (M32R-Opts): Document new command line switch.
6660
6661 2000-03-02  Michael Meissner  <meissner@redhat.com>
6662
6663         * config/tc-d30v.c (check_range): Remove code that incorrectly
6664         sign extended values where bits < 32.
6665
6666 2000-03-02  H.J. Lu  (hjl@gnu.org)
6667
6668         * configure.in: Support --enable-targets=all on ia32.
6669         * configure: Regenerated.
6670
6671 2000-03-01  Nick Clifton  <nickc@cygnus.com>
6672
6673         * gasp.c (do_align): Remove bogus check of alignment value.
6674
6675 2000-02-27  Thomas de Lellis  <tdel@windriver.com>
6676
6677         * config/obj-elf.c (elf_frob_symbol): Remove code which when
6678         TC_PPC was defined forced the type of a symbol with no other type
6679         to be BSF_OBJECT.
6680
6681 2000-02-27  Hans-Peter Nilsson  <hp@axis.com>
6682
6683         * doc/internals.texi (CPU backend): Mention that
6684         line_separator_chars do not break up comments.  Fix typos for
6685         LEX_AT and LEX_NAME descriptions.  Document operands for
6686         TC_EQUAL_IN_INSN, md_operand and md_section_align.  Correct
6687         description of md_create_short_jump usage.  Document argument for
6688         md_undefined_symbol.
6689
6690 2000-02-27  Jakub Jelinek  <jakub@redhat.com>
6691
6692         * config/tc-sparc.c (OPTION_UNDECLARED_REGS): New option.
6693         (md_parse_option): Handle it.
6694         (md_show_usage): Document it.
6695
6696 2000-02-27  Ian Lance Taylor  <ian@zembu.com>
6697
6698         * config/tc-alpha.c (md_assemble): Accept `1' and `9' in an
6699         opcode, for the instruction `pal19'.  From Andrea Arcangeli
6700         <andrea@suse.de>.
6701
6702 2000-02-26  Alan Modra  <alan@spri.levels.unisa.edu.au>
6703
6704         * config/tc-i386.c (i386_immediate): Move constant operand sizing
6705         from here..
6706         (md_assemble): To here, before template operands are matched.
6707         Also ensure a constant immediate is sign extended when we know the
6708         size is at most 16 bits.  This is to catch cases like "add
6709         $0xffc0,%ax" where we don't know the size, and thus that the
6710         immediate can be represented as Imm8S until after parsing the
6711         register operand.
6712         (i386_displacement): Similarly sign extend 16 bit constant
6713         displacements.
6714         (md_assemble): Relax 16-bit jump constant range check to suit sign
6715         extended displacements.
6716
6717 2000-02-26  Andreas Jaeger  <aj@suse.de>
6718
6719         * doc/c-mips.texi (MIPS Opts): Fix typo in last patch.
6720
6721 2000-02-25  Alan Modra  <alan@spri.levels.unisa.edu.au>
6722
6723         * config/tc-i386.c (md_assemble): Don't swap intersegment jmp and
6724         call operands when intel_syntax.
6725         (intel_float_operand): Return 2 for "fi...".
6726         (i386_operand_modifier): Change "DWORD PTR" test to suit above.
6727         Return SHORT_MNEM_SUFFIX for "WORD PTR" when "fi...".  Revert
6728         earlier "SHORT" change.
6729         (md_assemble): When determining suffix from Regs, exclude
6730         InOutPortReg.
6731
6732 2000-02-24  Nick Clifton  <nickc@cygnus.com>
6733
6734         * configure: Add arm-wince, mips-pe and sh-pe targets.
6735         * configure: Regenerate.
6736
6737         * config/obj-coff.h (COFF_WITH_PE): Define for mips-pe and
6738         sh-pe targets.
6739         (TARGET_FORMAT): Set to "pe-shl" for the sh-pe target and to
6740         "pe-mips" for the mips-pe target.
6741
6742         * config/tc-arm.c (insns): Change displacement encoded in BL
6743         and B instructions if the target port is arm-wince.
6744         (do_ldst): Do not bias the relocation offset if the target
6745         port is arm-wince.
6746         (md_pcrel_from): Add in missing relocation offset bias if the
6747         target os arm-wince.
6748
6749         * config/tc-mips.c (mips_target_format): Support COFF flavour.
6750         (md_begin): Disable -G support for mips-pe target.
6751         (md_apply_fix): Treat BFD_RELOC_RVA reloc as BFD_RELOC_32.
6752         * config/tc-mips.h (USE_GLOBAL_POINTER_OPT): Add support for
6753         COFF flavour.
6754
6755         * config/tc-sh.c (md_begin): sh-pe target is little endian.
6756         * config/tc-sh.h (SUB_SEGMENT_ALIGN): If using a BFD
6757         assembler, just set the alignment to 4.
6758
6759         * config/te-wince-pe.h: New file for WinCE targets.  Define
6760         TE_WINCE.
6761
6762 2000-02-25  Alan Modra  <alan@spri.levels.unisa.edu.au>
6763
6764         * config/tc-i386.c (md_assemble): Swap segments too for intel mode
6765         string instructions.
6766         (i386_operand_modifier): Set i.suffix = WORD_MNEM_SUFFIX for SHORT.
6767         (i386_intel_memory_operand): After finding a segment override,
6768         check again for no `[' before looking for a displacement.  Bomb if
6769         more than one displacement rather than silently discarding the
6770         second and subsequent ones.  Free strings malloc'd by
6771         build_displacement_string.
6772
6773 2000-02-24  Catherine Moore  <clm@cygnus.com>
6774
6775         * config/obj-som.c (obj_pseudo_table): Add "weak".
6776         (obj_som_weak): New routine.
6777
6778 2000-02-24  Alan Modra  <alan@spri.levels.unisa.edu.au>
6779
6780         * config/tc-i386.c (union i386_op): New.
6781         (struct _i386_insn): Delete disps[], imms[], regs[].  Add op[].
6782         Throughout file replace occurences of disps[n], imms[n], regs[n]
6783         with equivalent op[n].disps, op[n].imms, op[n].regs.  Simplify
6784         intel mode operand swapping.  Add assert in regKludge and
6785         fake_zero_displacement code.  Test i.types[n] when outputting
6786         displacements and immediates.  Combine output of Disp16 with
6787         Disp32.
6788         (md_assemble): Don't try to fix broken UNIXWARE_COMPAT opcodes
6789         when in intel mode by (not) reversing fsub and fdiv operands
6790         before the template search.  This fails for single operand
6791         shorthand forms of the instruction, and if UNIXWARE_COMPAT is
6792         undefined.  Instead fix the base_opcode after we've found the
6793         template.  Move base_opcode xor with found_reverse_match from
6794         opcode output code to before this fix so we test for the correct
6795         opcodes.
6796         (md_assemble): Don't use strcmp when deciding to ignore the suffix
6797         check in intel mode.  Instead compare opcodes.
6798
6799         * config/tc-i386.h (TC_RELOC): Delete.
6800         * config/tc-i386.c (TC_RELOC): Delete.  Replace usage of TC_RELOC
6801         with equivalent call to reloc.
6802
6803         * as.h (flag_m68k_mri): Move declaration after target include, and
6804         only declare when TC_M68K defined.  Define as zero otherwise.
6805         (LABELS_WITHOUT_COLONS, NO_PSEUDO_DOT): If undefined, define as 0.
6806         * app.c (scrub_m68k_mri): Declare only when TC_M68K defined.
6807         Define as zero otherwise.
6808         (do_scrub_begin): Use m68k_mri parameter only when TC_M68K defined.
6809         (struct app_save): Declare scrub_m68k_mri only when TC_M68K.
6810         (app_push, app_pop): Save scrub_m68k_mri only when TC_M68K.
6811         (do_scrub_chars): Use LABELS_WITHOUT_COLONS directly rather than
6812         testing whether defined.
6813         * cond.c (ignore_input): Use NO_PSEUDO_DOT directly.
6814         * expr.c (operand): #ifdef unused case labels when TC_M68K undefined.
6815         * read.c: Use LABELS_WITHOUT_COLONS and NO_PSEUDO_DOT directly
6816         rather than testing whether defined.
6817         (s_mri): Set flag_m68k_mri only when TC_M68K defined.
6818         (parse_mri_cons): Declare and use only when TC_M68K.
6819         * config/tc-hppa.h (LABELS_WITHOUT_COLONS): Define as 1.
6820         * config/tc-m68k.h (NO_PSEUDO_DOT): Define as 1.
6821         * config/tc-m88k.h (NO_PSEUDO_DOT): Define as 1.
6822
6823         * NEWS: Mention IBM 370 support.
6824
6825 2000-02-23  Richard Henderson  <rth@cygnus.com>
6826
6827         * config/tc-i386.c (md_assemble): When swapping operands for
6828         intel_syntax, assume everything that's not Imm or Disp is a
6829         register.
6830
6831 2000-02-23  Linas Vepstas <linas@linas.org>
6832
6833         * config/tc-i370.c, config/tc-i370.h: New files.
6834         * Makefile.am: Add support for Linux/IBM 370.
6835         * configure.in: Likewise.
6836         * app.c (do_scrub_begin): Don't lex single quote when TC_I370.
6837         * config/obj-elf.c: Include elf/i370.h
6838         (obj_elf_section): Don't do anything special for flag_mri if TC_I370.
6839
6840         * Makefile.in: Regenerate.
6841         * configure: Regenerate.
6842
6843         * doc/c-i370.texi: New file.
6844         * doc/all.texi: Include it.
6845         * doc/as.texinfo: And here.
6846         * doc/Makefile.am(CPU_DOCS): Add c-i370.texi.
6847         * doc/Makefile.in: Regenerate.
6848
6849 2000-02-19  Michael Meissner  <meissner@redhat.com>
6850
6851         * config/tc-d30v.c (parallel_ok): Use FLAG_NOT_WITH_ADDSUBppp to
6852         determine if an instruction can be used in parallel with an ADDppp
6853         or SUBppp instruction.
6854
6855 2000-02-22  Andrew Haley  <aph@cygnus.com>
6856
6857         * doc/c-mips.texi (MIPS Opts): Document -mgp32 and -mgp64.
6858
6859 2000-02-22  Andrew Haley  <aph@cygnus.com>
6860
6861         * config/tc-mips.c (mips_gp32): New variable.
6862         (macro_build) Use mips_gp32.
6863         (mips_ip): Ditto.
6864         (md_longopts): Add "-mgp32" and "-mgp64".
6865         (md_parse_option): Add OPTION_GP32 and OPTION_GP64.
6866
6867         (OPTION_M7900): Change offset
6868         (OPTION_NO_M7900): Ditto.
6869
6870 2000-02-22  Alexandre Oliva  <oliva@lsd.ic.unicamp.br>
6871
6872         * config/obj-coff.c (add_lineno): Accept non-positive lineno with
6873         warning, and bump it to 1.
6874
6875 2000-02-22  Ian Lance Taylor  <ian@zembu.com>
6876
6877         From Brad Lucier <lucier@math.purdue.edu>:
6878         * dwarf2dbg.c (print_stats): Add cast to force printf argument to
6879         match format.
6880
6881 2000-02-21  Catherine Moore  <clm@cygnus.com>
6882
6883         * config/tc-mips.c (MF_HILO_INSN): Define.
6884         (mips_7000_hilo_fix): Declare.
6885         (append_insn): Conditionally insert nops after an mfhi/mflo insn.
6886         (md_parse_option): Check for 7000_HILO_FIX options.
6887         (OPTION_M7000_HILO_FIX): Define.
6888         (OPTION_NO_M7000_HILO_FIX): Define.
6889         * doc/c-mips.texi (-mfix7000): Describe.
6890
6891 2000-02-21  Alan Modra  <alan@spri.levels.unisa.edu.au>
6892
6893         * listing.c (print_lines): Remove unused variable `end'.
6894
6895         * config/tc-i386.c (md_assemble): Use `reloc()' to select reloc
6896         type for JumpInterSegment output. Use enum bfd_reloc_code_real for
6897         reloc_type when BFD_ASSEMBLER.
6898         (md_estimate_size_before_relax): Use enum bfd_reloc_code_real for
6899         reloc_type when BFD_ASSEMBLER. Move common code out of switch
6900         statement and quell signed vs. unsigned comparison warning.
6901
6902 2000-02-18  Nick Clifton  <nickc@cygnus.com>
6903
6904         * config/tc-d10v.c (find_opcode): Add a symbol's value to
6905         the computed frag offset, rather than overwriting it.
6906
6907 Thu Feb 17 00:11:08 2000  J"orn Rennecke <amylaar@cygnus.co.uk>
6908
6909         * config/tc-sh.c ("elf/sh.h"): Include.
6910         (sh_dsp, valid_arch, reg_x, reg_y, reg_efg): New static variables.
6911         (md.begin): Initialize target_arch.
6912         Only include opcodes in has table that match selected architecture.
6913         (parse_reg): Recognize register names for sh-dsp.
6914         (parse_at): Recognize post-modify addressing.
6915         (get_operands): The leading space is now optional.
6916         (get_specific): Remove FDREG_N support.  Add support for sh-dsp
6917         arguments.  Update valid_arch.
6918         (build_Mytes): Add support for SDT_REG_N.
6919         (find_cooked_opcode): New function, broken out of md_assemble.
6920         (assemble_ppi, sh_elf_final_processing): New functions.
6921         (md_assemble): Use find_cooked_opcode and assemble_ppi.
6922         (md_longopts, md_parse_option): New option: -dsp.
6923         * config/tc-sh.h (elf_tc_final_processing): Define.
6924         (sh_elf_final_processing): Declare.
6925
6926 Fri Feb 11 14:21:51 2000  Jeffrey A Law  (law@cygnus.com)
6927
6928         * config/tc-hppa.c (pa_build_unwind_subspace): Use subseg_new to create
6929         the unwinder subspace.  Save the current seg/subseg before creating
6930         the new seg/subseg.
6931
6932 2000-02-10  Nick Clifton  <nickc@cygnus.com>
6933
6934         * config/tc-mcore.c (INST_BYTE0): Redefine to handle big and
6935         little endian targets.
6936         (INST_BYTE1): Redefine to handle big and little endian
6937         targets.
6938         (cpu_type): New type: Select between M340 and M210.
6939         (parse_psrmod): New function: Parse the PSRCLR and PSRSET
6940         instructions of the M340.
6941         (md_assemble): Add support for the MULSH and OPSR classes of
6942         instructions.
6943         (md_atof): Add support for little endian targets.
6944         (md_parse_option): Add support for -EL, -EB and -mcpu command
6945         line switches.
6946         (md_convert_frag): Add support for little endian targets.
6947         (md_apply_fix3): Add support for little endian targets.
6948         (md_number_to_chars): Add support for little endian targets.
6949
6950 2000-02-10  Timothy Wall  <twall@redhat.com>
6951
6952         * read.c (read_a_source_file): If TC_START_LABEL_WITHOUT_COLON is
6953         defined, use it to verify the symbol just read should be a label.
6954
6955 2000-02-10  Timothy Wall  <twall@redhat.com>
6956
6957         * app.c (do_scrub_chars): Handle "||" for parallel instructions
6958         when DOUBLEBAR_PARALLEL is defined.  Avoid stripping whitespace
6959         around colons when KEEP_WHITE_AROUND_COLON is defined.
6960         * doc/internals.texi (CPU backend): Document DOUBLEBAR_PARALLEL
6961         and KEEP_WHITE_AROUND_COLON.
6962
6963 2000-02-08  Timothy Wall  <twall@redhat.com>
6964
6965         * read.c (s_rept): Call do_repeat, which abstracts the repeat
6966         logic.
6967         (do_repeat): New.  Abstract repeat logic so that a "break" can be
6968         implemented.
6969         (end_repeat): New.  Provide support for a "break" out of the
6970         repeat loop.
6971         * read.h: Add prototypes for new functions.
6972
6973 2000-02-08  Timothy Wall  <twall@redhat.com>
6974
6975         * doc/internals.texi: Document NUMBERS_WITH_SUFFIX macro.
6976         * as.h: Provide a default NUMBERS_WITH_SUFFIX definition (zero).
6977         * expr.c: Handle numbers with suffixes if NUMBERS_WITH_SUFFIX is
6978         non-zero.
6979
6980 2000-02-08  Timothy Wall  <twall@redhat.com>
6981
6982         * read.c: Added elseif to directives table.
6983         * read.h: Added prototype for s_elseif.
6984         * doc/as.texinfo: Added description for elseif.
6985         * cond.c (s_elseif): New function
6986
6987 2000-02-04  Timothy Wall  <twall@redhat.com>
6988
6989         * listing.c (print_lines): Remove conditionals causing bug in
6990         listings.
6991
6992 2000-02-03  Timothy Wall  <twall@cygnus.com>
6993
6994         * as.h: Define OCTETS_PER_BYTE and OCTETS_PER_BYTE_POWER
6995         default values.
6996         * frags.c (frag_new): Calculate fr_fix in octets
6997         (frag_now_fix) Return offset as target address offset (bytes).
6998         (frag_now_fix_octets) New - Return offset in octets (8-bit
6999         quantities).
7000         * frags.h: Added prototype for frag_now_fix_octets().
7001         Distinguish between octets and bytes in field descriptions.
7002         * listing.c (calc_hex): Account for octets vs bytes when
7003         printing addresses/offsets.
7004         (print_lines) Ditto.  Also, if LISTING_WORD_SIZE is not 1, and
7005         target is little-endian, print the octets in a word in big-endian
7006         order so that the display looks like a proper hexadecimal number,
7007         instead of having the octets reversed.
7008         * read.c (do_align): When recording alignment, alignment power
7009         should be in terms of target bytes (minimum addressible unit)
7010         instead of octets.
7011         (do_org) Convert ORG target address (byte) argument into an
7012         octet offset when generating a variable fragment.
7013         * symbols.c (resolve_symbol_value): Symbol final value
7014         converted to a target address offset (bytes) from its octet offset.
7015         * config/obj-coff.c (coff_frob_symbol): Symbol target address
7016         offset (bytes) is adjusted by the frag offset (octets) converted
7017         to bytes.
7018         (coff_frob_section) Section alignment power is in terms of bytes;
7019         convert it to an octet alignment power when calculating size (and
7020         size mask) in octets.  Don't modify the section size in order to
7021         "align" it for TI COFF, since that format has a different method
7022         for storing alignment information.
7023
7024 2000-02-01  Timothy Wall  <twall@cygnus.com>
7025
7026         * stabs.c (generate_asm_file): Escape backslashes in stabs file
7027         entries, matching the way GCC generates them.  If not escaped, the
7028         filename is encoded incorrectly.
7029
7030 2000-01-31  Nick Clifton  <nickc@cygnus.com>
7031
7032         * config/tc-arm.c (reg_table): Add support for ATPCS register
7033         naming conventions.
7034
7035 2000-01-31  Geoff Keating  <geoffk@cygnus.com>
7036
7037         * config/obj-coff.h (OBJ_COPY_SYMBOL_ATTRIBUTES): Don't define if
7038         already defined.
7039         * config/tc-ppc.h [OBJ_XCOFF] (OBJ_COPY_SYMBOL_ATTRIBUTES):
7040         New macro.
7041         * config/tc-ppc.c (ppc_fix_adjustable): Don't look at the frag
7042         of a symbol when we really care about its value.
7043
7044 2000-01-19  Chandra Chavva  <cchavva@cygnus.com>
7045
7046         * config/tc-mcore.c (md_assemble): Give warning message if
7047         operands passes to instruction are more than the spec.
7048
7049 2000-01-27  Thomas de Lellis <tdel@windriver.com>
7050
7051         * config/tc-arm.c (armadjust_symtab): If the assembler is in
7052         Thumb mode but the label seen was not declared as '.thumb_func'
7053         then set the ST_INFO type to STT_ARM_16BIT mode.  This allows
7054         correct disassembly of Thumb code bounded by non function labels.
7055
7056 2000-01-27  Alan Modra  <alan@spri.levels.unisa.edu.au>
7057
7058         * Makefile.am (MULTI_CFILES): Add config/e-i386aout.c
7059         Add dependencies for e-i386aout.o.  Fix 2 comment lines.
7060
7061         * Makefile.in: Same here.
7062         Update copyright.
7063
7064         * configure.in: Set bfd_gas for i386-aout when primary target
7065         is bfd.  Handle i386aout emulation.  Don't use te_file=multi, as
7066         we may need the primary te_file.  Remove incorrect comment.
7067
7068         * configure: Regenerate.
7069
7070         * config/e-i386aout.c: New file.
7071
7072         * as.c (USE_EMULATIONS): Move to before print_version_id.
7073         (struct emulation): Add i386aout.
7074         (show_usage): Split text strings.  Reformat -a text.  Add --em
7075         help.
7076         Update copyright.
7077
7078         * obj.h (struct format_ops): Add s_get_other and s_get_desc.
7079         (aout_format_ops): New.
7080         Update copyright.
7081
7082         * read.c (s_lcomm_internal): Rewrite OBJ_AOUT,OBJ_BOUT
7083         preprocessor conditional and add aout USE_EMULATIONS tests.
7084         (read_a_source_file): Don't pass error strings to printf as
7085         format arg.
7086         Update copyright.
7087
7088         * gasp.c (exp_get_abs): Don't pass error strings to printf as
7089         format arg.
7090         (do_data): Same here.
7091         (process_file): And here.
7092         Update copyright.
7093
7094         * symbols.c (colon): Rewrite "already defined" fatal message
7095         code for aout with USE_EMULATIONS.
7096         Update copyright.
7097
7098         * config/obj-aout.c (OBJ_HEADER): Define.
7099         (obj_pseudo_table): Rename to aout_pseudo_table.  Init all
7100         fields of sentinel.
7101         (obj_aout_frob_symbol): Expand S_GET_DESC, S_GET_TYPE,
7102         S_GET_OTHER, S_SET_TYPE macros since we don't need obj-multi
7103         forms here.
7104         (obj_aout_type): Expand S_SET_OTHER here too.
7105         (obj_read_begin_hook): Remove.
7106         (aout_pop_insert): New.
7107         (obj_aout_s_get_other): New.
7108         (obj_aout_s_get_desc): New.
7109         (aout_format_ops): New.
7110         Update copyright.
7111
7112         * config/obj-aout.h (obj_pop_insert): Define so non-multi usage
7113         gets aout_pseudo_table.
7114         (aout_pseudo_table): Declare.
7115         (obj_read_begin_hook): Define.
7116         Update copyright.
7117
7118         * config/obj-coff.c (obj_pseudo_table): Rename to
7119         coff_pseudo_table.
7120         (coff_pop_insert): Use coff_pseudo_table.
7121         (coff_sec_sym_ok_for_reloc): Remove.
7122         (coff_format_ops): Add 0 entries for s_get_size, s_set_size,
7123         and comment all zero entries and remove #if 0 code.
7124         Update copyright.
7125
7126         * config/obj-coff.h (obj_pop_insert): Define.
7127         (coff_pseudo_table): Declare.
7128         Update copyright.
7129
7130         * config/obj-ecoff.c (ecoff_format_ops): Add 0 entries for
7131         s_get_size, s_set_size.  Comment all zero entries.
7132         Update copyright.
7133
7134         * config/obj-elf.c (elf_s_get_other): New function.
7135         (obj_read_begin_hook): Rename to elf_obj_read_begin_hook.
7136         (obj_symbol_new_hook): Rename to elf_obj_symbol_new_hook.
7137         (elf_format_ops): Add elf_s_get_other, 0 s_get_size entry, and
7138         comment.
7139         (obj_elf_parse_section_letters): Don't pass error strings to
7140         printf as format arg.
7141         Update copyright.
7142
7143         * config/obj-elf.h (ECOFF_DEBUGGING): Define when
7144         OBJ_MAYBE_ECOFF.
7145         (elf_s_get_other): Declare.
7146         (S_GET_OTHER) Define as elf_s_get_other if not already
7147         defined.
7148         (S_SET_OTHER): Only define when not already defined.
7149         (elf_obj_read_begin_hook): Declare.
7150         (obj_read_begin_hook): Define.
7151         (elf_obj_symbol_new_hook): Declare.
7152         (obj_symbol_new_hook): Define.
7153         Update copyright.
7154
7155         * config/obj-multi.h: Add copyright header and protect against
7156         multiple inclusion.  Add * to all function pointers.
7157         (OBJ_HEADER): If defined, include it rather than other defines
7158         in this file.
7159         (obj_frob_file_after_relocs): Test for NULL.
7160         (obj_symbol_new_hook): Here too.
7161         (obj_sec_sym_ok_for_reloc): And here.
7162         (S_GET_OTHER): Define.
7163         (S_GET_DESC): Define.
7164         (ECOFF_DEBUGGING): Remove as it's done in obj-elf.h
7165         (OBJ_MAYBE_ELF): Update comment.
7166
7167         * config/tc-i386.c (i386_immediate): Add OBJ_MAYBE_AOUT to
7168         OBJ_AOUT preprocessor conditional and handle emulation by
7169         testing OUTPUT_FLAVOR.
7170         (i386_displacement): Here too.
7171         (md_section_align): Similarly here.
7172         (i386_target_format): Conditionally compile when more than one
7173         of OBJ_MAYBE_{ELF,COFF,AOUT} defined.  Add aout case.
7174         (i386_immediate): Fix error message for aout BFD_ASSMBLER.
7175         (i386_displacement): Here too.
7176         Update copyright.
7177
7178         * config/tc-i386.h (AOUT_TARGET_FORMAT): Define for each TE_*.
7179         Define TARGET_FORMAT for aout only when not multi.
7180         Update copyright.
7181
7182         * config/te-multi.h: Delete file as it's identical to te-generic.h
7183
7184 2000-01-15  Alan Modra  <alan@spri.levels.unisa.edu.au>
7185
7186         * config/tc-i386.h (DWORD_MNEM_SUFFIX): Delete.
7187         * config/tc-i386.c (DWORD_MNEM_SUFFIX): Rename all occurrences to
7188         LONG_MNEM_SUFFIX.
7189
7190         * config/tc-i386.h (INTEL_DWORD_MNEM_SUFFIX): Rename to
7191         DWORD_MNEM_SUFFIX.
7192         * config/tc-i386.c (INTEL_DWORD_MNEM_SUFFIX): Here too.  Fix some
7193         comments.
7194
7195 2000-01-13  Clinton Popetz  <cpopetz@cygnus.com>
7196
7197         * config/tc-mips.c (mips_do_align): New function.
7198         * config/tc-mips.h (md_do_align): Define.
7199
7200 2000-01-10  Philip Blundell  <philb@gnu.org>
7201
7202         * doc/c-arm.texi (ARM Options): Fix typo.
7203         (ARM-Chars): Correct description of `#'.  Mention  that `;' is a
7204         line separator for Linux.
7205         * doc/as.texinfo (Comments): Mention the ARM.
7206
7207 2000-01-10  Philip Blundell  <pb@futuretv.com>
7208
7209         * configure.in (arm*-*-conix*): New target.
7210         (arm*-*-linux-gnu*): Match instead of arm-*-linux* and
7211         armv*-*-linux-gnu.
7212         * configure: Regenerate.
7213
7214 2000-01-03  Martin v. Loewis  <loewis@informatik.hu-berlin.de>
7215
7216         * config/obj-elf.c (elf_pseudo_table): Define visibility pseudos.
7217         (obj_elf_visibility): New function.
7218
7219         * doc/as.texinfo (Visibility): New node: document visibility
7220         pseudo ops.
7221
7222 For older changes see ChangeLog-9899