Add support for arm-vxworks target
[binutils-gdb.git] / gas / ChangeLog
1 2001-04-27 Sean McNeil <sean@mcneil.com>
2
3 * configure.in: Add arm-vxworks.
4 * configure: Regenerate.
5
6 2001-04-26 Nick Clifton <nickc@cambridge.redhat.com>
7
8 * config/tc-arm.c (arm_handle_align): New Function: Generate
9 no-op filled alignment frags.
10 (arm_frag_align_code): New Function: Create a code alignment frag.
11 (arm_init_frag): New Function: Initialse the target dependent
12 parts of a frag.
13
14 * config/tc-arm.h (TC_FRAG_TYPE): Define.
15 (TC_FRAG_INIT): Define.
16 (HANDLE_ALIGN): Define.
17 (md_do_align): Define.
18
19 2001-04-25 Nick Clifton <nickc@cambridge.redhat.com>
20
21 * config/obj-coff.c (do_linenos_for): Check to see if the filename
22 symbol has been initialised before extracting its symbol index.
23
24 2001-04-24 H.J. Lu <hjl@gnu.org>
25
26 * configure: Regenerated with the right version of autoconf.
27
28 2001-04-24 Christian Groessler <cpg@aladdin.de>
29
30 * config/tc-z8k.c (build_bytes): 12 and 16 bit displacements now
31 generate R_CALLR and R_REL16 relocations
32
33 2000-04-20 Jason Eckhardt <jle@redhat.com>
34
35 * config/tc-d10v.h (tc_frob_label): Update the symbol's frag
36 since frag_now can change after d10v_cleanup is called.
37
38 2001-04-16 David O'Brien <obrien@FreeBSD.org>
39
40 * configure.in: Add the em type for FreeBSD targets.
41 * configure: Regenerate.
42
43 2001-04-14 Alexandre Oliva <aoliva@redhat.com>
44
45 * struc-symbol.h (struct local_symbol): New TC_LOCAL_SYMFIELD_TYPE.
46 * symbols.c (local_symbol_convert): Call TC_LOCAL_SYMFIELD_CONVERT.
47
48 * config/tc-mn10300.c (md_assemble): Simplify offset adjustment of
49 pc-relative relocations not placed at the end of the instruction.
50
51 2001-04-13 Jim Wilson <wilson@redhat.com>
52
53 * tc-ia64.c (is_conditional_branch): Return true for br, brl, and br.
54 excluding br.i.
55
56 2001-04-13 Jakub Jelinek <jakub@redhat.com>
57
58 * config/obj-elf.c (obj_elf_change_section): Add entsize argument,
59 handle SHF_MERGE and SHF_STRINGS.
60 (obj_elf_parse_section_letters): Set SHF_MERGE and SHF_STRINGS.
61 (obj_elf_section): Allow additional argument specifying entity size.
62 * write.c (adjust_reloc_syms): Keep relocations against local symbols
63 in SEC_MERGE sections.
64
65 2001-04-12 Jason Merrill <jason_merrill@redhat.com>
66
67 * dwarf2dbg.c (process_entries): Don't optimize redundant line notes.
68
69 2001-04-12 Alexandre Oliva <aoliva@redhat.com>
70
71 * expr.c (operand): Pass &c to md_parse_name().
72 * config/tc-ia64.h, config/tc-ppc.h, config/tc-tic54x.h: Adjust.
73
74 2001-04-07 Steven J. Hill <sjhill@cotw.com>
75
76 * config/tc-mips.c: Support ELF64 for traditional MIPS targets.
77
78 * Makefile.am: (TARG_ENV_HFILES): Add tc-mips.h.
79 * Makefile.in: Regenerated.
80
81 * configure.in: Use traditional MIPS targets for Linux/MIPS.
82 * configure: Regenerated.
83
84 2001-04-06 Alexandre Oliva <aoliva@redhat.com>
85
86 * config/tc-mn10300.c (xr_registers): Added `pc'.
87
88 2001-04-05 Alan Modra <alan@linuxcare.com.au>
89
90 * configure.in: Add h8500-*-coff and h8500-*-rtems targets.
91 * configure: Regenerate.
92
93 * config/tc-h8500.c (md_estimate_size_before_relax): Add missing
94 cases, and always return size based on current fr_subtype.
95 (md_begin): Move initialization of md_relax_table..
96 (md_relax_table): ..to static initializer. Set rlx_length for
97 UNDEF_WORD_DISP cases.
98 * config/tc-w65.c (md_estimate_size_before_relax): Likewise.
99 (md_begin): Likewise.
100 (md_relax_table): Likewise.
101 * config/tc-mcore.c (md_estimate_size_before_relax): Likewise.
102 (md_relax_table): Set rlx_length for UNDEF_WORD_DISP cases.
103 Set rlx_backward and rlx_forward to zero for unused states.
104 * config/tc-sh.c (md_estimate_size_before_relax): Likewise.
105 (md_relax_table): Set rlx_length for UNDEF_WORD_DISP cases.
106 (UNCOND12, UNCOND32): Remove duplicate defines.
107
108 2001-04-04 Hans-Peter Nilsson <hp@axis.com>
109
110 * config/tc-cris.c (md_estimate_size_before_relax) <case
111 ENCODE_RELAX (STATE_CONDITIONAL_BRANCH, STATE_UNDF)>: Don't emit
112 32-bit branch, just set fragP->fr_subtype. Set fragP->fr_var.
113 <all cases>: Always set fragP->fr_var using md_cris_relax_table.
114 Add cases to cover all relax states.
115 (cris_insn_first_word_frag): New.
116 (md_assemble): Call cris_insn_first_word_frag to get the first
117 frag in an insn, not frag_more. Don't call dwarf2_emit_insn at
118 end. Drop variable insn_size.
119 (gen_bdap): Call cris_insn_first_word_frag, not frag_more.
120 (cris_sym_leading_underscore): Wrap first as_bad parameter in _().
121 (cris_sym_no_leading_underscore, s_cris_file, s_cris_loc): Ditto.
122
123 * write.c (write_object_file): Reset broken word state before
124 calling relax_seg.
125
126 2001-03-31 Alan Modra <alan@linuxcare.com.au>
127
128 * listing.c (listing_listing): Enable listing on EDICT_NOLIST_NEXT
129 for one line if not already enabled.
130 * cond.c (s_elseif): Correct conditional assembly listing.
131 (s_else): Likewise.
132
133 * cond.c (s_endif): Correct handling of "if .. elseif .." trees.
134 Don't abort on NULL current_cframe.
135
136 2001-03-30 Alan Modra <alan@linuxcare.com.au>
137
138 * dwarf2dbg.c (dwarf2_directive_file): Fix warnings.
139 (dwarf2dbg_convert_frag): Pass `finalize_syms' to resolve_symbol_value.
140 * config/obj-aout.c (obj_crawl_symbol_chain): Likewise.
141 * config/obj-bout.c (obj_crawl_symbol_chain): Likewise.
142 * config/obj-coff.c (do_relocs_for): Likewise.
143 (yank_symbols): Likewise.
144 (fixup_segment): Likewise.
145 * config/tc-ppc.c (ppc_frob_symbol): Likewise.
146 (ppc_fix_adjustable): Likewise.
147 * config/tc-mips.c (md_convert_frag): Likewise.
148 * config/obj-vms.c (obj_crawl_symbol_chain): Likewise.
149 * ehopt.c (eh_frame_convert_frag): Likewise.
150 * expr.c (make_expr_symbol): Likewise.
151
152 * frags.h (struct frag): Add last_fr_address. Reorder fields for
153 better packing.
154 * symbols.c (resolve_symbol_value): Don't fix expression values
155 until relaxation is complete.
156 (resolve_local_symbol): Pass `finalize_syms' to resolve_symbol_value.
157 (S_GET_VALUE): Likewise, and return unresolved expression value.
158 * write.c (finalize_syms): New.
159 (relax_and_size_seg): Split into..
160 (relax_seg): New function, returns 1 if anything changed..
161 (size_seg): And the remainder of relax_and_size_seg.
162 (fixup_segment): Arrange for final resolution of sym values.
163 (adjust_reloc_syms): Likewise.
164 (write_object_file): Likewise, and repeatedly call relax_seg until
165 nothing more changes.
166 (relax_segment): Return 1 if anything changed. Use correct types
167 for rs_org `target' and `after'.
168 * write.h (finalize_syms): Declare.
169 (relax_segment): Update prototype.
170
171 * config/tc-sh.c (md_estimate_size_before_relax): Add extra
172 do-nothing cases to switch to avoid abort on a second relaxation
173 pass, and tidy code a little.
174 * config/tc-cris.c (md_estimate_size_before_relax): Likewise.
175 * config/tc-h8500.c (md_estimate_size_before_relax): Likewise.
176 * config/tc-w65.c (md_estimate_size_before_relax): Likewise.
177 * config/tc-i386.c (UNCOND_JUMP, COND_JUMP, COND_JUMP86): Decrement.
178 (md_relax_table): Remove first four unused entries. Increment
179 rlx_length by one throughout table, and update comments to suit.
180 (md_estimate_size_before_relax): Return size of current variable
181 part of frag to reflect reality when relaxing more than once.
182 * config/tc-mcore.c (COND12, UNCD12): Rename to DISP12 throughout.
183 (COND32, UNCD32): Rename to DISP32 throughout.
184 (UNDEF_WORD_DISP): Renumber to 3.
185 (md_estimate_size_before_relax): Add extra do-nothing cases.
186 * config/tc-mn10200.c (md_estimate_size_before_relax): Rewrite.
187 * config/tc-mn10300.c (md_estimate_size_before_relax): Rewrite.
188 * config/tc-ns32k.c (md_estimate_size_before_relax): Add cases to
189 handle word and dword branches.
190
191 2001-03-29 Hans-Peter Nilsson <hp@axis.com>
192
193 * config/tc-cris.h (tc_fix_adjustable): Allow only
194 BFD_RELOC_CRIS_32_GOTREL of the PIC relocs.
195 * config/tc-cris.c (cris_get_pic_suffix): Correct reloc type in
196 example in comment to valid type.
197
198 2001-03-28 H.J. Lu <hjl@gnu.org>
199
200 * read.c (equals): Set to local for COFF only if it hasn't been
201 defined before.
202
203 2001-03-28 Alan Modra <alan@linuxcare.com.au>
204
205 * config/tc-hppa.c (DEFAULT_LEVEL): Define.
206 (md_begin): Use it when setting default architecture.
207
208 2001-03-27 Nick Papadonis <nick@coelacanth.com>
209
210 * read.c (equals): (for COFF) default symbols to being local.
211
212 2001-03-27 Hans-Peter Nilsson <hp@axis.com>
213
214 * configure.in (cris-*-*): Change default emulation to criself.
215 (cris-*-*aout*): New rule.
216 * configure: Regenerate.
217
218 2001-03-26 Martin Schwidefsky <schwidefsky@de.ibm.com>
219
220 * config/tc-s390.c (tc_s390_fix_adjustable): Add test for
221 BFD_RELOC_390_GOTENT.
222 * config/tc-s390.h (TC_RELOC_RTSYM_LOC_FIXUP): Add test for
223 BFD_RELOC_390_GOTENT.
224
225 2001-03-26 Nick Clifton <nickc@redhat.com>
226
227 * config/tc-s390.h (TC_FORCE_RELOCATION): Define.
228 * config/tc-s390.c (s390_force_relocation): New function: Force
229 relocations for VTINHERIT relocs.
230
231 2001-03-23 Stephane Carrez <Stephane.Carrez@worldnet.fr>
232
233 * doc/as.texinfo: Put @c man begin to generate the as man page.
234 When generating man, define all the variables. Re-organize some
235 options to obtain better indentation of man page.
236 * doc/Makefile.am (MANCONF, TEXI2POD, POD2MAN): New variable.
237 (as.1): Build from as.texinfo.
238 * doc/Makefile.in: Regenerate.Index: binutils/Makefile.am
239
240 2001-03-25 Alan Modra <alan@linuxcare.com.au>
241
242 * config/tc-i386.c (i386_scale): Accept an absolute expression for
243 scale factor, and return the end of the expression.
244 (i386_operand): Modify for above.
245
246 2001-03-23 Nick Clifton <nickc@redhat.com>
247
248 * doc/as.texinfo: Document --listing-XXX command line switches.
249 Explain why listings behave differently when -pipe is used.
250
251 2001-03-23 Richard Sandiford <rsandifo@redhat.com>
252
253 * write.c (fix_new_exp): Print an error if passed a register.
254
255 2001-03-23 Hans-Peter Nilsson <hp@axis.com>
256
257 * config/tc-cris.c: Tweak attribution. Fix typos. PIC support.
258 (PIC_SUFFIX_CHAR): New macro.
259 (cris_get_pic_suffix, cris_get_pic_reloc_size): New functions.
260 (pic): New variable.
261 (md_longopts): New option --pic.
262 (OPTION_PIC): Define.
263 (md_estimate_size_before_relax): Tweak longish comment.
264 (md_create_long_jump): Make the long jumps generate ADD.D offset,PC.
265 (md_assemble): Handle a PIC relocation on prefix and normal
266 instruction operands.
267 <output_instruction.insn_type == CRIS_INSN_BRANCH>: Handle
268 "complex" operand expressions. Call frag_more outside
269 gen_cond_branch_32 parameter list.
270 (cris_process_instruction): Handle PIC relocs on parsed
271 operand expressions. Validize PIC reloc sizes.
272 (get_autoinc_prefix_or_indir_op): Handle PIC suffix.
273 (gen_bdap): Handle "complex" operand expressions.
274 (gen_cond_branch_32): Use as_warn_where, not as_warn. Use
275 ADD.D offset,PC as jump instruction if generating PIC. Generate
276 error instead of crashing on complex expressions.
277 (cris_number_to_imm): Add segT parameter. All callers changed.
278 Use segT parameter, not now_seg, for segment of fixup. Handle
279 PCREL relocations but check that they are fully resolved.
280 (md_parse_option): Handle OPTION_PIC.
281 (tc_gen_reloc): Handle PIC relocs.
282 (md_show_usage): Update for --pic.
283 (md_apply_fix3): Renamed from md_apply_fix.
284 (md_pcrel_from): Accept emitting PCREL relocs when ELF.
285 (md_cris_force_relocation): Force relocation for PIC relocs.
286
287 * config/tc-cris.h: Tweak attribution.
288 (MD_APPLY_FIX3): Define.
289 (IS_CRIS_PIC_RELOC): New macro.
290 (TC_RELOC_RTSYM_LOC_FIXUP): Define.
291 (tc_fix_adjustable): Don't adjust a globally visible symbol when
292 generating ELF.
293 (tc_frob_symbol): Avoid emitting undefined symbols.
294
295 2001-03-20 Alan Modra <alan@linuxcare.com.au>
296
297 * frags.h (struct frag): Add relax_marker.
298 * write.c (is_dnrange): Delete.
299 (relax_frag): Use correct types for `aim', `target', `address'.
300 Delete `offset', `was_address'. Test `relax_marker' instead of
301 using fragile (and slow) address test.
302 (relax_segment): Init and flip `relax_marker'.
303
304 2001-03-19 Alan Modra <alan@linuxcare.com.au>
305
306 * config/tc-i386.c (md_assemble <REGISTER_WARNINGS>): Correct
307 used register name.
308
309 2001-03-18 Stephane Carrez <Stephane.Carrez@worldnet.fr>
310
311 * config/tc-m68hc11.c (md_pseudo_table): Recognize xrefb to comply
312 with 'Motorola specification for assembly language input standard'.
313
314 2001-03-17 Richard Henderson <rth@redhat.com>
315
316 * dwarf2dbg.c (user_filenum, user_filenum_allocated): Remove.
317 (dwarf2_directive_loc): Don't use them.
318 (dwarf2_directive_file): Reject duplicate file definitions.
319 (get_filenum): Zero allocated memory.
320 (out_file_list): Complain about missing file definitions.
321
322 2001-03-17 Alan Modra <alan@linuxcare.com.au>
323
324 * read.c (do_org): Handle complex expressions.
325 * cgen.c (gas_cgen_finish_insn): Likewise.
326
327 2001-03-15 David Mosberger <davidm@hpl.hp.com>
328
329 * config/tc-ia64.c (md): New member keep_pending_output.
330 (ia64_flush_pending_output): Flush only if md.keep_pending_output
331 is not set.
332 (dot_xdata): Turn on md.keep_pending_output for the duration of
333 this function.
334 (dot_xfloat_cons): Ditto.
335 (dot_xstringer): Ditto.
336 (dot_xdata_ua): Ditto.
337 (dot_xfloat_cons_ua): Ditto.
338
339 2001-03-15 Jim Wilson <wilson@redhat.com>
340
341 * config/tc-ia64.c (ia64_unrecognized_line, case '['): Add local
342 label support.
343
344 2001-03-15 Alexandre Oliva <aoliva@redhat.com>
345
346 * config/tc-sh.c (parse_reg): Match capital MACH and MACL.
347
348 2001-03-15 DJ Delorie <dj@redhat.com>
349
350 * stabs.c (s_stab_generic): Don't corrupt the notes obstack by
351 blindly freeing string if it isn't at the top of the obstack.
352
353 2001-03-13 Alan Modra <alan@linuxcare.com.au>
354
355 * config/tc-i386.c (RELOC_ENUM): Define. Use throughout file.
356 (NUM_FLAG_CODE): Define.
357 (lex_got): New function.
358 (got_reloc): New global var.
359 (x86_cons_fix_new): New function.
360 (x86_cons): New function.
361 (i386_immediate): Use lex_got here, replacing inline code. Change
362 "ignoring junk.." error message to "junk.."
363 (i386_displacement): Likewise.
364 * config/tc-i386.h (TC_PARSE_CONS_EXPRESSION): Define.
365 (x86_cons): Declare.
366 (TC_CONS_FIX_NEW): Define.
367 (x86_cons_fix_new): Declare.
368
369 2001-03-12 Nick Clifton <nickc@redhat.com>
370
371 * config/tc-arm.c (md_begin): Always set machine type based on
372 cpu_variant.
373
374 2001-03-07 Alan Modra <alan@linuxcare.com.au>
375
376 * config/tc-i386.c (struct _i386_insn): Rename disp_reloc to reloc.
377 (md_assemble) <smallest displacement>: Use correct field of i.op[]
378 union.
379 <JumpInterSegment output>: Use correct i.disp_reloc[].
380 <immediate output>: Likewise.
381
382 2001-03-06 Nick Clifton <nickc@redhat.com>
383
384 * config/tc-arm.c (md_apply_fix3): Clear bit zero of offset in
385 BLX(1) instruction.
386
387 2001-03-06 Igor Shevlyakov <igor@windriver.com>
388
389 * config/tc-m68k.c : Add 5407 to archs[] table.
390 (HAVE_LONG_BRANCH): Add mcf5407.
391 (select_control_regs): Recognize 5407.
392
393 2001-03-02 Dave Brolley <brolley@redhat.com>
394
395 * config/tc-m32r.c (expand_debug_syms): Call frag_align_code rather
396 than m32r_do_align.
397
398 2001-03-02 Richard Sandiford <rsandifo@redhat.com>
399
400 * config/atof-ieee.c (TC_LARGEST_EXPONENT_IS_NORMAL): New macro.
401 (gen_to_words): Print warnings if NaNs are found and the target CPU
402 does not support them. Allow largest exponent to be used in normal
403 numbers if TC_LARGEST_EXPONENT_IS_NORMAL evaluates to true.
404
405 2001-02-28 Andreas Jaeger <aj@suse.de>, Bo Thorsen <bo@suse.de>
406
407 * config/tc-i386.c (tc_gen_reloc): Remove ugly hack which is not needed
408 anymore since we use bfd_elf_generic_reloc now.
409 (md_apply_fix3): Only apply hack for partial_inplace if not using RELA.
410
411 2001-02-27 Alan Modra <alan@linuxcare.com.au>
412
413 * configure.in (BFD_VERSION): New.
414 (AM_INIT_AUTOMAKE): Use $BFD_VERSION.
415 * configure: Regenerate.
416 * Makefile.am: Run "make dep-am"
417 * Makefile.in: Regenerate.
418 * doc/Makefile.in: Regenerate.
419
420 2001-02-26 Mark Elbrecht <snowball3@bigfoot.com>
421
422 * config/obj-coff.c [BFD_ASSEMBLER] (obj_coff_section): Set
423 SEC_NEVER_LOAD when the 'n' flag is used.
424 Add SEC_NEVER_LOAD to matchflags.
425
426 2001-02-24 Stephane Carrez <Stephane.Carrez@worldnet.fr>
427
428 * symbols.c (decode_local_label_name): Initialize message_format
429 only when an error is reported (perf pb due to I18N).
430
431 2001-02-23 H.J. Lu <hjl@gnu.org>
432
433 * dwarf2dbg.c (dwarf2_directive_file): Call s_app_file (0) if
434 BFD_ASSEMBLER is not defined.
435
436 2001-02-23 Richard Sandiford <rsandifo@redhat.com>
437
438 * config/tc-mn10300.c (md_apply_fix3): Don't mark a fixup as
439 done if it's against a symbol.
440
441 2001-02-22 Timothy Wall <twall@cygnus.com>
442
443 * config/tc-ia64.c (ia64_target_format): Return ia64-aix-specific
444 target formats if applicable.
445 * config/te-ia64aix.h: New. Configuration for AIX5 on IA-64.
446 * Makefile.am (TARG_ENV_HFILES): Added config/te-ia64aix.h.
447 * Makefile.in: Regenerated.
448 * configure.in: Added configuration for ia64-*-aix*.
449 * configure: Regenerated.
450
451 2001-02-21 David Mosberger <davidm@hpl.hp.com>
452
453 * config/tc-ia64.c (enum operand_match_result): New type.
454 (operand_match): Change return type to operand_match_result.
455 Fix all returns appropriately, adding support for returning the
456 out-of-range result.
457 (parse_operands): New locals result, error_pos, out_of_range_pos,
458 curr_out_of_range_pos. Rewrite operand matching loop to give better
459 error messages.
460
461 2001-02-21 David Mosberger <davidm@hpl.hp.com>
462
463 * config/tc-ia64.c (struct unwind): Add member "prologue_count".
464 (dot_proc): Clear unwind.prologue_count to zero.
465 (dot_prologue): Increment unwind.prologue_count.
466 (dot_restore): If second operand is omitted, use
467 unwind.prologue_count -1 for "ecount" (# of additional regions to
468 pop). Decrement unwind.prologue_count by number of regions
469 popped.
470
471 2001-02-21 Nick Clifton <nickc@redhat.com>
472
473 * doc/as.texinfo (Section): Note that some flags to the COFF
474 version of .section remove attributes rather than setting them.
475
476 2001-02-20 Kazu Hirata <kazu@hxi.com>
477
478 * config/tc-pdp11.c: Fix formatting.
479 * config/tc-pdp11.h: Likewise.
480
481 2001-02-20 Bo Thorsen <bo@suse.de>
482
483 * config/tc-i386.c (tc_i386_fix_adjustable): Fix GOTPCREL GOT
484 entry.
485
486 2001-02-18 David O'Brien <obrien@FreeBSD.org>
487
488 * configure.in (cpu_type, arch): Add a generic FreeBSD specification as
489 all FreeBSD platforms should look the same at this level.
490 * configure: Rebuilt.
491 * config/tc-i386.c: Add support for old FreeBSD a.out hosts.
492
493 2001-02-18 lars brinkhoff <lars@nocrew.org>
494
495 * Makefile.am: Add PDP-11 target.
496 * configure.in: Likewise.
497 * config/tc-pdp11.c: New file.
498 * config/tc-pdp11.h: New file.
499 * doc/Makefile.am: Add PDP-11 documentation.
500 * doc/all.texi: Likewise.
501 * doc/as.texinfo: Likewise.
502 * doc/c-pdp11.texi: New file.
503
504 2001-02-16 matthew green <mrg@redhat.com>
505
506 * gas/cgen.c (gas_cgen_md_apply_fix3): Support BFD_RELOC_64.
507
508 2001-02-13 Jim Wilson <wilson@redhat.com>
509
510 * config/tc-ia64.c (operand_match, case TAG13): Make a BFD_RELOC_UNUSED
511 reloc instead of a 0 reloc.
512 (md_apply_fix3): Check for BFD_RELOC_UNUSED instead of 0, and mark it
513 as done.
514 * config/tc-ia64.h (TC_RELOC_RTSYM_LOC_FIXUP): Likewise.
515
516 2001-02-13 Ian Lance Taylor <ian@zembu.com>
517
518 * write.c (is_dnrange): Stop as soon as the address becomes
519 larger.
520 (relax_frag): Add segment parameter. Only call symbol_get_frag
521 once. Only call is_dnrange if the symbol is in the same segment,
522 and the symbol address is larger.
523 (relax_segment): Pass segment to md_relax_frag and relax_frag.
524 * write.h (relax_frag): Update declaration.
525 * config/tc-fr30.c (fr30_relax_frag): Add segment parameter. Pass
526 it to relax_frag.
527 * config/tc-m32r.c (m32r_relax_frag): Likewise.
528 * config/tc-m32r.h (md_relax_frag): Add segment parameter.
529 (m32r_relax_frag): Update declaration.
530 * config/tc-mips.h (md_relax_frag): Add segment parameter.
531 * config/tc-tic54x.h (md_relax_frag): Likewise.
532 * doc/internals.texi (CPU backend): Update documentation for
533 md_relax_frag.
534
535 2001-02-13 Alan Modra <alan@linuxcare.com.au>
536
537 * doc/c-i386.texi (i386-Arch): Add "jumps"/"nojumps" blurb.
538 Mention effect of < 386 architectures on jump promotion.
539 (i386-Jumps): xref above. Don't assume long disp is 32 bits.
540
541 * config/tc-i386.c (no_cond_jump_promotion): New.
542 (set_cpu_arch): Parse "jumps" arch modifier.
543 (insn_size): Modify usage comment.
544 (ENCODE_RELAX_STATE): Reformat and protect macro arg.
545 (SIZE_FROM_RELAX_STATE): Rename to DISP_SIZE_FROM_RELAX_STATE.
546 (TYPE_FROM_RELAX_STATE): New define.
547 (UNCOND_JUMP, COND_JUMP): Renumber.
548 (md_relax_table): Reorder to suit.
549 (COND_JUMP86): New define.
550 (md_relax_table): Handle COND_JUMP86 cases. Add a few comments.
551 (md_assemble): Create frag var for jumps of max size, encode relax
552 state for COND_JUMP86.
553 (md_estimate_size_before_relax): Handle COND_JUMP86 cases, and
554 leave conditional jumps small if no_cond_jump_promotion.
555 (md_convert_frag): Likewise.
556
557 * expr.c (operator): Don't bump input_line_pointer for two char
558 operators. Instead return operator size via new param num_chars.
559 (expr): Use above to parse multi-char operators correctly.
560
561 Mon Feb 12 17:45:50 CET 2001 Jan Hubicka <jh@suse.cz>
562
563 * config/tc-i386.c (i386_displacement): Fix handling of
564 BFD_RELOC_X86_64_GOTPCREL.
565 (i386_validate_fix): Likewise.
566
567 2001-02-12 Philip Blundell <pb@futuretv.com>
568
569 * config/tc-arm.c (do_ldst): Improve warnings for unpredictable
570 ldrt/strt instructions.
571
572 2001-02-11 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
573
574 * config/tc-mips.c (macro): For M_LA_AB emit a
575 BFD_RELOC_MIPS_CALL16 relocation or a
576 BFD_RELOC_MIPS_CALL_HI16/BFD_RELOC_MIPS_CALL_LO16 pair instead of
577 BFD_RELOC_MIPS_GOT16 and
578 BFD_RELOC_MIPS_GOT_HI16/BFD_RELOC_MIPS_GOT_LO16, respectively for
579 loading the jump register when generating SVR4_PIC code.
580
581 2001-02-10 Chris Demetriou <cgd@broadcom.com>
582
583 * configure.in: Make 'mipself' and 'mipsecoff' emulations
584 map to MIPS-specific files, as they used to do before the
585 change on 2000-05-21.
586 * configure: Regerate.
587
588 2001-02-10 Chris Demetriou <cgd@broadcom.com>
589
590 * config/tc-mips.c (md_parse_option): Don't try to compile
591 ELF-only option code if not ELF.
592
593 2001-02-08 David Mosberger <davidm@hpl.hp.com>
594
595 * config/tc-ia64.h (md_elf_section_type): New macro.
596 (ELF_TC_SPECIAL_SECTIONS): Drop .IA_64.unwind and .IA_64.unwind_info
597 (they're now handled via ia64_elf_section_type.
598
599 * config/tc-ia64.c (unwind): New members saved_text_seg,
600 saved_text_subseg, and force_unwind_entry.
601 (optimize_unw_records): New function to optimize away unnecessary
602 unwind directives.
603 (ia64_elf_section_type): New function.
604 (output_unw_records): Generate unwind info only if the size is
605 non-zero or if it's forced for some other reason (e.g.,
606 handlerdata or a personality routine).
607 (generate_unwind_image): Don't switch back to previous
608 section---stay inside the unwind info section instead so that
609 handlerdata that may follow goes into the right place.
610 (dot_handlerdata): Force generation of unwind entry and save the
611 current active text segment before generating unwind image.
612 (dot_unwentry): Force generation of unwind entry.
613 (dot_personality): Ditto.
614 (dot_endp): Generate unwind table entry only if there is
615 some unwind info or the unwind entry was forced.
616
617 * config/tc-ia64.c (make_unw_section_name): New macro to form
618 unwind section name.
619 (generate_unwind_image): Add "text_name" argument. Use it to
620 form unwind section name.
621 (dot_handlerdata): Determine current segment (section) name and
622 pass it to generate_unwind_image().
623 (dot_endp): Determine current segment (section) name and use
624 it to determine the appropriate unwind section name.
625 (ia64_md_do_align): Add missing ATTRIBUTE_UNUSED declarations to
626 n, fill, and max arguments.
627
628 2001-02-09 Schwidefsky <schwidefsky@de.ibm.com>
629
630 * Makefile.am: Add linux target for S/390.
631 * configure.in: Likewise.
632 * config/tc-s390.c: New file.
633 * config/tc-s390.h: New file.
634
635 2001-02-09 Alexandre Oliva <aoliva@redhat.com>
636
637 * config/tc-sh.c (md_pseudo_table): Add uaquad. Use s_uacons for
638 2byte, 4byte and 8byte.
639
640 2001-02-08 Alan Modra <alan@linuxcare.com.au>
641
642 * config/tc-hppa.c (pa_build_unwind_subspace): Don't call
643 md_number_to_chars with size > sizeof (valueT).
644
645 2001-02-06 H.J. Lu <hjl@gnu.org>
646
647 * config/tc-ia64.h (TC_RELOC_RTSYM_LOC_FIXUP): Do fixup if
648 there is no relocation.
649
650 2001-02-06 H.J. Lu <hjl@gnu.org>
651
652 * config/tc-ia64.h (TC_RELOC_RTSYM_LOC_FIXUP): New. Defined.
653
654 * config/tc-ia64.c (md_parse_option): Only accept the valid
655 ia64 options on "-axxx".
656
657 2001-02-05 Jim Wilson <wilson@redhat.com>
658
659 * config/tc-ia64.c (errata_nop_necessary_p): Return 0 instead of
660 aborting for invalid operands.
661
662 2001-02-06 Alan Modra <alan@linuxcare.com.au>
663
664 * config/tc-hppa.c (fix_new_hppa): Pass in unwind directly rather
665 than via pointer. Update all callers.
666 (UNWIND_LOW32): Define.
667 (UNWIND_HIGH32): Define.
668 (pa_build_unwind_subspace): Use the above macros instead of dumping
669 bitfields directly. Call frag_more once rather than multiple times.
670 (md_assemble): Use UNWIND_LOW32.
671 (pa_entry): Likewise
672 (pa_procend): Likewise.
673 (process_exit): Use UNWIND_HIGH32.
674
675 2001-02-04 Stephane Carrez <Stephane.Carrez@worldnet.fr>
676
677 * config/tc-m68hc11.h (LISTING_HEADER): Use m68hc11_listing_header
678 function to select the header according to the cpu.
679 (md_after_pass_hook, md_do_align): Remove.
680 (md_cleanup, m68hc11_cleanup): Remove.
681 (md_pcrel_from_section): Declare.
682 * config/tc-m68hc11.c (build_dbranch_insn): Remove insn_size.
683 (build_jump_insn, build_insn): Likewise.
684 (m68hc11_listing_header): New function.
685 (m68hc11_cleanup): Remove.
686
687 2001-02-02 Stephane Carrez <Stephane.Carrez@worldnet.fr>
688
689 * config/tc-m68hc11.c (relaxable_symbol): Relax externally visible
690 symbols because there is no support for shared libraries and these
691 symbols can't be overridden (unless they are weak).
692
693 2001-02-01 Momchil Velikov <velco@fadata.bg>
694
695 * dwarf2dbg.c (out_debug_abbrev): Terminate the abbreviations
696 for the compilation unit with a zero byte.
697
698 2001-01-30 Alan Modra <alan@linuxcare.com.au>
699
700 * config/tc-hppa.c (pa_ip): Support 12 bit branches to absolute
701 destinations. Correct range check for 17 and 22 bit branches.
702
703 2001-01-25 Nick Clifton <nickc@redhat.com>
704
705 * config/tc-m68k.c (tc_gen_reloc): Do not abort if tcbit is
706 still set. Issue an error message instead.
707 (md_estimate_size_before_relax): Delete unused variable
708 'buffer_address'. Fixup parentheses around if statement.
709
710 2001-01-23 Kazu Hirata <kazu@hxi.com>
711
712 * as.c: Fix formatting.
713 * ehopt.c: Likewise.
714 * messages.c: Likewise.
715 * stabs.c: Likewise.
716 * symbols.c: Likewise.
717
718 2001-01-23 Ben Elliston <bje@redhat.com>
719
720 * config/tc-m32r.c (m32r_handle_align): Declare type of fragp.
721
722 2001-01-22 Kazu Hirata <kazu@hxi.com>
723
724 * config/tc-alpha.c: Fix formatting.
725
726 2001-01-19 Kazu Hirata <kazu@hxi.com>
727
728 * config/tc-alpha.c: Fix formatting.
729
730 2001-01-18 Kazu Hirata <kazu@hxi.com>
731
732 * config/tc-alpha.c: Fix formatting.
733
734 2001-01-18 Nick Clifton <nickc@redhat.com>
735
736 * config/tc-arm.c (ldm_flags): Remove redundant bit from "fa" and
737 "da" flags.
738 (stm_flags): Remove redundant bit from "ed" and "da" flags.
739
740 2001-01-18 Alexandre Oliva <aoliva@redhat.com>
741
742 * configure.in (cpu_type, arch): Match i386 too.
743 * configure: Rebuilt.
744
745 2001-01-16 Kazu Hirata <kazu@hxi.com>
746
747 * config/tc-i386.c: Fix formatting.
748
749 2001-01-16 Alan Modra <alan@linuxcare.com.au>
750
751 * config/tc-hppa.c (tc_gen_reloc): Use SEGREL32 instead of DIR32
752 relocs for .PARISC.unwind section.
753
754 * config/tc-hppa.c (pa_build_unwind_subspace): Build unwind
755 depending on section flags, not just for .text.
756
757 2001-01-15 Jim Wilson <wilson@redhat.com>
758
759 * config/tc-ia64.c (ia64_flush_insns): Handle unwind directives
760 not immediately followed by an instruction.
761
762 2001-01-15 Kazu Hirata <kazu@hxi.com>
763
764 * config/tc-m68hc11.c: Fix formatting.
765
766 2001-01-15 Nick Clifton <nickc@redhat.com>
767
768 * symbols.c (colon): Change 'already defined symbol' from a
769 fatal error to an ordinary error. There is no reason why this
770 error should be fatal.
771
772 * message.c (as_fatal): Delete output file, if one has been
773 created.
774
775 2001-01-14 Alan Modra <alan@linuxcare.com.au>
776
777 * config/tc-hppa.h (TARGET_FORMAT): Add hppa-linux variants.
778
779 2001-01-14 Kazu Hirata <kazu@hxi.com>
780
781 * config/tc-alpha.c: Fix formatting.
782 * config/tc-arc.c: Likewise.
783 * config/tc-arc.h: Likewise.
784 * config/tc-d10v.c: Likewise.
785 * config/tc-i370.c: Likewise.
786 * config/tc-i386.c: Likewise.
787 * config/tc-i960.c: Likewise.
788 * config/tc-m68k.c: Likewise.
789 * config/tc-ppc.c: Likewise.
790 * config/tc-sparc.c: Likewise.
791 * config/tc-tahoe.c: Likewise.
792 * config/tc-vax.c: Likewise.
793
794 * config/tc-arc.c: Fix formatting.
795
796 * config/tc-arc.c: Fix formatting.
797
798 2001-01-14 Alan Modra <alan@linuxcare.com.au>
799
800 * config/tc-hppa.c (pa_build_unwind_subspace): Use SEGREL32 for
801 both 32 and 64 bit ELF.
802
803 * config/tc-hppa.c (pa_ip): Store `a' flag in bit zero of operand
804 and don't bother storing `m' for "ce" completer. Tidy handling of
805 'J' and 'K' operands to suit. Handle '<' and '>' operands.
806
807 Sun Jan 14 00:36:42 MET 2001 Jan Hubicka <jh@suse.cz>
808
809 * config/tc-i386.h (TARGET_MACH): New macro.
810 (i386_mach): Declare.
811 * config/tc-i386.c (i386_mach): New function.
812
813 2001-01-13 Philip Blundell <philb@gnu.org>
814
815 * doc/as.texinfo: Fix spelling and cross-references.
816
817 * doc/c-arm.texi: Fix typos. Say that `;' is a line separator
818 character for all systems, not just GNU/Linux. Make it explicit
819 that `-k' doesn't affect code generation, just ELF flags.
820
821 Sat Jan 13 01:47:35 MET 2001 Jan Hubicka <jh@suse.cz>
822
823 * config/tc-i386.c (md_assemble): Check cpu_flags even for nullary
824 instructions.
825
826 2001-01-12 Frank Ch. Eigler <fche@redhat.com>
827
828 * cgen.c (gas_cgen_finish_insn): Call dwarf2_emit_insn.
829
830 2001-01-12 Nick Clifton <nickc@redhat.com>
831
832 * as.c (print_args): Update copyright date to 2001.
833
834 2001-01-12 Peter Targett <peter.targett@arccores.com>
835
836 * doc/c-arc.texi: New file.
837 Some sections to be expanded.
838
839 2001-01-12 Alan Modra <alan@linuxcare.com.au>
840
841 * config/tc-i386.c (md_longopts): Recognize "--64" only for ELF.
842 (md_parse_option): Always accept "--32".
843
844 2001-01-11 Peter Targett <peter.targett@arccores.com>
845
846 * as.h (TC_ARC): Ensure struc-symbol.h included.
847 * as.c (dwarf2dbg.h): Include to remove implicit declaration
848 warnings.
849 * struc-symbol.h (SYMBOLS_NEED_BACKPOINTERS): Define.
850 (TARGET_SYMBOL_FIELDS) added.
851
852 * doc/Makefile.am (CPU_DOCS): Added c-arc.texi.
853 * doc/c-arc.texi: New file.
854 Some sections to be expanded.
855 * doc/as.texinfo: Update command-line options.
856 Removed outdated text for ARC dependant features, instead include
857 text from above file.
858
859 * config/obj-elf.h (ELF_TARGET_SYMBOL_FIELDS): Define local flag.
860 (TARGET_SYMBOL_FIELDS): Alias to previous definition.
861 (targ-cpu.h) header.
862 * config/tc-arc.h:
863 * config/tc-arc.c: New updated configuration for
864 ARC, including selection of core variants, and extensibility of
865 instructions, registers etc. through directives.
866
867 * config/tc-arc.c (arc_extinst): Minor corrections for
868 error messages.
869 (arc_common) Likewise. Make alignment argument optional for local
870 symbols also, with default of zero.
871
872 2001-01-11 Stephane Carrez <Stephane.Carrez@worldnet.fr>
873
874 * config/tc-m68hc11.c (md_estimate_size_before_relax): Fix
875 STATE_INDEXED_OFFSET when the symbol is undefined (16-bit offset).
876 (build_indexed_byte): Don't relax indexed byte, use 16-bit offset
877 and fix_new_exp() instead.
878 (md_convert_frag): For indexed post byte use the symbol value
879 rather than the displacement.
880 (md_relax_table): Fix indexed offset relax.
881
882 2001-01-11 Stephane Carrez <Stephane.Carrez@worldnet.fr>
883
884 * config/tc-m68hc11.c (md_estimate_size_before_relax):Don't
885 relax weak symbols.
886 (relaxable_symbol): New function.
887
888 2001-01-11 Andreas Jaeger <aj@suse.de>
889
890 * config/tc-i386.h (TC_RELOC_GLOBAL_OFFSET_TABLE): Removed, it's
891 not used anywhere.
892
893 2001-01-10 Nick Clifton <nickc@redhat.com>
894
895 * config/tc-arm.c (arm_fix_adjustable): Define for OBJ_COFF.
896 * config/tc-arm.h (obj_fix_adjustable): Define for OBJ_COFF
897
898 2001-01-10 Nick Clifton <nickc@redhat.com>
899
900 * symbols.c (DOLLAR_LABEL_CHAR): New constant - the magic
901 character used to dollar local symbols.
902 (LOCAL_LABEL_CHAR): New constant - the magic character used to
903 local label symbols.
904 (dollar_label_name): Use DOLLAR_LABEL_CHAR.
905 (fb_label_name): Prefix local labels with LOCAL_LABEL_PREFIX,
906 if defined.
907 Use LOCAL_LABEL_CHAR.
908 (decode_local_label_name): Skip LOCAL_LABEL_PREFIX.
909 Use DOLLAR_LABEL_CHAR and LOCAL_LABEL_CHAR.
910 (S_IS_LOCAL): Use DOLLAR_LABEL_CHAR and LOCAL_LABEL_CHAR.
911
912 2001-01-08 Bo Thorsen <bo@suse.de>
913
914 * config/tc-i386.c (i386_immediate, i386_displacement):
915 GOTPCREL check fix.
916
917 2001-01-07 Ian Lance Taylor <ian@zembu.com>
918
919 * doc/c-i386.texi (i386-Arch): Remove spaces incorrectly inserted
920 in last change.
921
922 2001-01-07 Philip Blundell <philb@gnu.org>
923
924 * doc/as.texinfo (Bug Reporting): Update email address for
925 reports.
926 * README: Likewise.
927
928 Sat Jan 6 13:33:10 MET 2001 Jan Hubicka <jh@suse.cz>
929
930 * configure.in: Define DEFAULT_ARCH for i386.
931 * config/tc-i386.c (md_assemble): Return after the error message;
932 move testing for 64bit operands to proper place.
933
934 2001-01-06 Jan Hubicka <jh@suse.cz>, Andreas Jaeger <aj@suse.de>
935
936 * doc/as.texinfo: Document '#' as comment character for i386 and
937 x86_64. Add AMD x86-64 into menu of machine dependent information.
938
939 * doc/c-i386.texi: Document x86_64 extensions.
940
941 Fri Jan 5 13:26:42 MET 2001 Jan Hubicka <jh@suse.cz>
942
943 * config/tc-i386.c (md_assemble): Handle third byte of the opcode as prefix.
944
945 Thu Jan 4 22:25:26 MET 2001 Jan Hubicka <jh@suse.cz>
946
947 * config/tc-i386.c (cpu_arch): Add Pentium4 and modify sledgehammer entry.
948 * NEWS: Add note about Pentium4 support.
949
950 Wed Jan 3 17:26:32 MET 2001 Jan Hubicka <jh@suse.cz>
951
952 * config/tc-i387.c (pi, pte, pt): Update.
953 (type_names): Add new types.
954
955 Wed Jan 3 16:26:52 MET 2001 Jan Hubicka <jh@suse.cz>
956
957 * config/tc-i386.h (CpuK6, CpuAthlon, CpuSledgehammer, CpuMMX, Cpu3dnow,
958 CpuUnknown): Renumber
959 (CpuP4, CpuSSE2): New.
960 (CpuUnknownFlags): Add CpuP4 and CpuSSE2
961
962 2001-01-03 Philip Blundell <pb@futuretv.com>
963
964 * config/tc-alpha.c (alpha_force_relocation): Handle vtable
965 relocs.
966 (alpha_fix_adjustable): Likewise.
967 (md_apply_fix): Likewise.
968
969 2000-12-31 H.J. Lu <hjl@gnu.org>
970
971 * listing.c (listing_message): Allocate string only if it is
972 used.
973
974 * configure: Rebuild.
975
976 2000-12-31 Hans-Peter Nilsson <hp@bitrange.com>
977
978 * doc/internals.texi (Relaxing with a table) <after relaxation>:
979 Point out caveats with generating fixups for the opcode in a frag.
980
981 Sat Dec 30 19:02:48 MET 2000 Jan Hubicka <jh@suse.cz>
982
983 * configure.in: Add support for x86_64 and x86_64-*-linux-gnu*
984 * NEWS: Add x86_64.
985
986 2000-12-29 H.J. Lu <hjl@gnu.org>
987
988 * listing.c (calc_hex): Print the variable part only if the
989 fragment type is rs_fill.
990
991 2000-12-29 Hans-Peter Nilsson <hp@bitrange.com>
992
993 * doc/internals.texi (tc_conditional_pseudoop,
994 TC_LINKRELAX_FIXUP): Fix typos.
995
996 2000-12-28 Richard Henderson <rth@redhat.com>
997
998 * write.c (subsegs_finish): Fix thinko last change -- don't
999 "optimize" the alignment == 0 case.
1000
1001 2000-12-28 Richard Henderson <rth@redhat.com>
1002
1003 * as.h (rs_align_test): New.
1004 * frags.c (NOP_OPCODE): Move default from read.c.
1005 (MAX_MEM_FOR_RS_ALIGN_CODE): New default.
1006 (frag_align_code): New.
1007 * frags.h (frag_align_code): Declare.
1008 * read.c (NOP_OPCODE): Remove.
1009 (do_align): Use frag_align_code.
1010 * write.c (NOP_OPCODE): Remove.
1011 (get_recorded_alignment): New.
1012 (cvt_frag_to_fill): Handle rs_align_test.
1013 (relax_segment): Likewise.
1014 (subsegs_finish): Align last subseg in section to the
1015 section alignment. Use frag_align_code.
1016 * write.h (get_recorded_alignment): Declare.
1017 * config/obj-coff.c (size_section): Handle rs_align_test.
1018 (fill_section, fixup_mdeps): Likewise.
1019 (write_object_file): Use frag_align_code.
1020
1021 * config/tc-alpha.c (alpha_align): Use frag_align_code.
1022 (alpha_handle_align): New.
1023 * config/tc-alpha.h (HANDLE_ALIGN): New.
1024 (MAX_MEM_FOR_RS_ALIGN_CODE): New.
1025
1026 * config/tc-i386.h (md_do_align): Use frag_align_code.
1027 (MAX_MEM_FOR_RS_ALIGN_CODE): New.
1028
1029 * config/tc-ia64.c (ia64_md_do_align): Don't do code alignment.
1030 (ia64_handle_align): New.
1031 * config/tc-ia64.h (HANDLE_ALIGN): New.
1032 (MAX_MEM_FOR_RS_ALIGN_CODE): New.
1033
1034 * config/tc-m32r.c (m32r_do_align): Remove.
1035 (m32r_handle_align): New.
1036 (fill_insn): Use frag_align_code.
1037 * config/tc-m32r.h (md_do_align): Remove.
1038 (HANDLE_ALIGN, MAX_MEM_FOR_RS_ALIGN_CODE): New.
1039 * config/tc-m88k.c, config/tc-m88k.h: Similarly.
1040 * config/tc-mips.c, config/tc-mips.h: Similarly.
1041
1042 * config/tc-sh.c (sh_cons_align): Use rs_align_test.
1043 (sh_handle_align): Likewise. Handle rs_align_code.
1044 (sh_do_align): Remove.
1045 * config/tc-sh.h (md_do_align): Remove.
1046 (MAX_MEM_FOR_RS_ALIGN_CODE): New.
1047
1048 * config/tc-sparc.c (sparc_cons_align): Use rs_align_test.
1049 (sparc_handle_align): Likewise. Handle rs_align_code.
1050 * config/tc-sparc.h (md_do_align): Remove.
1051 (MAX_MEM_FOR_RS_ALIGN_CODE): New.
1052
1053 2000-12-22 DJ Delorie <dj@redhat.com>
1054
1055 * config/tc-d10v.c (md_assemble): set prev_seg and prev_subseg
1056 when we assemble the first half of a pair.
1057
1058 2000-12-22 H.J. Lu <hjl@gnu.org>
1059
1060 * config/tc-i386.c (reloc): Update the macro for non-bfd
1061 assembler.
1062 (BFD_RELOC_X86_64_GOTPCREL): Set to 0 for non-bfd assembler.
1063
1064 2000-12-22 H.J. Lu <hjl@gnu.org>
1065
1066 * dwarf2dbg.c (dwarf2_finish): Remove #if BFD_ASSEMBLER.
1067
1068 Wed Dec 20 14:21:22 MET 2000 Jan Hubicka <jh@suse.cz>
1069
1070 * config/tc-i386.h (i386_target_format): Define even for ELFs.
1071 (QWORD_MNEM_SUFFIX): New macro.
1072 (CpuK6,CpuAthlon,CpuSledgehammer, Cpu64, CpuNo64, CpuUnknownFlags):
1073 New macros
1074 (CpuMMX,CpuSSE,Cpu3dnow, CpuUnknown): Renumber.
1075 (IgnoreSize, DefaultSize, No_?Suf, FWait, IsString, regKludge, IsPrefix,
1076 ImmExt): Renumber.
1077 (Size64, No_qSuf, NoRex64, Rex64): New macros.
1078 (Reg64, Imm32S, Imm64, Disp32S, Disp64): New macros.
1079 (Imm8, Imm8S, Imm16, Imm32, Imm1, BaseIndex, Disp8, Disp16, Disp32,
1080 InOutPortReg,ShiftCount, Control, Debug, Test, FloatReg, FloatAcc,
1081 SReg2, SReg3, Acc, JumpAbsolute, RegMMX, RegXMM, EsSeg, InvMem):
1082 Renumber.
1083 (Reg, WordReg): Add Reg64.
1084 (Imm): Add Imm32S and Imm64.
1085 (EncImm): New.
1086 (Disp): Add Disp64 and Disp32S.
1087 (AnyMem): Add Disp32S.
1088 (RegRex, RegRex64): New macros.
1089 (rex_byte): New type.
1090 * config/tc-i386.c (set_16bit_code_flag): Kill.
1091 (fits_in_unsigned_long, fits_in_signed_long): New functions.
1092 (reloc): New parameter "signed"; support x86_64.
1093 (set_code_flag): New.
1094 (DEFAULT_ARCH): New macro; default to "i386".
1095 (default_arch): New static variable.
1096 (struct _i386_insn): New fields Operand_PCrel; rex.
1097 (flag_16bit_code): Kill; All tests replaced to "flag_code == CODE_64BIT"
1098 (flag_code): New enum and static variable.
1099 (use_rela_relocations): New static variable.
1100 (flag_code_names): New static variable.
1101 (cpu_arch_flags): Default to CpuUnknownFlags|CpuNo64.
1102 (cpu_arch): Add "sledgehammer"; Add CPUAthlon to Athlon and CpuK6 to
1103 K6 and Athlon.
1104 (i386_align_code): Return plain "nop" for x86_64.
1105 (mode_from_disp_size): Support Disp32S.
1106 (smallest_imm_type): Support Imm32S and Imm64.
1107 (offset_in_range): Support size of 8.
1108 (set_cpu_arch): Do not clobber to Cpu64/CpuNo64.
1109 (md_pseudo_table): Add "code64"; use set_code_flat.
1110 (md_begin): Emit sane error message on hash failure.
1111 (tc_i386_fix_adjustable): Support x86_64 relocations.
1112 (md_assemble): Support QWORD_MNEM_SUFFIX, REX registers,
1113 instructions supported on particular arch just partially,
1114 output of 64bit immediates, handling of Imm32S and Disp32S type.
1115 (i386_immedaite): Support x86_64 relocations; support 64bit constants.
1116 (i386_displacement): Likewise.
1117 (i386_index_check): Cleanup; support 64bit addresses.
1118 (md_apply_fix3): Support x86_64 relocation and rela.
1119 (md_longopts): Add "32" and "64".
1120 (md_parse_option): Add OPTION_32 and OPTION_64.
1121 (i386_target_format): Call even for ELFs; choose between
1122 elf64-x86-64 and elf32-i386.
1123 (i386_validate_fix): Refuse GOTOFF in 64bit mode.
1124 (tc_gen_reloc): Support rela relocations and x86_64.
1125 (intel_e09_1): Support QWORD.
1126
1127 2000-12-15 Diego Novillo <dnovillo@redhat.com>
1128
1129 * config/tc-i386.c (intel_e09_1): Only flag as a memory operand if
1130 it's not an offset expression.
1131 (intel_e10_1): Ditto. Also, if the operand is an offset expression,
1132 keep the braces '[' and ']' in the output string.
1133 (intel_e11): Ditto. Also remove comparison intel_parser.op_modifier
1134 != FLAT. There is no such op_modifier.
1135
1136 2000-12-14 Michael Sokolov <msokolov@ivan.Harhan.ORG>
1137
1138 * dwarf2dbg.c: If we don't have <limits.h>, try including <sys/param.h>
1139 if we have it.
1140
1141 2000-12-13 Kazu Hirata <kazu@hxi.com>
1142
1143 * as.h: Fix formatting.
1144 * cgen.h: Likewise.
1145 * dwarf2dbg.c: Likewise.
1146 * input-scrub.c: Likewise.
1147 * read.h: Likewise.
1148
1149 2000-12-13 Mark Elbrecht <snowball3@bigfoot.com>
1150
1151 * configure.in (i386-*-msdosdjgpp): Set bfd_gas to yes.
1152 configure: Regenerate.
1153
1154 2000-12-13 Michael Sokolov <msokolov@ivan.Harhan.ORG>
1155
1156 * dwarf2dbg.c: #include <limits.h> only if it exists.
1157
1158 2000-12-13 Rodney Brown <RodneyBrown@mynd.com>
1159
1160 * config/tc-hppa.c (pa_ip): Correct CHECK_FIELD typo.
1161 (md_apply_fix): Here too.
1162
1163 2000-12-12 Jim Wilson <wilson@redhat.com>
1164
1165 * config/tc-ia64.h (ia64_init): Add prototype.
1166
1167 2000-12-12 H.J. Lu <hjl@gnu.org>
1168
1169 * dwarf2dbg.c: Enabled only if BFD_ASSEMBLER is defined.
1170
1171 * read.h (outputting_stabs_line_debug): Change it to int.
1172 * stabs.c (outputting_stabs_line_debug): Likewise.
1173
1174 2000-12-12 Geoffrey Keating <geoffk@redhat.com>
1175
1176 * config/obj-bout.c (obj_crawl_symbol_chain): Don't take
1177 the address of a function result.
1178
1179 2000-12-12 Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
1180
1181 * config/tc-ppc.c (md_pseudo_table): Add .file and .loc.
1182 (md_assemble): Call dwarf2_emit_insn.
1183 (shlib): Fix typo SHILB -> SHLIB.
1184 (md_parse_option): Likewise.
1185 (ppc_elf_validate_fix): Likewise:
1186 * config/tc-ppc.h (DWARF2_LINE_MIN_INSN_LENGTH): New.
1187
1188 2000-12-12 Nick Clifton <nickc@redhat.com>
1189
1190 * cgen.h: Fix formatting.
1191 * input-scrub.c: Fix formatting.
1192 * macro.c: Fix formatting.
1193 * config/tc-mips.c: Fix formatting.
1194 * doc/c-mips.texi: Fix formatting.
1195
1196 Mon Dec 11 14:35:42 MET 2000 Jan hubicka <jh@suse.cz>
1197
1198 * config/tc-i386.c (md_assemble): Refuse 's' and 'l' suffixes in the intel
1199 mode; convert 'd' suffix to 's' or 'l'; remove all DWORD_MNEM_SUFFIX
1200 references.
1201 (intel_e09_1): Convert QWORD to 'l' suffix for FP operations; refuse
1202 otherwise.
1203 * config/tc-i386.h (DWORD_MNEM_SUFFIX): Kill.
1204 (No_dSuf): Kill.
1205
1206 * i386.h (*_Suf): Remove No_dSuf.
1207 (d_suf, wld_Suf,sld_Suf, sldx_Suf, bwld_Suf, d_FP, sld_FP, sldx_FP)
1208 Remove.
1209 (i386_optab): Remove 'd' in the suffixes.
1210
1211 2000-12-06 Mark Elbrecht <snowball3@bigfoot.com>
1212
1213 * config/tc-i386.c (T_SHORT): Undefine before defining.
1214
1215 2000-12-05 Kazu Hirata <kazu@hxi.com>
1216
1217 * config/tc-mips.c: Fix formatting.
1218
1219 2000-12-04 Matthew Hiller <hiller@redhat.com>
1220
1221 * config/tc-d10v.c (flag_allow_gstabs_packing): New variable.
1222 (md_longopts): New options --gstabs-packing, --no-gstabs-packing.
1223 (md_show_usage): Ditto.
1224 (md_parse_option): Ditto.
1225 (d10v_cleanup): Writes pending instruction only if
1226 ! outputting_stabs_line_debug || ! flag_allow_gstabs_packing.
1227 Fix compile time warning messages.
1228
1229 * doc/c-d10v.texi: Documents new options.
1230
1231 2000-12-04 Matthew Hiller <hiller@redhat.com>
1232
1233 * stabs.c (outputting_stabs_line_debug): New variable.
1234 (stabs_generate_asm_lineno): Set outputting_stabs_line_debug at
1235 function entry and unset at function exit.
1236
1237 * read.h (outputting_stabs_line_debug): New extern declaration.
1238
1239 * as.c: Include dwarf2dbg.h for definition of dwarf2_finish.
1240
1241 * dwarf2dbg.c: Fix compile time warning messages.
1242
1243 2000-12-03 Kazu Hirata <kazu@hxi.com>
1244
1245 * config/tc-a29k.c: Fix formatting.
1246 * config/tc-alpha.c: Likewise.
1247 * config/tc-arm.c: Likewise.
1248 * config/tc-cris.c: Likewise.
1249 * config/tc-hppa.c: Likewise.
1250 * config/tc-i370.c: Likewise.
1251 * config/tc-i386.c: Likewise.
1252 * config/tc-i860.c: Likewise.
1253 * config/tc-i960.c: Likewise.
1254 * config/tc-ia64.c: Likewise.
1255 * config/tc-m68hc11.c: Likewise.
1256 * config/tc-m68k.c: Likewise.
1257 * config/tc-m88k.c: Likewise.
1258 * config/tc-pj.c: Likewise.
1259 * config/tc-ppc.c: Likewise.
1260 * config/tc-sh.c: Likewise.
1261 * config/tc-sparc.c: Likewise.
1262 * config/tc-tahoe.c: Likewise.
1263 * config/tc-vax.c: Likewise.
1264
1265 2000-12-01 Chris Demetriou <cgd@sibyte.com>
1266
1267 * config/tc-mips.c (mips_ip): When calculating offsets,
1268 don't accept as constant the difference between the
1269 addresses of symbols in two different sections.
1270
1271 * config/tc-mips.c (macro_build): Add new 'U' and 'J' operand
1272 specifiers.
1273 (validate_mips_insn): Likewise. Also, update 'B' operand
1274 specifier to use OP_*_CODE20 constants and delete 'm' operand
1275 specifier.
1276 (mips_ip): Remove 'm' operand specifier, add 'U' and 'J'
1277 operand specifiers. Change warning generated by 'B' operand
1278 specifier to reflect its new multi-purpose usage.
1279
1280 * config/tc-mips.c (mips_set_options): Use ISA_UNKNOWN rather than
1281 -1, and update comment.
1282 (file_mips_isa): Likewise.
1283 (mips_cpu): Use CPU_UNKNOWN rather than -1, and update comment.
1284 (ISA_HAS_COPROC_DELAYS, ISA_HAS_64BIT_REGS, gpr_interlocks): Use
1285 ISA_* constants rather than hard-coded numbers.
1286 (mips_cpu_info): New structure.
1287 (mips_cpu_info_table): New table describing CPU and ISA names
1288 and numbers.
1289 (mips_cpu_info_from_name, mips_cpu_info_from_isa,
1290 mips_cpu_info_from_cpu): New functions.
1291 (mips_isa_to_str): New function to get string for ISA name.
1292 (mips_cpu_to_str): Convert to use mips_cpu_info_from_cpu, and
1293 return const char *.
1294 (md_begin): Redo CPU and ISA selection logic, using
1295 mips_cpu_info_from_*. Convert to use ISA_* constants rather
1296 than hard-coded numbers.
1297 (append_insn, mips_emit_delays, macro, macro2): Convert to use
1298 ISA_* constants rather than hard-coded numbers.
1299 (mips_ip): Convert to use mips_isa_to_str to get ISA name.
1300 (md_longopts): Delete OPTION_NO_MIPS32.
1301 (md_parse_option): Convert to use ISA_* constants rather than
1302 hard-coded numbers. Make OPTIONS_MIPS32 case treat MIPS32
1303 as an ISA. Delete OPTION_NO_MIPS32 case. Convert OPTION_MCPU
1304 to use strcasecmp to recognize "default" and to use
1305 mips_cpu_info_from_name to get CPU numbers from argument.
1306 (md_show_usage): Move -mips32 so it's with the rest of the ISA
1307 flags. Change 4Kc, 4Kp and 4Km CPU entries to just be
1308 mips32-4k.
1309 (s_mipsset): Accept ISA value 32.
1310 * doc/as.texinfo: Clean up MIPS options summary slightly,
1311 remove -no-mips32. Add note about -mips4 and -mips32
1312 specifying those ISA levels. Delete -mips32 and -no-mips32
1313 cpu flag descriptions.
1314 * doc/c-mips.texi: Add -mips32 to list of ISA switches. Clean
1315 up the supported CPU switch list, and replace 4Kc, 4Km, and
1316 4Kp entries with a single mips32-4k entry. Note that you can
1317 use ".set mips32".
1318
1319 * config/tc-mips.c (ISA_HAS_64BIT_REGS): Add checks for ISA_MIPS5 and
1320 ISA_MIPS64.
1321 (md_longopts, OPTION_MIPS5, OPTION_MIPS64): Add options for
1322 -mips5 and -mips64.
1323 (md_parse_option): Add cases for OPTION_MIPS5 and
1324 OPTION_MIPS64.
1325 (md_show_usage): Mention -mips5 and -mips64 arguments.
1326 (s_mipsset): Add cases for MIPS5 and MIPS64.
1327 (mips_cpu_info_table): Add entries for MIPS5 and MIPS64 ISAs
1328 and pseudo-CPUs.
1329 * doc/as.texinfo: Mention -mips5 and -mips64 options
1330 and their meanings.
1331 * doc/c-mips.texi: Likewise. Also update introduction
1332 and ".set" usage information.
1333
1334 * config/tc-mips.c (md_show_usage): Add "sb1" to the
1335 CPU list.
1336 (mips_cpu_info_table): Add SB-1 entries.
1337 * doc/c-mips.texi: Add "sb1" to the list of CPUs
1338 known to the -mcpu option.
1339
1340 * doc/as.texinfo: Correct description of MIPS -mcpu
1341 option, by copying some of the text from doc/c-mips.texi.
1342
1343 2000-12-01 Joel Sherrill <joel@OARcorp.com>
1344
1345 * configure.in (arm-*-rtems*, a29k-*rtems*, h8300-*-rtems*):
1346 New targets.
1347 (sparc*-*-rtemself*, sparc*-*-rtemsaout*): New targets.
1348 (sparc*-*-rtems*): Switched from a.out to ELF.
1349 * configure: Regenerate.
1350 * config.in: Regenerate.
1351 * Makefile.in: Regenerate.
1352 * aclocal.m4: Regenerate.
1353 * po/gas.pot: Regenerate.
1354
1355 2000-11-30 Philip Blundell <pb@futuretv.com>
1356
1357 * config/obj-coff.c (obj_coff_weak): Use S_SET_WEAK if it exists,
1358 even in non BFD_ASSEMBLER case.
1359
1360 2000-11-30 Diego Novillo <dnovillo@redhat.com>
1361
1362 * config/tc-i386.c (md_assemble): Swap i.disp_relocs when using intel
1363 syntax.
1364
1365 2000-11-29 Richard Henderson <rth@redhat.com>
1366
1367 * dwarf2dbg.c: Rewrite from scratch. Queue all debugging output
1368 until dwarf2_finish; use relaxation to get cross-fragment offsets;
1369 thread multiple subsegments properly; handle multiple code
1370 sections properly; emit proper compilation unit info for assembler
1371 generated debugging.
1372
1373 * as.h (enum _relax_state): Add rs_dwarf2dbg.
1374 * dwarf2dbg.h (struct dwarf2_line_info): Remove filename.
1375 (dwarf2dbg_estimate_size_before_relax): Declare.
1376 (dwarf2dbg_relax_frag, dwarf2dbg_convert_frag): Declare.
1377 * write.c: Include dwarf2dbg.h.
1378 (cvt_frag_to_fill): Handle rs_dwarf2dbg.
1379 (relax_segment): Likewise.
1380
1381 2000-11-28 Hans-Peter Nilsson <hp@bitrange.com>
1382
1383 * config/tc-sh.c (md_convert_frag) <undefined symbol, conditional
1384 jump>: Use as_bad_where instead of as_bad. Tweak error message
1385 accordingly. Stabilize frag by updating fix part and resetting
1386 variant part.
1387 <undefined symbol, unconditional jump>: Ditto.
1388 (sh_elf_cons): Cast *input_line_pointer to unsigned char when
1389 indexing is_end_of_line[].
1390 (md_assemble): Initialize size to 0.
1391 (md_section_align): Mark parameter seg as unused.
1392 (parse_reg): Parse names case-insensitively.
1393
1394 2000-11-28 Kazu Hirata <kazu@hxi.com>
1395
1396 * config/obj-aout.h: Fix formatting.
1397 * config/obj-bout.h: Likewise.
1398 * config/obj-coff.c: Likewise.
1399 * config/obj-coff.h: Likewise.
1400 * config/obj-elf.h: Likewise.
1401 * config/obj-som.h: Likewise.
1402 * config/obj-vms.c: Likewise.
1403 * config/obj-vms.h: Likewise.
1404 * config/tc-h8300.h: Likewise.
1405 * config/tc-ns32k.h: Likewise.
1406 * config/tc-sparc.h: Likewise.
1407 * config/tc-tic54x.h: Likewise.
1408 * config/tc-z8k.h: Likewise.
1409
1410 2000-11-28 Nick Clifton <nickc@redhat.com>
1411
1412 * doc/as.1 (COPYING): Mention that the GNU Free Documentation
1413 License is present in the sources, but not the output, and
1414 also available from the GNU website.
1415 (GNU Free Documentation License): Comment out this section.
1416
1417 2000-11-28 Hans-Peter Nilsson <hp@axis.com>
1418
1419 * Makefile.am (CPU_OBJ_VALID): Add case to filter out invalid coff
1420 targets. Remove i860 from valid a.out targets.
1421 * Makefile.in: Regenerate.
1422
1423 * config/tc-cris.c: Include dwarf2dbg.h.
1424 (md_pseudo_table): Add .file and .loc.
1425 (md_assemble): Call dwarf2_emit_insn if generating ELF.
1426 (s_cris_file, s_cris_loc): New.
1427 * config/tc-cris.h (DWARF2_LINE_MIN_INSN_LENGTH): Define.
1428 * Makefile.am: Regenerate dependencies.
1429 * Makefile.in: Regenerate.
1430
1431 2000-11-28 Alan Modra <alan@linuxcare.com.au>
1432
1433 * expr.c (STANDARD_MUL_PRECEDENCE): Correct value.
1434 (MRI_MUL_PRECEDENCE): Likewise.
1435 (op_rank): Fix a comment typo.
1436
1437 2000-11-26 Stephane Carrez <Stephane.Carrez@worldnet.fr>
1438
1439 * config/tc-m68hc11.c (build_indexed_byte): Print the offset in
1440 the error message.
1441 (get_operand): Fix analysis for movw/movb instructions.
1442
1443 2000-11-24 Nick Clifton <nickc@redhat.com>
1444
1445 * configure.in (xscale-elf): Add target.
1446 (xscale-coff): Add target.
1447 * configure: Regenerate.
1448
1449 * config/tc-arm.c (ARM_EXT_V5E): New ARM architecture
1450 extenstion.
1451 (ARM_EXT_XSCALE): New ARM architecture extension.
1452 (ARM_LONGMUL): Rename to ARM_EXT_LONGMUL.
1453 (ARM_HALFWORD): Rename to ARM_EXT_HALFWORD.
1454 (ARM_THUMB): Rename to ARM_EXT_THUMB.
1455 (ARM_ARCH_V4): Remove processor from architecture.
1456 (ARM_ARCH_3M): New architecutre definition.
1457 (ARM_ARCH_V5TE): New architecutre definition.
1458 (ARM_ARCH_XSCALE): New architecutre definition.
1459 (CPU_DEFAULT): Allow to be defaulted to XScale.
1460 (atpcs): New boolean variable.
1461 (ldr_flags): Support 'd' flag for double word loads.
1462 (str_flags): Support 'd' flag for double word stored.
1463 (do_mia): New function.
1464 (do_mar): New function.
1465 (do_mra): New function.
1466 (do_pld): New function.
1467 (do_ldrd): New function.
1468 (do_blx): New function.
1469 (do_bkpt): New function.
1470 (do_clz): New function.
1471 (do_lstc2): New function.
1472 (do_cdp2): New function.
1473 (do_t_blx): New function.
1474 (do_t_bkpt): New function.
1475 (do_smla): New function.
1476 (do_smlal): New function.
1477 (do_smul): New function.
1478 (do_qadd): New function.
1479 (do_co_reg2c): New function.
1480 (LONGEST_INSN): Redefine to 7.
1481
1482 * doc/c-arm.texi: Document -mxscale, -mmarmv5te and -matpcs
1483 command line switches.
1484
1485 2000-11-22 Jim Wilson <wilson@redhat.com>
1486
1487 * config/tc-ia64.c (pseudo_func): Add missing initializers.
1488 (struct rsrc): Make line unsigned.
1489 (gr_values): Add missing initializer.
1490 (SLOT_NUM_NOT_SET): Add unsigned cast.
1491 (ia64_elf_section_flags, output_vbyte_mem, count_output, dot_radix,
1492 dot_fframe, dot_vframe, dot_vframesp, dot_vframepsp, dot_save,
1493 dot_restore, dot_restorereg, dot_restorereg_p, dot_handlerdata,
1494 dot_unwentry, dot_altrp, dot_saveg, dot_savef, dot_saveb, dot_savegf,
1495 dot_spill, dot_spillreg, dot_spillreg_p, dot_label_state,
1496 dot_copy_state, dot_unwabi, dot_personality, dot_proc, dot_body,
1497 dot_prologue, dot_endp, dot_regstk, dot_psr, dot_alias, dot_ln,
1498 dot_reg_val, dot_entry, dot_mem_offset, ia64_init, mark_resource,
1499 md_undefined_symbol, md_apply_fix3, tc_gen_reloc, ia64_md_do_align):
1500 Add ATTRIBUTE_UNUSED to unused parameters.
1501 (convert_expr_to_ab_reg): Add parens.
1502 (convert_expr_to_xy_reg): Add parens. Comment out >= REG_GR test.
1503 (dot_prologue): Initialize grsave when declared.
1504 (md_pseudo_table): Add missing initializers.
1505 (operand_match): Add casts to bfd_vma.
1506 (emit_one_bundle): Delete unused local prev. Make required_template
1507 unsigned.
1508 (specify_resource): Cast i to unsigned.
1509 (note_register_values): Use fprintf_vma.
1510 (print_dependency): Likewise.
1511
1512 2000-11-21 Jim Wilson <wilson@redhat.com>
1513
1514 * config/tc-ia64.c (generate_unwind_image): Call record_alignment
1515 for unwind info section.
1516 (dot_endp): Likewise for unwind section.
1517
1518 * config/tc-ia64.c (emit_one_bundle): Pass size of 8 not 4 to
1519 fix_new_exp.
1520
1521 2000-11-21 Jakub Jelinek <jakub@redhat.com>
1522
1523 * config/tc-sparc.c (md_pseudo_table): Add .file and .loc.
1524 (output_insn): Call dwarf2_emit_insn.
1525 * config/tc-sparc.h (DWARF2_LINE_MIN_INSN_LENGTH): New.
1526
1527 2000-11-17 Richard Henderson <rth@redhat.com>
1528
1529 * ehopt.c (eh_frame_code_alignment): New arg `in_seg', update all
1530 callers. Don't switch segments. Expect CIE == -1 in .debug_frame.
1531 (check_eh_frame): Handle .eh_frame and .debug_frame concurrently.
1532
1533 2000-11-17 Nick Clifton <nickc@redhat.com>
1534
1535 * config/tc-arm.c (md_pseudo_table): Add support for .line and
1536 .file pseudo ops.
1537
1538 2000-11-17 Richard Henderson <rth@redhat.com>
1539
1540 * config/tc-i386.c (md_pseudo_table): Add .file and .loc.
1541
1542 2000-11-17 Richard Henderson <rth@redhat.com>
1543
1544 * dwarf2dbg.c (dwarf2_gen_line_info): Early out for no line number.
1545 * config/obj-elf.h (ECOFF_DEBUGGING) [TC_ALPHA]: Adjust for
1546 tri-state definition of alpha_flag_mdebug.
1547 * config/tc-alpha.c (alpha_flag_mdebug): Init to -1.
1548 (s_alpha_file): Store first .file directive.
1549 (s_alpha_stab): New.
1550 (md_pseudo_table): Add stabs and stabn.
1551
1552 2000-11-17 Richard Henderson <rth@redhat.com>
1553
1554 * config/tc-i386.c (md_assemble): Call dwarf2_emit_insn.
1555
1556 2000-11-17 Richard Henderson <rth@redhat.com>
1557
1558 * as.c (debug_type): Init to DEBUG_UNSPECIFIED.
1559 (main): Call dwarf2_finish.
1560 * as.h (debug_type): Clarify documentation of the meaning
1561 of this variable.
1562 * dwarf2dbg.c (DWARF2_LINE_MIN_INSN_LENGTH): Default to 1.
1563 (print_stats): Fix parenthesis problem.
1564 (now_subseg_size): New.
1565 (dwarf2_finish): Use it. If DEBUG_DWARF2, emit bits for .debug_info.
1566 (dwarf2_directive_file): Don't set debug_type.
1567 (dwarf2_where): Honor DEBUG_DWARF2 first.
1568 (dwarf2_emit_insn): Renamed from dwarf2_generate_asm_lineno;
1569 do nothing if not emitting dwarf2 debug info, or no work.
1570 * dwarf2dbg.h (dwarf2_emit_insn): Update.
1571 * ecoff.c (add_file): Turn on DEBUG_ECOFF only if DEBUG_UNSPECIFIED.
1572 (ecoff_new_file): Likewise.
1573 * read.c (generate_lineno_debug): Kill ecoff hackery. Update
1574 commentary wrt dwarf2.
1575
1576 * config/tc-alpha.c (alpha_adjust_symtab_relocs): Add
1577 ATTRIBUTE_UNUSED as needed.
1578 (emit_insn): Call dwarf2_emit_insn.
1579 (s_alpha_file): New.
1580 (s_alpha_loc): New.
1581 (s_alpha_coff_wrapper): Don't handle them.
1582 (md_pseudo_table): Update for .file and .loc.
1583 * config/tc-alpha.h (DWARF2_LINE_MIN_INSN_LENGTH): New.
1584
1585 * config/tc-arm.c (output_inst): Update for dwarf2_emit_insn;
1586 don't protect with debug_type.
1587 * config/tc-hppa.c (md_assemble): Likewise.
1588 * config/tc-m68hc11.c (m68hc11_new_insn): Likewise.
1589 * config/tc-mn10300.c (md_assemble): Likewise.
1590 * config/tc-sh.c (md_assemble): Likewise.
1591 * config/tc-v850.c (md_assemble): Likewise.
1592
1593 * config/tc-arm.c (arm_end_of_source): Remove.
1594 * config/tc-hppa.c (pa_end_of_source): Remove.
1595 * config/tc-m68hc11.c (m68hc11_end_of_source): Remove.
1596 * config/tc-mn10300.c (mn10300_finalize): Remove.
1597 * config/tc-sh.c (sh_finalize): Remove.
1598 * config/tc-v850.c (sh_finalize): Remove.
1599
1600 * config/tc-arm.h (md_end): Remove.
1601 * config/tc-hppa.h (md_end): Remove.
1602 (DWARF2_LINE_MIN_INSN_LENGTH): New.
1603 * config/tc-m68hc11.h (md_end): Remove.
1604 * config/tc-mn10300.h (md_end): Remove.
1605 * config/tc-sh.h (md_end): Remove.
1606 * config/tc-v850.h (md_end): Remove.
1607
1608 * config/tc-ia64.c (emit_one_bundle): Don't protect
1609 dwarf2 bits with debug_type.
1610 (md_assemble): Likewise.
1611 (ia64_end_of_source): Don't call dwarf2_finish.
1612
1613 2000-11-16 Jim Wilson <wilson@redhat.com>
1614
1615 * config/tc-ia64.c (errata_nop_necessary_p): Abort if general regno
1616 >= 128 instead of > 128. Abort if predicate regno is >= 64 instead of
1617 > 16.
1618
1619 2000-11-16 H.J. Lu <hjl@gnu.org>
1620
1621 * config/obj-elf.c (obj_elf_symver): Don't check the missing
1622 version name.
1623
1624 2000-11-15 Kazu Hirata <kazu@hxi.com>
1625
1626 * config/tc-tic30.c: Fix formatting.
1627 * config/tc-tic80.c: Likewise.
1628 * config/tc-v850.c: Likewise.
1629 * config/tc-vax.c: Likewise.
1630 * config/tc-w65.c: Likewise.
1631 * config/tc-z8k.c: Likewise.
1632
1633 2000-11-14 DJ Delorie <dj@redhat.com>
1634
1635 * config/tc-v850.c: Support dwarf2.
1636 * config/tc-v850.h: Ditto.
1637
1638 * config/tc-v850.c (cons_fix_new_v850): Don't rely on
1639 parse_cons_expression_v850 to initialize hold_cons_reloc.
1640
1641 2000-11-15 Bernd Schmidt <bernds@redhat.com>
1642
1643 * config/tc-ia64.c (struct md): New entries LAST_GROUPS, GROUP_IDX.
1644 (errata_nops_necessary_p): New function.
1645 (emit_one_bundle): Call it. Update the GROUP_IDX field in struct
1646 md.
1647
1648 2000-11-14 Jim Wilson <wilson@redhat.com>
1649
1650 * config/tc-ia64.c (ia64_target_format): If EF_IA_64_BE not set, then
1651 return little endian bfd formats.
1652
1653 2000-11-14 Kazu Hirata <kazu@hxi.com>
1654
1655 * config/aout_gnu.h: Fix formatting.
1656 * config/atof-vax.c: Likewise.
1657 * config/m68k-parse.h: Likewise.
1658 * config/m88k-opcode.h: Likewise.
1659 * config/obj-elf.c: Likewise.
1660 * config/tc-arm.c: Likewise.
1661 * config/tc-cris.c: Likewise.
1662 * config/tc-i386.c: Likewise.
1663 * config/tc-ia64.c: Likewise.
1664 * config/tc-mn10300.c: Likewise.
1665 * config/te-386bsd.h: Likewise.
1666 * config/te-hppa.h: Likewise.
1667 * config/te-nbsd.h: Likewise.
1668 * config/te-ppcnw.h: Likewise.
1669 * config/te-sparcaout.h: Likewise.
1670 * config/te-tmips.h: Likewise.
1671 * config/vax-inst.h: Likewise.
1672 * config/vms-conf.h: Likewise.
1673
1674 2000-11-14 Jakub Jelinek <jakub@redhat.com>
1675
1676 * config/tc-alpha.c (s_alpha_prologue): Preserve visibility bits.
1677
1678 2000-11-13 H.J. Lu <hjl@gnu.org>
1679
1680 * config/obj-elf.c (elf_frob_symbol): Support
1681 ".symver name,name2@@@nodename".
1682 (elf_frob_file_before_adjust): Likewise.
1683
1684 * doc/as.texinfo: Updated for ".symver name,name2@@@nodename"
1685 and ".symver name,name2@@@nodename".
1686 Fix a typo.
1687
1688 2000-11-12 H.J. Lu (hjl@gnu.org)
1689
1690 * config/obj-elf.c (obj_elf_symver): Check missing version
1691 name.
1692
1693 2000-11-12 H.J. Lu (hjl@gnu.org)
1694
1695 * dwarf2dbg.c (dwarf2_generate_asm_lineno): Use addressT
1696 instead of bfd_vma for non-bfd assemblers.
1697
1698 2000-11-09 Kazu Hirata <kazu@hxi.com>
1699
1700 * itbl-ops.c: Fix comment typos.
1701
1702 2000-11-08 Jim Wilson <wilson@redhat.com>
1703
1704 * config/tc-ia64.c (struct unw_rec_list): Add slot_frag field.
1705 (struct unwind): Add next_slot_frag field.
1706 (slot_index): New parameters slot_frag and first_frag. Add code
1707 to add in frag sizes when different. Add comments.
1708 (fixup_unw_records): New locals first_frag and last_frag. Pass new
1709 arguments to slot_index.
1710 (emit_one_bundle): Set slot_frag field. Set next_slot_number after
1711 loop end. Set next_slot_frag field.
1712
1713 2000-11-07 H.J. Lu <hjl@gnu.org>
1714
1715 * doc/as.texinfo (.symver): Updated for versioned symbol
1716 reference.
1717
1718 * obj.h (format_ops): Add the frob_file_before_adjust field.
1719
1720 * config/obj-aout.c (aout_format_ops): Set the
1721 frob_file_before_adjust field to 0.
1722 * config/obj-coff.c (coff_format_ops): Likewise.
1723 * config/obj-ecoff.c (ecoff_format_ops): Likewise.
1724
1725 * config/obj-elf.c (obj_elf_symver): Allow duplicated version
1726 name.
1727 (elf_frob_file_before_adjust): New function to remove unneeded
1728 versioned symbols from the symbol table.
1729 (elf_format_ops): Set the frob_file_before_adjust field to
1730 elf_frob_file_before_adjust.
1731
1732 * config/obj-elf.h (obj_frob_file_before_adjust): Defined if
1733 not defined.
1734
1735 * config/obj-multi.h (obj_frob_file_before_adjust): Defined.
1736
1737 2000-11-07 Peter Targett <peter.targett@arccores.com>
1738
1739 * gas/config/tc-arc.h: Avoid warnings for LITTLE_ENDIAN and
1740 BIG_ENDIAN macros.
1741 * gas/config/tc-arc.c: Use S_IS_LOCAL to test local symbols.
1742 Fix compile time warning messages.
1743
1744 2000-11-07 Nick Clifton <nickc@redhat.com>
1745
1746 * stabs.c (generate_asm_file): Increase length of xmalloc'ed
1747 buffer in order to avoid buffer overflows.
1748
1749 2000-11-06 Steve Ellcey <sje@cup.hp.com>
1750
1751 * config/tc-ia64.c (md_shortopts, md_parse_option, md_show_usage):
1752 Change M to m for -milp32 or -mlp64 to match gcc.
1753 (dot_endp): Use bytes_per_address instead of 8.
1754 (emit_one_bundle): Use number_to_chars_littleendian instead of
1755 md_number_to_chars.
1756 (fix_insn): Likewise.
1757 (ia64_init): New function.
1758 (ia64_target_format): New function.
1759 (md_begin): Set endianness, arch, and machine as appropriate.
1760 * config/tc-ia64.h: (TARGET_BYTES_BIG_ENDIAN, md_number_to_chars):
1761 Make these macros depend on TE_HPUX macro.
1762 (TARGET_FORMAT): Define.
1763 (HOST_SPECIAL_INIT): Define.
1764 * config/te-hpux.h: New file.
1765 * configure.in: Add "ia64-*-hpux*" target to configure.
1766 * configure: Regenerate.
1767
1768 2000-11-06 Kazu Hirata <kazu@hxi.com>
1769
1770 * as.c: Fix formatting.
1771 * dwarf2dbg.c: Likewise.
1772 * input-file.c: Likewise.
1773 * input-file.h: Likewise.
1774 * input-scrub.c: Likewise.
1775 * itbl-ops.c: Likewise.
1776 * listing.c: Likewise.
1777 * macro.h: Likewise.
1778 * messages.c: Likewise.
1779 * read.c: Likewise.
1780 * subsegs.c: Likewise.
1781 * subsegs.h: Likewise.
1782 * write.c: Likewise.
1783
1784 2000-11-06 Nick Clifton <nickc@redhat.com>
1785
1786 * doc/as.texinfo: Add GNU Free Documentation License.
1787 * doc/gasp.texi: Add GNU Free Documentation License.
1788 * doc/as.1: Add GNU Free Documentation License.
1789
1790 2000-11-05 Nick Clifton <nickc@redhat.com>
1791
1792 * config/tc-arm.c: Add include of "dwarf2dbg.h"
1793
1794 2000-11-02 Per Lundberg <plundis@chaosdev.org>
1795
1796 * configure.in: Recognise i[3456]86-chaosdev-storm-chaos.
1797 * configure: Regenerate.
1798
1799 2000-11-01 Nick Clifton <nickc@redhat.com>
1800
1801 * read.c (original_case_string): New global variable.
1802 (read_a_source_file): Copy opcode string into
1803 original_case_string if clobbering the case of the opcode.
1804 * read.h: Export the definition of original_case_string.
1805 * config/tc-arm.c (md_assembler): When parsing a .req
1806 directive use the original opcode string, not the case
1807 clobbered version.
1808
1809 2000-11-02 Nick Clifton <nickc@redhat.com>
1810
1811 * config/tc-mn10300.c (debug_line): Remove this static
1812 variable.
1813 (md_assemble): Call dwarf2_generate_asm_lineno instead of
1814 dwarf2_where and dwarf2_gen_line_info.
1815
1816 2000-11-02 Theo Honohan <th@futuretv.com>
1817
1818 * config/tc-arm.c (do_msr): Improve error message.
1819
1820 2000-10-31 Eric Christopher <echristo@redhat.com>
1821
1822 * config/tc-mn10300.c (md_apply_fix3): Use valuep if fully resolved
1823 or pc-relative, else use fx_offset.
1824
1825 2000-10-31 Jim Wilson <wilson@redhat.com>
1826
1827 * config/tc-ia64.c (struct md): New field tag_fixups.
1828 (ia64_flush_insns): Handle tag_fixups. Error if dangling
1829 qualifying predicate.
1830 (emit_one_bundle): Delete spurious multiplication by one. Handle
1831 tag_fixups.
1832 (ia64_start_line): Error if dangling qualifying predicate.
1833 (defining_tag): New static variable.
1834 (ia64_unrecognized_line, case '['): Parse tags.
1835 (ia64_frob_label): Create tag_fixups.
1836 (md_assemble): Reset md.qp.X_op after using it.
1837
1838 2000-10-31 Kaz Kojima <kkojima@rr.iij4u.or.jp>
1839
1840 * config/tc-sh.c (md_apply_fix [BFD_RELOC_SH_PCDISP12BY2]): Allow 4094.
1841
1842 2000-10-31 Bernd Schmidt <bernds@redhat.co.uk>
1843
1844 * config/tc-ia64.c (extra_goodness): Only prefer F in slot 1 and B in slot 2.
1845
1846 2000-10-30 Kazu Hirata <kazu@hxi.com>
1847
1848 * expr.c: Fix formatting.
1849 * flonum-copy.c: Likewise.
1850 * flonum.h: Likewise.
1851 * gasp.c: Likewise.
1852 * hash.c: Likewise.
1853
1854 2000-10-30 Hans-Peter Nilsson <hp@bitrange.com>
1855
1856 * as.h (OPTION_MD_BASE): Bump to 190.
1857 * as.c (parse_args) <std_longopts>: Add comment about the need to
1858 check OPTION_MD_BASE in as.h.
1859
1860 * config/tc-sh.c (md_apply_fix): For ELF, do not "adjust back" VAL
1861 for weak symbols.
1862
1863 2000-10-27 Nick Clifton <nickc@redhat.com>
1864
1865 * configure.in (emulations): Add m68hc12.
1866 * configure: Regenerate.
1867 * po/gas.pot: Regenerate.
1868
1869 2000-10-27 Aldy Hernandez <aldyh@redhat.com>
1870
1871 * config/tc-arm.c (psrs): Remove lowercase versions of spsr* and
1872 cpsr*.
1873 (arm_psr_parse): Handle lowercase CPSR and SPSR.
1874
1875 2000-10-25 Nick Clifton <nickc@redhat.com>
1876
1877 * dwarf2out.c (dwarf2_generate_asm_lineno): New function: Generate
1878 a DWARF2 line number information sequence.
1879
1880 *dwarf2out.h: Add prototype for dwarf2_generate_asm_lineno.
1881
1882 * read.c (generate_lineno_debug): Update comment describing why
1883 DWARF2 line number debug information is not generated
1884 automatically by this function.
1885
1886 * doc/as.texinfo: Note that --gdwarf2 only works on some targets,
1887 not all.
1888
1889 * config/tc-arm.h (md_end): Define.
1890 (DWARF2_LINE_MIN_INSN_LENGTH): Define.
1891
1892 * config/tc-arm.c (output_inst): Call dwarf2_generate_asm_lineno
1893 if generating DWARF2 line numbers.
1894 (arm_end_of_source): New function. Call dwarf2_finish if
1895 necessary.
1896
1897 * config/tc-hppa.c (md_assemble): Use dwarf2_generate_asm_lineno.
1898 * config/tc-m68hc11.c (m68hc11_new_insn): Use dwarf2_generate_asm_lineno.
1899 * config/tc-sh.c (md_assemble): Use dwarf2_generate_asm_lineno.
1900
1901 2000-10-25 Diego Novillo <dnovillo@cygnus.com>
1902
1903 * config/tc-i386.c: Fix prototype declarations for functions taking no
1904 arguments.
1905
1906 2000-10-24 Diego Novillo <dnovillo@cygnus.com>
1907
1908 * config/tc-i386.c (i386_operand_modifier): Remove.
1909 (build_displacement_string): Remove.
1910 (i386_parse_seg): Remove.
1911 (i386_intel_memory_operand): Remove.
1912 (i386_intel_operand): Re-write using recursive descent parser based
1913 on MASM documentation.
1914 (struct intel_parser_s): New structure.
1915 (intel_parser): New static variable.
1916 (struct intel_token): New structure.
1917 (cur_token, prev_token): New static variables.
1918 (T_NIL): Define.
1919 (T_CONST): Define.
1920 (T_REG): Define.
1921 (T_BYTE): Define.
1922 (T_WORD): Define.
1923 (T_DWORD): Define.
1924 (T_QWORD): Define.
1925 (T_XWORD): Define.
1926 (T_SHORT): Define.
1927 (T_OFFSET): Define.
1928 (T_PTR): Define.
1929 (T_ID): Define.
1930 (intel_match_token): New function.
1931 (intel_get_token): New function.
1932 (intel_putback_token): New function.
1933 (intel_expr): New function.
1934 (intel_e05): New function.
1935 (intel_e05_1): New function.
1936 (intel_e06): New function.
1937 (intel_e06_1): New function.
1938 (intel_e09): New function.
1939 (intel_e09_1): New function.
1940 (intel_e10): New function.
1941 (intel_e10_1): New function.
1942 (intel_e11): New function.
1943
1944 2000-10-20 Jakub Jelinek <jakub@redhat.com>
1945
1946 * config/tc-sparc.c (sparc_ip): Fix a bug which caused v9_arg_p
1947 instructions to loose any special insn->architecture mask.
1948
1949 * config/tc-sparc.c (v9a_asr_table): Add v9b ASRs.
1950 (sparc_md_end, sparc_arch_types, sparc_arch,
1951 sparc_elf_final_processing): Handle v8plusb and v9b architectures.
1952 (sparc_ip): Handle siam mode operands. Support v9b ASRs (and
1953 request v9b architecture if they are used).
1954
1955 2000-10-18 Michael Sokolov <msokolov@ivan.Harhan.ORG>
1956
1957 * config/tc-m68k.c: Fix the previous misapplied patch.
1958
1959 2000-10-18 Michael Sokolov <msokolov@ivan.Harhan.ORG>
1960
1961 * config/tc-m68k.h (RELAX_RELOC_*): New definitions for both
1962 BFD_ASSEMBLER and !BFD_ASSEMBLER.
1963 * config/tc-m68k.c (md_convert_frag_1): Use them instead of
1964 BFD_RELOC_*.
1965
1966 2000-10-17 Kazu Hirata <kazu@hxi.com>
1967
1968 * debug.c: Fix formatting.
1969 * depend.c: Likewise.
1970 * dwarf2dbg.c: Likewise.
1971 * dwarf2dbg.h: Likewise.
1972 * ecoff.c: Likewise.
1973 * expr.c: Likewise.
1974 * expr.h: Likewise.
1975 * flonum-konst.c: Likewise.
1976 * frags.h: Likewise.
1977
1978 2000-10-17 Chandrakala Chavva <cchavva@redhat.com>
1979
1980 * as.c: New option OPTION_TARGET_HELP. Prints all target specific
1981 options.
1982 * doc/as.texinfo: Added notes about this new option.
1983
1984 2000-10-16 Hans-Peter Nilsson <hp@bitrange.com>
1985
1986 * config/tc-sh.c (JREG): Remove.
1987 (md_convert_frag): Remove #if 0:d code using JREG.
1988
1989 2000-10-15 Diego Novillo <dnovillo@cygnus.com>
1990
1991 * config/tc-i386.c (i386_operand_modifier): Only match
1992 modifiers SHORT and FLAT if they are followed by a space.
1993 (parse_register): When `allow_naked_reg' is set, do not confuse
1994 identifiers that start with a register name with a register.
1995
1996 2000-10-12 Kazu Hirata <kazu@hxi.com>
1997
1998 * app.c: Fix formatting.
1999 * as.c: Likewise.
2000 * as.h: Likewise.
2001 * bit_fix.h: Likewise.
2002 * cgen.c: Likewise.
2003 * cgen.h: Likewise.
2004 * cond.c: Likewise.
2005
2006 2000-10-11 Alan Modra <alan@linuxcare.com.au>
2007
2008 * config/obj-elf.c (elf_frob_symbol): Revert 2000-10-07 change.
2009
2010 2000-10-07 Alan Modra <alan@linuxcare.com.au>
2011
2012 * config/tc-hppa.c (md_apply_fix): Remove plainly wrong assert.
2013 Re-arrange function a little and improve error message.
2014
2015 * write.c (write_relocs): Fix a comment.
2016
2017 * config/obj-elf.c (elf_frob_symbol): Make section syms global on
2018 link-once sections.
2019
2020 2000-10-05 Jim Wilson <wilson@cygnus.com>
2021
2022 * config/tc-ia64.c (resources_match): Handle IA64_RS_PRr.
2023
2024 2000-10-05 Alan Modra <alan@linuxcare.com.au>
2025
2026 * config/tc-i386.c: Delete some useless comments, reformat others.
2027
2028 * config/tc-i386.h (TC_FIX_ADJUSTABLE): Add check to cover
2029 non-global syms in linkonce sections.
2030
2031 2000-10-04 Ralf Baechle <ralf@gnu.org>
2032
2033 * config/tc-ia64.c (operand_match): Don't use // style comments.
2034 * config/tc-i370.c: Likewise.
2035
2036 2000-09-29 Hans-Peter Nilsson <hp@axis.com>
2037
2038 Changes to handle varying register prefix and user symbol prefix.
2039 * config/tc-cris.c (SYNTAX_RELAX_REG_PREFIX,
2040 SYNTAX_ENFORCE_REG_PREFIX, SYNTAX_USER_SYM_LEADING_UNDERSCORE,
2041 SYNTAX_USER_SYM_NO_LEADING_UNDERSCORE, REGISTER_PREFIX_CHAR): New.
2042 (s_syntax, cris_force_reg_prefix, cris_relax_reg_prefix,
2043 cris_sym_leading_underscore, cris_sym_no_leading_underscore): New.
2044 (demand_register_prefix): New variable.
2045 (md_pseudo_table): New pseudo ".syntax".
2046 (md_longopts): New options --no-underscore and --underscore.
2047 (cris_target_format): Return elf32-us-cris or elf32-cris depending
2048 on symbols_have_leading_underscore.
2049 (get_gen_reg): Accept or require REGISTER_PREFIX_CHAR.
2050 (get_spec_reg): Ditto.
2051 (cris_number_to_imm) <case BFD_RELOC_VTABLE_ENTRY>: Remove FIXME.
2052 Fix formatting.
2053 (md_parse_option) <case 'h' 'H'>: Deprecate; add reference to
2054 --help.
2055 <case OPTION_NO_US, case OPTION_US>: New.
2056 (md_show_usage): Be brief and reformat to match continuation of
2057 --help.
2058 * po/gas.pot: Regenerate.
2059
2060 2000-09-28 Alan Modra <alan@linuxcare.com.au>
2061
2062 * config/tc-hppa.c (hppa_force_relocation): If OBJ_SOM, don't
2063 force relocs for 12 bit branches.
2064 (md_apply_fix): Similarly, adjust logic here.
2065
2066 2000-09-28 Alan Modra <alan@linuxcare.com.au>
2067
2068 * config/tc-hppa.c (md_apply_fix): Add fmt assertion. Don't
2069 adjust for external and weak syms as we will use a reloc. Allow
2070 for +8 offset when calculating limits of branches.
2071 (hppa_fix_adjustable): Undo 2000-09-23 change.
2072 (hppa_force_relocation): Likewise. Add fx_addsy assertion.
2073 Correct distance calculation.
2074 (tc_gen_reloc): Print the file name and line number if we can't
2075 handle a fixup.
2076
2077 From John David Anglin <dave@hiauly1.hia.nrc.ca>
2078 * config/tc-hppa.c (nonzero_dibits): Define.
2079 (arg_reloc_stub_needed): Check each arg and return value
2080 separately for zero case.
2081 (pa_align): Declare argument `bytes'.
2082
2083 2000-09-25 Kazu Hirata <kazu@hxi.com>
2084
2085 * config/tc-cris.c: Fix formatting.
2086 * config/tc-d10v.h: Likewise.
2087 * config/tc-d30v.c: Likewise.
2088 * config/tc-d30v.h: Likewise.
2089 * config/tc-fr30.c: Likewise.
2090 * config/tc-fr30.h: Likewise.
2091 * config/tc-m68k.c: Likewise.
2092 * config/tc-m68k.h: Likewise.
2093 * config/tc-pj.h: Likewise.
2094 * config/tc-ppc.c: Likewise.
2095 * config/tc-ppc.h: Likewise.
2096 * config/tc-sh.c: Likewise.
2097 * config/tc-sh.h: Likewise.
2098 * config/tc-sparc.c: Likewise.
2099 * config/tc-v850.h: Likewise.
2100 * config/tc-vax.h: Likewise.
2101 * config/tc-w65.h: Likewise.
2102 * config/tc-z8k.h: Likewise.
2103
2104 2000-09-23 Alan Modra <alan@linuxcare.com.au>
2105
2106 * config/tc-hppa.c (hppa_fix_adjustable): Do the external and weak
2107 checks only for ELF.
2108 (hppa_force_relocation): Likewise.
2109
2110 2000-09-22 Jim Wilson <wilson@cygnus.com>
2111
2112 * config/tc-ia64.c (dv_sem): Add "stop".
2113 (specify_resource, case IA64_RS_PR): Only handles regs 1 to 15 now.
2114 (specify_resource, case IA64_RS_PRr): New for regs 16 to 62.
2115 (specify_resource, case IA64_RS_PR63): Reorder (note == 7) test to
2116 match above.
2117 (mark_resources): Check IA64_RS_PRr.
2118
2119 2000-09-22 Michael Sokolov <msokolov@ivan.Harhan.ORG>
2120
2121 * config/tc-m68k.c (md_relax_table, m68k_ip, md_convert_frag_1,
2122 md_estimate_size_before_relax): Redesign and clean up the
2123 relaxation mechanism.
2124
2125 2000-09-21 Kazu Hirata <kazu@hxi.com>
2126
2127 * config/tc-ns32k.c: Fix formatting.
2128 * config/tc-ns32k.h: Likewise.
2129
2130 2000-09-20 Kazu Hirata <kazu@hxi.com>
2131
2132 * config/tc-m32r.c: Fix formatting.
2133 * config/tc-m32r.h: Likewise.
2134 * config/tc-m68851.h: Likewise.
2135 * config/tc-m68hc11.c: Likewise.
2136 * config/tc-m68hc11.h: Likewise.
2137 * config/tc-m88k.c: Likewise.
2138 * config/tc-mcore.c: Likewise.
2139 * config/tc-mcore.h: Likewise.
2140 * config/tc-mips.c: Likewise.
2141 * config/tc-mips.h: Likewise.
2142 * config/tc-mn10200.h: Likewise.
2143 * config/tc-mn10300.h: Likewise.
2144 * config/tc-tahoe.c: Likewise.
2145 * config/tc-tahoe.h: Likewise.
2146
2147 2000-09-19 Michael Sokolov <msokolov@ivan.Harhan.ORG>
2148
2149 * config/tc-vax.c (synthetic_votstrs): Remove jbssi and jbcci.
2150 Likewise in relaxation description comments.
2151
2152 2000-09-18 Alan Modra <alan@linuxcare.com.au>
2153
2154 * config/tc-hppa.h (TC_FORCE_RELOCATION_SECTION): Allow
2155 subtraction of two syms without emitting a relocation.
2156
2157 From David Huggins-Daines <dhd@linuxcare.com>
2158 * config/tc-hppa.c (hppa_force_relocation): Force relocations for
2159 global or weak symbols.
2160
2161 2000-09-15 Kazu Hirata <kazu@hxi.com>
2162
2163 * config/tc-h8300.h: Fix formatting.
2164 * config/tc-h8500.c: Likewise.
2165 * config/tc-h8500.h: Likewise.
2166 * config/tc-hppa.h: Likewise.
2167 * config/tc-i370.h: Likewise.
2168 * config/tc-i386.h: Likewise.
2169 * config/tc-i860.c: Likewise.
2170 * config/tc-i860.h: Likewise.
2171 * config/tc-i960.h: Likewise.
2172 * config/tc-ia64.c: Likewise.
2173 * config/tc-ia64.h: Likewise.
2174
2175 2000-09-14 Kazu Hirata <kazu@hxi.com>
2176
2177 * config/tc-a29k.c: Fix formatting.
2178 * config/tc-alpha.c: Likewise.
2179 * config/tc-arc.c: Likewise.
2180 * config/tc-arc.h: Likewise.
2181 * config/tc-arm.c: Likewise.
2182 * config/tc-arm.h: Likewise.
2183 * config/tc-avr.c: Likewise.
2184 * config/tc-avr.h: Likewise.
2185 * config/tc-tic30.c: Likewise.
2186 * config/tc-tic30.h: Likewise.
2187 * config/tc-tic54x.c: Likewise.
2188 * config/tc-tic54x.h: Likewise.
2189 * config/tc-tic80.c: Likewise.
2190 * config/tc-tic80.h: Likewise.
2191
2192 2000-09-14 Timothy Wall <twall@cygnus.com>
2193
2194 * config/tc-ia64.c (specify_resource): For PR%/PR63, note types of
2195 parallel comparisons for later use.
2196 (struct rsrc): Add parallel comparison type.
2197 (resources_match): Skip special cases of PR usage (non-conflicting
2198 parallel compares).
2199
2200 2000-09-13 Kazu Hirata <kazu@hxi.com>
2201
2202 * config/obj-ecoff.c: Fix formatting.
2203 * config/obj-elf.c: Likewise.
2204 * config/obj-elf.h: Likewise.
2205 * config/obj-evax.h: Likewise.
2206 * config/obj-generic.h: Likewise.
2207 * config/obj-hp300.c: Likewise.
2208 * config/obj-hp300.h: Likewise.
2209 * config/obj-ieee.h: Likewise.
2210 * config/obj-vms.c: Likewise.
2211 * config/obj-vms.h: Likewise.
2212
2213 2000-09-13 Anders Norlander <anorland@acc.umu.se>
2214
2215 * config/tc-mips.c (md_begin): Recognize 4Kc, 4Km and 4Kp processors.
2216 (md_parse_option): Ditto.
2217 (md_longopts): Add -mips32 option.
2218 (md_show_usage): Document new options.
2219 (mips_ip): Assemble sdbbp 20 bit 'm' args for MIPS32.
2220 (mips_ip): Assemble mfc0 with a sub-selection code.
2221 (validate_mips_insn): Handle 'H' (OP_*_SEL) and 'm' (OP_*_CODE20).
2222 (mips_cpu_to_str): New function.
2223 (mips_ip): Use mips_cpu_to_str instead of printing numeric cpu value.
2224 Use CPU_* defines instead of hardcoded numbers.
2225
2226 * doc/as.texinfo: Document new options.
2227 * doc/c-mips.texi: Ditto.
2228
2229 2000-09-12 Kazu Hirata <kazu@hxi.com>
2230
2231 * as.h: Fix formatting.
2232 * asintl.h: Likewise.
2233 * bit_fix.h: Likewise.
2234 * config/obj-aout.c: Likewise.
2235 * config/obj-aout.h: Likewise.
2236 * config/obj-bout.c: Likewise.
2237 * config/obj-bout.h: Likewise.
2238 * config/obj-coff.c: Likewise.
2239 * config/obj-coff.h: Likewise.
2240 * dwarf2dbg.h: Likewise.
2241 * expr.h: Likewise.
2242 * flonum.h: Likewise.
2243 * frags.h: Likewise.
2244 * itbl-ops.h: Likewise.
2245 * macro.h: Likewise.
2246 * read.h: Likewise.
2247 * sb.h: Likewise.
2248 * struc-symbol.h: Likewise.
2249 * subsegs.h: Likewise.
2250 * symbols.h: Likewise.
2251 * tc.h: Likewise.
2252 * write.h: Likewise.
2253
2254 2000-09-11 Kazu Hirata <kazu@hxi.com>
2255
2256 * bignum-copy.c: Fix formatting.
2257 * config/tc-i370.c: Likewise.
2258 * config/tc-i960.c: Likewise.
2259 * config/tc-m68k.c: Likewise.
2260 * ehopt.c: Likewise.
2261 * flonum-copy.c: Likewise.
2262 * flonum-konst.c: Likewise.
2263 * flonum-mult.c: Likewise.
2264 * literal.c: Likewise.
2265 * read.c: Likewise.
2266 * sb.c: Likewise.
2267 * stabs.c: Likewise.
2268 * subsegs.c: Likewise.
2269
2270 2000-09-09 Philip Blundell <philb@gnu.org>
2271
2272 * configure.in (arm*-*-uclinux*): New target.
2273 * configure: Regenerate.
2274
2275 2000-09-09 Kazu Hirata <kazu@hxi.com>
2276
2277 * input-file.c: Fix formatting.
2278 * itbl-ops.c: Likewise.
2279 * messages.c: Likewise.
2280
2281 2000-09-08 Philip Blundell <philb@gnu.org>
2282
2283 * config/tc-arm.c (md_apply_fix3): Correct handling of ADRL when
2284 offset is negative.
2285
2286 2000-09-07 H.J. Lu <hjl@gnu.org>
2287
2288 * configure.in (AC_ISC_POSIX): Put after AC_CANONICAL_SYSTEM.
2289 * configure: Rebuild.
2290
2291 2000-09-07 Kazu Hirata <kazu@hxi.com>
2292
2293 * atof-generic.c: Fix formatting.
2294 * config/tc-mips.c: Likewise.
2295 * config/tc-vax.c: Likewise.
2296 * input-scrub.c: Likewise.
2297
2298 2000-09-07 Alexandre Oliva <aoliva@redhat.com>
2299
2300 * config/tc-sh.h (TARGET_FORMAT): Use sh-linux targets.
2301 * configure.in (sh-*-linux*): Added.
2302 * configure: Rebuilt.
2303
2304 2000-09-06 Kazu Hirata <kazu@hxi.com>
2305
2306 * config/tc-hppa.c: Fix formatting.
2307
2308 * ecoff.c: Fix formatting.
2309
2310 2000-09-06 Alexandre Oliva <aoliva@redhat.com>
2311
2312 * configure: Rebuilt with new libtool.m4.
2313
2314 2000-09-05 Kazu Hirata <kazu@hxi.com>
2315
2316 * cgen.c: Fix formatting.
2317 * config/tc-ia64.c: Likewise.
2318
2319 2000-09-05 Nick Clifton <nickc@redhat.com>
2320
2321 * aclocal.m4: Regenerate.
2322 * config.in: Regenerate.
2323 * configure: Regenerate.
2324 * po/gas.pot: Regenerate.
2325
2326 2000-09-05 Hans-Peter Nilsson <hp@axis.com>
2327
2328 * config/tc-cris.c: Correct comment typos.
2329
2330 2000-09-05 Eric Christopher <echristo@cygnus.com>
2331
2332 * config/tc-mn10300.c: Cleanup.
2333 (md_pcrel_from): Enable.
2334
2335 2000-09-05 Alan Modra <alan@linuxcare.com.au>
2336
2337 * expr.c (operand): Fix a comment typo.
2338 * write.c (write_relocs): Fix a signed/unsigned warning.
2339
2340 * config/tc-hppa.c (fudge_reg_expressions): New
2341 (hppa_force_reg_syms_absolute): New.
2342 (pa_equ): Allow reg_section expressions.
2343 * config/tc-hppa.c (md_optimize_expr): Define.
2344 (hppa_force_reg_syms_absolute): Prototype.
2345
2346 * config/tc-hppa.c (pa_11_fp_reg_struct): Delete.
2347 (pa_parse_number): Pass in arg to select fp reg parsing.
2348 Return 1 to indicate format checks pass. If strict, then only
2349 accept a register or register symbol. Return value in...
2350 (pa_number): New static for pa_parse_number.
2351 (FP_REG_BASE): Define.
2352 (FP_REG_RSEL): Define.
2353 (pre_defined_registers): Apply FP_REG_BASE and FP_REG_RSEL as
2354 appropriate. White space changes.
2355 (need_pa11_opcode): Don't bother passing any params, get them from
2356 globals instead.
2357 (pa_ip): Modify all calls to pa_parse_number and need_pa11_opcode.
2358 Remove extraneous check in case 'Q'.
2359 (pa_equ): Modify call to pa_parse_number to do strict parsing. If
2360 reg, set section of resulting symbol to reg_section.
2361 (pa_parse_space_stmt): Modify call to pa_parse_number.
2362 (pa_space): Likewise.
2363
2364 * config/tc-hppa.c: (md_apply_fix): Handle vtable relocs.
2365 (hppa_force_relocation): Handle vtable relocs.
2366 (pa_vtable_entry): New.
2367 (pa_vtable_inherit): New.
2368 (md_pseudo_table): Add entries for vtable pseudos.
2369 (hppa_fix_adjustable): Reject reduction of R_PARISC_GNU_VTINHERIT
2370 and R_PARISC_GNU_VTENTRY relocs. Reject reduction of relocs
2371 against weak syms.
2372 (tc_gen_reloc): Remove ELF_ARG_RELOC_INSN code.
2373 (pa_type_args): Don't call symbol_get_bfdsym multiple times.
2374 Set STT_PARISC_MILLICODE for OBJ_ELF when encountering a
2375 millicode import.
2376 * config/obj-elf.c (obj_elf_type): Allow md_elf_symbol_type to
2377 specify a symbol type.
2378
2379 * config/tc-hppa.h: Reorganize file a little, grouping OBJ_ELF
2380 dependent things together.
2381 (md_elf_symbol_type): Define.
2382
2383 * config/tc-hppa.c (fix_new_hppa): Elide "$PIC_pcrel$0" pseudo
2384 symbol.
2385 * config/tc-hppa.h (tc_frob_symbol): Elide "$PIC_pcrel$0" here too.
2386
2387 * config/obj-elf.h (obj_elf_vtable_inherit): Declare.
2388 (obj_elf_vtable_entry): Declare.
2389
2390 * config/obj-elf.c (obj_elf_vtable_inherit): Return struct fix *
2391 and export function.
2392 (obj_elf_vtable_entry): Similarly.
2393 (elf_pseudo_table): Fix the damage with a cast.
2394
2395 2000-09-03 Richard Henderson <rth@cygnus.com>
2396
2397 * config/tc-ia64.c (emit_one_bundle): Stop collecting insns
2398 for template selection when a label is needed.
2399
2400 2000-09-02 Kazu Hirata <kazu@hxi.com>
2401
2402 * config/tc-ia64.c: Fix formatting.
2403
2404 2000-09-02 Nick Clifton <nickc@redhat.com>
2405
2406 * configure.in: Increase version number to 2.10.91.
2407 * configure: Regenerate.
2408 * aclocal.m4: Regenerate.
2409 * config.in: Regenerate.
2410 * po/gas.pot: Regenerate.
2411 * Makefile.in: Regenerate.
2412
2413 2000-09-01 Alexandre Oliva <aoliva@redhat.com>
2414
2415 * config/tc-sh.h [OBJ_ELF] (TC_FIX_ADJUSTABLE): Define.
2416 * config/tc-sh.c (md_apply_fix): Map 32-bit relocations that
2417 become PC-relative to BFD_RELOC_32_PCREL. Reject 16- or 8-bit
2418 similar relocs.
2419 (sh_obj_adjustable): Return 1 for PC-relative offsets used in
2420 branches.
2421
2422 2000-09-01 Niibe Yutaka <gniibe@m17n.org>, Kaz Kojima <kkojima@rr.iij4u.or.jp>, Alexandre Oliva <aoliva@redhat.com>
2423
2424 * config/tc-sh.h (DIFF_EXPR_OK, GLOBAL_OFFSET_TABLE_NAME,
2425 TC_RELOC_GLOBAL_OFFSET_TABLE, TC_RELOC_RTSYM_LOC_FIXUP): Define.
2426 * config/tc-sh.c (sh_elf_cons, sh_elf_suffix): New functions.
2427 [OBJ_ELF] (md_pseudo_table) <long, int, word, short>: Use them.
2428 (GOT_symbol): New variable.
2429 (md_undefined_symbol): Set it.
2430
2431 2000-09-01 Richard Henderson <rth@cygnus.com>
2432
2433 * config/tc-ia64.c (match): Don't inline.
2434 (extra_goodness): New.
2435 (md_begin): Prefer nop.f and nop.b for best_template.
2436
2437 2000-08-31 Kazu Hirata <kazu@hxi.com>
2438
2439 * as.c: Fix formatting.
2440 * cond.c: Likewise.
2441 * frags.c: Likewise.
2442 * macro.c: Likewise.
2443
2444 2000-08-31 Eric Christopher <echristo@cygnus.com>
2445
2446 * config/tc-mn10300.c: Cleanup and fix warnings.
2447 (md_pseudo_table): Add initializers.
2448 (md_show_usage): Cleanup.
2449 (md_parse_option): Fix warnings.
2450 (md_undefined_symbol): Fix warnings.
2451 (md_conver_frag): Fix warnings.
2452 (tc_gen_reloc): Fix warnings.
2453 (md_apply_fix3): Fix warnings.
2454 (check_operand): Fix warnings.
2455
2456 2000-08-31 Alexandre Oliva <aoliva@redhat.com>
2457
2458 * acinclude.m4: Include libtool and gettext macros from the
2459 top level.
2460 * aclocal.m4, configure: Rebuilt.
2461
2462 2000-08-30 Mark Hatle <mhatle@mvista.com>
2463
2464 * config/tc-ppc.c (md_parse_option): Recognize -m405.
2465
2466 2000-08-31 Kazu Hirata <kazu@hxi.com>
2467
2468 * listing.c: Fix formatting.
2469
2470 2000-08-29 Kazu Hirata <kazu@hxi.com>
2471
2472 * app.c: Fix a comment typo. Fix formatting.
2473
2474 2000-08-25 J. David Anglin <dave@hiauly1.hia.nrc.ca>
2475
2476 * config/tc-vax.c (md_convert_frag): Correctly calculate the pc relative
2477 offset of the target destination for jmp instructions.
2478 (md_assemble): Change mode to VAX_ABSOLUTE_MODE as per comments.
2479
2480 2000-08-24 Hans-Peter Nilsson <hp@axis.com>
2481
2482 * NEWS: Mention support for CRIS.
2483
2484 Thu Aug 24 20:41:05 2000 Denis Chertykov <denisc@overta.ru>
2485
2486 * config/tc-avr.h (TC_IMPLICIT_LCOMM_ALIGNMENT): New macros.
2487 Sets `.lcomm' alignment to zero.
2488
2489 2000-08-23 Alexandre Oliva <aoliva@redhat.com>
2490
2491 * config/tc-i386.h (OBJ_MAYBE_ELF, OBJ_MAYBE_COFF,
2492 TC_FIX_ADJUSTABLE): Define.
2493
2494 2000-08-23 Jim Wilson <wilson@cygnus.com>
2495
2496 * config/tc-ia64.c (output_unw_records): Set U & E flags only if
2497 unwind.personality_routine is set.
2498
2499 2000-08-23 H.J. Lu <hjl@gnu.org>
2500
2501 * write.c (TC_FIX_ADJUSTABLE): Remove the duplicate.
2502
2503 2000-08-23 Alexandre Oliva <aoliva@redhat.com>
2504
2505 * config/tc-i386.h (TC_FIX_ADJUSTABLE): Do *NOT* define if target
2506 environment is pe.
2507
2508 2000-08-22 H.J. Lu <hjl@gnu.org>
2509
2510 * config.in (STRICTCOFF): New for strict COFF.
2511
2512 * configure.in: Define STRICTCOFF for i386-*-msdosdjgpp*,
2513 i386-*-go32* and i386-go32-rtems*.
2514 * configure: Rebuilt.
2515
2516 * config/obj-coff.c (obj_coff_endef): Follow the historical
2517 behavior if STRICTCOFF is not defined.
2518
2519 * doc/internals.texi: Document STRICTCOFF.
2520
2521 2000-08-22 Alexandre Oliva <aoliva@redhat.com>
2522
2523 * write.c (TC_FIX_ADJUSTABLE): Define to 1, if not defined.
2524 (fixup_segment) Use it instead of TC_DONT_FIX_NON_ADJUSTABLE.
2525 * config/tc-i386.h (TC_DONT_FIX_NON_ADJUSTABLE): Remove.
2526 <OBJ_ELF, OBJ_COFF, TE_PE> (TC_FIX_ADJUSTABLE): Define.
2527 * config/tc-arm.h (TC_DONT_FIX_NON_ADJUSTABLE): Remove.
2528 <OBJ_ELF> (TC_FIX_ADJUSTABLE): Define.
2529 * config/tc-i960.h, config/tc-m68k.h, config/tc-v850.h:
2530 Likewise.
2531
2532 2000-08-22 Eric Christopher <echristo@cygnus.com>
2533
2534 * config/tc-mn10300.c: (md_apply_fix): New function.
2535 (mn10300_force_relocation): New function.
2536 (mn10300_fix_adjustable): New function.
2537
2538 * config/tc-mn10300.h: (TC_FORCE_RELOCATION): Define.
2539 (TC_HANDLES_FX_DONE): Define.
2540 (obj_fix_adjustable): Define.
2541 (MD_APPLY_FIX3): Define.
2542 (TC_LINKRELAX_FIXUP): Define.
2543
2544 * write.c: (TC_LINKRELAX_FIXUP): Define if not
2545 previously defined.
2546 (fixup_segment): Use TC_LINKRELAX_FIXUP.
2547
2548 * doc/internals.texi: Document TC_LINKRELAX_FIXUP.
2549
2550 2000-08-21 Jason Eckhardt <jle@cygnus.com>
2551
2552 * config/tc-i860.c (md_apply_fix3): Do not insert the immediate
2553 if the fixup resulted in a relocation.
2554
2555 2000-08-18 Nick Clifton <nickc@redhat.com>
2556
2557 * config/tc-arm.c (decode_shift): Replace as_tsktsk with as_warn.
2558 Make reference to first element of shift_names explicit.
2559
2560 2000-08-18 Alexandre Oliva <aoliva@redhat.com>
2561
2562 * write.c (fixup_segment) [TC_DONT_FIX_NON_ADJUSTABLE]: Use
2563 obj_fix_adjustable() and tc_fix_adjustable() to tell whether to
2564 add a symbol's address. Removed all target-specific #ifdefs that
2565 used to accomplished the same.
2566 * config/tc-v850.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
2567 * config/tc-m68k.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
2568 * config/tc-arm.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
2569 * config/tc-i960.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
2570 * config/tc-i386.h (TC_DONT_FIX_NON_ADJUSTABLE): Define.
2571
2572 2000-08-17 Kazu Hirata <kazu@hxi.com>
2573
2574 * dwarf2dbg.c: Fix formatting.
2575
2576 2000-08-17 Nick Clifton <nickc@redhat.com>
2577
2578 * config/tc-arm.c (decode_shift): Allow illegal shifts by zero
2579 to be recoded as logical shift lefts by zero.
2580
2581 2000-08-16 Jim Wilson <wilson@cygnus.com>
2582
2583 * config/tc-ia64.c (specify_resource, case IA64_RS_GR): Handle
2584 postincrement modified registers. Handle IA64_OPND_R3_2 addl
2585 source registers.
2586 (note_register_values): Handle IA64_OPND_R3_2 operands.
2587
2588 2000-08-16 Jason Eckhardt <jle@cygnus.com>
2589
2590 * config/tc-i860.c (md_operand): Silly typo fixed.
2591
2592 2000-08-16 Nick Clifton <nickc@redhat.com>
2593
2594 * config/tc-arm.c (struct asm_shift): Delete.
2595 (shift[]): Delete.
2596 (enum asm_shift_index): New.
2597 (struct asm_shift_properties): New.
2598 (struct asm_shift_name): New.
2599 (shift_properties[]); New.
2600 (shift_names[]); New.
2601
2602 (decode_shift): Use new structures.
2603 Issue a warning is "ROR #0" is used.
2604 Issue a warning if "ASR #0" or "LSR #0" is used.
2605
2606 (md_begin): Initialise arm_shift_hsh table from new
2607 asm_shift_name array.
2608
2609 2000-08-16 Jakub Jelinek <jakub@redhat.com>
2610
2611 * config/tc-sparc.c: Kill all warnings.
2612 (md_parse_option): Set -32/-64 for -xarch=, allow all -A archs
2613 in -xarch= as well.
2614 (md_show_usage): Update usage text.
2615
2616 2000-08-16 Nick Clifton <nickc@redhat.com>
2617
2618 * config/tc-arm.c (do_bx): Warn about "bx px" not being very
2619 useful.
2620
2621 2000-08-15 Will Cohen <wcohen@redhat.com>
2622
2623 * config/tc-sh.h (DWARF2_LINE_MIN_INSN_LENGTH): Defined.
2624
2625 * config/tc-sh.c (md_assemble): Changed so debug_type
2626 test performed for ppi_assemble
2627 * config/tc-sh.c: Included dwarf2dbg.h.
2628 (debug_line): Defined.
2629 (md_assemble): Generates dwarf2 line info.
2630 (sh_finalize): New function. Finalize dwarf2 info.
2631 (assemble_ppi): Returns size of code generated.
2632 (build_Mytes): Returns size of code generated.
2633 (md_pseudo_table): Added "file" and "loc" psuedo ops.
2634 * config/tc-sh.h (md_end): Defined.
2635 (sh_finalize): Declared.
2636
2637 2000-08-15 Alexandre Oliva <aoliva@redhat.com>
2638
2639 * config/tc-sh.c (md_apply_fix) [BFD_RELOC_32, BFD_RELOC_16]: Use
2640 md_number_to_chars.
2641
2642 2000-08-14 Nick Clifton <nickc@redhat.com>
2643
2644 * config/tc-arm.c (do_bx): Allow "bx pc".
2645
2646 2000-08-14 Jim Wilson <wilson@cygnus.com>
2647
2648 * config/tc-ia64.c (md_longopts): Add -mconstant-gp and -mauto-pic.
2649 (md_parse_option): Add OPTION_MCONSTANT_GP and OPTION_MAUTO_PIC.
2650 (md_begin): Change assignment to md.flag to OR in the new bit.
2651
2652 2000-08-14 Mark Elbrecht <snowball3@bigfoot.com>
2653
2654 * config/obj-coff.c (obj_coff_endef) [BFD_ASSEMBLER]: Set the debug
2655 flag for storage types C_ARG, C_REGPARM, C_FIELD, C_MOS, C_MOE,
2656 C_MOU, and C_EOS.
2657
2658 2000-08-14 Jason Eckhardt <jle@cygnus.com>
2659
2660 * NEWS: Mention i860 support.
2661
2662 Mon Aug 14 11:49:12 2000 Jeffrey A Law (law@cygnus.com)
2663
2664 * config/tc-mn10300.h (DWARF2_LINE_MIN_INSN_LENGTH): Define.
2665
2666 2000-08-14 Andreas Schwab <schwab@suse.de>
2667
2668 * doc/c-arm.texi (ARM Directives): Fix warnings from makeinfo.
2669
2670 2000-08-11 Andreas Schwab <schwab@suse.de>
2671
2672 * doc/c-i860.texi (Opcodes for i860): Remove braces from @item
2673 argument.
2674
2675 2000-08-11 Kazu Hirata <kazu@hxi.com>
2676
2677 * expr.c: Fix formatting.
2678 * config/obj-bout.c: Likewise.
2679
2680 2000-08-10 Jason Eckhardt <jle@cygnus.com>
2681
2682 * doc/c-i860.texi: Flesh out the i860 section more.
2683
2684 2000-08-10 Kazu Hirata <kazu@hxi.com>
2685
2686 * symbols.c: Fix formatting.
2687 * expr.c: Likewise.
2688
2689 Wed Aug 9 16:28:21 EDT 2000 Diego Novillo <dnovillo@cygnus.com>
2690
2691 * config/tc-i386.c (md_assemble): Skip suffix check if the opcode
2692 modifier has the IgnoreSize bit set.
2693
2694 2000-08-09 Alan Modra <alan@linuxcare.com.au>
2695
2696 From Rodney Brown <RodneyBrown@mynd.com>
2697 * configure.in: Use elf on Unixware 7 (i586-sco-sysv5uw7.1.0)
2698 * configure: Regenerate.
2699
2700 2000-08-09 Kazu Hirata <kazu@hxi.com>
2701
2702 * hash.c: Fix formatting.
2703 * gasp.c: Likewise.
2704
2705 2000-08-08 Jason Eckhardt <jle@cygnus.com>
2706
2707 * config/tc-i860.h: Rework completely for BFD_ASSEMBLER.
2708 (i860_fix_info): New enum.
2709 (MD_APPLY_FIX3): Define.
2710 (WORKING_DOT_WORD): Define.
2711 (TC_HANDLES_FX_DONE): Define.
2712 (DIFF_EXPR_OK): Define.
2713 (LISTING_HEADER): Define.
2714 (TARGET_FORMAT): Select target format based on endian flag.
2715 (TARGET_BYTES_BIG_ENDIAN): Default to little endian.
2716 (target_big_endian): Add external declaration.
2717
2718 * config/tc-i860.c: All existing code reworked completely. Other
2719 new code shown below.
2720 (SYNTAX_SVR4): Define.
2721 (target_warn_expand): New variable.
2722 (md_shortopts): Declare and define (-Qy, -Qn, and -V options).
2723 (md_longopts): Declare and define with new options (-EL, -EB,
2724 and -mwarn-expand).
2725 (md_show_usage): New function.
2726 (md_operand): New function.
2727 (obtain_reloc_for_imm16): New function.
2728 (md_apply_fix3): New function.
2729 (tc_gen_reloc): New function.
2730
2731 2000-08-08 Stephane Carrez <Stephane.Carrez@worldnet.fr>
2732
2733 * config/tc-m68hc11.c (build_jump_insn): Make sure the
2734 2 bytes of the jump address are in the same frag.
2735 (find): Accept 68hc12 register indirect modes.
2736
2737 * NEWS: Mention 68HC11 & 68HC12 support.
2738
2739 2000-08-07 Richard Henderson <rth@cygnus.com>
2740
2741 * config/tc-ia64.c (unwind): Add prologue_mask member.
2742 (dot_vframe): Elide psp_gr record if it overlaps prologue_gr.
2743 (dot_save): Likewise for pfs_gr, rp_gr, and preds_gr.
2744 (dot_body): Clear unwind.prologue_mask.
2745 (dot_prologue): Set it. Accept a register second argument.
2746
2747 2000-08-07 Kazu Hirata <kazu@hxi.com>
2748
2749 * config/atof-ieee.c: Fix formatting.
2750 * config/atof-tahoe.c: Likewise.
2751
2752 2000-08-06 Nick Clifton <nickc@cygnus.com>
2753
2754 * config/tc-sparc.c (md_begin): Fix typo in recent formatting
2755 work.
2756
2757 * doc/as.texinfo (Pseudo Ops): Update to include descriptions
2758 of .popsection, .previous, .pushsection, .subsection,
2759 .version, .vtable_entry, .vtable_inherit and .weak.
2760
2761 2000-08-05 Kazu Hirata <kazu@hxi.com>
2762
2763 * config/tc-cris.c: Fix formatting.
2764 * config/tc-i386.c: Likewise.
2765 * config/tc-sparc.c (sparc_ip): Simplify the code.
2766
2767 2000-08-04 Kazu Hirata <kazu@hxi.com>
2768
2769 * config/tc-cris.c: Rearrange code for readability.
2770 * config/tc-d10v.c: Fix formatting.
2771 * config/tc-m32r.c: Likewise.
2772 * config/tc-sparc.c: Likewise.
2773
2774 2000-08-02 Jim Wilson <wilson@cygnus.com>
2775
2776 * config/tc-ia64.c (emit_one_bundle): Call ia64_free_opcode
2777 before ia64_find_opcode.
2778 (md_assemble): Likewise.
2779
2780 2000-08-01 Nick Clifton <nickc@cygnus.com>
2781
2782 * config/tc-arm.c (do_mrs): Fix skip of 'cpsr_all' flag.
2783 Undo some formatting fixes.
2784
2785 2000-08-01 Kazu Hirata <kazu@hxi.com>
2786
2787 * config/obj-som.c: Fix formatting.
2788 * config/obj-ieee.c: Likewise.
2789 * config/tc-arm.c: Likewise.
2790 * config/tc-v850.c: Likewise.
2791
2792 2000-08-01 Nick Clifton <nickc@redhat.com>
2793
2794 * doc/c-m68k.texi (section M680x0 Options): Turn into a table
2795 index by command line option.
2796
2797 2000-08-01 Michael Sokolov <msokolov@ivan.Harhan.ORG>
2798
2799 * doc/c-m68k.texi (@cindex @samp{--pcrel}): Rewrite option description.
2800 (@node M68K-Branch): Rewrite to match the reality.
2801
2802 2000-07-31 Jason Eckhardt <jle@cygnus.com>
2803
2804 * doc/c-i860.texi: New file.
2805 * doc/Makefile.am (CPU_DOCS): Add c-i860.texi.
2806 * doc/Makefile.in: Regenerate.
2807 * doc/all.texi: Add I860 as relevant architecture.
2808 * doc/as.texinfo: Include i860 dependent file c-i860.texi.
2809
2810 2000-07-31 Kazu Hirata <kazu@hxi.com>
2811
2812 * config/tc-d30v.c: Fix formatting.
2813
2814 2000-07-31 Michael Sokolov <msokolov@ivan.Harhan.ORG>
2815
2816 * config/tc-m68k.c (flag_keep_pcrel, OPTION_PCREL): Add --pcrel option.
2817 (md_convert_frag_1, md_estimate_size_before_relax): When making DBcc
2818 long emit a long branch if available instead of an absolute jump, never
2819 emit absolute jumps for anything with --pcrel.
2820
2821 * doc/c-m68k.texi: Document new command line option.
2822
2823 2000-07-29 Marek Michalkiewicz <marekm@linux.org.pl>
2824
2825 * config/tc-avr.c: Use PARAMS macro in function declarations.
2826 Don't declare md_pcrel_from_section (already in tc-avr.h).
2827 (avr_operands): Use AVR_UNDEF_P and AVR_SKIP_P macros.
2828 (avr_operand): Don't set (unsigned) op_mask to -1.
2829
2830 2000-07-28 Jason Eckhardt <jle@cygnus.com>
2831
2832 * configure.in: Add bits for i860-stardent-{sysv4, elf}*.
2833 * configure: Regenerated.
2834 * config/obj-elf.c (obj_elf_type): Recognize a fifth type
2835 of operand to the .type directive (.e.g, "type").
2836
2837 2000-07-28 Alan Modra <alan@linuxcare.com.au>
2838
2839 * as.h (warn_comment, found_comment, found_comment_file): Declare.
2840 * app.c (do_scrub_chars): Record where first comment found.
2841 * read.c (read_a_source_file): Init found_comment on entry, and
2842 notify whether comments found on exit.
2843 * config/tc-hppa.c (md_shortopts): Add "c".
2844 (md_longopts): Add warn-comment.
2845 (md_parse_option): Handle it.
2846 (md_show_usage): Show available options.
2847 * config/tc-hppa.h (WARN_COMMENTS): Define if TE_LINUX
2848
2849 Thu Jul 27 11:25:01 2000 Andrew Cagney <cagney@b1.cygnus.com>
2850
2851 * config/tc-mn10300.c (md_convert_frag): Fix printfs.
2852 (tc_gen_reloc): Add cast when assigning bfd_abs_symbol to
2853 sym_ptr_ptr
2854 (md_estimate_size_before_relax): Don't fall off end of function.
2855
2856 2000-07-27 Kazu Hirata <kazu@hxi.com>
2857
2858 * config/tc-avr.c: Fix formatting.
2859 * config/tc-ns32k.c: Likewise.
2860
2861 2000-07-27 Alan Modra <alan@linuxcare.com.au>
2862
2863 * config/tc-d10v.c (find_opcode): Remove extraneous `='.
2864
2865 2000-07-27 Kazu Hirata <kazu@hxi.com>
2866
2867 * config/tc-d10v.c: Fix formatting.
2868 * config/tc-z8k.c: Likewise.
2869 * config/tc-sparc.c: Likewise.
2870
2871 2000-07-26 Dave Brolley <brolley@redhat.com>
2872
2873 * cgen.c (queue_fixup): Declare opinfo.
2874 (gas_cgen_parse_operand): Mark unused parameters with ATTRIBUTE_UNUSED.
2875 (gas_cgen_md_operand): Ditto.
2876 (gas_cgen_md_apply_fix3): Ditto.
2877
2878 2000-07-24 Mark Elbrecht <snowball3@bigfoot.com>
2879
2880 * config/obj-coff.c (obj_frob_symbol): Don't merge
2881 labels. Don't merge if the symbol isn't constant. Return
2882 immediately if a symbol is merged.
2883
2884 2000-07-22 Alan Modra <alan@linuxcare.com.au>
2885
2886 * frags.c (frag_align): Correct absolute section alignment.
2887
2888 2000-07-20 DJ Delorie <dj@redhat.com>
2889
2890 * config/obj-coff.c (obj_frob_symbol): revert previous change,
2891 it breaks linking against DLLs.
2892
2893 2000-07-20 Hans-Peter Nilsson <hp@axis.com>
2894
2895 * configure.in: Add CRIS support.
2896 * configure: Regenerate.
2897 * Makefile.am: (CPU_TYPES): Add cris.
2898 (CPU_OBJ_VALID) [aout]: Add cris.
2899 (MULTI_CPU_TYPES): Add cris.
2900 (MULTI_CPU_OBJ_VALID) [aout]: Add cris.
2901 [coff]: Only i386 and mips are valid.
2902 (TARGET_CPU_CFILES): Add config/tc-cris.c.
2903 (TARGET_CPU_HFILES): Add config/tc-cris.h.
2904 (MULTI_CFILES): Add config/e-crisaout.c and config/e-criself.c.
2905 Regenerate dependencies.
2906 * Makefile.in: Regenerate.
2907 * aclocal.m4: Regenerate.
2908 * as.c: Declare crisaout, criself.
2909 * config/tc-cris.h, config/tc-cris.c: New.
2910 * config/e-criself.c, config/e-crisaout.c: New.
2911 * po/POTFILES.in, po/gas.pot: Regenerate.
2912
2913 2000-07-20 Kazu Hirata <kazu@hxi.com>
2914
2915 * read.c: Fix formatting.
2916 * write.c: Fix formatting.
2917
2918 2000-07-19 H.J. Lu <hjl@gnu.org>
2919
2920 * sb.c: Include <stdlib.h> if exists for abort ().
2921
2922 2000-07-19 Alan Modra <alan@linuxcare.com.au>
2923
2924 * config/tc-hppa.c (hppa_fix_adjustable): Correct LR%/RR% comment.
2925 (arg_reloc_stub_needed): #ifdef OBJ_SOM, not #ifdef SOM.
2926 (pa_type_args): Same here.
2927
2928 2000-07-17 Mark Elbrecht <snowball3@bigfoot.com>
2929
2930 * config/obj-coff.c (obj_frob_symbol): Don't merge labels. Don't
2931 merge if the symbol isn't constant. Don't call S_SET_EXTERNAL if
2932 the storage class is already set.
2933
2934 2000-07-17 Kazu Hirata <kazu@hxi.com>
2935
2936 * config/tc-m68hc11.c: Fix formatting.
2937 * config/tc-mn10200.c: Likewise.
2938 * config/tc-mn10300.c: Likewise.
2939 * config/tc-pj.c: Likewise.
2940 * config/tc-tic80.c: Likewise.
2941 * config/tc-w65.c: Likewise.
2942
2943 2000-07-17 Frank Ch. Eigler <fche@redhat.com>
2944
2945 * expr.c (operand): Permit %bin literals if LITERAL_PREFIXPERCENT_BIN
2946 is defined.
2947
2948 2000-07-15 Ian Lance Taylor <ian@zembu.com>
2949
2950 * doc/c-mips.texi (MIPS Opts): Remove erroneous space after
2951 @code.
2952
2953 2000-07-15 Alan Modra <alan@linuxcare.com.au>
2954
2955 * config/tc-hppa.c (hppa_fix_adjustable): Use the same checks for
2956 ELF as are used for SOM (except the 32-bit reloc one) to decide
2957 whether a symbol can be reduced to a section symbol. Expand on
2958 the comment for symbols involved in LR% and RR% expressions.
2959
2960 2000-07-14 Nick Clifton <nickc@cygnus.com>
2961
2962 * config/tc-mips.c (mips_disable_float_construction): New
2963 static variable. Set to true if doubles should not be
2964 constructed by loading two single width fp registers with
2965 halves of the value.
2966 (mips_ip): Test mips_disable_float_construction.
2967 (md_longopts): Add command line switches --construct-floats
2968 and --no-construct-floats.
2969 (md_parse_option): Parse new command line options.
2970 (md_show_usage): Describe new command line options.
2971
2972 * doc/c-mips.texi: Document new command line options.
2973
2974 2000-07-13 Koundinya K <kk@ddeorg.soft.net>
2975
2976 * configure.in: Remove the test /usr/dde for mips-*-sysv4*MP*
2977 * configure: Regenerate.
2978
2979 2000-07-13 Hans-Peter Nilsson <hp@axis.com>
2980
2981 * configure.in (DEFAULT_EMULATION setting): Revert part of
2982 2000-07-01 change that set te_multi=multi unless set to tmips.
2983 * configure: Regenerate.
2984
2985 2000-07-12 Mark Elbrecht <snowball3@bigfoot.com>
2986
2987 * config/obj-coff.c (coff_frob_section): Add padding to the last
2988 section when aligning it increases its size.
2989
2990 2000-07-11 Kazu Hirata <kazu@hxi.com>
2991
2992 * config/tc-tic54x.c: Fix formatting.
2993
2994 2000-07-10 Kazu Hirata <kazu@hxi.com>
2995
2996 * config/tc-h8500.c: Fix formatting.
2997 * config/tc-tic54x.c: Fix formatting.
2998
2999 2000-07-10 Alan Modra <alan@linuxcare.com.au>
3000
3001 * config/tc-hppa.c (md_apply_fix): Check fmt 12 and 22 pc-rel
3002 displacements correctly.
3003
3004 * read.h (s_abort): Add ATTRIBUTE_NORETURN.
3005
3006 2000-07-10 Ryan Bradetich <rbradetich@uswest.net>
3007
3008 * hash.c (hash_insert): Add cast to obstruct_alloc to fix
3009 warning.
3010 (hash_jam): Ditto.
3011
3012 2000-07-09 Alan Modra <alan@linuxcare.com.au>
3013
3014 From David Huggins-Daines <dhd@linuxcare.com>
3015 * config/te-hppalinux64.h: Add a new emulation.
3016 * configure.in (emulations): Add configure bits to support the
3017 64-bit Linux/parisc target.
3018 * configure: Regenerate.
3019
3020 * config/tc-hppa.c (md_parse_option): Support `-V' for ELF.
3021 (md_shortopts): Add `V' for ELF.
3022
3023 * config/tc-hppa.c (arg_reloc_stub_needed): Define as zero except
3024 when SOM or ELF_ARG_RELOC are defined.
3025 (pa_type_args): Only set symbol_arg_reloc_info when SOM or
3026 ELF_ARG_RELOC are defined.
3027 (pa_stringer_aux): Don't pa_check_current_space_and_subspace here..
3028 (pa_stringer): ..Do it here instead. Fix comment typos.
3029 (hppa_force_relocation): Cast enums to int before comparing with
3030 ints.
3031
3032 From Ryan Bradetich <rbradetich@uswest.net>
3033 * config/tc-hppa.c: Removed unneeded libbfd.h to fix macro
3034 redifinition warning.
3035 (md_apply_fix): Added cast from enum to int for fixP->fx_r_type.
3036 (hppa_force_relocation): ditto
3037 (md_apply_fix): Added cast to buf to fix warnings.
3038
3039 * config/tc-hppa.h (pa_define_label, parse_cons_expression_hppa,
3040 cons_fix_new_hppa, hppa_force_relocation): Prototype.
3041
3042 * config/tc-hppa.c (reloc_type): It's an enum for OBJ_ELF.
3043 (R_N0SEL, R_N1SEL): Define only for OBJ_SOM.
3044 (tc_gen_reloc): Make `code' a reloc_type and `codes' a
3045 reloc_type** to avoid warnings in switch.
3046 (md_apply_fix): Make insn, val signed. Zap buf_wd and read insn a
3047 little earlier instead.
3048
3049 * config/tc-hppa.c (symbol_arg_reloc_info): Define for both som
3050 and elf.
3051 (pa_type_args): Use symbol_arg_reloc_info.
3052 (struct pa_it): Make arg_reloc unsigned int.
3053 (struct hppa_fix_struct): Likewise for fx_arg_reloc.
3054 (pa_text, pa_data, pa_comm): Don't compile for TE_LINUX.
3055 (pa_code): Delete. pa_text duplicates this function.
3056 (md_pseudo_table): Call obj_elf_text for ".code" if TE_LINUX.
3057 (fix_new_hppa): Argument offset is offsetT, arg_reloc is unsigned
3058 int.
3059 (cons_fix_new_hppa): Actually change selector to e_fsel when
3060 warning about assuming so.
3061 (tc_gen_reloc): More example elf arg reloc code.
3062 (md_apply_fix): Use arg_reloc_stub_needed for elf too.
3063 (hppa_force_relocation): Likewise.
3064
3065 * config/tc-hppa.h: Use TARGET_ARCH_SIZE to select target include
3066 files.
3067 (pa_end_of_source): Prototype.
3068 (hppa_fix_adjustable): Prototype.
3069 (LABELS_WITHOUT_COLONS): Move it..
3070 * config/te-hppa.h: To here.
3071
3072 * config/te-hppa64.h: New file.
3073
3074 * config/tc-hppa.c: Use TARGET_ARCH_SIZE to select target reloc
3075 type.
3076 (md_apply_fix): Pass stdoutput to bfd_hppa_insn2fmt. Handle
3077 format -10, -16, 16 relocs.
3078 (hppa_elf_mark_end_of_function): Test for null
3079 last_call_info->start_symbol
3080
3081 * config/tc-hppa.c (pa_ip): In case 'V', pass `strict' to
3082 CHECK_FIELD, not INSERT_FIELD_AND_CONTINUE. Don't pass opcode to
3083 re_assesmble_* functions. Delete extraneous statements. Fix
3084 typos in comments.
3085 (md_apply_fix): Compare against 1048575 in case 21. Don't pass
3086 insn to re_assemble_*.
3087
3088 2000-07-08 Ulf Carlsson <ulfc@engr.sgi.com>
3089
3090 * doc/internals.texi (Expressions): Fix typo.
3091
3092 2000-07-08 Kazu Hirata <kazu@hxi.com>
3093
3094 * config/tc-sh.c: Fix formatting.
3095 * config/tc-tic54x.c: Fix formatting.
3096 * depend.c: Fix formatting.
3097 * flonum-konst.c: Likewise.
3098 * flonum-mult.c: Likewise.
3099
3100 2000-07-07 Kazu Hirata <kazu@hxi.com>
3101
3102 * config/tc-sh.c: Fix comments.
3103 * config/obj-vms.c: Fix comments.
3104 * config/tc-a29k.c: Likewise.
3105 * config/tc-alpha.c: Likewise.
3106 * config/tc-h8300.c: Likewise.
3107 * config/tc-h8500.c: Likewise.
3108 * config/tc-i370.c: Likewise.
3109 * config/tc-ia64.c: Likewise.
3110 * config/tc-m68hc11.c: Likewise.
3111 * config/tc-m68k.c: Likewise.
3112 * config/tc-mips.c: Likewise.
3113 * config/tc-ns32k.c: Likewise.
3114 * config/tc-ppc.c: Likewise.
3115 * config/tc-z8k.c: Likewise.
3116
3117 2000-07-06 Mark Elbrecht <snowball3@bigfoot.com>
3118
3119 * config/obj-coff.c (TC_COFF_SECTION_DEFAULT_ATTRIBUTES): New.
3120 Default to '(SEC_LOAD | SEC_DATA)'.
3121 (obj_coff_section) [BFD_ASSEMBLER]: Use it.
3122
3123 * doc/internals.texi (CPU Backend): Describe
3124 TC_COFF_SECTION_DEFAULT_ATTRIBUTES.
3125
3126 Thu Jul 6 17:20:58 2000 Andrew Cagney <cagney@b1.cygnus.com>
3127
3128 * as.c (parse_args): NULL terminate the long option list.
3129
3130 Tue Jul 4 14:08:28 2000 Andrew Cagney <cagney@b1.cygnus.com>
3131
3132 * config/tc-d30v.h: Include "write.h" for fixS.
3133 (d30v_start_line, md_pcrel_from_section): Add function prototypes.
3134
3135 2000-07-05 Nick Clifton <nickc@cygnus.com>
3136
3137 * config/tc-d30v.c (write_2_short): Further changes to warning
3138 messages produced when combining EITHER_BUT_PREFER_MU attributed
3139 opcodes.
3140
3141 2000-07-05 DJ Delorie <dj@redhat.com>
3142
3143 * MAINTAINERS: new
3144
3145 2000-07-04 Alexandre Oliva <aoliva@redhat.com>
3146
3147 * config/tc-arm.c (psrs): Accept combinations of flags.
3148
3149 2000-07-03 Marek Michalkiewicz <marekm@linux.org.pl>
3150
3151 * config/tc-avr.c: Change _ () to _() around all strings marked
3152 for translation (exception from the usual coding style).
3153 (avr_opt): New struct variable, how the new switches are set.
3154 (OPTION_MMCU): Define as 'm' and actually use.
3155 (md_longopts): Add -mall-opcodes, -mno-skip-bug, -mno-wrap.
3156 (show_mcu_list): New function, display the list of known MCUs.
3157 (md_show_usage): Document the new switches. Call show_mcu_list.
3158 (avr_set_arch): Change 'm' to OPTION_MMCU.
3159 (md_parse_option): Call show_mcu_list if unknown MCU specified.
3160 Handle the new switches.
3161 (avr_operands): Disable warnings for undefined combinations of
3162 operands if -mall-opcodes. Disable warnings for skipping two-word
3163 instructions if enhanced core or -mno-skip-bug.
3164 (avr_operand): Accept all addressing modes on avr1 if -mall-opcodes.
3165 (md_apply_fix3): Reject 8K wrap if >8K or -mno-wrap.
3166 (md_assemble): Accept opcodes not supported by MCU if -mall-opcodes.
3167 (avr_ldi_expression): Warn about implicit lo8().
3168 * config/tc-avr.h (md_pcrel_from_section): Add prototype.
3169
3170 2000-07-01 Koundinya K <kk@ddeorg.soft.net>
3171
3172 * configure.in: Add entry for mips-*-sysv4*MP*
3173 * configure: Rebuild
3174 * config/tc-mips.c (mips_target_format): Return elf32-tradbigmips or
3175 elf32-tradlittlemips for traditional mips targets.
3176 * config/tc-mips.c (md_estimate_size_before_relax): Duplicate the
3177 test for Link Once sections as in adjust_reloc_syms.
3178 * config/te-tmips.h: New file for traditional mips targets. Define
3179 TE_TMIPS.
3180
3181 2000-06-29 Mark Elbrecht <snowball3@bigfoot.com>
3182
3183 * config/obj-coff.c (obj_coff_setcion) [BFD_ASSEMBLER]: If the
3184 flags argument is not present, don't change an existing section's
3185 section's attributes. If the flags argument is present, warn if the
3186 attributes don't match the section's current attributes. When
3187 long section names are supported, set SEC_LINK_ONCE and
3188 SEC_LINK_DUPLICATES_DISCARD for a new .gnu.linkonce section.
3189
3190 Thu Jun 29 21:30:00 2000 Hans-Peter Nilsson <hp@axis.com>
3191
3192 * config/obj-aout.c (obj_aout_type): Do not ignore for undefined
3193 symbols; create them.
3194
3195 2000-06-29 Mark Elbrecht <snowball3@bigfoot.com>
3196
3197 * write.c (set_segment_vma): New: Set vma and lma for a segment.
3198 (write_object_file) [BFD_ASSEMBLER && OBJ_COFF && TE_GO32]: Use it.
3199
3200 2000-06-27 Aldy Hernandez <aldyh@redhat.com>
3201
3202 * config/tc-mips.c (mips_ip): handle "(foo-.-4)" type of
3203 expressions. Ignore the problem when handling 16 bit signed
3204 immediates, because the assembler will take care of the relocation
3205 later.
3206
3207 2000-06-27 Nick Clifton <nickc@cygnus.com>
3208
3209 * config/tc-d30v.c (write_2_short): Do not allow opcodes with
3210 the EITHER_BUT_PREFER_MU attribute to be combined into a reverse
3211 sequential order, and emit warning messages if the input source
3212 code contains constructs like that, or parallel constructs
3213 containing such opcodes.
3214
3215 2000-06-26 Marek Michalkiewicz <marekm@linux.org.pl>
3216
3217 * config/tc-avr.c (mcu_types): Rename avr4 to avr5, add avr4.
3218 Add more MCU types for avr4 and avr5. Replace at94k{10,20,40}
3219 with just at94k. Change AVR_ISA_85xx back to AVR_ISA_2xxx.
3220 (md_show_usage): Update usage message.
3221 (md_parse_option): Allow redefinition of MCU type within the
3222 same avr[1-5] bfd machine type. Show both old and new MCU type
3223 in the error message.
3224 (md_apply_fix3): Support 8K wrap if AVR_ISA_MEGA is not set.
3225 Simplify 8K wrap code.
3226
3227 2000-06-25 Kazu Hirata <kazu@hxi.com>
3228
3229 * config/obj-aout.c: Remove all uses of DEFUN.
3230 * config/obj-ieee.c: Likewise.
3231 * config/tc-sh.c: Fix comment typos.
3232 * config/tc-tahoe.c: Likewise.
3233 * config/tc-vax.c: Likewise.
3234 * config/tc-w65.c: Likewise.
3235 * config/tc-z8k.c: Likewise.
3236 * config/tc-h8300.c (build_bytes): Assemble ldmac correctly.
3237
3238 2000-06-24 DJ Delorie <dj@cygnus.com>
3239
3240 * config/tc-i386.c (md_estimate_size_before_relax): Revert
3241 more changes from Sept 1999
3242 (tc_i386_fix_adjustable): ditto
3243 (md_apply_fix3): ditto
3244
3245 2000-06-24 Frank Ch. Eigler <fche@redhat.com>
3246
3247 * cgen.c (expr_jmp_buf_p): New validity flag for expr_jmp_buf.
3248 (gas_cgen_parse_operand): Set it around expression() call.
3249 (gas_cgen_md_operand): Test for it before longjmp().
3250
3251 2000-06-24 Kazu Hirata <kazu@hxi.com>
3252
3253 * config/tc-h8500.c: Remove all uses of DEFUN.
3254 * config/tc-sh.c: Likewise.
3255 * config/tc-w65.c: Likewise.
3256 * config/tc-z8k.c: Likewise.
3257
3258 * config/tc-h8500.c: Fix typos in comments.
3259
3260 2000-06-23 Frank Ch. Eigler <fche@redhat.com>
3261
3262 * expr.c (operand): Permit $hex literals if LITERAL_PREFIXDOLLAR_HEX
3263 is defined.
3264
3265 2000-06-23 matthew green <mrg@redhat.com>
3266
3267 * expr.c (operand): Do not as_bad() if RELAX_PAREN_GROUPING is
3268 defined. Fix error message for `[' grouping.
3269
3270 2000-06-22 Kazu Hirata <kazu@hxi.com>
3271
3272 * config/tc-h8300.c: Fix formatting and comment typos.
3273
3274 2000-06-22 Timothy Wall <twall@cygnus.com>
3275
3276 * config/tc-ia64.c (note_register_values): Move premature QP
3277 notation clearing into the appropriate place.
3278
3279 2000-06-22 Alan Modra <alan@linuxcare.com.au>
3280
3281 * dep-in.sed: Escape literal `.'s on patterns. Trim off `../'
3282 first before anything else. Add bin-bugs.h, emul.h and progress.h
3283 Sort list of files as for $(OBJS) in Makefile.am.
3284
3285 * Makefile.am (DEP): grep for leading `/' in DEPA, and fail if we
3286 find one. Remake dependencies.
3287 ($(OBJS)): Add bin-bugs.h, emul.h, and progress.h Sort the list.
3288 * Makefile.in: Regenerate.
3289 * doc/Makefile.in: Regenerate.
3290
3291 * config/tc-i386.c (i386_displacement): Don't assume a constant
3292 displacement is necessarily 16 bits when in 16 bit code mode.
3293 (md_assemble): Instead size the displacement here after we know
3294 for sure that a .code16gcc operand hasn't automatically added
3295 operand size prefixes.
3296
3297 2000-06-21 H.J. Lu <hjl@gnu.org>
3298
3299 * Makefile.am: Rebuild dependency.
3300 * Makefile.in: Rebuild.
3301
3302 2000-06-21 Kazu Hirata <kazu@hxi.com>
3303
3304 * config/tc-h8300.c (parse_reg): Make the function static.
3305 (parse_exp): Likewise.
3306
3307 2000-06-20 DJ Delorie <dj@cygnus.com>
3308
3309 * config/tc-i386.c (tc_i386_fix_adjustable): Revert change from
3310 Sept 1999; RVA relocs need to be treated more like DIR32 relocs
3311 for cygwin import libraries to work properly.
3312
3313 2000-06-20 H.J. Lu <hjl@gnu.org>
3314
3315 * Makefile.am: Rebuild dependency.
3316 * Makefile.in: Rebuild.
3317 * configure: Likewise.
3318 * doc/Makefile.in: Likewise.
3319
3320 2000-06-20 Timothy Wall <twall@cygnus.com>
3321
3322 * doc/internals.texi (CPU backend): Add @itemx for
3323 TC_START_LABEL_WITHOUT_COLON.
3324 * doc/c-tic54x.texi: New.
3325 * doc/as.texinfo: Add tic54x features and include primary tic54x
3326 documentation file.
3327 * doc/all.texi: Add C54X.
3328 * doc/Makefile.am (CPU_DOCS): Add c-tic54x.texi.
3329 * doc/Makefile.in: Regenerate.
3330 * configure.in: Add tic54x and define LIBM for tic54x.
3331 * configure: Regenrate.
3332 * config/tc-tic54x.[ch]: New.
3333 * config/obj-coff.h: Add tic54x.
3334 * Makefile.am: (CPU_TYPES): Add tic54x.
3335 (TARGET_CPU_CFILES): Add 'tc-tic54x.c'.
3336 (TARGET_CPU_HFILES): Add 'tc-tic54x.h'.
3337 (as_new_LDADD): Add $(LIBM).
3338 * Makefile.in: Regenerate.
3339
3340 2000-06-18 Stephane Carrez <stcarrez@worldnet.fr>
3341
3342 * doc/Makefile.am (CPU_DOCS): Added 68hc11 file.
3343 * doc/c-m68hc11.texi: Document 68HC11 and 68HC12 port.
3344 * doc/as.texinfo: Likewise.
3345
3346 * configure, Makefile.in: Regenerate.
3347 * configure.in (emulations): Recognize m6811 and m6812.
3348 * Makefile.am (CPU_TYPES, TARGET_CPU_CFILES, TARGET_CPU_HFILES):
3349 Added files for 68hc11 and 68hc12 assembler.
3350 * config/tc-m68hc11.c: Assembler for 68hc11 and 68hc12.
3351 * config/tc-m68hc11.h: Header definition for that assembler.
3352
3353 2000-06-18 Nick Clifton <nickc@redhat.com>
3354
3355 * symbols.c (resolve_symbol_value): Use bfd_octets_per_byte
3356 instead of OCTETS_PER_BYTE.
3357
3358 * config/tc-v850.c: Fix compile time warnings.
3359 * config/tc-ppc.c: Fix compile time warnings.
3360
3361 2000-06-18 H.J. Lu <hjl@gnu.org>
3362
3363 * configure.in: Don't emulate i386-pc-pe-coff with i386coff.
3364 * configure: Rebuild.
3365
3366 2000-06-17 Mark Elbrecht <snowball3@bigfoot.com>
3367
3368 * config/obj-coff.c (obj_coff_weak): Typo fix: Change BFD_ASSEMLER
3369 to BFD_ASSEMBLER.
3370
3371 2000-06-16 Nick Clifton <nickc@cygnus.com>
3372
3373 * config/tc-mips.c (md_parse_option): Accept RM5200,RM5230,
3374 RM5231, RM5261, RM5721 and RM7000 as r5000 cpu variants.
3375
3376 * doc/c-mips.texi: Document newly accepted cpu variants.
3377
3378 2000-06-15 Ulf Carlsson <ulfc@engr.sgi.com>
3379
3380 * config/tc-mips.h: Remove definition of ONLY_STANDARD_ESCAPES.
3381
3382 2000-06-13 Ulf Carlsson <ulfc@engr.sgi.com>
3383
3384 * macro.c (getstring): Make it possible to escape the quote
3385 character.
3386
3387 Tue Jun 13 20:58:28 2000 Catherine Moore <clm@redhat.com>
3388
3389 * config/tc-hppa.c (pa_export): Weak symbols can be global.
3390
3391 2000-06-13 H.J. Lu <hjl@gnu.org>
3392
3393 * configure: Regenerate.
3394
3395 2000-06-09 Alan Modra <alan@linuxcare.com.au>
3396
3397 * app.c (do_scrub_begin): Don't default lex[';'] as a line
3398 separator.
3399 * doc/internals.texi (line_separator_chars): Semicolon is no
3400 longer a default. Mention null and newline as defaults.
3401
3402 * read.c (is_end_of_line): Remove ifdef TC_HPPA.
3403
3404 * config/tc-i386.h (line_separator_chars): Explicitly mention `;'
3405 * config/tc-i860.h (line_separator_chars): Likewise.
3406 * config/tc-h8300.c (line_separator_chars): Likewise.
3407 * config/tc-i960.c (line_separator_chars): Likewise.
3408 * config/tc-m68k.c (line_separator_chars): Likewise.
3409 * config/tc-mips.c (line_separator_chars): Likewise.
3410 * config/tc-ns32k.c (line_separator_chars): Likewise.
3411 * config/tc-sparc.c (line_separator_chars): Likewise.
3412 * config/tc-vax.c (line_separator_chars): Likewise.
3413
3414 * config/tc-h8300.c (comment_chars): Use string initialiser.
3415 * config/tc-i960.c (line_comment_chars): Likewise.
3416 * config/tc-z8k.c (comment_chars, line_comment_chars,
3417 line_separator_chars): Likewise.
3418
3419 * config/tc-arm.c (line_separator_chars): Always use `;', not just
3420 for TE_LINUX.
3421
3422 2000-06-08 Nick Clifton <nickc@cygnus.com>
3423
3424 * config/tc-arm.c (cons_fix_new_arm): Assign correct reloc value
3425 for size 1 fixes.
3426
3427 2000-06-08 David O'Brien <obrien@FreeBSD.org>
3428
3429 * configure.in (VERSION): Update to show this is the CVS mainline.
3430
3431 2000-06-08 Matthew Jacob <mjacob@feral.com>
3432
3433 * config/tc-alpha.c (md_undefined_symbol): Properly understand that
3434 $at is the integer register $r28, vs. both $r28 and the floating
3435 point register $f28.
3436
3437 2000-06-08 James E. Wilson <wilson@cygnus.com>
3438
3439 * config/tc-ia64.c (generate_unwind_image): Call ia64_flush_insns.
3440 (dot_endp): Don't call ia64_flush_insns.
3441 (emit_one_bundle): Don't delete prologue/body records from
3442 unwind_record list in first loop. Rewrite second loop to account for
3443 this.
3444
3445 2000-06-07 David Mosberger <davidm@hpl.hp.com>
3446
3447 * config/tc-ia64.c: Add missing prototypes.
3448 (generate_unwind_image): Cast argument to output_unw_records call.
3449
3450 Wed Jun 7 22:44:14 2000 Denis Chertykov <denisc@overta.ru>
3451
3452 * config/tc-avr.c (avr_operand): fix the formatting of the comment.
3453
3454 Wed Jun 7 21:26:15 2000 Denis Chertykov <denisc@overta.ru>
3455
3456 * config/tc-avr.c (AVR_ISA_???): moved to include/opcode/avr.h
3457 (REGISTER_P): likewise.
3458 (avr_opcodes): uses include/opcode/avr.h
3459 (avr_operand): enable ld r,Z or st r,Z for at90s1200.
3460
3461 2000-06-04 Alan Modra <alan@linuxcare.com.au>
3462
3463 * read.c (is_end_of_line): No ';' for TC_HPPA. Add missing
3464 initializers too.
3465
3466 2000-06-03 H.J. Lu <hjl@gnu.org>
3467
3468 * read.c (is_end_of_line): Put back `;'.
3469
3470 2000-06-03 Alan Modra <alan@linuxcare.com.au>
3471
3472 * config/tc-i386.c (md_shortopts): Remove 'm', add 'q' to non-elf.
3473
3474 2000-06-01 Alan Modra <alan@linuxcare.com.au>
3475
3476 * expr.c (operand): Test is_end_of_line outside switch to catch
3477 line separator chars that are also operators.
3478 (operator): Return O_illegal for line separator chars.
3479
3480 * read.c (is_end_of_line): Use 1 instead of 99. Don't set `;'
3481 entry (or `!' entry for TC_HPPA).
3482
3483 * config/tc-arm.c (my_get_float_expression): Cast to unsigned char
3484 before indexing is_end_of_line. Remove redundant check for '\0'.
3485 (fp_op2): Likewise.
3486 * config/tc-h8500.c (md_assemble): Likewise.
3487 * config/tc-mcore.c (md_assemble): Likewise.
3488 * config/tc-tic30.c (tic30_find_parallel_insn): Likewise.
3489 (md_atof): Likewise
3490
3491 * config/tc-m88k.c (s_bss): Cast to unsigned char before indexing
3492 is_end_of_line.
3493 * config/tc-mcore.c (mcore_cons): Likewise.
3494 (mcore_float_cons): Likewise.
3495 (mcore_stringer): Likewise.
3496 * config/tc-tic30.c (tic30_find_parallel_insn): Likewise.
3497
3498 2000-06-01 Scott Bambrough <scottb@netwinder.org>
3499
3500 * config/tc-arm.c (do_mrs): Allow SPSR_BIT to be set correctly.
3501
3502 2000-05-29 Nick Clifton <nickc@cygnus.com>
3503
3504 * config/tc-sh.c: Fix compile time warning messages.
3505
3506 * config/tc-mips.c: Fix compile time warning messages.
3507
3508 2000-05-29 Philip Blundell <philb@gnu.org>
3509
3510 * doc/as.texinfo: Update copyright dates.
3511 (Local Labels): Delete misplaced mention of ARM.
3512 * NEWS: Mention ARM ELF support.
3513
3514 2000-05-27 Alexandre Oliva <aoliva@cygnus.com>
3515
3516 * config/tc-mn10300.c (md_assemble): Copy size to real_size before
3517 it is modified, and use the real_size to compute the frag address
3518 for dwarf2 line info.
3519
3520 2000-05-27 Alan Modra <alan@linuxcare.com.au>
3521
3522 * Makefile.am (DEP, DEP1, dep, dep-in, dep-am): Use a better sed
3523 line-matching scheme to cope with automake moving variables around.
3524 ($(TARG_CPU_O)): Remove dependency on TARG_CPU_DEP_@target_cpu_type@
3525 * Makefile.in: Regenerate.
3526
3527 2000-05-26 Jakub Jelinek <jakub@redhat.com>
3528
3529 * config/tc-sparc.c (sparc_relax): New.
3530 (md_longopts): Add -relax and -no-relax options.
3531 (md_parse_options, md_show_usage): Likewise.
3532 (md_apply_fix3): Optimize tail call into branch always if possible.
3533
3534 Thu May 4 15:27:07 2000 Donald Lindsay <dlindsay@cygnus.com>
3535
3536 * config/tc-d10v.c (write_2_short, parallel_ok, md_assemble,
3537 d10v_cleanup) implement Mitsubishi's newly explained branch-packing
3538 rules, with warning when a GAS statement specifies a packing that
3539 will result in an instruction being squashed.
3540 Added typdef packing_type and enumerals, changed various integer
3541 literals to use the enumerals.
3542
3543 2000-05-24 David Mosberger <davidm@hpl.hp.com>
3544
3545 * config/tc-ia64.c (dot_restorereg_p): New function.
3546 (md_pseudo_table): Add restorereg.p.
3547 (output_X3_format): Fix typo: record type should be UNW_X3, not UNW_X1.
3548 (output_X4_format): Fix typo: record type should be UNW_X4, not UNW_X2.
3549
3550 * config/tc-ia64.h (unw_record_type): Add unwabi.
3551 (unw_r_record): Rename member MASK to GRMASK. Add sub-structure
3552 called MASK with members for imask, and the masks produced by
3553 fr_mem, gr_mem, br_mem, and frgr_mem.
3554 (unw_p_record): Add members ABI and CONTEXT.
3555 (unw_x_record): Add member AB.
3556 * config/tc-ia64.c (enum reg_symbol): Add REG_PSP and REG_PRIUNAT
3557 as pseudo-register for use during unwind info generation.
3558 (AR_PFS, AR_LC): New macros.
3559 (enum pseudo_type): Add PSEUDO_FUNC_REG to permit declaring registers
3560 whose names start with an at sign (as in "@priunat").
3561 (pseudo_func): Add "svr4", "hpux", "nt" constants and "priunat"
3562 register.
3563 (unwind_list, unwind_tail, current_unwind_entry, proc_start,
3564 proc_end, unwind_info, personality_routine): Consolidate into
3565 "unwind" structure to reduce offset-table use. Add member
3566 NEXT_SLOT_NUMBER to track the slot number for the next instruction
3567 to be emitted.
3568 (output_R1_format, output_R3_format, output_P3_format,
3569 output_P6_format): Initialize R with zero to reduce compiler warnings.
3570 (output_P7_format): Ditto. Add `default' branch to switch
3571 statement to reduce compiler warnings.
3572 (output_P8_format, output_B1_format, output_B4_format): Ditto.
3573 (output_P4_format): Rename 2nd & 3rd arg to IMASK and IMASK_SIZE.
3574 (format_ab_reg): Rename from format_a_b_reg. Merge A and B args
3575 into single argument.
3576 (output_X1_format, output_X3_format): Initialize R with zero to reduce
3577 compiler warnings. Merge A and B args into single argument.
3578 (output_X2_format, output_X4_format): Remove unused variable R. Merge
3579 A and B args into single argument.
3580 (free_record): Removed (wasn't used).
3581 (free_list_records): Also free imasks in prologue records.
3582 (output_prologue, output_prologue_gr): Initialize mask bits to zero.
3583 (output_spill_mask): Remove.
3584 (output_unwabi): New function.
3585 (output_epilogue, output_label_state, output_copy_state): Call
3586 alloc_record.
3587 (output_spill_psprel, output_spill_sprel, output_spill_psprel_p,
3588 output_spill_sprel_p, output_spill_reg, output_spill_reg_p): Add AB
3589 argument.
3590 (process_one_record): New locals FR_MASK and GR_MASK. Ignore
3591 gr_mem, fr_mem, br_mem, and frgr_mem records and instead emit them
3592 as part of handling the prologue records. Emit region's imask if
3593 we have one. Handle unwabi, epilogue, label_state, copy_state,
3594 spill_psprel, spill_sprel, spill_reg, spill_psprel_p,
3595 spill_sprel_p, and spill_reg_p records.
3596 (set_imask, count_bits, slot_index): New function.
3597 (fixup_unw_records): Fix region size computation. Handle
3598 epilogue, spill_reg, spill_sprel, spill_psprel, spill_reg_p,
3599 spill_sprel_p, and spill_psprel_p records. Merge mask bits of
3600 frgr_mem, fr_mem, gr_mem, br_mem on a per-region basis and
3601 set_imask accordingly. Update imask for gr_gr, and br_gr records.
3602 (convert_expr_to_ab_reg, convert_expr_to_xy_reg): New function.
3603 (dot_save): Use manifest constants for applicaton registers.
3604 Handle REG_PR and REG_PRIUNAT.
3605 (dot_restore): Don't just ignore it.
3606 (dot_restorereg): New function..
3607 (generate_unwind_image): Ensure unwind info is a multiple of eight
3608 bytes, not just four bytes.
3609 (dot_handlerdata, dot_unwentry): Demand empty rest of line.
3610 (dot_altrp): Don't just ignore it.
3611 (dot_savemem): New function. Replaces dot_savesp() and
3612 dot_savepsp(). Use manifest constants for applicaton registers.
3613 Handle REG_PR and REG_PRIUNAT.
3614 (dot_savef): Simplify.
3615 (dot_saveb): Support generation of br_gr.
3616 (dot_spillreg, dot_spillmem, dot_spillreg_p, dot_spillmem_p,
3617 dot_label_state, dot_copy_state): New function.
3618 (dot_unwabi): Don't just ignore it.
3619 (md_pseudo_table): Add restorereg, spillreg, spillsp, spillpsp,
3620 spillreg.p, spillsp.p, spillpsp, label_state, copy_state,
3621 unwabi, vframesp, and vframepsp. Fix typo alprp->altrp.
3622 (emit_one_bundle): Set slot number for prologue/body records
3623 *before* emitting the first insn.
3624 (emit_one_bundle): Set UNWIND.NEXT_SLOT_NUMBER.
3625 (md_begin): Declare "psp" pseudo-register.
3626 (md_operand): Handle PSEUDO_FUNC_REG. Fix printing of error message
3627 so we don't get segfault.
3628 (output_psp_sprel): Output sp/psp relative offsets as 4-byte word
3629 counts as required per SW Conventions manual
3630 (output_rp_psprel, output_rp_sprel, output_pfs_psprel,output_pfs_sprel,
3631 output_preds_psprel, output_preds_sprel, output_spill_base,
3632 output_unat_psprel, output_unat_sprel, output_lc_psprel,
3633 output_lc_sprel, output_fpsr_psprel, output_fpsr_sprel,
3634 output_priunat_psprel, output_priunat_sprel, output_bsp_psprel,
3635 output_bsp_sprel, output_bspstore_psprel, output_bspstore_sprel,
3636 output_rnat_psprel, output_rnat_sprel, output_spill_psprel,
3637 output_spill_sprel, output_spill_psprel_p, output_spill_sprel_p):Ditto.
3638 (dot_vframe): Implement.
3639 (dot_vframesp, dot_vframepsp): New function.
3640
3641 Tue May 23 00:57:05 2000 Hans-Peter Nilsson <hp@axis.com>
3642
3643 * configure.in (i386-*-freebsd a.out entry): Quote properly.
3644 * configure: Regenerate.
3645
3646 2000-05-23 Alan Modra <alan@linuxcare.com.au>
3647
3648 * config/tc-i386.c (md_assemble): Pass jump reloc in fr_var...
3649 (md_estimate_size_before_relax): so we can use it here instead of
3650 old kludges. Localise vars to blocks. Comment.
3651
3652 * frags.c (frag_new): Update fr_var comments.
3653 * frags.h (struct frag): Ditto.
3654
3655 2000-05-22 Richard Henderson <rth@cygnus.com>
3656
3657 * config/tc-ia64.c (FUNC_PC_RELATIVE): New.
3658 (pseudo_func): Add pcrel.
3659 (operand_match): Handle IA64_OPND_TGT64.
3660 (build_insn): Likewise.
3661 (md_begin): Initialize pseudo_func[FUNC_PC_RELATIVE].
3662 (ia64_gen_real_reloc_type): Handle FUNC_PC_RELATIVE.
3663 (fix_insn): Handle all three 64-bit relocation types.
3664
3665 Mon May 22 22:43:32 2000 Hans-Peter Nilsson <hp@axis.com>
3666
3667 * obj.h (struct format_ops): New members begin, app_file,
3668 s_set_other, s_set_desc, s_get_type, s_set_type,
3669 separate_stab_sections, init_stab_section.
3670
3671 * config/obj-multi.h: Update GPL notice to v2.
3672 (obj_begin): New.
3673 (obj_app_file): New.
3674 (S_SET_SIZE): Test s_set_size for NULL before calling.
3675 (S_SET_ALIGN): Similar for s_set_align.
3676 (S_SET_OTHER): New.
3677 (S_SET_DESC): New.
3678 (S_GET_TYPE): New.
3679 (S_SET_TYPE): New.
3680 (SEPARATE_STAB_SECTIONS): New.
3681 (INIT_STAB_SECTION): New.
3682 (EMIT_SECTION_SYMBOLS): New.
3683 (AOUT_STABS) [OBJ_MAYBE_AOUT]: Define.
3684
3685 * config/obj-elf.h: Update GPL notice to v2.
3686 Mention that this file is included from obj-multi.h.
3687 (obj_begin): Wrap definition in ifndef.
3688 (elf_file_symbol): Constify declaration.
3689 (obj_app_file): Ditto.
3690 (SEPARATE_STAB_SECTIONS, INIT_STAB_SECTION, OBJ_PROCESS_STAB):
3691 Wrap in ifndef SEPARATE_STAB_SECTIONS.
3692
3693 * config/obj-elf.c (elf_s_set_other): New.
3694 (elf_file_symbol): Constify argument.
3695 (elf_separate_stab_sections): New.
3696 (elf_init_stab_section): New.
3697 (elf_format_ops): Add new members. Remove comma at end.
3698
3699 * config/obj-ecoff.c (ecoff_separate_stab_sections): New.
3700 (ecoff_format_ops): Add new fields. Remove comma at end.
3701 Mention inconsistency for emit_section_symbols.
3702
3703 * config/obj-coff.h (c_dot_file_symbol): Constify declaration.
3704
3705 * config/obj-coff.c (c_dot_file_symbol): Constify argument.
3706 (coff_separate_stab_sections): New.
3707 (coff_format_ops): Add new members.
3708
3709 * config/obj-aout.c (obj_aout_sec_sym_ok_for_reloc): New.
3710 (obj_aout_s_set_other): New.
3711 (obj_aout_s_set_desc): New.
3712 (obj_aout_s_get_type): New.
3713 (obj_aout_s_set_type): New.
3714 (obj_aout_separate_stab_sections): New.
3715 (aout_format_ops): New members added. Use obj_aout_process_stab,
3716 not 0. Use obj_aout_sec_sym_ok_for_reloc, not 0.
3717 (obj_aout_frob_symbol): Add ATTRIBUTE_UNUSED to args as
3718 appropriate.
3719 (obj_aout_line, obj_aout_weak, obj_aout_type): Ditto.
3720
3721 2000-05-22 Alan Modra <alan@linuxcare.com.au>
3722
3723 * config/tc-i386.c (tc_i386_fix_adjustable): Prevent adjustment
3724 for OBJ_MAYBE_ELF too. Use S_IS_EXTERNAL instead of S_IS_EXTERN.
3725 (md_estimate_size_before_relax): Ensure jumps to weak and
3726 externally visible symbols are relocatable.
3727
3728 Sat May 20 16:41:55 2000 Hans-Peter Nilsson <hp@axis.com>
3729
3730 * stabs.c (aout_process_stab): Make global.
3731 (s_desc): Add ATTRIBUTE_UNUSED to args as appropriate.
3732 * read.h (aout_process_stab): Declare.
3733
3734 * configure.in (EMULATIONS) [i386aout, i386coff, i386elf]:
3735 Generalize to *aout, *coff *elf.
3736 * configure: Regenerated.
3737
3738 * doc/internals.texi (Object format backend): Say
3739 SEPARATE_STAB_SECTIONS needs to be nonzero, not just defined.
3740
3741 * Makefile.am (TARG_ENV_HFILES): Delete te-multi.h.
3742 * Makefile.in: Regenerated.
3743
3744 2000-05-19 Catherine Moore <clm@cygnus.com>
3745
3746 * cgen.h (GAS_CGEN_MAX_FIXUPS): Check if already defined.
3747
3748 2000-05-18 Alan Modra <alan@linuxcare.com.au>
3749
3750 * config/tc-hppa.c (md_apply_fix): Mask out immediate bits of
3751 instruction to reflect change in re_assemble_*.
3752
3753 Thu May 18 10:52:14 2000 Jeffrey A Law (law@cygnus.com)
3754
3755 * configure.in (hppa-*-hpux11*): If the cpu is hppa*64*, then
3756 build PA64 ELF tools.
3757 * configure: Rebuilt.
3758
3759 2000-05-17 Alan Modra <alan@linuxcare.com.au>
3760
3761 * Makefile.am: Regenerate dependencies.
3762 * Makefile.in: Regenerate.
3763
3764 2000-05-15 Nick Clifton <nickc@cygnus.com>
3765
3766 * config/tc-arm.c (struct asm_psr): Add boolean field
3767 distinguishing between CSPR and SPSR. Rename 'number' field
3768 to 'field'.
3769 (psrs): Rearrange contents to match new asm_psr structure.
3770 (arm_psr_parse): Move next to psr_required_here. Make it
3771 return an asm_psr structure.
3772 (psr_required_here): Use asm_psr structure returned by
3773 arm_psr_parse.
3774 (do_msr): Reorganise to allow psr_required_here to be called
3775 only once.
3776 (md_undefined_name): Mark 'name' parameter as unused, since
3777 the COFF target does not use it.
3778
3779 2000-05-14 David O'Brien <obrien@FreeBSD.org>
3780
3781 * config/te-386bsd.h: Clean up comments to adhere to the GNU coding
3782 standards.
3783 * config/te-aux.h: Likewise.
3784 * config/te-dpx2.h: Likewise.
3785 * config/te-go32.h: Likewise.
3786 * config/te-hp300.h: Likewise.
3787 * config/te-hppa.h: Likewise.
3788 * config/te-i386aix.h: Likewise.
3789 * config/te-ic960.h: Likewise.
3790 * config/te-interix.h: Likewise.
3791 * config/te-nbsd532.h: Likewise.
3792 * config/te-pc532mach.h: Likewise.
3793 * config/te-ppcnw.h: Likewise.
3794 * config/te-psos.h: Likewise.
3795 * config/te-sparcaout.h: Likewise.
3796 * config/te-sun3.h: Likewise.
3797 * config/te-sysv32.h: Likewise.
3798
3799 2000-05-14 Alan Modra <alan@linuxcare.com.au>
3800
3801 * config/tc-h8300.c (do_a_fix_imm): Don't rely on `short' being 16
3802 bits. Instead explicitly mask and sign extend. Do the 8 bit mask
3803 and sign extend without an if statement.
3804 (build_bytes): Likewise.
3805
3806 2000-05-14 Kazu Hirata <kazu@hxi.com>
3807
3808 * config/tc-h8300.c (do_a_fix_imm): Output a reloc for no
3809 X_add_symbol L_32 case.
3810
3811 2000-05-14 David O'Brien <obrien@FreeBSD.org>
3812
3813 * config/te-freebsd.h: New file.
3814
3815 2000-05-13 Alan Modra <alan@linuxcare.com.au>
3816
3817 * asintl.h (gettext, dgettext, dcgettext, textdomain,
3818 bindtextdomain): Replace defines with those from intl/libgettext.h
3819 to quieten gcc warnings.
3820
3821 * NEWS: Mention x86 .arch and -q.
3822
3823 * config/tc-i386.c (quiet_warnings): New.
3824 (md_assemble): Use quiet_warnings.
3825 (md_parse_option): Set quiet_warnings from -q.
3826 (md_show_usage): Mention -q, delete -m.
3827 (flag_do_long_jump): Delete.
3828 (md_parse_option): Remove -m.
3829 (md_show_usage): Remove -m.
3830 (md_create_long_jump): Remove useless flag_do_long_jump code.
3831
3832 * as.c (parse_args): In case OPTION_DEFSYM, use a valueT to hold
3833 the symbol value, and use bfd_scan_vma if BFD_ASSEMBLER.
3834
3835 2000-05-13 Alan Modra <alan@linuxcare.com.au>
3836 Alexander Sokolov <robocop@netlink.ru>
3837
3838 * doc/c-i386.texi (i386-Arch): New section.
3839 (i386-Syntax): Mention .intel_syntax and .att_syntax.
3840
3841 * config/tc-i386.c (cpu_arch_name, cpu_arch_flags): New.
3842 (smallest_imm_type): Use smallest opcode for shift by one if cpu
3843 architecture has been given and is not 486.
3844 (set_cpu_arch): New.
3845 (md_pseudo_table): Add .arch.
3846 (md_assemble): Warn if cpu architecture has been given and an
3847 unsupported instruction.
3848
3849 * config/tc-i386.h (SMALLEST_DISP_TYPE): Delete.
3850 Move operand_types bit defines after relevant template field.
3851 (template): Add cpu_flags.
3852 (Cpu*): Define.
3853 (arch_entry): New.
3854
3855 2000-05-12 Alexandre Oliva <aoliva@cygnus.com>
3856
3857 * config/tc-mn10300.h (md_end): Define.
3858 (mn10300_finalize): Declare.
3859 * config/tc-mn10300.c: Include dwarf2dbg.h.
3860 (debug_line): Define.
3861 (md_assemble): Generate dwarf2 line info.
3862 (mn10300_finalize): New function. Finalize dwarf2 info.
3863
3864 2000-05-11 Ulf Carlsson <ulfc@engr.sgi.com>
3865
3866 * config/tc-mips.c (md_estimate_size_before_relax): Use the
3867 external version of the relocation for weak symbols.
3868
3869 2000-05-08 David Mosberger <davidm@hpl.hp.com>
3870
3871 * config/tc-ia64.c (output_P7_format, case mem_stack_f): Output fixed
3872 frame size in units of 16 bytes, as required per SW Conventions manual.
3873 (output_unw_records): Output info-block header as a dword to get
3874 byte-order right.
3875
3876 2000-05-08 Alan Modra <alan@linuxcare.com.au>
3877
3878 * as.h: #include "file", not <file> on files from ../include.
3879 (as_abort, as_fatal): Add ATTRIBUTE_NORETURN.
3880 * config/tc-m68k.c (m68k_ip): Fix signed/unsigned warnings.
3881 (md_convert_frag): Add ATTRIBUTE_UNUSED.
3882 (tc_coff_symbol_emit_hook): Ditto.
3883 (OPTCOUNT): Cast to int to avoid compiler warning.
3884 (md_begin): Fix signed/unsigned warnings.
3885
3886 2000-05-08 Michael Sokolov <msokolov@ivan.Harhan.ORG>
3887
3888 * config/tc-m68k.c (md_convert_frag_1): Abort if we end up in the
3889 ABRANCH LONG case for a conditional branch on a 68000.
3890 (md_estimate_size_before_relax): Likewise. Also handle
3891 flag_short_refs correctly for ABRANCH, BCC68000, and DBCC.
3892 (m68k-ip: case ABSL): Relax absolute references to 16-bit
3893 PC-relative on all CPUs.
3894 (md_estimate_size_before_relax): Likewise.
3895
3896 2000-05-04 Alan Modra <alan@linuxcare.com.au>
3897
3898 * as.c (parse_args): Just mention current year in printed
3899 copyright message.
3900
3901 2000-05-03 J.T. Conklin <jtc@redback.com>
3902
3903 * config/tc-ppc.c (pre_defined_registers): Add entries for vector
3904 unit registers.
3905 (md_parse_option): Recognize -m7400.
3906
3907 2000-05-03 Ian Lance Taylor <ian@zembu.com>
3908
3909 * config/atof-ieee.c (gen_to_words): When adding carry back in,
3910 don't permit lp to become less than the words array.
3911
3912 2000-05-03 Rodney Brown <RodneyBrown@pmsc.com>
3913
3914 config/tc-mcore.c (md_apply_fix3): BFD_RELOC_MCORE_PCREL_IMM11BY2
3915 Fix little-endian case.
3916
3917 2000-05-03 David O'Brien <obrien@NUXI.com>
3918
3919 * as.c (parse_args): Update copyright.
3920
3921 2000-05-03 Mark Elbrecht <snowball3@bigfoot.com>
3922
3923 * gas/config/tc-i386.h (SUB_SEGMENT_ALIGN): If TE_GO32, return 4
3924 for the .bss section too.
3925
3926 2000-05-02 Alan Modra <alan@linuxcare.com.au>
3927
3928 * configure.in: Set em=linux for hppa-*-linux.
3929 * configure: Regenerate.
3930 * doc/Makefile.in: Regenerate with correct automake.
3931
3932 * frags.c (frag_grow): Sanity check chunk_size.
3933
3934 * config/obj-elf.h: #include "bfd.h" not <bfd.h>
3935 * config/obj-som.h: Likewise.
3936 * config/obj-ieee.h: Likewise.
3937
3938 * config/tc-hppa.h: Test BFD_ARCH_SIZE, not BFD64.
3939
3940 * config/tc-hppa.c (log2): Only compile when OBJ_SOM.
3941 (md_pseudo_table): Fully initialise OBJ_ELF cases.
3942 (fix_new_hppa): Add ATTRIBUTE_UNUSED to args as appropriate.
3943 (pa_ip): low_sign_unext now returns via function value. Use
3944 re_assemble_* instead of dis_assemble_* and
3945 INSERT_FIELD_AND_CONTINUE combination. Don't call sign_unext
3946 unnecessarily.
3947 (md_convert_frag): Add ATTRIBUTE_UNUSED to args as appropriate.
3948 (md_section_align, md_parse_option, md_show_usage,
3949 md_undefined_symbol, pa_align, pa_block, pa_brtab, pa_try,
3950 pa_callinfo, pa_code, pa_comm, pa_end, pa_enter, pa_entry,
3951 pa_exit, pa_export, pa_import, pa_label, pa_leave, pa_level,
3952 pa_origin, pa_param, pa_proc, pa_procend, pa_space, pa_spnum,
3953 pa_version, pa_compiler, pa_copyright, pa_data, pa_fill, pa_lsym,
3954 pa_text): Likewise.
3955 (md_apply_fix): Change type of new_val to offsetT. Delete w1, w2,
3956 w, resulti. Add insn, val. Move bfd_get_32 and bfd_put_32
3957 outside of switch. Correct mask and shifting errors in case 10
3958 and case -11. In case 21, compare against signed range to suit
3959 hppa_field_adjust changes. In case 12, use re_assemble_12. In
3960 case 17 and case 22, use offsetT variable to properly check range.
3961 Use re_assemble_* here too.
3962 (evaluate_absolute): Change type of value to offsetT. Call
3963 hppa_field_adjust to do the work for us.
3964 (pa_parse_cmpb_64_cmpltr): Delete save_s.
3965 (pa_parse_cmpib_64_cmpltr): Ditto.
3966 (pa_build_unwind_subspace): Delete unused var subseg. Change type
3967 of i to unsigned int.
3968 (pa_type_args): Conditionally declare symbol if OBJ_SOM.
3969 (pa_end_of_source): Return type is void.
3970
3971 Mon May 1 08:54:23 2000 Catherine Moore <clm@cygnus.com>
3972
3973 * macro.c (macro_expand_body): Don't prepend macro number with zeroes.
3974
3975 Mon May 1 14:19:39 2000 Denis Chertykov <denisc@overta.ru>
3976
3977 * config/tc-avr.c: ATTRIBUTE_UNUSED added to the necessary places.
3978 More comments added.
3979 (md_begin): Removed "construct symbols for each register name".
3980 Because register names conflicts with GCC generated function
3981 names.
3982 (avr_operand): Now constant numbers can be used as a register
3983 identifiers (0 as r0, 31 as r31).
3984 (md_assemble): use skip_space () before parsing instruction
3985 operands.
3986
3987 2000-05-01 Alan Modra <alan@linuxcare.com.au>
3988
3989 * configure.in: Set bfd_gas=yes on i386-*-pe and i386-*-nt* to
3990 ensure all pe targets use bfd. Remove unnecessary bfd_gas=yes on
3991 arm-*-netbsd* and arm-*-wince as this is set for all arm*.
3992 * configure: Regenerate.
3993
3994 2000-04-29 Andreas Jaeger <aj@suse.de>
3995
3996 * as.h: Correctly check GCC version.
3997
3998 2000-04-26 David O'Brien <obrien@FreeBSD.org>
3999
4000 * doc/as.1: Fix unbalanced brackets.
4001
4002 * config/tc-i386.c (comment_chars): Don't use '/' as comment start if
4003 TE_FreeBSD.
4004 (line_comment_chars): Set to '/' if TE_FreeBSD.
4005
4006 Tue Apr 25 11:02:02 2000 Jeffrey A Law (law@cygnus.com)
4007
4008 * configure.in: Configury support for PA64 (currently disabled).
4009 * configure: Rebuilt.
4010
4011 2000-04-25 Machida Hiroyuki <machida@sm.sony.co.jp>
4012
4013 * config/tc-mips.c (s_change_sec): Use record_alignment, not
4014 bfd_set_section_alignment.
4015
4016 2000-04-25 Alan Modra <alan@linuxcare.com.au>
4017
4018 * config/tc-i386.c (offset_in_range): Ensure shift counts are less
4019 than 32.
4020
4021 2000-04-24 Nick Clifton <nickc@cygnus.com>
4022
4023 * doc/c-arm.texi (ARM Directives): Document behaviour of .align 0.
4024 * doc/as.texinfo (Align): Include arm and strongarm in list of
4025 targets that have the second form of the behaviour of the .align
4026 directive.
4027
4028 2000-04-24 Mark Klein <mklein@dis.com>
4029
4030 * config/obj-som.c: Terminate obj_pseudo_table.
4031
4032 Mon Apr 24 15:21:11 2000 Clinton Popetz <cpopetz@cygnus.com>
4033
4034 * as.c (parse_args): Allow md_parse_option to override -a listing
4035 option.
4036 * config/obj-coff.c (add_lineno): Change type of offset parameter
4037 from "int" to "bfd_vma."
4038 * config/tc-ppc.c (md_pseudo_table): Add "llong" and "machine."
4039 (ppc_mach, ppc_subseg_align, ppc_target_format): New.
4040 (ppc_change_csect): Align correctly for XCOFF64.
4041 (ppc_machine): New function, which discards "ppc_machine" line.
4042 (ppc_tc): Cons for 8 when code is 64 bit.
4043 (md_apply_fix3): Don't check operand->insert. Handle 64 bit
4044 relocations.
4045 (md_parse_option): Handle -a64 and -a32.
4046 (ppc_xcoff64): New.
4047 * config/tc-ppc.h (TARGET_MACH): Define.
4048 (TARGET_FORMAT): Move to function.
4049 (SUB_SEGMENT_ALIGN): Use ppc_subseg_align.
4050
4051 Sun Apr 23 16:45:45 2000 Denis Chertykov <denisc@overta.ru>
4052
4053 * config/tc-avr.c: New AVR_ISA_ defined.
4054 (md_assemble): Handle opcodes with optional operands (lpm,elpm).
4055 (avr_operand): Handle 'a', 'v' and 'z' constraint letters needed
4056 for `fmul', `movw' and `lpm R,Z' instructions.
4057 (avr_operands): Warn if current opcode is a two-word instruction
4058 and previous opcode was cpse/sbic/sbis/sbrc/sbrs.
4059 (avr_opcodes): New commands added.
4060 (REGISTER_P): Check 'a' and 'v' constraint letters.
4061 (mcu_types): New MCU added.
4062
4063 2000-04-22 Timothy Wall <twall@cygnus.com>
4064
4065 * config/tc-ia64.c (pseudo_func[]): Add new "nat" entry equivalent
4066 to "natval".
4067 (operand_match): Conditionally insert default bit values for IMMU9.
4068
4069 2000-04-14 Matthew Green <mrg@cygnus.com>
4070
4071 * configure.in: Add NetBSD/sparc ELF and NetBSD/sparc64 support.
4072 * configure: Rebuilt.
4073
4074 Fri Apr 21 14:29:43 2000 Jeffrey A Law (law@cygnus.com)
4075 Jason Eckhardt <jle@cygnus.com>
4076
4077 * config/tc-hppa.c (md_apply_fix): Handle new PA2.0 formats.
4078
4079 * config/tc-hppa.c (CHECK_ALIGN): New macro.
4080 Added handling of new operand types l,y,&,fe,fE,fx.
4081
4082 Fri Apr 21 13:20:53 2000 Richard Henderson <rth@cygnus.com>
4083 David Mosberger <davidm@hpl.hp.com>
4084 Timothy Wall <twall@cygnus.com>
4085 Andrew MacLeod <amacleod@cygnus.com>
4086 Jim Wilson <wilson@cygnus.com>
4087
4088 * Makefile.am (CPU_TYPES): Add ia64.
4089 (TARGET_CPU_CFILES): Add config/tc-ia64.c.
4090 (TARGET_CPU_HFILES): Add config/tc-ia64.h.
4091 * Makefile.in: Rebuild.
4092 * app.c (do_scrub_chars): Handle DOUBLESLASH_COMMENTS.
4093 * configure: Rebuild.
4094 * configure.in: Recognize ia64 as cpu type. Set bfd_gas.
4095 (ia64-*-elf*, ia64-*-linux-gnu*): New targets.
4096 * expr.c (expr): Handle md_optimize_expr.
4097 * read.c (LEX_HASH): Add comment.
4098 * config/tc-ia64.c, config/tc-ia64.h: New files.
4099
4100 2000-04-21 Richard Henderson <rth@cygnus.com>
4101
4102 * config/tc-d30v.c (write_2_short): Disregard opcode1->ecc when
4103 bundling a non-delayed branch type instruction.
4104
4105 2000-04-20 Alexandre Oliva <aoliva@cygnus.com>
4106
4107 * config/tc-mn10300.c (HAVE_AM30): Define.
4108 (md_assemble): Use it.
4109
4110 2000-04-19 Alan Modra <alan@linuxcare.com.au>
4111
4112 * config/obj-elf.c (obj_elf_change_section): Check for changed
4113 section attributes.
4114
4115 * Makefile.am: (CPU_MULTI_VALID): Remove.
4116 (MULTI_CPU_TYPES): Define.
4117 (MULTI_CPU_OBJ_VALID): Define.
4118 (DEPTC): Use the above.
4119 (DEPOBJ): Same here.
4120 (DEP2): And here.
4121 Regenerate dependencies.
4122 * Makefile.in: Regenerate.
4123
4124 2000-04-19 Michael Sokolov <msokolov@ivan.Harhan.ORG>
4125
4126 * Makefile.am (YACC, LEX): Get them from configure.
4127
4128 2000-04-18 H.J. Lu (hjl@gnu.org)
4129
4130 * config/tc-i386.c (offset_in_range): Use addressT instead of
4131 bfd_vma for non-bfd assemblers.
4132
4133 2000-04-17 Alan Modra <alan@linuxcare.com.au>
4134
4135 * config/tc-i386.c (offset_in_range): Sign extend val so BFD64
4136 doesn't give spurious errors.
4137
4138 2000-04-14 Michael Sokolov <msokolov@ivan.Harhan.ORG>
4139
4140 * as.h (SEEK_SET): Define if undefined.
4141
4142 2000-04-13 Alan Modra <alan@linuxcare.com.au>
4143
4144 * config/tc-arm.c (md_apply_fix3): Don't use UL suffix on
4145 constants, and don't assume offsetT is 32 bits.
4146
4147 2000-04-12 Andrew Cagney <cagney@b1.cygnus.com>
4148
4149 * config/tc-d10v.h: Include "write.h" to get definition of fixS.
4150 (md_pcrel_from_section): Add prototype.
4151 (d10v_fix_adjustable): Add prototype.
4152 (d10v_force_relocation): Replace 'struct fix' with 'fixS'.
4153
4154 * config/tc-d10v.c (md_apply_fix3): Add paren around &&.
4155
4156 2000-04-12 Nick Clifton <nickc@cygnus.com>
4157
4158 * config/tc-d10v.c (find_opcode): Correctly calculate position of
4159 symbol in frag chain.
4160
4161 2000-04-10 Alan Modra <alan@linuxcare.com.au>
4162
4163 * config/tc-i386.c (fits_in_signed_byte): Change arg to offsetT.
4164 (fits_in_unsigned_byte, fits_in_unsigned_word): Ditto.
4165 (fits_in_signed_word, smallest_imm_type): Ditto.
4166 (md_assemble): Use an offsetT var to hold offsetT values, not a
4167 long.
4168 (offset_in_range): New.
4169 (md_assemble): Use it.
4170 (md_convert_frag): Change type of target_address, opcode_address,
4171 and displacement_from_opcode_start to offsetT.
4172 (md_create_short_jump): Change type of offset to offsetT.
4173 (md_create_long_jump): Ditto.
4174 (md_apply_fix3): Use -4, not 0xfffffffc for BFD_RELOC_386_PLT32.
4175 (md_chars_to_number): Remove.
4176 (output_invalid): Remove duplicate prototype.
4177
4178 2000-04-09 Nick Clifton <nickc@cygnus.com>
4179
4180 * Makefile.am (CPU_TYPES): Add 'avr'.
4181 (TARGET_CPU_CFILES): Add 'tc-avr.c'.
4182 (TARGET_CPU_HFILES): Add 'tc-avr.h'.
4183
4184 * Makefile.in: Regenerate.
4185
4186 * doc/as.texinfo: Add M32R documentation.
4187
4188 Fri Apr 7 15:56:57 2000 Andrew Cagney <cagney@b1.cygnus.com>
4189
4190 * configure.in (WARN_CFLAGS): Set to -W -Wall by default. Add
4191 --enable-build-warnings option.
4192 * Makefile.am (AM_CFLAGS, WARN_CFLAGS): Add definitions.
4193 * Makefile.in, configure: Re-generate.
4194
4195 2000-04-07 Nick Clifton <nickc@cygnus.com>
4196
4197 * config/tc-arm.c (md_apply_fix3): Treat BFD_RELOC_ARM_PCREL_BLX
4198 in the same way as BFD_RELOC_ARM_PCREL_BRANCH, and
4199 BFD_RELOC_THUMB_PCREL_BLX lie BFD_RELOC_THUMB_PCREL_BRANCH.
4200 (tc_gen_reloc): Accept BFD_RELOC_{ARM|THUMB}_PCREL_BLX.
4201 (arm_force_relocation): Force relocations for
4202 BFD_RELOC_{ARM|THUMB}_PCREL_BLX as well.
4203
4204 Wed Apr 5 22:26:32 2000 J"orn Rennecke <amylaar@cygnus.co.uk>
4205
4206 * config/tc-sh.c (get_operands): There's no third operand if the
4207 first operand is an immediate.
4208
4209 Wed Apr 5 22:07:19 2000 J"orn Rennecke <amylaar@cygnus.co.uk>
4210
4211 * config/tc-sh.c (immediate): Delete.
4212 (sh_operand_info): Add immediate member.
4213 (parse_reg): Use A_PC for pc.
4214 (parse_exp): Add second argument 'op'. All callers changed.
4215 (parse_at): Expect pc to be coded as A_PC.
4216 Use immediate field in *op.
4217 (insert): Add fourth argument 'op'. All callers changed.
4218 (build_relax): Add second argument 'op'. All callers changed.
4219 (insert_loop_bounds): New function.
4220 (build_Mytes): Remove DISP_4.
4221 Split IMM_[48]{,BY[24]} into IMM[01]_[48]{,BY[24]}. Add REPEAT.
4222 (assemble_ppi): Use immediate field in *operand.
4223 (sh_force_relocation): Handle BFD_RELOC_SH_LOOP_{START,END}.
4224 (md_apply_fix): Likewise.
4225 (tc_gen_reloc): Likewise. Check for a pcrel BFD_RELOC_SH_LABEL.
4226
4227 Wed Apr 5 06:35:45 2000 Alexandre Oliva <oliva@lsd.ic.unicamp.br>
4228
4229 * config/tc-sparc.c (sparc_ip): Avoid string pasting.
4230
4231 Tue Apr 4 19:27:50 2000 Hans-Peter Nilsson <hp@axis.com>
4232
4233 * internals.texi (CPU backend): Document
4234 TC_CHECK_ADJUSTED_BROKEN_DOT_WORD.
4235
4236 2000-04-04 Alan Modra <alan@linuxcare.com.au>
4237
4238 * po/gas.pot: Regenerate.
4239
4240 * as.c (show_usage): Restore translated part of bug string.
4241 * gasp.c (show_usage): Likewise.
4242
4243 * Makefile.am (MKDEP): Use gcc -MM rather than ../mkdep.
4244 (DEP): Quote when passing vars to sub-make. Use "mv -f" rather
4245 than move-if-change.
4246 (DEP1): Modify for "gcc -MM".
4247 (DEPTC): Likewise.
4248 (DEPOBJ): Likewise.
4249 (DEP2): Likewise.
4250 (CLEANFILES): Add DEPTCA, DEPOBJA, DEP2a, DEPA.
4251 Update dependencies.
4252 * Makefile.in: Regenerate.
4253
4254 2000-04-03 Alexandre Oliva <aoliva@cygnus.com>
4255
4256 * config/tc-mn10300.c (md_pseudo_table): Use constant names.
4257 (md_begin): Likewise.
4258 (HAVE_AM33): New macro.
4259 (md_assemble): Use it. Match r_regs and xr_regs only if
4260 HAVE_AM33.
4261
4262 2000-04-03 Alan Modra <alan@linuxcare.com.au>
4263
4264 * as.h: #include "bin-bugs.h"
4265 * as.c (show_usage): Use REPORT_BUGS_TO.
4266 * gasp.c: #include "bin-bugs.h"
4267 (show_usage): Use REPORT_BUGS_TO.
4268
4269 * config/tc-sparc.c (md_show_usage): Add a trailing newline.
4270
4271 Mon Apr 3 13:56:03 2000 Hans-Peter Nilsson <hp@axis.com>
4272
4273 * write.c (write_object_file) [! WORKING_DOT_WORD]: If defined,
4274 call TC_CHECK_ADJUSTED_BROKEN_DOT_WORD for each word after
4275 adjustments.
4276
4277 2000-04-03 Alan Modra <alan@linuxcare.com.au>
4278
4279 * config/tc-i386.c (i386_immediate): Don't assume a constant
4280 immediate is necessarily 16 bits when in 16 bit code mode.
4281 (md_assemble): Instead set guess_suffix here after we have checked
4282 registers.
4283
4284 2000-04-02 Richard Henderson <rth@cygnus.com>
4285
4286 * config/tc-d30v.c (check_range): Allow signed or unsigned 32-bit
4287 quantities. Correct right shift sign extension.
4288 (build_insn): Make `number' unsigned long. Mask top 6 bits of
4289 32-bit value when shifting into place.
4290
4291 2000-04-01 Ian Lance Taylor <ian@zembu.com>
4292
4293 * app.c: Add ATTRIBUTE_UNUSED as needed.
4294 * config/tc-ppc.c: Likewise.
4295 (ppc_size): Make unsigned long.
4296 (ppc_insert_operand): Add casts to avoid warnings.
4297
4298 2000-03-31 Nick Clifton <nickc@cygnus.com>
4299
4300 * config/tc-d10v.h (md_flush_pending_output): Define.
4301
4302 2000-03-29 Nick Clifton <nickc@cygnus.com>
4303
4304 * config/tc-sh.h (SEG_NAME): New macro: return the name of a
4305 segment. Works for both BFD_ASSEMBLER and others.
4306 (SUB_SEGMENT_ALIGN): Use SEG_NAME.
4307
4308 2000-03-29 Nick Clifton <nickc@cygnus.com
4309
4310 * config/tc-arm.c (tinsns): Add "bal" instruction pattern.
4311
4312 2000-03-28 Alan Modra <alan@linuxcare.com.au>
4313
4314 * listing.c (LISTING_LHS_WIDTH): Default depends on
4315 LISTING_WORD_SIZE.
4316 (LISTING_LHS_WIDTH_SECOND): Default to LISTING_LHS_WIDTH.
4317
4318 2000-03-27 Ian Lance Taylor <ian@zembu.com>
4319
4320 * config/tc-sh.c (md_show_usage): Use backslash before newline in
4321 string literal.
4322
4323 2000-03-27 Alan Modra <alan@linuxcare.com.au>
4324
4325 * config/tc-avr.h (TC_HANDLES_FX_DONE): Define.
4326
4327 * config/tc-avr.c (mcu_types): Add missing initialiser.
4328 (md_pcrel_from_section): Add prototype.
4329 (avr_operand): Remove redundant test of unsigned < 0.
4330 (avr_cons_fix_new): Ensure exp_mod_pm zero on function exit.
4331
4332 2000-03-27 Denis Chertykov <denisc@overta.ru>
4333
4334 * config/tc-avr.c: New file for AVR support.
4335 * config/tc-avr.h: Likewise.
4336 * configure.in: Add AVR support.
4337 * configure: Regenerate.
4338
4339 2000-03-26 Timothy Wall <twall@cygnus.com>
4340
4341 * gasp.c (macro_op): Add new argument to check_macro call.
4342 Macro structure definitions moved to macro.h
4343 * sb.h: Add argument to prototype for input_scrub_include_sb.
4344 * input-scrub.c (input_scrub_include_sb): Allow disabling of sb
4345 nesting checks with an additional flag.
4346 (struct input_save): Add flag to indicate whether current sb
4347 should be checked for proper macro/conditional nesting.
4348 (input_scrub_push/pop): Save/restore nest check flag.
4349 (input_scrub_next_buffer): Ditto. Also call end of macro hook if
4350 defined.
4351 * macro.c (check_macro): Allow caller to retrieve parsed macro
4352 information if a pointer is provided. This information may be
4353 used by the new macro hooks.
4354 * macro.h: Update prototype for check_macro. Macro struct
4355 definitions moved here from macro.c/gasp.c.
4356 * read.c (read_a_source_file): Add parameter to check_macro call,
4357 and pass macro info to the macro hook, if defined.
4358 (input_scrub_insert_line): New. Allow insertion of a line of
4359 characters into the input stream.
4360 (input_scrub_insert_file): New. Allow insertion of an arbitrary
4361 file into the input stream.
4362 (s_include): Use input_scrub_insert_file.
4363 * internals.texi: Document new macro hooks.
4364 * as.h: New prototypes added.
4365
4366 2000-03-26 Alan Modra <alan@linuxcare.com.au>
4367
4368 * config/tc-i386.c: Don't start any as_bad or as_warn message with
4369 an initial capital letter.
4370 (i386_index_check): Reindent.
4371
4372 2000-03-19 Nick Clifton <nickc@cygnus.com>
4373
4374 * config/tc-arm.c (md_apply_fix3): Fix bug detecting overflow of pc
4375 relative branches.
4376
4377 2000-03-17 Thomas de Lellis <tdel@windriver.com>
4378
4379 * config/tc-arm.c (do_t_adr): Flag "adr Rd,label"
4380 instruction operand bad if Rd > 7 when generating
4381 thumb instructions. Prevents for example,
4382 "adr r12,label" from silently failing and generating
4383 the wrong instruction.
4384
4385 2000-03-17 Nick Clifton <nickc@cygnus.com>
4386
4387 * config/tc-arm.c (md_apply_fix3): Handle same-section relocations
4388 that have a destingation >= 0x400000.
4389 Fix compile time warning messages.
4390
4391 Thu Mar 16 23:45:16 2000 J"orn Rennecke <amylaar@cygnus.co.uk>
4392
4393 * config/tc-sh.c (md_begin): When encountering insn that are
4394 not supported by the current arch, only change the name if
4395 its contents are the same as prev_name.
4396 (get_specific): If the the architecture doesn't match, fail.
4397
4398 Thu Mar 16 21:18:13 2000 J"orn Rennecke <amylaar@cygnus.co.uk>
4399
4400 * config/tc-sh.c (IDENT_CHAR): Define.
4401 (parse_reg): Use it instead of isalnum. Put r[0..7]_bank operand
4402 matching back where it came from.
4403
4404 Thu Mar 16 20:58:10 2000 J"orn Rennecke <amylaar@cygnus.co.uk>
4405
4406 * config/tc-sh.c (md_show_usage): Add description of -dsp.
4407
4408 2000-03-15 Jonathan Larmour <jlarmour@redhat.co.uk>
4409
4410 * config/tc-sh.c (parse_reg): Match r[0..7]_bank operands before
4411 normal operands.
4412
4413 2000-03-15 Kazu Hirata <kazu@hxi.com>
4414
4415 * config/tc-h8300.c: Add ATTRIBUTE_UNUSED as appropriate.
4416
4417 Mon Mar 13 22:02:59 2000 Hans-Peter Nilsson <hp@axis.se>
4418
4419 * expr.c (operand) [case 'f']: When testing if '0f' can start a
4420 floating-point-number, make sure 'f' is in FLT_CHARS.
4421
4422 Sat Mar 11 00:01:39 2000 Hans-Peter Nilsson <hp@axis.se>
4423
4424 * read.c (TC_IMPLICIT_LCOMM_ALIGNMENT): New default-definition.
4425 (s_lcomm_internal): Use it.
4426 * doc/internals.texi (CPU backend): Document it.
4427 * config/obj-evax.h (TC_IMPLICIT_LCOMM_ALIGNMENT): Set to 2**3
4428 bytes.
4429
4430 2000-03-10 Geoffrey Keating <geoffk@cygnus.com>
4431
4432 * config/tc-mips.c (mips_ip): Don't put stuff in .rodata
4433 when embedded-pic.
4434
4435 * config/tc-mips.c (SWITCH_TABLE): The ELF embedded-pic
4436 implementation doesn't have special handling for switch
4437 statements.
4438 (macro_build): Allow for code in sections other than .text.
4439 (macro): Likewise.
4440 (mips_ip): Likewise.
4441 (md_apply_fix): Do pc-relative relocation madness for MIPS ELF.
4442 Don't perform relocs if we will be outputting them.
4443 (tc_gen_reloc): For ELF, just use fx_addnumber for pc-relative
4444 relocations. Allow BFD_RELOC_16_PCREL_S2 relocs when
4445 embedded-pic.
4446
4447 2000-03-09 Catherine Moore <clm@cygnus.com>
4448
4449 * config/tc-m32r.c (m32r_fix_adjustable): Look up the
4450 relocation type based on the entry in the fixup structure.
4451 Put S_IS_EXTERN processing back in.
4452
4453 2000-03-08 H.J. Lu (hjl@gnu.org)
4454
4455 * Makefile.am (install-exec-tooldir): Depend on
4456 install-exec-bindir for parallel make.
4457 * Makefile.in: Regenerated.
4458
4459 2000-03-06 Nick Clifton <nickc@cygnus.com>
4460
4461 * config/tc-m32r.c (struct md_longopts): Add -m32r command line
4462 switch.
4463 (md_parse_option): Parse -m32r command line switch - disable m32rx
4464 compatability.
4465 (md_show_usage): Document new option.
4466
4467 * doc/Makefile.am (CPU_DOCS): Add c-m32r.texi.
4468 * doc/Makefile.in: Regenerate.
4469 * doc/c-m32r.texi (M32R-Opts): Document new command line switch.
4470
4471 2000-03-02 Michael Meissner <meissner@redhat.com>
4472
4473 * config/tc-d30v.c (check_range): Remove code that incorrectly
4474 sign extended values where bits < 32.
4475
4476 2000-03-02 H.J. Lu (hjl@gnu.org)
4477
4478 * configure.in: Support --enable-targets=all on ia32.
4479 * configure: Regenerated.
4480
4481 2000-03-01 Nick Clifton <nickc@cygnus.com>
4482
4483 * gasp.c (do_align): Remove bogus check of alignment value.
4484
4485 2000-02-27 Thomas de Lellis <tdel@windriver.com>
4486
4487 * config/obj-elf.c (elf_frob_symbol): Remove code which when
4488 TC_PPC was defined forced the type of a symbol with no other type
4489 to be BSF_OBJECT.
4490
4491 2000-02-27 Hans-Peter Nilsson <hp@axis.com>
4492
4493 * doc/internals.texi (CPU backend): Mention that
4494 line_separator_chars do not break up comments. Fix typos for
4495 LEX_AT and LEX_NAME descriptions. Document operands for
4496 TC_EQUAL_IN_INSN, md_operand and md_section_align. Correct
4497 description of md_create_short_jump usage. Document argument for
4498 md_undefined_symbol.
4499
4500 2000-02-27 Jakub Jelinek <jakub@redhat.com>
4501
4502 * config/tc-sparc.c (OPTION_UNDECLARED_REGS): New option.
4503 (md_parse_option): Handle it.
4504 (md_show_usage): Document it.
4505
4506 2000-02-27 Ian Lance Taylor <ian@zembu.com>
4507
4508 * config/tc-alpha.c (md_assemble): Accept `1' and `9' in an
4509 opcode, for the instruction `pal19'. From Andrea Arcangeli
4510 <andrea@suse.de>.
4511
4512 2000-02-26 Alan Modra <alan@spri.levels.unisa.edu.au>
4513
4514 * config/tc-i386.c (i386_immediate): Move constant operand sizing
4515 from here..
4516 (md_assemble): To here, before template operands are matched.
4517 Also ensure a constant immediate is sign extended when we know the
4518 size is at most 16 bits. This is to catch cases like "add
4519 $0xffc0,%ax" where we don't know the size, and thus that the
4520 immediate can be represented as Imm8S until after parsing the
4521 register operand.
4522 (i386_displacement): Similarly sign extend 16 bit constant
4523 displacements.
4524 (md_assemble): Relax 16-bit jump constant range check to suit sign
4525 extended displacements.
4526
4527 2000-02-26 Andreas Jaeger <aj@suse.de>
4528
4529 * doc/c-mips.texi (MIPS Opts): Fix typo in last patch.
4530
4531 2000-02-25 Alan Modra <alan@spri.levels.unisa.edu.au>
4532
4533 * config/tc-i386.c (md_assemble): Don't swap intersegment jmp and
4534 call operands when intel_syntax.
4535 (intel_float_operand): Return 2 for "fi...".
4536 (i386_operand_modifier): Change "DWORD PTR" test to suit above.
4537 Return SHORT_MNEM_SUFFIX for "WORD PTR" when "fi...". Revert
4538 earlier "SHORT" change.
4539 (md_assemble): When determining suffix from Regs, exclude
4540 InOutPortReg.
4541
4542 2000-02-24 Nick Clifton <nickc@cygnus.com>
4543
4544 * configure: Add arm-wince, mips-pe and sh-pe targets.
4545 * configure: Regenerate.
4546
4547 * config/obj-coff.h (COFF_WITH_PE): Define for mips-pe and
4548 sh-pe targets.
4549 (TARGET_FORMAT): Set to "pe-shl" for the sh-pe target and to
4550 "pe-mips" for the mips-pe target.
4551
4552 * config/tc-arm.c (insns): Change displacement encoded in BL
4553 and B instructions if the target port is arm-wince.
4554 (do_ldst): Do not bias the relocation offset if the target
4555 port is arm-wince.
4556 (md_pcrel_from): Add in missing relocation offset bias if the
4557 target os arm-wince.
4558
4559 * config/tc-mips.c (mips_target_format): Support COFF flavour.
4560 (md_begin): Disable -G support for mips-pe target.
4561 (md_apply_fix): Treat BFD_RELOC_RVA reloc as BFD_RELOC_32.
4562 * config/tc-mips.h (USE_GLOBAL_POINTER_OPT): Add support for
4563 COFF flavour.
4564
4565 * config/tc-sh.c (md_begin): sh-pe target is little endian.
4566 * config/tc-sh.h (SUB_SEGMENT_ALIGN): If using a BFD
4567 assembler, just set the alignment to 4.
4568
4569 * config/te-wince-pe.h: New file for WinCE targets. Define
4570 TE_WINCE.
4571
4572 2000-02-25 Alan Modra <alan@spri.levels.unisa.edu.au>
4573
4574 * config/tc-i386.c (md_assemble): Swap segments too for intel mode
4575 string instructions.
4576 (i386_operand_modifier): Set i.suffix = WORD_MNEM_SUFFIX for SHORT.
4577 (i386_intel_memory_operand): After finding a segment override,
4578 check again for no `[' before looking for a displacement. Bomb if
4579 more than one displacement rather than silently discarding the
4580 second and subsequent ones. Free strings malloc'd by
4581 build_displacement_string.
4582
4583 2000-02-24 Catherine Moore <clm@cygnus.com>
4584
4585 * config/obj-som.c (obj_pseudo_table): Add "weak".
4586 (obj_som_weak): New routine.
4587
4588 2000-02-24 Alan Modra <alan@spri.levels.unisa.edu.au>
4589
4590 * config/tc-i386.c (union i386_op): New.
4591 (struct _i386_insn): Delete disps[], imms[], regs[]. Add op[].
4592 Throughout file replace occurences of disps[n], imms[n], regs[n]
4593 with equivalent op[n].disps, op[n].imms, op[n].regs. Simplify
4594 intel mode operand swapping. Add assert in regKludge and
4595 fake_zero_displacement code. Test i.types[n] when outputting
4596 displacements and immediates. Combine output of Disp16 with
4597 Disp32.
4598 (md_assemble): Don't try to fix broken UNIXWARE_COMPAT opcodes
4599 when in intel mode by (not) reversing fsub and fdiv operands
4600 before the template search. This fails for single operand
4601 shorthand forms of the instruction, and if UNIXWARE_COMPAT is
4602 undefined. Instead fix the base_opcode after we've found the
4603 template. Move base_opcode xor with found_reverse_match from
4604 opcode output code to before this fix so we test for the correct
4605 opcodes.
4606 (md_assemble): Don't use strcmp when deciding to ignore the suffix
4607 check in intel mode. Instead compare opcodes.
4608
4609 * config/tc-i386.h (TC_RELOC): Delete.
4610 * config/tc-i386.c (TC_RELOC): Delete. Replace usage of TC_RELOC
4611 with equivalent call to reloc.
4612
4613 * as.h (flag_m68k_mri): Move declaration after target include, and
4614 only declare when TC_M68K defined. Define as zero otherwise.
4615 (LABELS_WITHOUT_COLONS, NO_PSEUDO_DOT): If undefined, define as 0.
4616 * app.c (scrub_m68k_mri): Declare only when TC_M68K defined.
4617 Define as zero otherwise.
4618 (do_scrub_begin): Use m68k_mri parameter only when TC_M68K defined.
4619 (struct app_save): Declare scrub_m68k_mri only when TC_M68K.
4620 (app_push, app_pop): Save scrub_m68k_mri only when TC_M68K.
4621 (do_scrub_chars): Use LABELS_WITHOUT_COLONS directly rather than
4622 testing whether defined.
4623 * cond.c (ignore_input): Use NO_PSEUDO_DOT directly.
4624 * expr.c (operand): #ifdef unused case labels when TC_M68K undefined.
4625 * read.c: Use LABELS_WITHOUT_COLONS and NO_PSEUDO_DOT directly
4626 rather than testing whether defined.
4627 (s_mri): Set flag_m68k_mri only when TC_M68K defined.
4628 (parse_mri_cons): Declare and use only when TC_M68K.
4629 * config/tc-hppa.h (LABELS_WITHOUT_COLONS): Define as 1.
4630 * config/tc-m68k.h (NO_PSEUDO_DOT): Define as 1.
4631 * config/tc-m88k.h (NO_PSEUDO_DOT): Define as 1.
4632
4633 * NEWS: Mention IBM 370 support.
4634
4635 2000-02-23 Richard Henderson <rth@cygnus.com>
4636
4637 * config/tc-i386.c (md_assemble): When swapping operands for
4638 intel_syntax, assume everything that's not Imm or Disp is a
4639 register.
4640
4641 2000-02-23 Linas Vepstas <linas@linas.org>
4642
4643 * config/tc-i370.c, config/tc-i370.h: New files.
4644 * Makefile.am: Add support for Linux/IBM 370.
4645 * configure.in: Likewise.
4646 * app.c (do_scrub_begin): Don't lex single quote when TC_I370.
4647 * config/obj-elf.c: Include elf/i370.h
4648 (obj_elf_section): Don't do anything special for flag_mri if TC_I370.
4649
4650 * Makefile.in: Regenerate.
4651 * configure: Regenerate.
4652
4653 * doc/c-i370.texi: New file.
4654 * doc/all.texi: Include it.
4655 * doc/as.texinfo: And here.
4656 * doc/Makefile.am(CPU_DOCS): Add c-i370.texi.
4657 * doc/Makefile.in: Regenerate.
4658
4659 2000-02-19 Michael Meissner <meissner@redhat.com>
4660
4661 * config/tc-d30v.c (parallel_ok): Use FLAG_NOT_WITH_ADDSUBppp to
4662 determine if an instruction can be used in parallel with an ADDppp
4663 or SUBppp instruction.
4664
4665 2000-02-22 Andrew Haley <aph@cygnus.com>
4666
4667 * doc/c-mips.texi (MIPS Opts): Document -mgp32 and -mgp64.
4668
4669 2000-02-22 Andrew Haley <aph@cygnus.com>
4670
4671 * config/tc-mips.c (mips_gp32): New variable.
4672 (macro_build) Use mips_gp32.
4673 (mips_ip): Ditto.
4674 (md_longopts): Add "-mgp32" and "-mgp64".
4675 (md_parse_option): Add OPTION_GP32 and OPTION_GP64.
4676
4677 (OPTION_M7900): Change offset
4678 (OPTION_NO_M7900): Ditto.
4679
4680 2000-02-22 Alexandre Oliva <oliva@lsd.ic.unicamp.br>
4681
4682 * config/obj-coff.c (add_lineno): Accept non-positive lineno with
4683 warning, and bump it to 1.
4684
4685 2000-02-22 Ian Lance Taylor <ian@zembu.com>
4686
4687 From Brad Lucier <lucier@math.purdue.edu>:
4688 * dwarf2dbg.c (print_stats): Add cast to force printf argument to
4689 match format.
4690
4691 2000-02-21 Catherine Moore <clm@cygnus.com>
4692
4693 * config/tc-mips.c (MF_HILO_INSN): Define.
4694 (mips_7000_hilo_fix): Declare.
4695 (append_insn): Conditionally insert nops after an mfhi/mflo insn.
4696 (md_parse_option): Check for 7000_HILO_FIX options.
4697 (OPTION_M7000_HILO_FIX): Define.
4698 (OPTION_NO_M7000_HILO_FIX): Define.
4699 * doc/c-mips.texi (-mfix7000): Describe.
4700
4701 2000-02-21 Alan Modra <alan@spri.levels.unisa.edu.au>
4702
4703 * listing.c (print_lines): Remove unused variable `end'.
4704
4705 * config/tc-i386.c (md_assemble): Use `reloc()' to select reloc
4706 type for JumpInterSegment output. Use enum bfd_reloc_code_real for
4707 reloc_type when BFD_ASSEMBLER.
4708 (md_estimate_size_before_relax): Use enum bfd_reloc_code_real for
4709 reloc_type when BFD_ASSEMBLER. Move common code out of switch
4710 statement and quell signed vs. unsigned comparison warning.
4711
4712 2000-02-18 Nick Clifton <nickc@cygnus.com>
4713
4714 * config/tc-d10v.c (find_opcode): Add a symbol's value to
4715 the computed frag offset, rather than overwriting it.
4716
4717 Thu Feb 17 00:11:08 2000 J"orn Rennecke <amylaar@cygnus.co.uk>
4718
4719 * config/tc-sh.c ("elf/sh.h"): Include.
4720 (sh_dsp, valid_arch, reg_x, reg_y, reg_efg): New static variables.
4721 (md.begin): Initialize target_arch.
4722 Only include opcodes in has table that match selected architecture.
4723 (parse_reg): Recognize register names for sh-dsp.
4724 (parse_at): Recognize post-modify addressing.
4725 (get_operands): The leading space is now optional.
4726 (get_specific): Remove FDREG_N support. Add support for sh-dsp
4727 arguments. Update valid_arch.
4728 (build_Mytes): Add support for SDT_REG_N.
4729 (find_cooked_opcode): New function, broken out of md_assemble.
4730 (assemble_ppi, sh_elf_final_processing): New functions.
4731 (md_assemble): Use find_cooked_opcode and assemble_ppi.
4732 (md_longopts, md_parse_option): New option: -dsp.
4733 * config/tc-sh.h (elf_tc_final_processing): Define.
4734 (sh_elf_final_processing): Declare.
4735
4736 Fri Feb 11 14:21:51 2000 Jeffrey A Law (law@cygnus.com)
4737
4738 * config/tc-hppa.c (pa_build_unwind_subspace): Use subseg_new to create
4739 the unwinder subspace. Save the current seg/subseg before creating
4740 the new seg/subseg.
4741
4742 2000-02-10 Nick Clifton <nickc@cygnus.com>
4743
4744 * config/tc-mcore.c (INST_BYTE0): Redefine to handle big and
4745 little endian targets.
4746 (INST_BYTE1): Redefine to handle big and little endian
4747 targets.
4748 (cpu_type): New type: Select between M340 and M210.
4749 (parse_psrmod): New function: Parse the PSRCLR and PSRSET
4750 instructions of the M340.
4751 (md_assemble): Add support for the MULSH and OPSR classes of
4752 instructions.
4753 (md_atof): Add support for little endian targets.
4754 (md_parse_option): Add support for -EL, -EB and -mcpu command
4755 line switches.
4756 (md_convert_frag): Add support for little endian targets.
4757 (md_apply_fix3): Add support for little endian targets.
4758 (md_number_to_chars): Add support for little endian targets.
4759
4760 2000-02-10 Timothy Wall <twall@redhat.com>
4761
4762 * read.c (read_a_source_file): If TC_START_LABEL_WITHOUT_COLON is
4763 defined, use it to verify the symbol just read should be a label.
4764
4765 2000-02-10 Timothy Wall <twall@redhat.com>
4766
4767 * app.c (do_scrub_chars): Handle "||" for parallel instructions
4768 when DOUBLEBAR_PARALLEL is defined. Avoid stripping whitespace
4769 around colons when KEEP_WHITE_AROUND_COLON is defined.
4770 * doc/internals.texi (CPU backend): Document DOUBLEBAR_PARALLEL
4771 and KEEP_WHITE_AROUND_COLON.
4772
4773 2000-02-08 Timothy Wall <twall@redhat.com>
4774
4775 * read.c (s_rept): Call do_repeat, which abstracts the repeat
4776 logic.
4777 (do_repeat): New. Abstract repeat logic so that a "break" can be
4778 implemented.
4779 (end_repeat): New. Provide support for a "break" out of the
4780 repeat loop.
4781 * read.h: Add prototypes for new functions.
4782
4783 2000-02-08 Timothy Wall <twall@redhat.com>
4784
4785 * doc/internals.texi: Document NUMBERS_WITH_SUFFIX macro.
4786 * as.h: Provide a default NUMBERS_WITH_SUFFIX definition (zero).
4787 * expr.c: Handle numbers with suffixes if NUMBERS_WITH_SUFFIX is
4788 non-zero.
4789
4790 2000-02-08 Timothy Wall <twall@redhat.com>
4791
4792 * read.c: Added elseif to directives table.
4793 * read.h: Added prototype for s_elseif.
4794 * doc/as.texinfo: Added description for elseif.
4795 * cond.c (s_elseif): New function
4796
4797 2000-02-04 Timothy Wall <twall@redhat.com>
4798
4799 * listing.c (print_lines): Remove conditionals causing bug in
4800 listings.
4801
4802 2000-02-03 Timothy Wall <twall@cygnus.com>
4803
4804 * as.h: Define OCTETS_PER_BYTE and OCTETS_PER_BYTE_POWER
4805 default values.
4806 * frags.c (frag_new): Calculate fr_fix in octets
4807 (frag_now_fix) Return offset as target address offset (bytes).
4808 (frag_now_fix_octets) New - Return offset in octets (8-bit
4809 quantities).
4810 * frags.h: Added prototype for frag_now_fix_octets().
4811 Distinguish between octets and bytes in field descriptions.
4812 * listing.c (calc_hex): Account for octets vs bytes when
4813 printing addresses/offsets.
4814 (print_lines) Ditto. Also, if LISTING_WORD_SIZE is not 1, and
4815 target is little-endian, print the octets in a word in big-endian
4816 order so that the display looks like a proper hexadecimal number,
4817 instead of having the octets reversed.
4818 * read.c (do_align): When recording alignment, alignment power
4819 should be in terms of target bytes (minimum addressible unit)
4820 instead of octets.
4821 (do_org) Convert ORG target address (byte) argument into an
4822 octet offset when generating a variable fragment.
4823 * symbols.c (resolve_symbol_value): Symbol final value
4824 converted to a target address offset (bytes) from its octet offset.
4825 * config/obj-coff.c (coff_frob_symbol): Symbol target address
4826 offset (bytes) is adjusted by the frag offset (octets) converted
4827 to bytes.
4828 (coff_frob_section) Section alignment power is in terms of bytes;
4829 convert it to an octet alignment power when calculating size (and
4830 size mask) in octets. Don't modify the section size in order to
4831 "align" it for TI COFF, since that format has a different method
4832 for storing alignment information.
4833
4834 2000-02-01 Timothy Wall <twall@cygnus.com>
4835
4836 * stabs.c (generate_asm_file): Escape backslashes in stabs file
4837 entries, matching the way GCC generates them. If not escaped, the
4838 filename is encoded incorrectly.
4839
4840 2000-01-31 Nick Clifton <nickc@cygnus.com>
4841
4842 * config/tc-arm.c (reg_table): Add support for ATPCS register
4843 naming conventions.
4844
4845 2000-01-31 Geoff Keating <geoffk@cygnus.com>
4846
4847 * config/obj-coff.h (OBJ_COPY_SYMBOL_ATTRIBUTES): Don't define if
4848 already defined.
4849 * config/tc-ppc.h [OBJ_XCOFF] (OBJ_COPY_SYMBOL_ATTRIBUTES):
4850 New macro.
4851 * config/tc-ppc.c (ppc_fix_adjustable): Don't look at the frag
4852 of a symbol when we really care about its value.
4853
4854 2000-01-19 Chandra Chavva <cchavva@cygnus.com>
4855
4856 * config/tc-mcore.c (md_assemble): Give warning message if
4857 operands passes to instruction are more than the spec.
4858
4859 2000-01-27 Thomas de Lellis <tdel@windriver.com>
4860
4861 * config/tc-arm.c (armadjust_symtab): If the assembler is in
4862 Thumb mode but the label seen was not declared as '.thumb_func'
4863 then set the ST_INFO type to STT_ARM_16BIT mode. This allows
4864 correct disassembly of Thumb code bounded by non function labels.
4865
4866 2000-01-27 Alan Modra <alan@spri.levels.unisa.edu.au>
4867
4868 * Makefile.am (MULTI_CFILES): Add config/e-i386aout.c
4869 Add dependencies for e-i386aout.o. Fix 2 comment lines.
4870
4871 * Makefile.in: Same here.
4872 Update copyright.
4873
4874 * configure.in: Set bfd_gas for i386-aout when primary target
4875 is bfd. Handle i386aout emulation. Don't use te_file=multi, as
4876 we may need the primary te_file. Remove incorrect comment.
4877
4878 * configure: Regenerate.
4879
4880 * config/e-i386aout.c: New file.
4881
4882 * as.c (USE_EMULATIONS): Move to before print_version_id.
4883 (struct emulation): Add i386aout.
4884 (show_usage): Split text strings. Reformat -a text. Add --em
4885 help.
4886 Update copyright.
4887
4888 * obj.h (struct format_ops): Add s_get_other and s_get_desc.
4889 (aout_format_ops): New.
4890 Update copyright.
4891
4892 * read.c (s_lcomm_internal): Rewrite OBJ_AOUT,OBJ_BOUT
4893 preprocessor conditional and add aout USE_EMULATIONS tests.
4894 (read_a_source_file): Don't pass error strings to printf as
4895 format arg.
4896 Update copyright.
4897
4898 * gasp.c (exp_get_abs): Don't pass error strings to printf as
4899 format arg.
4900 (do_data): Same here.
4901 (process_file): And here.
4902 Update copyright.
4903
4904 * symbols.c (colon): Rewrite "already defined" fatal message
4905 code for aout with USE_EMULATIONS.
4906 Update copyright.
4907
4908 * config/obj-aout.c (OBJ_HEADER): Define.
4909 (obj_pseudo_table): Rename to aout_pseudo_table. Init all
4910 fields of sentinel.
4911 (obj_aout_frob_symbol): Expand S_GET_DESC, S_GET_TYPE,
4912 S_GET_OTHER, S_SET_TYPE macros since we don't need obj-multi
4913 forms here.
4914 (obj_aout_type): Expand S_SET_OTHER here too.
4915 (obj_read_begin_hook): Remove.
4916 (aout_pop_insert): New.
4917 (obj_aout_s_get_other): New.
4918 (obj_aout_s_get_desc): New.
4919 (aout_format_ops): New.
4920 Update copyright.
4921
4922 * config/obj-aout.h (obj_pop_insert): Define so non-multi usage
4923 gets aout_pseudo_table.
4924 (aout_pseudo_table): Declare.
4925 (obj_read_begin_hook): Define.
4926 Update copyright.
4927
4928 * config/obj-coff.c (obj_pseudo_table): Rename to
4929 coff_pseudo_table.
4930 (coff_pop_insert): Use coff_pseudo_table.
4931 (coff_sec_sym_ok_for_reloc): Remove.
4932 (coff_format_ops): Add 0 entries for s_get_size, s_set_size,
4933 and comment all zero entries and remove #if 0 code.
4934 Update copyright.
4935
4936 * config/obj-coff.h (obj_pop_insert): Define.
4937 (coff_pseudo_table): Declare.
4938 Update copyright.
4939
4940 * config/obj-ecoff.c (ecoff_format_ops): Add 0 entries for
4941 s_get_size, s_set_size. Comment all zero entries.
4942 Update copyright.
4943
4944 * config/obj-elf.c (elf_s_get_other): New function.
4945 (obj_read_begin_hook): Rename to elf_obj_read_begin_hook.
4946 (obj_symbol_new_hook): Rename to elf_obj_symbol_new_hook.
4947 (elf_format_ops): Add elf_s_get_other, 0 s_get_size entry, and
4948 comment.
4949 (obj_elf_parse_section_letters): Don't pass error strings to
4950 printf as format arg.
4951 Update copyright.
4952
4953 * config/obj-elf.h (ECOFF_DEBUGGING): Define when
4954 OBJ_MAYBE_ECOFF.
4955 (elf_s_get_other): Declare.
4956 (S_GET_OTHER) Define as elf_s_get_other if not already
4957 defined.
4958 (S_SET_OTHER): Only define when not already defined.
4959 (elf_obj_read_begin_hook): Declare.
4960 (obj_read_begin_hook): Define.
4961 (elf_obj_symbol_new_hook): Declare.
4962 (obj_symbol_new_hook): Define.
4963 Update copyright.
4964
4965 * config/obj-multi.h: Add copyright header and protect against
4966 multiple inclusion. Add * to all function pointers.
4967 (OBJ_HEADER): If defined, include it rather than other defines
4968 in this file.
4969 (obj_frob_file_after_relocs): Test for NULL.
4970 (obj_symbol_new_hook): Here too.
4971 (obj_sec_sym_ok_for_reloc): And here.
4972 (S_GET_OTHER): Define.
4973 (S_GET_DESC): Define.
4974 (ECOFF_DEBUGGING): Remove as it's done in obj-elf.h
4975 (OBJ_MAYBE_ELF): Update comment.
4976
4977 * config/tc-i386.c (i386_immediate): Add OBJ_MAYBE_AOUT to
4978 OBJ_AOUT preprocessor conditional and handle emulation by
4979 testing OUTPUT_FLAVOR.
4980 (i386_displacement): Here too.
4981 (md_section_align): Similarly here.
4982 (i386_target_format): Conditionally compile when more than one
4983 of OBJ_MAYBE_{ELF,COFF,AOUT} defined. Add aout case.
4984 (i386_immediate): Fix error message for aout BFD_ASSMBLER.
4985 (i386_displacement): Here too.
4986 Update copyright.
4987
4988 * config/tc-i386.h (AOUT_TARGET_FORMAT): Define for each TE_*.
4989 Define TARGET_FORMAT for aout only when not multi.
4990 Update copyright.
4991
4992 * config/te-multi.h: Delete file as it's identical to te-generic.h
4993
4994 2000-01-15 Alan Modra <alan@spri.levels.unisa.edu.au>
4995
4996 * config/tc-i386.h (DWORD_MNEM_SUFFIX): Delete.
4997 * config/tc-i386.c (DWORD_MNEM_SUFFIX): Rename all occurrences to
4998 LONG_MNEM_SUFFIX.
4999
5000 * config/tc-i386.h (INTEL_DWORD_MNEM_SUFFIX): Rename to
5001 DWORD_MNEM_SUFFIX.
5002 * config/tc-i386.c (INTEL_DWORD_MNEM_SUFFIX): Here too. Fix some
5003 comments.
5004
5005 2000-01-13 Clinton Popetz <cpopetz@cygnus.com>
5006
5007 * config/tc-mips.c (mips_do_align): New function.
5008 * config/tc-mips.h (md_do_align): Define.
5009
5010 2000-01-10 Philip Blundell <philb@gnu.org>
5011
5012 * doc/c-arm.texi (ARM Options): Fix typo.
5013 (ARM-Chars): Correct description of `#'. Mention that `;' is a
5014 line separator for Linux.
5015 * doc/as.texinfo (Comments): Mention the ARM.
5016
5017 2000-01-10 Philip Blundell <pb@futuretv.com>
5018
5019 * configure.in (arm*-*-conix*): New target.
5020 (arm*-*-linux-gnu*): Match instead of arm-*-linux* and
5021 armv*-*-linux-gnu.
5022 * configure: Regenerate.
5023
5024 2000-01-03 Martin v. Loewis <loewis@informatik.hu-berlin.de>
5025
5026 * config/obj-elf.c (elf_pseudo_table): Define visibility pseudos.
5027 (obj_elf_visibility): New function.
5028
5029 * doc/as.texinfo (Visibility): New node: document visibility
5030 pseudo ops.
5031
5032 For older changes see ChangeLog-9899