* config/tc-mips.c (md_parse_option): When debugging, set
[binutils-gdb.git] / gas / ChangeLog
1 Wed Feb 12 14:36:29 1997 Ian Lance Taylor <ian@cygnus.com>
2
3 * config/tc-mips.c (md_parse_option): When debugging, set
4 mips_optimize to 1, not 0.
5
6 * config/tc-mips.c (mips16_ip): Handle an extend operand.
7
8 * config/tc-mips.c (my_getExpression): In mips16 mode, if it looks
9 like the expression was based on `.', adjust the value of the
10 symbol.
11
12 * config/tc-mips.c (append_insn): Warn about an attempt to put an
13 extended instruction in a delay slot when not reordering. Set
14 prev_insn_valid even if not reordering.
15 (md_convert_frag): Warn if an extended instruction appears in a
16 delay slot.
17
18 * config/tc-mips.c (mips_pseudo_table): Add "insn".
19 (s_insn): New static function.
20 * doc/c-mips.texi: Document .insn.
21
22 * config/tc-mips.c (md_begin): Add the general registers to the
23 symbol table.
24 (mips16_ip): First parse the expression, and then see whether it
25 came up with a register, rather than trying to first see whether
26 we are looking at a register.
27
28 start-sanitize-tic80
29 Tue Feb 11 15:13:39 1997 Fred Fish <fnf@cygnus.com>
30
31 * config/tc-tic80.c: Numerous changes and additions to flesh
32 out functions that were previously just stubs, and fix some
33 problems found using the new TIc80 testsuite cases.
34
35 end-sanitize-tic80
36 Tue Feb 11 15:52:22 1997 Ian Lance Taylor <ian@cygnus.com>
37
38 * config/tc-mips.c (mips16_ip): Handle %gprel modifier.
39 (md_apply_fix): Handle BFD_RELOC_MIPS16_GPREL.
40
41 * config/tc-mips.c (append_insn): Output jump instruction as a
42 pair of 2 byte instructions, rather than as a single 4 byte
43 instruction.
44
45 start-sanitize-r5900
46 * config/tc-mips.c (md_begin): Correct test of mips_5900.
47 (mips_ip): Don't check INSN_ISA for a macro.
48
49 end-sanitize-r5900
50 start-sanitize-r5900
51 Fri Feb 7 11:11:06 1997 Gavin Koch <gavin@cygnus.com>
52
53 * config/tc-mips.c: added r5900.
54
55 end-sanitize-r5900
56 Mon Feb 10 22:06:00 1997 Dawn Perchik (dawn@cygnus.com)
57
58 * itbl-ops.c, itbl-lex.l, itbl-parse.y, itbl-ops.h,
59 config/itbl-mips.h: Add copyright message and fix indentation.
60
61 Mon Feb 10 18:09:00 1997 Dawn Perchik (dawn@cygnus.com)
62
63 * itbl-ops.c: New file. Add support for dynamically read
64 instruction registers, opcodes and formats. Build internal table
65 for new instructions and provide callbacks for assembler and
66 disassembler.
67 * itbl-lex.l, itbl-parse.y: Lex and yacc parsers for instruction
68 spec table.
69 * itbl-ops.h: New file. Header file for itbl support.
70 * config/itbl-mips.h: New file. Mips specific definitions for
71 itbl support.
72
73 Fri Feb 7 09:52:34 1997 Jeffrey A Law (law@cygnus.com)
74
75 * config/tc-mn10200.c (md_assemble): If a constant operand won't
76 fit into the constant field of a relaxable operand, then it does
77 not match.
78
79 Thu Feb 6 20:08:12 1997 Jeffrey A Law (law@cygnus.com)
80
81 * config/tc-mn10200.c (md_estimate_size_before_relax): Treat
82 a jsr target in a different section just like a jsr to
83 an undefined target.
84
85 Thu Feb 6 16:52:57 1997 Ian Lance Taylor <ian@cygnus.com>
86
87 * config/tc-mips.c (mips_fix_adjustable): Don't adjust relocations
88 against any mips16 symbols, not just externally visible ones.
89 (md_apply_fix): Corresponding change.
90
91 Wed Feb 5 11:11:06 1997 Ian Lance Taylor <ian@cygnus.com>
92
93 * config/tc-mips.c (mips16_ip): Accept floating point registers in
94 the operand of the exit instruction.
95
96 Tue Feb 4 14:12:39 1997 Ian Lance Taylor <ian@cygnus.com>
97
98 * symbols.c (resolve_symbol_value): If we leave an equated symbol
99 as O_symbol, copy over the segment.
100
101 Mon Feb 3 12:35:54 1997 Ian Lance Taylor <ian@cygnus.com>
102
103 * config/tc-mips.c (md_apply_fix): If we aren't adjusting this
104 fixup to be against the section symbol, adjust the value
105 accordingly.
106
107 * symbols.c (resolve_symbol_value): Don't change X_add_number for
108 an equated symbol.
109 * write.c (write_relocs): Avoid looping on equated symbols.
110 Adjust fx_offset by X_add_number for each symbol.
111 * config/obj-coff.c (do_relocs_for): Avoid looping on equated
112 symbols.
113 (fixup_segment): Add a loop to track down equated symbols and
114 adjust fx_offset appropriately.
115
116 Fri Jan 31 15:21:02 1997 Jeffrey A Law (law@cygnus.com)
117
118 * config/tc-mn10200.c (md_relax_table): Add entries to allow
119 jmp -> bra relaxing.
120 (md_convert_frag): Handle jmp->bra relaxing.
121 (md_assemble): Handle jmp->bra relaxing.
122 (md_estimate_size_before_relax): Likewise.
123
124 Fri Jan 31 13:15:05 1997 Alan Modra <alan@spri.levels.unisa.edu.au>
125
126 * config/tc-i386.c (i386_align_code): Add comments explaining the
127 nop instructions.
128
129 Fri Jan 31 10:46:14 1997 Ian Lance Taylor <ian@cygnus.com>
130
131 * config/tc-sparc.c (enforce_aligned_data): New static variable.
132 (sparc_cons_align): Don't do anything unless enforce_aligned_data
133 is set.
134 (md_longopts): Add "enforce-aligned-data".
135 (md_show_usage): Mention --enforce-aligned-data.
136 * doc/c-sparc.texi (Sparc-Aligned-Data): New node; document
137 enforce-aligned-data.
138
139 * config/tc-ppc.c (md_pseudo_table): If OBJ_XCOFF, add "long",
140 "word", and "short".
141 (ppc_xcoff_cons): New static function.
142
143 * write.c (relax_segment): Give an error if a .space symbol is
144 common or undefined.
145
146 * read.c (read_a_source_file): Don't handle mri_pending_align if
147 the handler is s_globl or s_ignore.
148
149 Thu Jan 30 11:46:59 1997 Fred Fish <fnf@cygnus.com>
150
151 * config/tc-d10v.c (find_opcode): Remove unused variable "numops".
152 start-sanitize-tic80
153 * config/tc-tic80.c: Many additions to previous placeholder file.
154 * config/tc-tic80.h: Ditto.
155 end-sanitize-tic80
156
157 Thu Jan 30 12:28:18 1997 Alan Modra <alan@spri.levels.unisa.edu.au>
158
159 * config/tc-i386.c (i386_align_code): Improve the nop patterns.
160
161 Thu Jan 30 12:08:40 1997 Ian Lance Taylor <ian@cygnus.com>
162
163 * config/tc-mips.c (mips_fix_adjustable): New function.
164 * config/tc-mips.h (tc_fix_adjustable): Call mips_fix_adjustable.
165 (mips_fix_adjustable): Declare.
166
167 Ideas from Srinivas Addagarla <srinivas@cdotd.ernet.in>:
168 * read.c (read_a_source_file): After doing an mri_pending_align,
169 adjust the line_label if there is one.
170 (s_space): Set mri_pending_align if an odd number of bytes were
171 output.
172
173 start-sanitize-d10v
174 Wed Jan 29 15:31:12 1997 Martin M. Hunt <hunt@pizza.cygnus.com>
175
176 * config/tc-d10v.h (md_do_align): Add this hook to call
177 d10v_cleanup() when a ".align" is detected. Fixes PR11487.
178
179 * config/tc-d10v.c (find_opcode): Correctly calculate
180 branch displacement when .aligns are present.
181
182 end-sanitize-d10v
183 Wed Jan 29 09:42:11 1997 Jeffrey A Law (law@cygnus.com)
184
185 * config/tc-mn10200.c (md_relax_table): Define.
186 (md_convert_frag): Implement.
187 (md_assemble): Handle relaxable operands/instructions correctly.
188 (md_estimate_size_before_relax): Implement.
189 * config/tc-mn10200.h (TC_GENERIC_RELAX_TABLE): Define.
190
191 Tue Jan 28 15:27:28 1997 Ian Lance Taylor <ian@cygnus.com>
192
193 * config/tc-mips.c (append_insn): Give an error for jumps to a
194 misaligned address.
195 (md_apply_fix): Make a branch to an odd address an error rather
196 than a warning.
197
198 * config/tc-mips.c (md_convert_frag): If the user explicitly
199 requested an extended opcode, pass warn as true to mips16_immed.
200
201 * config/tc-mips.c (mips16_ip): Handle a missing expression like
202 an explicit 0, so that explicitly extended instructions work
203 correctly.
204
205 Mon Jan 27 17:41:20 1997 Ian Lance Taylor <ian@cygnus.com>
206
207 * ecoff.c (ecoff_build_symbols): Don't generate a local ECOFF
208 symbol for a common symbol.
209
210 Wed Jan 22 10:39:39 1997 Doug Evans <dje@canuck.cygnus.com>
211
212 Patch presumed to have been checked in awhile ago but wasn't.
213 Mon Nov 25 10:45:14 1996 Doug Evans <dje@seba.cygnus.com>
214 * write.c: Delete "ifndef md_relax_frag" around is_dnrange.
215 (relax_segment, case rs_org): Move code inside braces. Move locals
216 target,after inside too.
217 (relax_segment, case rs_machine_dependent): Guts moved to ...
218 (relax_frag): New function.
219 Call md_prepare_relax_scan if defined.
220
221 Mon Jan 20 10:56:47 1997 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
222
223 * config/tc-m68k.c (m68k_ip): Reject pc-relative addresses for the
224 'p' operand specifier.
225
226 Mon Jan 20 10:39:36 1997 J.T. Conklin <jtc@cygnus.com>
227
228 * config/tc-m68k.c (HAVE_LONG_BRANCH): New macro, returns true for
229 m68k family cpus which support long branch addressing modes.
230 (m68k_ip, md_convert_frag_1, md_estimate_size_before_relax,
231 md_create_long_jump): Use it.
232
233 Mon Jan 20 12:42:06 1997 Ian Lance Taylor <ian@cygnus.com>
234
235 * config/tc-mips.c (md_begin): Don't set SEC_ALLOC or SEC_LOAD for
236 the .reginfo or .MIPS.options section if configured for an
237 embedded target.
238
239 * config/tc-mips.c (md_begin): Don't set interlocks for
240 mips_4650.
241
242 Wed Jan 15 13:51:50 1997 Ian Lance Taylor <ian@cygnus.com>
243
244 * read.c (read_a_source_file): Make sure the symbol ends with
245 whitespace before checking whether the next character is '='.
246
247 Tue Jan 14 15:07:27 1997 Robert Lipe <robertl@dgii.com>
248
249 * config/tc-i386.c (sco_id): Moved from here...
250 * config/obj-elf.c (sco_id): ...to here. Adding the identifier
251 really is an SCO ELF specific thing, not just a SCO x86 specific
252 thing.
253
254 start-sanitize-tic80
255 Mon Jan 13 22:43:01 1997 Michael Meissner <meissner@tiktok.cygnus.com>
256
257 * configure.in (tic80-*-*): Don't require 'coff'.
258 * configure: Regenerate.
259
260 end-sanitize-tic80
261 Thu Jan 9 09:08:43 1997 Ian Lance Taylor <ian@cygnus.com>
262
263 * read.c (emit_expr): Check for overflow of a negative value
264 correctly.
265 * write.c (fixup_segment): Likewise.
266 * config/obj-coff.c (fixup_segment): Likewise.
267
268 * config/tc-m68k.c (struct label_line): Define.
269 (labels, current_label): New static variables.
270 (md_assemble): Mark current_label as text, and clear it.
271 (m68k_frob_label): New function.
272 (m68k_flush_pending_output): New function.
273 (m68k_frob_symbol): New function.
274 * config/tc-m68k.h (tc_frob_label): Define.
275 (md_flush_pending_output): Define.
276 (tc_frob_symbol): Don't warn, just call m68k_frob_symbol.
277 (tc_frob_coff_symbol): Likewise.
278
279 * read.c (read_a_source_file): When defining a macro in MRI mode,
280 don't add the symbol to the symbol table.
281
282 Tue Jan 7 11:21:42 1997 Jeffrey A Law (law@cygnus.com)
283
284 * config/tc-mn10300.c (tc_gen_reloc): Handle sym1-sym2 fixups
285 here since fixup_segment doesn't (linkrelax is set).
286 * config/tc-mn10200.c (tc_gen_reloc): Likewise.
287
288 Mon Jan 6 15:19:32 1997 Jeffrey A Law (law@cygnus.com)
289
290 * config/tc-mn10200.c (md_assemble): Tweak fx_offset for pc-relative
291 relocs.
292
293 Fri Jan 3 16:47:08 1997 Jeffrey A Law (law@cygnus.com)
294
295 * config/tc-hppa.c (struct hppa_fix_struct): Tweak fx_r_field's type
296 to avoid warnings with the native HP compiler.
297 (fix_new_hppa): Similarly for the r_type argument.
298 (pa_build_unwind_subspace, hppa_elf_mark_end_of_function): Enclose
299 in an #if OBJ_ELF to keep gcc -Wall quiet.
300 (md_apply_fix): Always initialize "result".
301
302 * config/tc-mn10200.c (md_assemble): Generate relocations.
303
304 Fri Jan 3 18:17:23 1997 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
305
306 * config/tc-m68k.c (s_even): Adjust the alignment of the current
307 section.
308
309 Fri Jan 3 17:10:33 1997 Richard Henderson <rth@tamu.edu>
310
311 * config/obj-elf.c (elf_file_symbol): When using ECOFF debugging,
312 pass on the new file hook.
313
314 * config/tc-alpha.c (alpha_fix_adjustable): Not quite the same as
315 !alpha_force_relocation, as local LITERALs can be adjusted to be
316 relative to the section.
317
318 Fri Jan 3 12:09:24 1997 Ian Lance Taylor <ian@cygnus.com>
319
320 * config/obj-coff.c (yank_symbols): If tc_frob_coff_symbol is
321 defined, call it.
322 * config/tc-m68k.h (tc_frob_symbol): Check whether text label is
323 aligned to odd boundary.
324 (tc_frob_coff_symbol): Define.
325
326 * doc/as.texinfo (Set): Change parenthesized @xref to @pxref.
327
328 * macro.c (macro_expand_body): In MRI mode, just copy a single &.
329
330 * config/tc-m68k.c (m68k_ip): Call frag_grow before adding a
331 PCINDEX frag. From Ronald F. Guilmette <rfg@monkeys.com>.
332
333 * config/tc-m68k.c (m68k_ip): Accept 'B' as a size for an
334 immediate value.
335 (md_assemble): If the size is 'B', set fx_signed.
336 (md_apply_fix_2): Use fx_signed when checking for overflow.
337
338 * write.h (struct fix): Add fx_signed field.
339 * write.c (fix_new_internal): Initialize fx_no_overflow and
340 fx_signed fields.
341 (fixup_segment): Use fx_signed when checking for overflow.
342 * config/obj-coff.c (fixup_segment): Check fx_no_overflow and
343 fx_signed when checking for overflow.
344
345 Thu Jan 2 13:37:29 1997 Ian Lance Taylor <ian@cygnus.com>
346
347 * NOTES, NOTES.config: Removed. These are rarely, if ever,
348 updated, and all the useful information is in doc/internals.texi.
349
350 Based on patch from Ronald F. Guilmette <rfg@monkeys.com>:
351 * read.c (read_a_source_file): Check for conditional operators
352 before doing an MRI pending alignment.
353 * config/tc-m68k.h (m68k_conditional_pseudoop): Declare.
354 (tc_conditional_pseudop): Define.
355 * config/tc-m68k.c (m68k_conditional_pseudop): New function.
356 * doc/internals.texi (CPU backend): Describe
357 tc_conditional_pseudoop.
358
359 Based on patch from Ronald F. Guilmette <rfg@monkeys.com>:
360 * config/tc-m68k.c (m68k_rel32_from_cmdline): New static
361 variable.
362 (md_begin): Check m68k_rel32_from_cmdline before setting
363 m68k_rel32.
364 (m68k_mri_mode_change): Likewise.
365 (md_longopts): Add --disp-size-default-16 and
366 --disp-size-default-32.
367 (md_parse_option): Handle new options.
368 (md_show_usage): Mention new options.
369 * doc/c-m68k.texi (M68K-Opts): Document new options.
370
371 Based on patch from Ronald F. Guilmette <rfg@monkeys.com>:
372 * config/tc-m68k.c (m68k_index_width_default): New static
373 variable.
374 (m68k_ip): Use m68k_index_width_default to set the size of a base
375 register whose size was not given.
376 (md_longopts): Add --base-size-default-16 and
377 --base-size-default-32.
378 (md_parse_option): Handle new options.
379 (md_show_usage): Mention new options.
380 * doc/c-m68k.texi (M68K-Opts): Document new options.
381
382 * doc/c-mips.texi: Mention ISA level 4, and the -mips16 option.
383
384 * configure.in: Recognize mips-*-linux* target.
385 * configure: Rebuild.
386
387 * config/tc-mips.c (load_register): Rewrite 64 bit handling to
388 work if valueT is only 32 bits.
389
390 * config/tc-mips.c: Throughout, check target_big_endian rather
391 than byte_order.
392 (byte_order): Remove.
393 (mips_init_after_args): Remove.
394 * config/tc-mips.h (LITTLE_ENDIAN, BIG_ENDIAN): Don't define.
395 (mips_init_after_args): Don't declare.
396 (tc_init_after_args): Don't define.
397
398 * config/tc-mips.h (tc_frob_after_relocs): Define if
399 OBJ_MAYBE_ELF.
400 (mips_elf_final_processing): Likewise.
401 (ELF_TC_SPECIAL_SECTIONS): Likewise.
402
403 start-sanitize-v850
404 Tue Dec 31 15:12:35 1996 Michael Meissner <meissner@tiktok.cygnus.com>
405
406 * config/tc-v850.c (md_assemble): If this is sst.{h,w} or
407 sld.{h,w} and the operand is relocatable, adjust the adend by
408 shifting it right one bit.
409
410 end-sanitize-v850
411 Tue Dec 31 12:56:41 1996 Ian Lance Taylor <ian@cygnus.com>
412
413 * read.c (read_a_source_file): Check mri_pending_align after
414 checking for a macro. From Ronald F. Guilmette
415 <rfg@monkeys.com>.
416
417 * Makefile.in (ALL_CFLAGS): Add -D_GNU_SOURCE.
418
419 * config/tc-sparc.c (md_apply_fix3): Rename from md_apply_fix, and
420 add segment argument. If OBJ_ELF, treat a relocation against a
421 symbol in a linkonce section like a relocation against an external
422 symbol.
423 * config/tc-sparc.h (MD_APPLY_FIX3): Define.
424
425 Mon Dec 30 11:35:40 1996 Ian Lance Taylor <ian@cygnus.com>
426
427 * config/tc-mips.c (mips16_macro): Add case for M_ABS.
428
429 Fri Dec 27 22:51:51 1996 Fred Fish <fnf@cygnus.com>
430
431 * NOTES.config (Implementation): as.h #define's "GAS" not "gas",
432 includes config.h instead of host.h, tc.h instead of tp.h, and
433 targ-env.h instead of target-environment.h.
434 Also, obj-format.h includes targ-cpu.h instead of
435 target-processor.h.
436 start-sanitize-tic80
437 * configure.in (case ${generic_target}): Add tic80-*-coff entry.
438 * configure: Rebuild with autoconf.
439 * config/obj-coff.h (coff/tic80.h): Include if TC_TIC80 defined.
440 (TARGET_FORMAT): Define to "coff-tic80".
441 * config/tc-tic80.c: New file for TIc80 support.
442 * config/tc-tic80.h: New file for TIc80 support.
443 end-sanitize-tic80
444
445 Fri Dec 27 11:42:29 1996 Ian Lance Taylor <ian@cygnus.com>
446
447 * doc/as.texinfo (M): Mention explicitly that -M changes macro
448 handling.
449
450 Thu Dec 19 12:06:08 1996 Ian Lance Taylor <ian@cygnus.com>
451
452 * write.c (adjust_reloc_syms): If the fixup symbol has been
453 equated to an undefined symbol, convert the fixup to being against
454 the target symbol. Remove obsolete code handling a special case
455 for i386 PIC.
456
457 Wed Dec 18 22:54:39 1996 Stan Shebs <shebs@andros.cygnus.com>
458
459 * mpw-make.sed: Use NewFolderRecursive for installation.
460
461 start-sanitize-d10v
462 Wed Dec 18 16:00:42 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
463
464 * config/tc-d10v.c (do_assemble): Correct previous bug fix.
465
466 Wed Dec 18 15:27:40 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
467
468 * config/tc-d10v.c (md_assemble): Fix bug which caused
469 second instruction in a line to be case sensitize. PR11312
470
471 end-sanitize-d10v
472 Wed Dec 18 10:08:46 1996 Jeffrey A Law (law@cygnus.com)
473
474 * config/tc-mn10200.c (mn10200_insert_operand): Don't
475 range check operands with MN10200_OPERAND_NOCHECK set.
476 (check_operand): Likewise.
477
478 Tue Dec 17 10:59:32 1996 Ian Lance Taylor <ian@cygnus.com>
479
480 * config/tc-mips.c: Undo part of last Friday's alignment changes.
481 (md_begin): Always align the text section to a four byte
482 boundary.
483 (append_insn): Remove call to record_align.
484
485 * config/tc-mips.c (insn_label): Remove.
486 (struct insn_label_list): Define.
487 (insn_labels, free_insn_labels): New static variables.
488 (mips_clear_insn_labels): New static function.
489 (append_insn): Mark all mips16 text labels, and make them odd.
490 Handle all labels after emitting a nop, not just one. Call
491 mips_clear_insn_labels rather than just clearing insn_label.
492 (mips_emit_delays): Add insns parameter, and use it to decide
493 whether to mark mips16 labels. Handle all labels, not just one.
494 Force mips16 labels to be odd. Change all callers.
495 (mips16_immed): Don't check for an odd branch target.
496 (md_apply_fix): Don't check mips16 mode for a branch reloc.
497 (mips16_extended_frag): Ignore the low bit in a branch target.
498 (md_convert_frag): Likewise.
499 (mips_no_prev_insn): Call mips_clear_insn_labels rather than just
500 clearing insn_label.
501 (mips_align, mips_flush_pending_output, s_cons): Likewise.
502 (s_float_cons, s_gpword): Likewise.
503 (s_align): Use insn_labels rather than insn_label.
504 (s_cons, s_float_cons, s_gpword): Likewise.
505 (mips_frob_file_after_relocs): New function.
506 (mips_define_label): Rewrite to add to insn_labels list.
507 * config/tc-mips.h (tc_frob_file_after_relocs): Define.
508 * ecoff.c (ecoff_build_symbols): If the size of a function comes
509 out odd, increment it.
510
511 * config/tc-mips.c (append_insn): Only update prev_insn when not
512 reordering if place is NULL.
513
514 * config/tc-mips.c (mips16_ip): Check for a missing expression
515 when using the register indirect addressing mode.
516
517 Mon Dec 16 10:08:46 1996 Jeffrey A Law (law@cygnus.com)
518
519 * config/tc-mn10200.c (mn10200_insert_operand): Don't
520 check 24bit operands for overflow.
521 (check_operand): Likewise.
522
523 Mon Dec 16 11:50:40 1996 Ian Lance Taylor <ian@cygnus.com>
524
525 * doc/as.texinfo (Section): Document how to use the .section
526 pseudo-op for COFF and ELF.
527
528 Sun Dec 15 15:26:37 1996 Ian Lance Taylor <ian@cygnus.com>
529
530 * write.c (adjust_reloc_syms): Fix linkonce check for ELF.
531
532 Sat Dec 14 22:37:27 1996 Ian Lance Taylor <ian@cygnus.com>
533
534 * config/tc-mips.c (prev_insn_reloc_type): New static variable.
535 (RELAX_MIPS16_ENCODE): Add dslot and jal_dslot arguments, and
536 store them. Adjust other RELAX_MIPS16 macros.
537 (RELAX_MIPS16_DSLOT): Define.
538 (RELAX_MIPS16_JAL_DSLOT): Define.
539 (append_insn): Pass new arguments to RELAX_MIPS16_ENCODE. Correct
540 handling of whether previous instruction has a fixup. Set
541 prev_insn_reloc_type.
542 (mips_no_prev_insn): Clear prev_insn_reloc_type.
543 (mips16_extended_frag): Use the right base address for a PC
544 relative add or load.
545 (md_convert_frag): Likewise. If a PC relative add or load is
546 used, record the alignment for the section.
547
548 Fri Dec 13 13:00:33 1996 Ian Lance Taylor <ian@cygnus.com>
549
550 * write.c (adjust_reloc_syms): Don't reduce a reloc against a
551 linkonce section into a reloc against the section symbol.
552
553 * config/tc-mips.c (mips16_macro): Remove nop instructions after
554 branch instructions.
555
556 * config/tc-mips.c (md_begin): If configured for an embedded ELF
557 system, don't set the section alignment to 2**4.
558 (s_change_sec): Likewise.
559 (append_insn): Call record_alignment for the section.
560 (md_section_align): Don't align the section size for an embedded
561 ELF system.
562
563 Thu Dec 12 16:40:47 1996 Ian Lance Taylor <ian@cygnus.com>
564
565 * write.c (adjust_reloc_syms): Make sure that symbols are
566 resolved; expression symbols may have been skipped.
567 * config/obj-coff.c (fixup_segment): Likewise.
568
569 Thu Dec 12 15:18:21 1996 Michael Meissner <meissner@tiktok.cygnus.com>
570
571 * config/tc-ppc.c (ppc_elf_suffix): Move @plt to
572 BFD_RELOC_24_PLT_PCREL relocation.
573 (md_apply_fix3): Support BFD_RELOC_24_PLT_PCREL.
574
575 start-sanitize-d10v
576 Tue Dec 10 13:51:55 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
577
578 * config/tc-d10v.c (write_2_short): Remove code that called
579 parallel_ok() when the programmer specified parallel instructions.
580
581 end-sanitize-d10v
582 Tue Dec 10 12:23:19 1996 Jeffrey A Law (law@cygnus.com)
583
584 * config/tc-mn10300.c (md_assemble): Update to handle endianness
585 issues correctly.
586
587 * config/tc-mn10200.c (md_assemble): Opcode 0x0 is valid!
588 * config/tc-mn10300.c (md_assemble): Likewise.
589
590 Tue Dec 10 11:37:14 1996 Ian Lance Taylor <ian@cygnus.com>
591
592 * config/tc-mips.c (append_insn): Make sure there is enough room
593 in a frag after a mips16 instruction to switch it with a jump
594 instruction.
595
596 * config/tc-mips.c (mips16_extended_frag): Give an error for an
597 attempt to use a non absolute symbol in an extending frag.
598
599 Mon Dec 9 16:48:20 1996 Jeffrey A Law (law@cygnus.com)
600
601 * config/tc-mn10200.c: Flesh out assembler support for MN10200.
602 * config/tc-mn10200.h: Likewise.
603
604 Mon Dec 9 17:09:42 1996 Ian Lance Taylor <ian@cygnus.com>
605
606 * app.c (do_scrub_chars): At the end of a C comment, pass space to
607 UNGET rather than PUT. Set old_state before setting state to -2.
608
609 * config/tc-mips.c (mips16_extended_frag): Avoid an infinite loop
610 when extending because the value is exactly maxtiny + 1.
611
612 * config/tc-mips.c (RELAX_MIPS16_ENCODE): Add small and ext
613 arguments, and store them. Adjust other RELAX_MIPS16 macros.
614 (RELAX_MIPS16_USER_SMALL): Define.
615 (RELAX_MIPS16_USER_EXT): Define.
616 (mips16_small, mips16_ext): New static variables.
617 (append_insn): Pass mips16_small and mips16_ext to
618 RELAX_MIPS16_ENCODE.
619 (mips16_ip): Set mips16_small and mips16_ext.
620 (mips16_immed): Don't check mips16_autoextend.
621 (mips16_extended_frag): Check USER_SMALL and USER_EXT.
622
623 * write.c (write_relocs): Print an error for an out of range
624 fixup, rather than calling abort.
625
626 * as.c (main): Unlink the output file if there are errors while
627 generating the fixups.
628
629 Fri Dec 6 18:48:13 1996 Ian Lance Taylor <ian@cygnus.com>
630
631 * config/tc-mips.c (mips16_extended_frag): Don't call
632 S_GET_VALUE.
633 (md_convert_frag): Call resolve_symbol_value before calling
634 S_GET_VALUE, and don't add in the frag address.
635
636 * config/tc-mips.c (mips16_immed): Add file and line parameters,
637 and use them when reporting errors. Change all callers.
638
639 Fri Dec 6 15:36:32 1996 Jeffrey A Law (law@cygnus.com)
640
641 * config/tc-mn10300.c: Fix various gcc -Wall warnings.
642 Remove '$' prefixing for registers.
643
644 start-sanitize-d10v
645 Fri Dec 6 00:55:48 1996 Martin <hunt@cygnus.com>
646
647 * config/tc-d10v.c (md_assemble): Check to see if prev_seg
648 is initialized before using it.
649 (d10v_cleanup): No longer uses its argument, so make it void.
650
651 * config/tc-d10v.h (d10v_cleanup): Change prototype.
652
653 end-sanitize-d10v
654 Thu Dec 5 11:03:31 1996 Ian Lance Taylor <ian@cygnus.com>
655
656 * write.c (fixup_segment): Don't discard the symbol for a PC
657 relative fixup to an absolute symbol.
658
659 start-sanitize-d10v
660 Wed Dec 4 15:42:41 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
661
662 * config/tc-d10v.c (md_assemble, d10v_cleanup): Fix bug
663 with multiple sections.
664
665 end-sanitize-d10v
666 Wed Dec 4 13:00:07 1996 Ian Lance Taylor <ian@cygnus.com>
667
668 * config/tc-mips.c (md_longopts): Rename mips-16 to mips16, and
669 no-mips-16 to no-mips16.
670 (s_mipsset): Accept .set mips16 and .set nomips16.
671
672 Wed Dec 4 10:35:33 1996 Michael Meissner <meissner@tiktok.cygnus.com>
673
674 * config/tc-ppc.c (ppc_elf_suffix): Take expressionS pointer
675 argument, and check for +/- constant following the suffix, folding
676 it into the expression.
677 (ppc_elf_cons): Change ppc_elf_suffix calls.
678 (md_assemble): Ditto.
679 (shlib): Replace boolean mrelocatable with enumeration shlib.
680 (md_parse_option): Discriminate between PIC style shared libraries
681 and -mrelocatable.
682 (ppc_elf_validate_fix): Don't report warnings for PIC style shared
683 libraries.
684
685 Tue Dec 3 23:18:29 1996 Michael Meissner <meissner@tiktok.cygnus.com>
686
687 * config/tc-ppc.h ({tc,ppc}_comment_chars): Define, so that we can
688 change the comment characters.
689
690 * config/tc-ppc.c (comment_chars): Delete in favor of
691 tc_comment_chars.
692 (ppc_{eabi,solaris}_comment_chars): Eabi and Solaris versions of
693 comment chars.
694 (ppc_comment_chars): Select appropriate comment chars by default.
695 (msolaris): New flag for -m{,no-}solaris.
696 (md_parse_option): Recognize -K pic. Add support for
697 -m{,no-}solaris.
698 (md_show_usage): Update.
699 (md_begin): Do not set ELF flags if Solaris.
700 (ppc_elf_suffix): @local sets R_PPC_LOCAL24PC relocation.
701 (md_apply_fix3): Add support for R_PPC_LOCAL24PC.
702
703 Mon Dec 2 13:48:57 1996 Ian Lance Taylor <ian@cygnus.com>
704
705 * as.c (main): Correct handling of flag_always_generate_output.
706
707 Sun Dec 1 21:46:05 1996 Jeffrey A Law (law@cygnus.com)
708
709 * config/tc-mn10300.c (tc_gen_reloc): Get the addend from
710 fx_offset, not fx_addnumber.
711
712 * config/tc-mn10300.h (tc_fix_adjustable): Don't do any
713 reloc adjustments.
714
715 Sat Nov 30 17:34:48 1996 Eliot Dresselhaus <eliot@wally.edc.com>
716
717 * config/tc-i386.c: Correct misspelling: balenced to balanced.
718
719 Wed Nov 27 13:25:39 1996 Ian Lance Taylor <ian@cygnus.com>
720
721 * config/tc-mips.c (md_section_align): Check for an alignment of
722 4, not an alignment of 16. Corrects August 7 patch.
723
724 Tue Nov 26 10:33:16 1996 Ian Lance Taylor <ian@cygnus.com>
725
726 * configure, conf.in: Rebuild with autoconf 2.12.
727
728 * config/tc-ppc.c (ppc_elf_lcomm): Don't give an error if no
729 alignment is specified.
730
731 Add support for mips16 (16 bit MIPS implementation):
732 * config/tc-mips.c: Extensive additions for mips16 support, not
733 listed here.
734 (RELAX_OLD, RELAX_NEW): Use only 7 bits each.
735 (insn_uses_reg): Change last parameter to an enum.
736 * config/tc-mips.h (LOCAL_LABELS_DOLLAR): Define as 0.
737 (md_relax_frag): Define as mips_relax_frag.
738 (mips_relax_frag): Declare.
739 (struct mips_cl_insn): Add use_extend and extend fields.
740 (tc_fix_adjustable): Define.
741 * config/obj-elf.h (S_GET_OTHER): Define.
742 (S_SET_OTHER): Define.
743
744 Mon Nov 25 18:02:29 1996 J.T. Conklin <jtc@beauty.cygnus.com>
745
746 * config/tc-m68k.c (m68k_ip): Implement cases for new <, >, m, n,
747 o and p operand specifiers.
748
749 Mon Nov 25 10:45:14 1996 Doug Evans <dje@seba.cygnus.com>
750
751 * write.c: Delete "ifndef md_relax_frag" around is_dnrange.
752 (relax_segment, case rs_org): Move code inside braces. Move locals
753 target,after inside too.
754 (relax_segment, case rs_machine_dependent): Guts moved to ...
755 (relax_frag): New function.
756 Call md_prepare_relax_scan if defined.
757 * config/tc-m68k.h (md_prepare_relax_scan): Renamed from
758 M68K_AIM_KLUDGE.
759
760 Mon Nov 25 08:49:36 1996 Jeffrey A Law (law@cygnus.com)
761
762 * config/tc-mn10300.c (address_registers): Use '$' as register
763 prefix instead of '%'.
764 (data_registers, other_registers, md_assemble): Likewise.
765
766 * config/tc-mn10300.c (address_registers): Use '%' prefix for regs.
767 (data_registers, other_registers, md_assemble): Likewise.
768
769 * config/tc-mn10300.c (md_assemble): Correctly determine the
770 correct location and type for each relocation.
771 (md_pcrel_from): Simplify.
772
773 Fri Nov 22 15:42:26 1996 Ian Lance Taylor <ian@cygnus.com>
774
775 * config/tc-sh.c (md_convert_frag): Improve warning when branch is
776 converted into branch around branch.
777
778 Thu Nov 21 11:56:11 1996 Jeffrey A Law (law@cygnus.com)
779
780 * config/tc-mn10300.h (DIFF_EXPR_OK): Don't define this.
781 (tc_fix_adjustable): Don't adjust relocs against weak symbols or
782 pc-relative relocs.
783 * config/tc-mn10300.c (md_begin): Set linkrelax.
784 (md_assemble): Create fixups as needed.
785 (md_apply_fix3): Gut. It shouldn't ever get called anymore.
786
787 start-sanitize-d10v
788 Tue Nov 19 17:48:06 1996 Michael Meissner <meissner@tiktok.cygnus.com>
789
790 * config/tc-d10v.c (parallel_ok): When automatically converting
791 serial ops to parallel, do not consider a branch as the first
792 instruction.
793
794 end-sanitize-d10v
795 Tue Nov 19 13:35:22 1996 Jeffrey A Law (law@cygnus.com)
796
797 * config/tc-mn10300.c (md_assemble): Handle MN10300_OPERAND_REG_LIST.
798
799 Mon Nov 18 15:26:55 1996 Jeffrey A Law (law@cygnus.com)
800
801 * config/tc-mn10300.c (mn10300_insert_operand): Provide prototype
802 via PARAMS.
803 (check_operand): Likewise.
804
805 start-sanitize-d10v
806 Mon Nov 18 15:22:28 1996 Michael Meissner <meissner@tiktok.cygnus.com>
807
808 * config/tc-d10v.c (parallel_ok): Branch and link instructions
809 modify r13.
810 (write_2_short): Call parallel_ok to check whether two short
811 instructions the user requested execute in parallel, can be
812 executed that way.
813
814 Thu Nov 14 11:17:49 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
815
816 * config/tc-d10v.c (write_2_short): Fix bug that wouldn't
817 allow a branch and link in parallel with an exe instruction.
818
819 Fri Nov 8 13:55:03 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
820
821 * doc/c-d10v.texi: Add info on @word modifier.
822
823 end-sanitize-d10v
824 Wed Nov 6 13:46:07 1996 Jeffrey A Law (law@cygnus.com)
825
826 * config/tc-mn10300.c (mn10300_insert_operand): MN10300_OPERAND_SPLIT
827 operands are assumed to be 32bits. Use "bits" field to hold the
828 number of bits in the main instruction word for MN10300_OPERAND_SPLIT.
829 (mn10300_check_operand): MN10300_OPERAND_SPLIT operands are assumed
830 to be 32bits.
831
832 * config/tc-mn10300.c (mn10300_insert_operand): Shift low part
833 of a MN10300_OPERAND_SPLIT operand by operand->shift.
834
835 * config/tc-mn10300.c (mn10300_insert_operand): Handle
836 MN10300_OPERAND_SPLIT.
837
838 Tue Nov 5 13:30:40 1996 Jeffrey A Law (law@cygnus.com)
839
840 * config/tc-mn10300.c (md_assemble): Insert operands into
841 the extension part of the instruction if necessary.
842 (mn10300_insert_operand): Accept pointer to extension word
843 argument. Make insn a pointer argument too. Return type
844 is now void. All callers changed.
845
846 Mon Nov 4 12:53:40 1996 Jeffrey A Law (law@cygnus.com)
847
848 * config/tc-mn10300.c (mn10300_insert_operand): Handle
849 repeated register operands.
850
851 Fri Nov 1 10:42:49 1996 Ian Lance Taylor <ian@cygnus.com>
852
853 * doc/as.texinfo: Added section on reporting bugs.
854
855 * config/tc-alpha.c: Change uses of void * to PTR. Change the
856 alpha_macro emit field to expect a const argument, and change the
857 arg field to be const. Fix some spacing to follow the GNU
858 standard.
859
860 Fri Nov 1 10:32:03 1996 Richard Henderson <rth@tamu.edu>
861
862 * config/tc-alpha.c (md_parse_option): Add knowledge of 21164pc
863 (pca56) and 21264 (ev6) cpus.
864 (md_apply_fix): Private relocation types are now negative.
865 (alpha_force_relocation): Likewise.
866 (tc_gen_reloc): Likewise.
867 (emit_insn): Likewise.
868 (emit_ldXu): Do the right thing when the hardware can do byte insns.
869 (emit_stX): Likewise.
870 (emit_sextX): Likewise.
871
872 Thu Oct 31 16:33:21 1996 Ian Lance Taylor <ian@cygnus.com>
873
874 * config/obj-coff.c (do_relocs_for): Call resolve_symbol_value on
875 a symbol found in a reloc.
876
877 * symbols.c (resolve_symbol_value): Improve the error message if
878 an undefined symbol is used in an expression.
879
880 Wed Oct 30 20:15:35 1996 Ian Lance Taylor <ian@cygnus.com>
881
882 * doc/internals.texi: Rewrite, and add a lot of documentation.
883 * doc/Makefile.in (internals.info): New target.
884
885 start-sanitize-v850
886 Wed Oct 30 14:55:57 1996 Jeffrey A Law (law@cygnus.com)
887
888 * config/tc-v850.h (tc_fix_adjustable): Don't adjust relocs
889 against weak symbols.
890
891 Tue Oct 29 12:28:16 1996 Jeffrey A Law (law@cygnus.com)
892
893 * config/tc-v850.c (md_assemble): Don't lose for relaxable
894 addresses like .+6.
895
896 * config/tc-v850.c (md_convert_frag): Make sure we insert the
897 fixup at the right address within the frag.
898
899 * config/tc-v850.c (md_convert_frag): Don't set fragP->fr_fix
900 to an absolute value, instead increment it as needed.
901
902 * config/tc-v850.h (TC_GENERIC_RELAX_TABLE): Define.
903 * config/tc-v850.c: Fix some indention problems.
904 (md_relax_table): Define for D9->D99 branch displacement
905 relaxing.
906 (md_convert_frag): Do something useful instead of aborting.
907 (md_estimate_size_before_relax): Likewise.
908 (md_assemble): Note if the matching instruction has a relaxable
909 operand. If it does, allocate frag with frag_var and don't
910 do any fixups.
911
912 end-sanitize-v850
913 start-sanitize-d10v
914 Mon Oct 28 10:48:40 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
915
916 * config/tc-d10v.h (md_cleanup): New function. This is needed to
917 write out any buffered instructions when a ".end" is found.
918
919 end-sanitize-d10v
920 Mon Oct 28 10:43:45 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
921
922 * read.c (read_a_source_file): New hook md_cleanup().
923
924 Fri Oct 25 00:01:00 1996 Ian Lance Taylor <ian@cygnus.com>
925
926 * write.c (fix_new_exp): Use make_expr_symbol to build an
927 expression symbol for a complex fixup.
928
929 start-sanitize-v850
930 Thu Oct 24 14:31:04 1996 Jeffrey A Law (law@cygnus.com)
931
932 * config/tc-v850.c (v850_reloc_prefix): Several disgusting
933 hacks to improve parsing of complex hi, lo, zda, etc
934 expressions.
935 (md_assemble): Don't demand and eat a trailing ')' after finding
936 a v850 relocation prefix. Sign extend the constant in a
937 BFD_RELOC_LO16 expression. Do eat a trailing ')' after a complete
938 operand.
939 (parse_cons_expression_v850): Don't eat a trailing ')' after
940 finding a v850 relocation prefix.
941
942 * config/tc-v850.h (TC_PARSE_CONS_EXPRESSION): Define.
943 (TC_CONS_FIX_NEW): Likewise.
944 * config/tc-v850.c (parse_cons_expression_v850): New function.
945 (cons_fix_new_v850): Likewise.
946
947 * config/tc-v850.h (tc_fix_adjustable): Don't adjust TDA relocs.
948
949 end-sanitize-v850
950 Wed Oct 23 18:20:29 1996 Ian Lance Taylor <ian@cygnus.com>
951
952 * config/tc-ppc.c (md_apply_fix3): Give a better warning message
953 for an unknown relocation type.
954
955 start-sanitize-v850
956 Wed Oct 23 16:21:28 1996 Jeffrey A Law (law@cygnus.com)
957
958 * config/tc-v850.c (md_pseudo_table): Add .word; allocates
959 4 bytes of space.
960
961 Tue Oct 22 22:01:25 1996 Jeffrey A Law (law@cygnus.com)
962
963 * config/tc-v850.c (md_assemble): Handle TDAOFF relocs
964 differently for movea & sst/sld insns.
965
966 end-sanitize-v850
967 start-sanitize-d10v
968 Tue Oct 22 17:09:32 1996 Michael Meissner <meissner@tiktok.cygnus.com>
969
970 * config/tc-d10v.c (parallel_ok): Don't allow illegal combinations
971 of instructions.
972
973 end-sanitize-d10v
974 Tue Oct 22 11:28:39 1996 Ian Lance Taylor <ian@cygnus.com>
975
976 * obj.h (struct format_ops): Add frob_file_after_relocs field.
977 * config/obj-multi.h (obj_frob_file_after_relocs): Define.
978 * config/obj-ecoff.c (ecoff_format_ops): Initialize new
979 frob_file_after_relocs field.
980 * config/obj-elf.c (elf_format_ops): Likewise.
981 * config/tc-mips.c: Undefine obj_frob_file_after_relocs before
982 including obj-elf.h.
983
984 Mon Oct 21 11:38:30 1996 Ian Lance Taylor <ian@cygnus.com>
985
986 * config/tc-mips.c (cons_fix_new_mips): Only treat 8 byte reloc
987 specially if not ELF.
988 (md_apply_fix): Handle BFD_RELOC_64.
989 (tc_gen_reloc): Handle BFD_RELOC_64.
990
991 * config/tc-i386.c (md_apply_fix3): Don't increment value for a PC
992 relative reloc when BFD_ASSEMBLER and OBJ_AOUT (more ugly gas
993 reloc hacking).
994
995 * config/obj-aout.h (S_IS_DEFINE): non BFD_ASSEMBLER version:
996 Don't check S_GET_OTHER.
997
998 Fri Oct 18 14:06:26 1996 Ian Lance Taylor <ian@cygnus.com>
999
1000 * config/tc-mips.c (mips_ip): Accept an odd floating point
1001 register with l.s or s.s.
1002
1003 * config/obj-aout.c (obj_pseudo_table): Use obj_aout_type for
1004 .type pseudo-op.
1005 (obj_aout_type): New static function.
1006
1007 Thu Oct 17 17:55:17 1996 Ian Lance Taylor <ian@cygnus.com>
1008
1009 * Makefile.in ($(OBJS)): Depend upon libiberty.h.
1010
1011 start-sanitize-v850
1012 Wed Oct 16 11:28:31 1996 Jeffrey A Law (law@cygnus.com)
1013
1014 * config/tc-v850.c (v850_reloc_prefix): Recognize zdaoff, tdaoff
1015 and sdaoff expressions.
1016
1017 * write.c (fixup_segment): Don't add symbol value to addend if
1018 TC_V850 and OBJ_ELF.
1019 * config/tc-v850.h (tc_fix_adjustable): Don't adjust any
1020 pc-relative fixups.
1021
1022 * config/tc-v850.c (md_pcrel_from): Undo yesterday's changes.
1023 (md_pcrel_from_section): Likewise.
1024 * config/tc-v850.h (MD_PCREL_FROM_SECTION): Likewise.
1025
1026 Tue Oct 15 23:19:00 1996 Jeffrey A Law (law@cygnus.com)
1027
1028 * config/tc-v850.c (md_pcrel_from): Delete unused function.
1029 (md_pcrel_from_section): New function.
1030 * config/tc-v850.h (MD_PCREL_FROM_SECTION): Define.
1031
1032 end-sanitize-v850
1033 Mon Oct 14 13:59:12 1996 Ian Lance Taylor <ian@cygnus.com>
1034
1035 * config/tc-mips.c (load_register): Add cast to offsetT when using
1036 a constant with &~.
1037
1038 Mon Oct 14 11:24:28 1996 Richard Henderson <rth@tamu.edu>
1039
1040 * config/obj-elf.c (elf_frob_file): Move ECOFF debug processing to ...
1041 (elf_frob_file_after_relocs): ... here. New function.
1042 * config/obj-elf.h (obj_from_file_after_relocs): New macro.
1043 * write.c (write_object_file): Call *frob_after_relocs after the
1044 call to write_relocs.
1045
1046 * config/tc-alpha.c: Use new BFD_RELOC_ALPHA_ELF_LITERAL reloc.
1047
1048 * config/tc-alpha.c (load_expression): Don't SET_VALUE on the section
1049 symbol, as this messes up linking. Instead, expand the recursive call
1050 inline and change up the appropriate bits to get the 0x8000 offset
1051 in the reloc addend.
1052
1053 Thu Oct 10 17:30:31 1996 Ian Lance Taylor <ian@cygnus.com>
1054
1055 * config/tc-sparc.h (tc_fix_adjustable): Permit the difference of
1056 two symbols in the same segment to be adjusted.
1057
1058 * configure.in: Don't get confused by CPU-VENDOR-linux-gnu.
1059 * configure: Rebuild.
1060
1061 Thu Oct 10 17:22:18 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1062
1063 * config/tc-ppc.c (ppc_insert_operand): Change most warnings into
1064 errors.
1065 (ppc_elf_validate_fix): Ditto.
1066 (md_assemble): Ditto.
1067 (ppc_tc): Ditto.
1068 (ppc_pe_section): Ditto.
1069 (ppc_frob_symbol): Ditto.
1070
1071 Thu Oct 10 12:05:45 1996 Jeffrey A Law (law@cygnus.com)
1072
1073 * config/mn10300.c (md_assemble): Pass an extra shift count
1074 to mn10300_insert_operand based on the opcode format.
1075 (mn10300_insert_operand): Accept and use extra shift count
1076 parameter.
1077
1078 * config/tc-mn10300.c (md_assemble): Use FMT_* macros for
1079 formats rather than hard-coded constants.
1080
1081 * config/tc-mn10300.c (md_assemble): Format D5 instructions
1082 are 7 bytes long. Write out instructions in big-endian format.
1083
1084 Tue Oct 8 14:56:15 1996 Jeffrey A Law (law@cygnus.com)
1085
1086 * config/tc-mn10300.c (md_assemble): Tweak further so
1087 that all instructions are parsed correctly.
1088
1089 Tue Oct 8 13:02:21 1996 Ian Lance Taylor <ian@cygnus.com>
1090
1091 * as.h: Include libiberty.h.
1092 (xmalloc, xrealloc): Don't declare.
1093 * as.c: Don't include libiberty.h.
1094 * expr.c, read.c, stabs.c, config/obj-coff.c: Likewise.
1095 * config/tc-mips.c: Likewise.
1096 * messages.c: Likewise.
1097 (xstrerror): Don't declare.
1098 * xmalloc.c: Remove.
1099
1100 Mon Oct 7 16:53:23 1996 Jeffrey A Law (law@cygnus.com)
1101
1102 * config/tc-mn10300.h (pre_defined_registers) Remove.
1103 (system_registers, cc_names): Likewise.
1104 (address_registers, data_registers, other_registers): New register
1105 arrays.
1106 (register_name, system_register_name, cc_name): Remove.
1107 (mn10300_reloc_prefix): Likewise.
1108 (data_register_name): New function.
1109 (address_register_name, other_register_name): Likewise.
1110 (md_assemble): Rough cut at parsing operands. Remove lots of
1111 unwanted code.
1112 (md_apply_fix3): Disable for now.
1113
1114 Mon Oct 7 11:38:34 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
1115
1116 * config/tc-m68k.c (select_control_regs): New function, extracted
1117 out of m68k_init_after_args.
1118 (m68k_init_after_args): Use it.
1119 (mri_chip): Use it here as well to update set of allowed control
1120 regs for movec.
1121
1122 Mon Oct 7 11:24:29 1996 Ian Lance Taylor <ian@cygnus.com>
1123
1124 * config/obj-elf.c (elf_begin): New function.
1125 (obj_elf_section): Add the section symbol to the symbol table.
1126 * config/obj-elf.h (obj_begin): Define.
1127 (elf_begin): Declare.
1128 * as.c (perform_an_assembly_pass): Call obj_begin if it is
1129 defined.
1130
1131 Fri Oct 4 18:37:32 1996 Ian Lance Taylor <ian@cygnus.com>
1132
1133 * config/obj-coff.c (fixup_segment): Subtract the section address
1134 from a PC relative reloc if TC_M68K.
1135
1136 Thu Oct 3 15:15:30 1996 Ian Lance Taylor <ian@cygnus.com>
1137
1138 * config/tc-sparc.c (md_pseudo_table): Make .uahalf, .uaword, and
1139 .uaxword available even if not OBJ_ELF.
1140 (md_atof): Remove unused local variable wordP.
1141
1142 Thu Oct 3 00:16:50 1996 Jeffrey A Law (law@cygnus.com)
1143
1144 * config/tc-mn10x00.c, config/tc-mn10x00.h: New files
1145 for Matsushita MN10x00 support.
1146 * configure.in: Recognize mn10x00-*-*
1147 * configure: Rebuilt.
1148
1149 Wed Oct 2 15:54:03 1996 Klaus Kaempf <kkaempf@progis.de>
1150
1151 * obj-evax.h: move openvms definitions from here to tc-alpha.c.
1152 * tc-alpha.c: add support for vms_case_hack like in vax/vms.
1153 (load_expression): track clobbering of base reg before jmp/jsr.
1154 (s_alpha_file): pass case_hack flags and source filename via
1155 symbol table to bfd.
1156 * tc-alpha.h (TC_CONS_FIX_NEW): define
1157
1158 Tue Oct 1 16:16:01 1996 Joel Sherrill <joel@oarcorp.com>
1159
1160 * configure.in (mips-*-rtems*): New target, like mips-*-elf*.
1161 * configure: Rebuild.
1162
1163 Tue Oct 1 12:37:48 1996 Ian Lance Taylor <ian@cygnus.com>
1164
1165 * read.c (s_macro): Warn if a macro has the same name as a
1166 pseudo-op.
1167 (s_space): In m68k MRI mode, align to a word boundary.
1168 * macro.c (define_macro): Add namep parameter. Change all
1169 callers.
1170 * macro.h (define_macro): Update declaration.
1171
1172 * as.c (show_usage): Print bug report address.
1173 (parse_args): Change version printing to match current GNU
1174 standards.
1175 * gasp.c (show_usage): Print bug report address.
1176 (main): Change version printing to match current GNU standards.
1177
1178 * config/tc-m68k.c (init_table): Correct access control unit
1179 register numbers. From Ken Rose <rose@netcom.com>.
1180
1181 * config/tc-alpha.c: Add some static function prototypes.
1182 (alpha_macros): Move to top of file. Make static.
1183 (alpha_num_macros): Move to top of file.
1184
1185 start-sanitize-v850
1186 Tue Oct 1 09:36:19 1996 Stu Grossman (grossman@critters.cygnus.com)
1187
1188 * tc-v850.h: Define LOCAL_LABEL to recognise _.L_* symbols
1189 generated by DWARF.
1190
1191 end-sanitize-v850
1192 Sat Sep 28 03:38:08 1996 Ian Lance Taylor <ian@cygnus.com>
1193
1194 * listing.c (list_symbol_table): Remove bogus code in BFD64 case,
1195 and just call sprintf_vma.
1196
1197 Thu Sep 26 16:04:11 1996 Ian Lance Taylor <ian@cygnus.com>
1198
1199 * expr.c (expr): Change >>= to >> (fix typo). (From meissner).
1200
1201 Tue Sep 24 19:05:08 1996 Ian Lance Taylor <ian@cygnus.com>
1202
1203 * read.c (float_cons): Call md_flush_pending_output if it is
1204 defined.
1205
1206 start-sanitize-d10v
1207 Tue Sep 24 12:22:18 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1208
1209 * config/tc-d10v.c (md_operand): Created. Allows operands to
1210 start with '#'.
1211 * config/tc-d10v.h (md_operand): Undefined.
1212
1213 end-sanitize-d10v
1214 Mon Sep 23 12:13:18 1996 Ian Lance Taylor <ian@cygnus.com>
1215
1216 * config/tc-m68k.c (add_fix): Treat a width of '3' like 'B'.
1217 (md_assemble): A fixup width of '3' means a 1 byte reloc.
1218
1219 Thu Sep 19 12:21:24 1996 Ian Lance Taylor <ian@cygnus.com>
1220
1221 * config/obj-coff.c (fixup_segment): Don't adjust PC relative
1222 reloc for the i960 for a reloc in the same section. This undoes
1223 one of the two changes made Aug 19.
1224
1225 Wed Sep 18 12:11:58 1996 Ian Lance Taylor <ian@cygnus.com>
1226
1227 * config/obj-coff.c (obj_coff_endef): Both versions: Move C_STAT
1228 symbols to the position of the debugging information.
1229
1230 Mon Sep 16 11:41:40 1996 Ian Lance Taylor <ian@cygnus.com>
1231
1232 * expr.c (expr): Always use unsigned right shifts for >>.
1233
1234 Thu Sep 12 10:25:45 1996 James G. Smith <jsmith@cygnus.co.uk>
1235
1236 * config/tc-arm.c (md_apply_fix3): Update two thumb instruction
1237 slots when processing BL fixups.
1238
1239 * config/tc-arm.c (output_inst): Ensure Thumb BL fixup is marked
1240 on the first half of the instruction.
1241
1242 Wed Sep 11 00:09:35 1996 Ian Lance Taylor <ian@cygnus.com>
1243
1244 * ecoff.c (ecoff_stab): Create an expression symbol for a complex
1245 stabs expression, rather than giving an error.
1246
1247 * ecoff.c (ecoff_new_file): Don't do anything if we are still in
1248 the same file.
1249
1250 Tue Sep 10 11:45:37 1996 Ian Lance Taylor <ian@cygnus.com>
1251
1252 * config/tc-mips.c (append_insn): Fill in the value for a constant
1253 jump, rather than creating a reloc.
1254
1255 Mon Sep 9 10:57:42 1996 Ian Lance Taylor <ian@cygnus.com>
1256
1257 * config/tc-mips.c (append_insn): Don't swap an instruction which
1258 sets a condition code with an instruction which uses a condition
1259 code.
1260 (mips_ip): In cases 'N' and 'M', look for $fccN rather than an
1261 immediate value.
1262
1263 * config/tc-mips.c (md_begin): Recognize r5000 for cpu.
1264 (mips_ip): Give a better error message if the ISA level is wrong.
1265 (md_parse_option): Recognize -mcpu=[v][r]5000.
1266
1267 Sat Sep 7 13:25:55 1996 James G. Smith <jsmith@cygnus.co.uk>
1268
1269 * config/tc-mips.c (COUNT_TOP_ZEROES): Added macro to count
1270 leading zeroes.
1271 (load_register): Ensure hi32 bits are not lost during lo32bit
1272 processing. Fix shift offset that was overflowing into the next
1273 instruction field. Add code to generate shorter sequences for
1274 constants with a single contiguous seqeuence of ones.
1275
1276 start-sanitize-d10v
1277 Fri Sep 6 17:07:12 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1278
1279 * config/tc-d10v.c (d10v_dot_word): New function to support
1280 "@word" with the word pseudo-op.
1281 (md_apply_fix3): Cleanup and changes to support correct sizes
1282 for 16 and 18-bit relocs.
1283
1284 end-sanitize-d10v
1285 Fri Sep 6 16:00:29 1996 Doug Evans <dje@canuck.cygnus.com>
1286
1287 * configure.in (sparc-*-aout): Set `em'.
1288 * configure: Regenerated.
1289 * config/te-sparcaout.h: New file.
1290 * config/tc-sparc.h (TARGET_BYTES_BIG_ENDIAN): Define.
1291 Ifdef TE_SPARCOUT define TARGET_FORMAT and SPARC_BIENDIAN.
1292 * config/tc-sparc.c (INSN_BIG_ENDIAN): New macro.
1293 (SPECIAL_CASE_{SETSW,SETX}): Define.
1294 ({NOP,OR,FMOVS,SETHI,SLLX,SRA}_INSN): Define.
1295 (md_begin): Delete setting of `target_big_endian'.
1296 (output_insn): New function.
1297 (md_assemble): Rewrite. Add `setx' support.
1298 (sparc_ip): Handle `0' operand char. Recognize setuw, setsw, setx
1299 special cases.
1300 (md_atof): Add little endian support.
1301 (md_number_to_chars): Likewise.
1302 (md_apply_fix): Likewise.
1303 (md_longopts): Recognize -EL,-EB ifdef SPARC_BIENDIAN.
1304 (md_parse_option): Likewise.
1305 (md_show_usage): Print -EL, -EB ifdef SPARC_BIENDIAN.
1306
1307 Thu Sep 5 13:40:29 1996 Ian Lance Taylor <ian@cygnus.com>
1308
1309 * ecoff.c (ecoff_new_file): New function.
1310 * ecoff.h (ecoff_new_file): Declare.
1311 * config/obj-ecoff.h (obj_app_file): Define.
1312
1313 Thu Sep 5 13:39:25 1996 Richard Henderson <rth@tamu.edu>
1314
1315 * config/tc-alpha.c (load_expression): Bias the .lit8 section
1316 symbol by 32k so that our 16-bit signed offset can address the
1317 entire chunk. Reported by <matt@lkg.dec.com>.
1318
1319 Wed Sep 4 10:23:20 1996 Ian Lance Taylor <ian@cygnus.com>
1320
1321 * config/tc-mips.c (load_register): Remove unused variable tmp.
1322
1323 Wed Sep 4 11:24:29 1996 James G. Smith <jsmith@cygnus.co.uk>
1324
1325 * config/tc-mips.c (load_register): Remove unnecessary code that
1326 was causing the high 32bits of 64bit constants to be lost.
1327
1328 start-sanitize-d10v
1329 Tue Sep 3 13:52:56 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1330
1331 * config/tc-d10v.c: Added changes to support function
1332 pointers and "@word" syntax.
1333
1334 end-sanitize-d10v
1335 start-sanitize-v850
1336 Tue Sep 3 11:57:18 1996 Jeffrey A Law (law@cygnus.com)
1337
1338 * config/tc-v850.c: Remove commented out and #if 0'd code.
1339 (v850_reloc_prefix): Provide prototype.
1340 (postfix, get_reloc, build_insn): Remove prototypes for nonexistant
1341 functions.
1342 (md_begin, md_assemble, md_apply_fix3): Remove unused variables.
1343 (md_assemble): Add default to case statement.
1344
1345 Sat Aug 31 16:03:00 1996 Jeffrey A Law (law@cygnus.com)
1346
1347 * config/tc-v850.c (md_assemble): Compute size of the instrction
1348 from the opcode.
1349
1350 * config/tc-v850.c (md_apply_fix3): Do simple byte, short and
1351 word fixups too.
1352
1353 Fri Aug 30 23:50:08 1996 Jeffrey A Law (law@cygnus.com)
1354
1355 * config/tc-v850.c (md_apply_fix3): Use little endian get/put
1356 routines to fetch/store the updated instruction from/to memory.
1357 (v850_insert_operand): If the operand has a specialized insert
1358 routine, call it.
1359
1360 Fri Aug 30 18:35:26 1996 J.T. Conklin <jtc@hippo.cygnus.com>
1361
1362 * config/tc-v850.c (reg_name_search): Align calling convention to
1363 be like identical function found in tc-ppc.c.
1364 (get_reloc): Removed.
1365 (v850_reloc_prefix): New function, parse lo(), hi() and hi0().
1366 (md_assemble): emit fixups.
1367 (md_pcrel_from): renamed from md_pcrel_from_section, emit proper
1368 displacement.
1369 (md_apply_fix3): handle fixups/relocs.
1370 * config/tc-v850.h (MD_PCREL_FROM_SECTION): Removed definition.
1371
1372 end-sanitize-v850
1373 Fri Aug 30 18:12:00 1996 Ian Lance Taylor <ian@cygnus.com>
1374
1375 Add SH ELF support.
1376 * configure.in (sh-*-elf*): New target.
1377 * config/tc-sh.h (TARGET_ARCH): Define.
1378 (WORKING_DOT_WORD): Define.
1379 (TC_COFF_FIX2RTYPE): Only define if OBJ_COFF.
1380 (BFD_ARCH, COFF_MAGIC, TC_COUNT_RELOC): Likewise.
1381 (TC_RELOC_MANGLE, tc_coff_symbol_emit_hook): Likewise.
1382 (DO_NOT_STRIP, NEED_FX_R_TYPE, TC_KEEP_FX_OFFSET): Likewise.
1383 (TC_COFF_SIZEMACHDEP, tc_frob_file): Likewise.
1384 (SUB_SEGMENT_ALIGN): Likewise.
1385 (RELOC_32): Don't define.
1386 (tc_frob_file_before_adjust): Define if BFD_ASSEMBLER.
1387 (target_big_endian): Declare if OBJ_ELF.
1388 (TARGET_FORMAT): Define if OBJ_ELF.
1389 * config/tc-sh.c: Use BFD reloc codes instead of SH COFF reloc
1390 numbers throughout.
1391 (tc_crawl_symbol_chain): Only define if OBJ_COFF.
1392 (tc_headers_hook, tc_coff_sizemachdep): Likewise.
1393 (struct sh_count_relocs): Define.
1394 (sh_count_relocs): New static function, broken out of
1395 sh_frob_file. Add BFD_ASSEMBLER code.
1396 (sh_frob_section): Likewise.
1397 (sh_frob_file): Call sh_frob_section.
1398 (md_convert_frag): If BFD_ASSEMBLER, change type of headers, and
1399 call section_symbol rather than seg_info (seg)->dot.
1400 (md_section_align): Add OBJ_ELF version.
1401 (SWITCH_TABLE_CONS): Define.
1402 (SWITCH_TABLE): Use SWITCH_TABLE_CONS.
1403 (md_apply_fix): Change parameter types if BFD_ASSEMBLER. Only
1404 handle fx_r_type == 0 if not BFD_ASSEMBLER. Return 0 if
1405 BFD_ASSEMBLER.
1406 (struct reloc_map): Define if not BFD_ASSEMBLER.
1407 (coff_reloc_map): Likewise.
1408 (sh_coff_reloc_mangle): Use coff_reloc_map to convert fx_r_type.
1409 (tc_gen_reloc): New function if BFD_ASSEMBLER.
1410 * write.c (write_relocs): Ifdef out fx_where test which triggers
1411 inappropriately for SH ELF.
1412 (write_object_file): Call tc_frob_file_before_adjust and
1413 obj_frob_file_before_adjust if they are defined.
1414
1415 * write.c (write_object_file): Use BFD_RELOC_16, not
1416 BFD_RELOC_NONE, when calling fix_new_exp for a broken word.
1417
1418 * read.c (emit_expr): Fix conversion of byte count to BFD reloc
1419 code.
1420
1421 start-sanitize-d10v
1422 Fri Aug 30 14:47:38 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1423
1424 * config/tc-d10v.c (find_opcode): Fix problem with calculating
1425 branch sizes in across sections.
1426
1427 end-sanitize-d10v
1428 start-sanitize-v850
1429 Fri Aug 30 00:44:13 1996 Jeffrey A Law (law@cygnus.com)
1430
1431 * config/tc-850.c (md_assemble): Handle hi() correctly. Handle
1432 hi0() too.
1433
1434 Wed Aug 28 23:11:08 1996 Jeffrey A Law (law@cygnus.com)
1435
1436 * config/tc-v850.c (md_begin): Deal with end of opcode
1437 table marker.
1438
1439 end-sanitize-v850
1440 start-sanitize-d10v
1441 Wed Aug 28 19:20:04 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1442
1443 * config/tc-d10v.c (find_opcode): Fix a bug which could generate
1444 the wrong opcode for cases like st2w where there are many forms
1445 of the same instruction.
1446
1447 end-sanitize-d10v
1448 Tue Aug 27 13:53:22 1996 Ian Lance Taylor <ian@cygnus.com>
1449
1450 * expr.c (operand): If md_parse_name is defined, call it before
1451 calling symbol_find_or_make.
1452 * config/tc-ppc.h (md_parse_name): Define.
1453 (ppc_parse_name): Declare.
1454 * config/tc-ppc.c (reg_name_search): Add regs and regcount
1455 parameters.
1456 (register_name): Update call to reg_name_search.
1457 (cr_operand): New static variable.
1458 (cr_names): New static const array.
1459 (ppc_parse_name): New function.
1460 (md_assemble): If PPC_OPERAND_CR is set in the operand flags, set
1461 cr_operand before calling expression.
1462
1463 Tue Aug 27 09:05:50 1996 Jeffrey A Law (law@cygnus.com)
1464
1465 * config/tc-hppa.c (tc_gen_reloc): Add new argument to
1466 hppa_gen_reloc_type call.
1467
1468 start-sanitize-d10v
1469 Mon Aug 26 18:24:51 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1470
1471 * config/tc-d10v.c: Fixed ".word". Fixed problem with range checking
1472 on addresses. Improved error messages.
1473 * doc/c-d10v.texi: Added docs for register pairs.
1474
1475 Mon Aug 26 13:39:27 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1476
1477 * config/tc-d10v.c (parallel_ok): Fix bug in parallel
1478 checking code.
1479
1480 end-sanitize-d10v
1481 Mon Aug 26 14:38:22 1996 Ian Lance Taylor <ian@cygnus.com>
1482
1483 * ecoff.c (init_file): Initialize fMerge to 1.
1484 (add_file): Restore old file merging code, but only merge files if
1485 fMerge is set.
1486 (ecoff_directive_loc): Clear fMerge field of current file.
1487 (ecoff_generate_asm_lineno): Likewise.
1488
1489 start-sanitize-d10v
1490 Fri Aug 23 11:40:47 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1491
1492 * doc/c-d10v.texi: Fix typo.
1493
1494 end-sanitize-d10v
1495 start-sanitize-v850
1496 Fri Aug 23 10:41:32 1996 Jeffrey A Law (law@cygnus.com)
1497
1498 * config/tc-v850.c (md_assemble): Correct bit masking for
1499 hi and lo expressions.
1500
1501 * config/tc-v850.c (md_assemble): Rough cut at demanding
1502 "ep" or "r30" in sst and sld instructions.
1503 (md_apply_fix3): Don't abort. Just warn that we don't
1504 have relocs yet.
1505
1506 * config/tc-v850.c (CC_NAME_CNT): Define.
1507 (cc_name): New function.
1508 (md_assemble): Handle V850_OPERAND_CC correctly.
1509
1510 * config/tc-v850.c (md_assemble): Don't forget to initialize
1511 "insn"!
1512
1513 * config/tc-v850.c (reg_name_search): Generalize to search
1514 any given register table.
1515 (register_name): Pass appropriate table and size to reg_name_search.
1516 (system_register_name): New function.
1517 (SYSREG_NAME_CNT): Define.
1518 (md_assemble): Handle operands which are system registers.
1519
1520 * config/tc-v850.c (md_assemble): If we find a register, but the
1521 opcode doesn't want a register, then we don't have a match.
1522 (md_assemble): Get size of the instruction from the opcode table.
1523
1524 end-sanitize-v850
1525 Thu Aug 22 10:20:30 1996 Ian Lance Taylor <ian@cygnus.com>
1526
1527 * configure.in: Set and substitute HLDENV.
1528 * configure: Rebuild.
1529 * Makefile.in (HLDENV): New variable.
1530 (as.new): Use $(HLDENV).
1531
1532 * ecoff.c (ecoff_directive_endef): Avoid a division by zero error
1533 if an array dimension is not known.
1534
1535 start-sanitize-d10v
1536 Thu Aug 22 10:50:00 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1537
1538 * config/tc-d10v.c: Fix a reloc bug caused by my last change.
1539 * doc/c-d10v.texi: Cleanup.
1540
1541 end-sanitize-d10v
1542 start-sanitize-v850
1543 Tue Aug 20 15:15:16 1996 J.T. Conklin <jtc@hippo.cygnus.com>
1544
1545 * config/tc-v850.c: New file.
1546 * config/tc-v850.h: New file.
1547 * configure (v850-*-elf): New target.
1548 * configure.in (v850-*-elf): New target.
1549
1550 end-sanitize-v850
1551 start-sanitize-d10v
1552 Wed Aug 21 15:50:54 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1553
1554 * doc/c-d10v.texi: New file.
1555 * doc/all.texi: Added D10V stuff.
1556 * doc/as.texinfo: Added D10V stuff.
1557
1558 Tue Aug 20 14:10:02 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1559
1560 * config/tc-d10v.c: All references to defined symbols should
1561 now use the optimal instruction. .float and .double now work.
1562
1563 end-sanitize-d10v
1564 Mon Aug 19 14:41:36 1996 Ian Lance Taylor <ian@cygnus.com>
1565
1566 * config/obj-coff.c (fixup_segment): Adjust PC relative reloc by
1567 section address for the i960 as is done for the i386.
1568
1569 Thu Aug 15 16:37:59 1996 Stan Shebs <shebs@andros.cygnus.com>
1570
1571 * mpw-config.in: Add wildcards for config matching, add mips-*-*
1572 case, forward-include bfd/elf-bfd.h.
1573
1574 start-sanitize-d10v
1575 Thu Aug 15 13:24:30 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1576
1577 * config/tc-d10v.c: Add additional information to the opcode
1578 table to help determinine which instructions can be done
1579 in parallel.
1580
1581 end-sanitize-d10v
1582 Thu Aug 15 17:01:31 1996 James G. Smith <jsmith@cygnus.co.uk>
1583
1584 * config/tc-arm.c: Major changes to add Thumb support, with lots
1585 of change input from <rearnsha@armltd.co.uk>.
1586 Reverted to INSN_SIZE macro, rather than insn_size variable.
1587 (insns): Added ARM "bx" instruction support.
1588 (tinsns): Added Thumb instruction definition structure.
1589 (arm_tops_hsh): Added hash structure for Thumb opcodes.
1590 (md_pseudo_table): Added ".arm", ".thumb" and ".code" pseudo-ops.
1591 (opcode_select,s_arm,s_thumb,s_code): Added.
1592 (decode_shift): Allow upper-case RRX.
1593 (do_ldst): Simpler halfword support.
1594 (do_ldmstm): Improved.
1595 (reg_list, do_bx, thumb_reg, thumb_add_sub, thumb_shift,
1596 thumb_mov_compare, thumb_load_store, do_t_arit, do_t_add,
1597 do_t_asr, do_t_branch, do_t_bx, do_t_compare, do_t_ldmstm,
1598 do_t_ldrb, do_t_ldrh, do_t_lds, do_t_lsl, do_t_lsr, do_t_mov,
1599 do_t_push_pop, do_t_str, do_t_strb, do_t_strh, do_t_sub, do_t_swi,
1600 do_t_adr): Added.
1601 (md_apply_fix3): Add support for BFD_RELOC_ARM_THUMB_* relocations.
1602 (md_parse_option): Add support for -mthumb.
1603 (md_show_usage): Updated to reflect new command line option.
1604 (arm_data_in_code, arm_canonicalize_symbol_name): Added.
1605 * config/tc-arm.h: Provide TC_FIX_TYPE to allow private ARM
1606 fragment information to be held.
1607
1608 Thu Aug 15 16:12:00 1996 Richard Earnshaw (rearnsha@armltd.co.uk)
1609
1610 * tc-arm.c (md_apply_fix3): Also set fixP->fx_done if fx_addsy is
1611 non-null, but is a constant.
1612 (fix_new_arm): Call make_expr_symbol to make the expression symbol
1613 so that error reporting will work correctly.
1614
1615 Wed Aug 14 10:37:21 1996 Ian Lance Taylor <ian@cygnus.com>
1616
1617 * config/tc-i386.c (tc_i386_fix_adjustable): Don't adjust relocs
1618 against weak symbols.
1619
1620 Tue Aug 13 17:39:24 1996 Ian Lance Taylor <ian@cygnus.com>
1621
1622 * config/tc-ppc.h (TC_FORCE_RELOCTION): Define if OBJ_XCOFF.
1623 (ppc_force_relocation): Declare if OBJ_XCOFF.
1624 * config/tc-ppc.c (ppc_force_relocation): New function if
1625 OBJ_XCOFF.
1626
1627 Mon Aug 12 16:49:43 1996 Ian Lance Taylor <ian@cygnus.com>
1628
1629 * config/tc-mips.h (BYTE_ORDER): Don't define. No longer used.
1630
1631 start-sanitize-d10v
1632 Fri Aug 9 17:48:28 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1633
1634 * config/tc-d10v.c: Fix problem with relocs.
1635
1636 end-sanitize-d10v
1637 Fri Aug 9 14:16:14 1996 Ian Lance Taylor <ian@cygnus.com>
1638
1639 * config/tc-sh.c (sh_do_align): If not BFD_ASSEMBLER, always align
1640 with nops if not in data_section or bss_section.
1641
1642 Thu Aug 8 12:32:56 1996 Klaus Kaempf <kkaempf@progis.de>
1643
1644 Add support for openVMS/Alpha.
1645 * as.h (PRINTF_LIKE): Don't define if VMS, for now.
1646 * config/obj-evax.c: New file.
1647 * config/obj-evax.h: New file.
1648 * config/tc-alpha.c: Add support for EVAX format if OBJ_EVAX is
1649 defined.
1650 * config/tc-alpha.h: Add support for EVAX format if OBJ_EVAX is
1651 defined. Add case for bfd_target_evax_flavour.
1652 * config/vms-a-conf.h: New file.
1653 * conf-a-gas.com: New file.
1654 * configure.in: Add target alpha-*-*vms*.
1655 * configure: Rebuild.
1656 * makefile.vms: New file.
1657 * read.c (s_lcomm): Align bss_seg on 8 byte boundary if OBJ_EVAX.
1658 Don't call ffs on openVMS/Alpha.
1659
1660 Wed Aug 7 14:19:03 1996 Philippe De Muyter <phdm@info.ucl.ac.be>
1661
1662 * configure.in: Make GAS_CHECK_DECL_NEEDED include <string.h> or
1663 <strings.h> if they exist. Call GAS_CHECK_DECL_NEEDED on strstr
1664 and sbrk.
1665 * acconfig.h (NEED_DECLARATION_STRSTR): New macro.
1666 (NEED_DECLARATION_SBRK): New macro.
1667 * configure, conf.in: Rebuild.
1668 * as.h: Only include <strings.h> if HAVE_STRINGS_H.
1669 (strstr): Declare if NEED_DECLARATION_STRSTR.
1670 * as.c: If HAVE_SBRK and NEED_DECLARATION_SBRK, declare sbrk.
1671
1672 Wed Aug 7 11:50:26 1996 Ian Lance Taylor <ian@cygnus.com>
1673
1674 * symbols.c (resolve_symbol_value): Handle addition or subtraction
1675 by a constant before entering the main switch. Reject attempts to
1676 apply an arithmetic function to non-absolute symbols, except for
1677 the special case of subtraction of two symbols in the same
1678 section.
1679
1680 * config/tc-mips.c (md_section_align): Do align if OBJ_ELF, but
1681 not to more than a 16 byte boundary.
1682
1683 * config/tc-i386.c (tc_gen_reloc): Accept all relocs; remove
1684 #ifndef OBJ_ELF lines. From Eric Valette <valette@crf.canon.fr>.
1685 (tc_gen_reloc): If out of memory call as_fatal rather than
1686 assert. If no howto found, call as_bad_where rather than
1687 as_fatal. Change the error message slightly. Set howto to a
1688 non-NULL value in order to keep going.
1689
1690 start-sanitize-d10v
1691 Tue Aug 6 12:58:03 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1692
1693 * config/tc-d10v.c: Added code to support 32-bit fixups for stabs.
1694
1695 end-sanitize-d10v
1696 Tue Aug 6 11:15:26 1996 Jeffrey A Law (law@cygnus.com)
1697
1698 * config/tc-h8300.c (get_specific): New operand "size" derived
1699 from ".b", ".w" and ".l" extensions. All callers changed. If
1700 the base instruction has no operands, then use the size to
1701 determine which specific instruction to use.
1702
1703 Mon Aug 5 14:21:10 1996 Ian Lance Taylor <ian@cygnus.com>
1704
1705 * config/tc-i960.c (mem_fmt): Call parse_expr before emit.
1706
1707 Fri Aug 2 11:23:31 1996 Ian Lance Taylor <ian@cygnus.com>
1708
1709 * config/tc-mips.c (md_section_align): Don't change addr if
1710 OBJ_ELF.
1711
1712 Thu Aug 1 23:51:52 1996 Jeffrey A Law (law@cygnus.com)
1713
1714 * config/tc-hppa.c: Revert yesterday's changes.
1715
1716 start-sanitize-d10v
1717 Wed Jul 31 14:46:11 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1718
1719 * config/tc-d10v.c: Disable range checking on 16-bit values.
1720
1721 end-sanitize-d10v
1722 Wed Jul 31 16:27:19 1996 Ian Lance Taylor <ian@cygnus.com>
1723
1724 * config/tc-m68k.c (m68k_ip): Set ok_arch for every instruction,
1725 not just the ones that don't match.
1726
1727 start-sanitize-d10v
1728 Wed Jul 31 11:45:15 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1729
1730 * config/tc-d10v.c: Fixed bugs in short relocs and range checking.
1731
1732 end-sanitize-d10v
1733 Wed Jul 31 15:41:42 1996 James G. Smith <jsmith@cygnus.co.uk>
1734
1735 * config/tc-arm.c: Changed INSN_SIZE to variable insn_size, as
1736 pre-cursor to adding Thumb support. Also added cpu_variant flag
1737 information to each of the asm_flg structures.
1738 (md_parse_option): Updated ARM7 parsing to allow 't' for
1739 thumb/halfword support, aswell as 'm' for long multiply.
1740 (md_show_usage): Updated help message.
1741 (md_assemble): Check that instruction flags are applicated to the
1742 current cpu variant.
1743 (md_apply_fix3, tc_gen_reloc): Add BFD_RELOC_ARM_OFFSET_IMM8 and
1744 BFD_RELOC_ARM_HWLITERAL relocation support for new halfword and
1745 signextension instructions.
1746 (do_ldst): Generate halfword and signextension variants if
1747 mnemonic flags match.
1748 (ldst_extend): Do not allow shifts in the offset field of halfword
1749 or signextension instructions.
1750 (validate_offset_imm): Provide check on halfword and signextension
1751 immediate range.
1752 (add_to_lit_pool): Merge identical literal pool values.
1753
1754 Tue Jul 30 14:28:23 1996 Jeffrey A Law (law@cygnus.com)
1755
1756 * config/tc-hppa.c (selector_table): Add 'E' selector.
1757 (cons_fix_new_hppa): Don't coke on e_esel.
1758 (tc_gen_reloc, SOM version): Handle R_COMP2 when used
1759 to help generate exception handling tables.
1760 (md_apply_fix): Don't try to apply fixups with an e_esel
1761 selector.
1762 (hppa_fix_adjustable): Fixups with e_esel selectors
1763 are not adjustable.
1764
1765 Tue Jul 30 15:51:41 1996 Ian Lance Taylor <ian@cygnus.com>
1766
1767 * config/tc-sparc.c (md_pseudo_table): Add 2byte, 4byte, and 8byte
1768 pseudo-ops.
1769
1770 start-sanitize-d10v
1771 Fri Jul 26 11:43:03 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1772
1773 * config/tc-d10v.c: Added lots of error checking. Added hacks
1774 to support accumulator shifts.
1775
1776 end-sanitize-d10v
1777 Fri Jul 26 11:56:08 1996 Ian Lance Taylor <ian@cygnus.com>
1778
1779 * symbols.c (S_SET_EXTERNAL): Let .weak override.
1780 (S_CLEAR_EXTERNAL): Likewise.
1781 (S_SET_WEAK): Remove error; just let .weak override.
1782
1783 start-sanitize-d10v
1784 Thu Jul 25 15:22:51 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1785
1786 * config/tc-d10v.c (md_assemble): Now handles multiline
1787 instructions.
1788
1789 Thu Jul 25 12:03:33 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1790
1791 * config/tc-d10v.c: Fix packaging bug. Added range checking.
1792 Added kludge for divs instruction. Fixed minor problem with
1793 multiple text sections.
1794 * config/tc-d10v.h (d10v_cleanup): Change prototype.
1795
1796 Tue Jul 23 10:49:36 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1797
1798 * config/tc-d10v.c (md_apply_fix3): Fix all instruction
1799 addresses to be right-shifted by 2.
1800
1801 Mon Jul 22 11:32:36 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1802
1803 * config/tc-d10v.c: Many changes to get relocs working.
1804 (register_name): No longer creates a symbol for register names.
1805 (pre_defined_registers): moved to opcodes/d10v-opc.c.
1806 (d10v_insert_operand): Now works correctly for either container.
1807 * config/tc-d10v.h (d10v_cleanup): Declare.
1808
1809 end-sanitize-d10v
1810 Mon Jul 22 14:01:33 1996 Ian Lance Taylor <ian@cygnus.com>
1811
1812 * config/tc-mips.c (tc_gen_reloc): BFD_RELOC_PCREL_HI16_S and
1813 BFD_RELOC_PCREL_LO16 are expected to be PC relative.
1814
1815 Mon Jul 22 12:46:55 1996 Richard Henderson <rth@tamu.edu>
1816
1817 * tc-alpha.c: Patches to track current minimum alignment to reduce
1818 the number of fragments created with frag_align.
1819 (alpha_current_align): New static variable.
1820 (s_alpha_text): Reset alignment to 0.
1821 (s_alpha_data, s_alpha_rdata, s_alpha_sdata): Likewise.
1822 (s_alpha_stringer, s_alpha_space): New functions.
1823 (s_alpha_cons, alpha_flush_pending_output): Remove functions.
1824 (alpha_cons_align): New function to replace both of them.
1825 (emit_insn): Only align if alpha_current_align is less than 2;
1826 reset alpha_current_align to 2.
1827 (s_alpha_gprel32): Likewise.
1828 (s_alpha_section): New function. Basically duplicate the other
1829 alpha section change hooks. Only define for ELF.
1830 (s_alpha_float_cons): Simplify alignment handling.
1831 (md_pseudo_table): Only define "rdata" and "sdata" if OBJ_ECOFF.
1832 If OBJ_ELF, define "section", "section.s", "sect", and "sect.s".
1833 Don't define the s_alpha_cons pseudo-ops. Do define
1834 s_alpha_stringer and s_alpha_space pseudo-ops.
1835 (alpha_align): Skip if less than current default alignment. Set
1836 default alignment.
1837 * tc-alpha.h (md_flush_pending_output): Remove.
1838 (md_cons_align): Add.
1839
1840 * tc-alpha.c: Add oodles of function description comments.
1841 (md_bignum_to_chars): Remove; there are no callers.
1842 (md_show_usage): Mention some more variants.
1843
1844 Thu Jul 18 15:54:54 1996 Ian Lance Taylor <ian@cygnus.com>
1845
1846 From Andrew Gierth <ANDREWG@microlise.co.uk>:
1847 * configure.in (sparc-*-sysv4*): New target.
1848 * configure: Rebuild.
1849
1850 * config/tc-sparc.c (md_pseudo_table): Change uahalf, uaword, and
1851 uaxword to use s_uacons.
1852 (sparc_no_align_cons): New static variable.
1853 (s_uacons): New static function.
1854 (sparc_cons_align): If sparc_no_align_cons is set, just clear it
1855 and return.
1856
1857 * config/tc-sparc.c (s_common): Remove unused label allocate_bss.
1858
1859 * configure.in: Add mips-*-irix6* target. Handle Irix 6 like Irix
1860 5 with regard to shared libraries.
1861 * configure: Rebuild.
1862
1863 * config/tc-m68k.c (m68k_ip): Use the correct length when
1864 allocating space for the unsupported architecture error message.
1865
1866 start-sanitize-d10v
1867 Thu Jul 18 12:57:10 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1868
1869 * configure.in (d10v-*-*): Allow d10v-*-*, don't require d10v-*-elf*.
1870
1871 Wed Jul 17 14:25:13 1996 Martin M. Hunt <hunt@pizza.cygnus.com>
1872
1873 * config/tc-d10v.c: New file.
1874 * config/tc-d10v.h: New file.
1875 * configure (d10v-*-elf): New target.
1876 * configure.in (d10v-*-elf): New target.
1877 end-sanitize-d10v
1878
1879 Fri Jul 12 20:54:19 1996 Michael Meissner <meissner@tiktok.cygnus.com>
1880
1881 * config/tc-ppc.c (md_parse_option): Recognize -K PIC.
1882
1883 Wed Jul 10 12:39:08 1996 Richard Henderson <rth@tamu.edu>
1884
1885 * config/tc-alpha.c (alpha_align): Change fill parameter
1886 to a pointer. Take NULL as 0 or nop depending on section. Change
1887 all callers.
1888 (s_alpha_align): Rename local variables.
1889
1890 * doc/as.texinfo (.align): Document action of omitted
1891 fill parameter.
1892
1893 Wed Jul 10 00:23:30 1996 Ian Lance Taylor <ian@cygnus.com>
1894
1895 * config/tc-ppc.c (md_apply_fix3): Give a useful error message
1896 when an unsupported PC relative reloc is seen, rather than calling
1897 abort.
1898
1899 * app.c (do_scrub_chars): Remove not_cpp_line local variable.
1900 Instead, check state when '#' comment is seen.
1901
1902 Mon Jul 8 14:11:49 1996 Ian Lance Taylor <ian@cygnus.com>
1903
1904 * config/tc-mips.c (mips_regmask_frag): Only define if OBJ_ELF or
1905 OBJ_MAYBE_ELF.
1906 (tc_gen_reloc): If fixup was changed to be PC relative, change
1907 reloc type accordingly. Use name of reloc in error message.
1908
1909 * as.h: Don't define const or volatile.
1910 * flonum.h: Don't define const.
1911
1912 * config/tc-m68k.c (tc_gen_reloc): Change the code appropriately
1913 if fx_pcrel is set. Correct setting the addend case in the
1914 OBJ_ELF case (from Andreas Schwab
1915 <schwab@issan.informatik.uni-dortmund.de>).
1916 (md_show_usage): Correct -mfc5200 to -m5200.
1917
1918 Fri Jul 5 10:32:58 1996 J.T. Conklin <jtc@rtl.cygnus.com>
1919
1920 * doc/c-m68k.texi: Document -m5200 flag.
1921 * doc/as.texinfo: Likewise.
1922
1923 * config/tc-m68k.c (m68k_ip): The coldfire does not support 8x
1924 scale factor.
1925
1926 Fri Jul 5 11:07:24 1996 Ian Lance Taylor <ian@cygnus.com>
1927
1928 * symbols.c (S_SET_EXTERNAL): Change as_warn to as_bad.
1929 (S_CLEAR_EXTERNAL, S_SET_WEAK): Likewise.
1930
1931 Thu Jul 4 11:59:46 1996 Ian Lance Taylor <ian@cygnus.com>
1932
1933 * Makefile.in (VERSION): Set to cygnus-2.7.1.
1934
1935 * Released binutils 2.7.
1936
1937 Thu Jul 4 10:11:33 1996 James G. Smith <jsmith@cygnus.co.uk>
1938
1939 * config/tc-mips.c (mips_ip): Only perform range check when
1940 dealing with O_constant expressions.
1941
1942 Wed Jul 3 15:02:21 1996 J.T. Conklin <jtc@rtl.cygnus.com>
1943
1944 * m68k-parse.h (m68k_register): Add new coldfile control
1945 registers.
1946
1947 * config/tc-m68k.c (mcf5200_control_regs): New variable,
1948 array of control registers for the coldfire.
1949 (cpu_of_arch): Added mcf5200.
1950 (archs): Added mcf5200.
1951 (init_table): Add new control registers.
1952 (m68k_ip): Added support for new control registers.
1953 (m68k_init_after_args): Likewise.
1954
1955 * config/tc-m68k.c (md_show_usage): Add -m5200 to usage text.
1956
1957 Wed Jul 3 16:05:50 1996 Ian Lance Taylor <ian@cygnus.com>
1958
1959 * read.h (is_it_end_of_statement): Declare.
1960 * read.c (is_it_end_of_statement): Remove declaration.
1961
1962 * config/tc-ppc.c (ppc_elf_suffix): Correct parenthesization of ||
1963 within &&.
1964 (md_assemble): Fix handling of @l with an unsigned constant. Add
1965 default case to reloc switch.
1966
1967 * config/tc-i386.h (AOUT_MACHTYPE): Define as 0 if TE_386BSD.
1968
1969 Based on patches from Tom Quiggle <quiggle@sgi.com>:
1970 * ecoff.c (last_lineno): New static variable.
1971 (add_procedure): Set last_lineno.
1972 (ecoff_directive_loc): Likewise.
1973 (ecoff_generate_asm_lineno): Likewise.
1974 (ecoff_fix_loc): New function.
1975 * ecoff.h (ecoff_fix_loc): Declare.
1976 * config/tc-mips.c (append_insn): When inserting nops, and using
1977 ECOFF debugging, call ecoff_fix_loc.
1978
1979 Tue Jul 2 23:02:12 1996 Jeffrey A Law (law@cygnus.com)
1980
1981 * config/tc-h8300.c (build_bytes): If an operand type is
1982 marked as SRC_IN_DST retrieve it from the "destination" op.
1983
1984 Sat Jun 29 13:38:31 1996 Ian Lance Taylor <ian@cygnus.com>
1985
1986 * configure.in (arm-*-riscix*): Set emulation to riscix.
1987 * configure: Rebuild.
1988 * config/te-riscix.h: New file to define TE_RISCIX.
1989
1990 * config/tc-sh.h (SUB_SEGMENT_ALIGN): Define.
1991
1992 Fri Jun 28 15:14:31 1996 Ian Lance Taylor <ian@cygnus.com>
1993
1994 * Makefile.in (config.status): Just run config.status as other
1995 tools do.
1996
1997 Fri Jun 28 11:09:38 1996 Stan Shebs <shebs@andros.cygnus.com>
1998
1999 * mpw-config.in (TARGET_OS): Add definition to conf.
2000
2001 Thu Jun 27 20:39:40 1996 James G. Smith <jsmith@cygnus.co.uk>
2002
2003 * config/tc-mips.c (append_insn): Parenthesize
2004 cop_interlocks expressions.
2005
2006 Thu Jun 27 12:18:26 1996 Ian Lance Taylor <ian@cygnus.com>
2007
2008 * listing.c (listing_print): Close the listing file if it is not
2009 stdout. Close the other files opened for the listing.
2010
2011 * config/tc-sparc.h (md_cons_align): Define.
2012 (sparc_cons_align): Declare.
2013 (HANDLE_ALIGN): Define.
2014 (sparc_handle_align): Declare.
2015 * config/tc-sparc.c (sparc_cons_align): New function.
2016 (sparc_handle_align): New function.
2017 * read.c (cons_worker): Call md_cons_align if it is defined.
2018
2019 * as.h (struct frag): Add fr_file and fr_line fields.
2020 * frags.c (frag_new): Set fr_file and fr_line.
2021 (frag_var): Likewise.
2022 (frag_variant): Likewise.
2023
2024 * as.h (struct frag): Remove unused align_mask and align_offset
2025 fields.
2026
2027 * listing.c (calc_hex): Offset by fr_fix when examining fr_var.
2028 From <uddeborg@carmen.se>.
2029
2030 Wed Jun 26 13:21:34 1996 Ian Lance Taylor <ian@cygnus.com>
2031
2032 * configure.in (mips-*-osf*): New target.
2033 * configure: Rebuild.
2034
2035 * config/tc-m68k.c: Add 68ec060 as a synonym for 68060.
2036
2037 Wed Jun 26 16:23:08 1996 James G. Smith <jsmith@cygnus.co.uk>
2038
2039 * config/tc-mips.c: Added cop_interlocks, to avoid NOP insertion
2040 between co-processor comparisons and branches for the VR4300.
2041
2042 Mon Jun 24 18:02:50 1996 Jason Molenda (crash@godzilla.cygnus.co.jp)
2043
2044 * Makefile.in (bindir, libdir, datadir, mandir, infodir, includedir,
2045 INSTALL_PROGRAM, INSTALL_DATA): Use autoconf-set values.
2046 (docdir): Removed.
2047 * configure.in (AC_PREREQ): autoconf 2.5 or higher.
2048 * doc/Makefile.in (bindir, libdir, datadir, mandir, infodir,
2049 includedir): Use autoconf set values.
2050 (docdir): Removed.
2051
2052 Mon Jun 24 11:58:14 1996 Ian Lance Taylor <ian@cygnus.com>
2053
2054 * listing.c (listing_eject): Don't do anything if listing is 0.
2055 (listing_list): Likewise.
2056 (listing_source_line): Likewise.
2057 (listing_title): Don't save title if listing is 0.
2058 (listing_source_file): Check listing rather than listing_tail.
2059
2060 * configure.in: On alpha*-*-osf*, link against libbfd.a if not
2061 using shared libraries.
2062 * configure: Rebuild.
2063
2064 Fri Jun 21 18:22:23 1996 Ian Lance Taylor <ian@cygnus.com>
2065
2066 * config/tc-mips.c (mips_ip): In case 'i'/'j', don't require an
2067 absolute expression if a relocation type was specified.
2068
2069 Fri Jun 21 17:40:16 1996 Joel Sherrill <joel@merlin.gcs.redstone.army.mil>
2070
2071 * configure.in: Add support for *-*-rtems* configurations.
2072 * configure: Rebuild.
2073
2074 Fri Jun 21 16:01:18 1996 Richard Henderson <rth@tamu.edu>
2075
2076 * configure.in: Add alpha-*-linuxecoff* target. Use elf for
2077 alpha-*-linux* target. Force bfd_gas for alpha-*. Require
2078 opcodes library for alpha.
2079 * configure: Rebuild with autoconf 2.10.
2080 * config/tc-alpha.c: Substantial rewrite to add ELF support and
2081 use new opcode table.
2082 * config/tc-alpha.h (md_undefined_symbol): Don't define.
2083 (LOCAL_LABEL): Define differently if OBJ_ELF.
2084 (FAKE_LABEL_NAME): Define if OBJ_ELF.
2085 * config/alpha-opcode.h: Remove.
2086 * config/obj-elf.h: If TC_ALPHA, define ECOFF_DEBUGGING.
2087 * Makefile.in (TARG_CPU_DEP_alpha): Depend upon
2088 include/opcode/alpha.h rather than config/alpha-opcode.h.
2089
2090 Thu Jun 20 19:10:28 1996 Ian Lance Taylor <ian@cygnus.com>
2091
2092 * config/obj-aout.c (obj_emit_relocations): Give an error if the
2093 relocation symbol was not resolved.
2094 * config/obj-coff.c (do_relocs_for): Likewise.
2095
2096 * write.c (adjust_reloc_syms): Refetch the symbol section after
2097 calling S_GET_VALUE, since it may have changed.
2098
2099 * expr.c (struct expr_symbol_line): Define.
2100 (expr_symbol_lines): New static variable.
2101 (make_expr_symbol): Add entry to expr_symbol_lines.
2102 (expr_symbol_where): New function.
2103 * expr.h: Use extern on function declarations.
2104 (expr_symbol_where): Declare.
2105 * symbols.c (resolve_symbol_value): Try to use expr_symbol_where
2106 rather than printing the meaningless name of an expression
2107 symbol.
2108
2109 Thu Jun 20 15:57:41 1996 Ken Raeburn <raeburn@cygnus.com>
2110
2111 * config/tc-i386.c (md_number_to_chars): Deleted.
2112 * config/tc-i386.h (md_number_to_chars): New macro.
2113
2114 * config/tc-alpha.c (build_operate_n, build_mem): Moved earlier in
2115 the file.
2116 (load_symbol_address, load_expression): Use build_mem.
2117 (build_operate): New function.
2118 (emit_addq_r): Use it.
2119
2120 Wed Mar 13 22:14:14 1996 Pat Rankin <rankin@eql.caltech.edu>
2121
2122 * symbols.c (colon): #if VMS, use S_SET_OTHER to store `const_flag'.
2123
2124 Tue Mar 5 14:31:45 1996 Pat Rankin <rankin@eql.caltech.edu>
2125
2126 * config/tc-vax.h (NOP_OPCODE): Define.
2127
2128 Sun Feb 4 21:01:03 1996 Pat Rankin <rankin@eql.caltech.edu>
2129
2130 * config/obj-vms.h (S_IS_COMMON): Define.
2131 (S_IS_LOCAL): Check for \002 as well as \001.
2132 (LONGWORD_ALIGNMENT): New macro.
2133 (SUB_SEGMENT_ALIGN): Use it.
2134
2135 Fri Jan 26 17:44:09 1996 Pat Rankin <rankin@eql.caltech.edu>
2136
2137 * config/vms-conf.h: Reconcile with conf.in.
2138
2139 Wed Jun 19 11:31:50 1996 Ian Lance Taylor <ian@cygnus.com>
2140
2141 * write.c (is_dnrange): Only define if TC_GENERIC_RELAX_TABLE is
2142 defined.
2143
2144 * doc/as.texinfo: Document that any number of hex digits can
2145 follow \x.
2146
2147 * as.c (struct defsym_list): Define.
2148 (defsyms): New static variable.
2149 (parse_args): Just put --defsym arguments on defsyms list, rather
2150 than defining them.
2151 (main): Define defsyms after output file is created.
2152
2153 * config/tc-m68k.c (m68k_ip): Reject PRE and POST indexing mode on
2154 cpu32. From Eric Norum <Eric.Norum@usask.ca>.
2155
2156 * config/tc-mips.c (mips_ip): In cases 'I', 'i', and 'j', set
2157 insn_error rather than calling check_absolute_expr.
2158
2159 * as.c (emulation_name): Remove unused static variable.
2160 (default_emul_bfd_name): Add return NULL to avoid warning.
2161 * ecoff.c (ecoff_stab): Remove unused variables name and
2162 name_end.
2163 * frags.c (frag_new): Remove unused variable tmp.
2164 * hash.c (hash_grow): Parenthesize + within <<.
2165 (hash_print_statistics): Use %lu, not %d, to print unsigned
2166 long variables.
2167 * messages.c: Include "libiberty.h".
2168 (fprint_value): Add cast to avoid printf warning.
2169 (sprint_value): Likewise.
2170 * read.c: Include "ecoff.h".
2171 (emit_expr): Add casts to avoid printf warnings.
2172 * read.h: Use extern for function declarations.
2173 (pop_insert): Declare.
2174 * stabs.c: Include "ecoff.h".
2175 * subsegs.c (subseg_set_rest): Remove unused variables tmp,
2176 former_last_fragP, and new_fragP.
2177 * subsegs.h (subsegs_print_statistics): Declare.
2178 * symbols.c (debug_verify_symchain): Change macro to discard
2179 arguments.
2180 * write.c (dump_section_relocs): Likewise.
2181 * write.h: Use extern for function declarations.
2182 (write_print_statistics): Declare.
2183 * config/e-mipsecoff.c (mipsecoff_bfd_name): Return NULL to avoid
2184 warning.
2185 * config/e-mipself.c (mipself_bfd_name): Likewise.
2186 * config/obj-elf.h (elf_ecoff_set_ext): Declare.
2187
2188 * config/tc-sparc.h (TC_RELOC_RTSYM_LOC_FIXUP): If OBJ_ELF, always
2189 emit relocations against external symbols.
2190
2191 * config/tc-alpha.c (tc_gen_reloc): Output a sensible error
2192 message if bfd_reloc_type_lookup fails, rather than calling
2193 assert.
2194
2195 * config/tc-alpha.c (alpha_force_relocation): Add
2196 BFD_RELOC_12_PCREL to switch.
2197
2198 Tue Jun 18 20:29:57 1996 Doug Evans <dje@canuck.cygnus.com>
2199
2200 * config/tc-i386.h (LOCAL_LABEL,FAKE_LABEL_NAME): Use defaults for
2201 TE_PE (Lfoo, not .Lfoo).
2202
2203 Tue Jun 18 17:13:33 1996 Ian Lance Taylor <ian@cygnus.com>
2204
2205 * read.c (s_fill): Don't warn about a zero repeat count.
2206
2207 * config/tc-mips.c (mips_ip): Don't warn about using AT as a
2208 coprocessor register.
2209
2210 * config/tc-i386.c (md_assemble): When checking the size of a
2211 register to set the size of an instruction, do a bitwise and with
2212 Reg8 and Reg16 rather than requiring the type to be exactly Reg8
2213 or Reg16.
2214
2215 Tue Jun 18 13:19:51 1996 Jeffrey A. Law <law@rtl.cygnus.com>
2216
2217 * config/tc-h8300.c (parse_reg): Tweak error messages.
2218 (build_bytes): Likewise.
2219 (skip_colonthing): Handle :32 suffix.
2220 (get_specific): Promote L_24 to L_32 if it makes a match.
2221 Don't always promote L_8 to L_16.
2222 (do_a_fix_imm): Clean up L_32 and L_24 handling.
2223
2224 * config/tc-h8300.c (Smode): New variable.
2225 (h8300hmode): Turn off Hmode.
2226 (h8300smode): New function. Turn on Smode and Hmode.
2227 (md_pseudo_table): New ".h8300s" pseudo-op.
2228 (parse_reg): Handle "exr" register.
2229 (get_operand): Handle bizarre syntax for "stm.l" and "ldm.l".
2230 Handle "mach" and "machl" operands for ldmac.
2231 (get_specific): Handle "stm.l" and "ldm.l".
2232 (build_bytes): Handle "stm.l" and "ldm.l"; handle MACREG operands.
2233 * config/tc-h8300.h (COFF_MAGIC): Handle H8/S magic number.
2234 (Smode): Declare.
2235
2236 Mon Jun 17 15:50:53 1996 J.T. Conklin <jtc@rtl.cygnus.com>
2237
2238 * doc/as.texinfo: Reorder chapter of machine dependent options so
2239 that it is sorted by chip name.
2240
2241 * doc/as.texinfo: Use consistant spelling of Vax.
2242 * doc/c-vax.texi: Likewise.
2243
2244 Mon Jun 17 11:26:56 1996 Jeffrey A. Law <law@rtl.cygnus.com>
2245
2246 * config/tc-hppa.c (md_pseudo_table): Add ".begin_try" and ".end_try"
2247 pseudo ops.
2248 (tc_gen_reloc, SOM version): Handle R_BEGIN_TRY and R_END_TRY.
2249 (md_apply_fix): Likewise.
2250 (pa_try): New function.
2251 (hppa_force_relocation): Force relocs for BEGIN_TRY and END_TRY.
2252
2253 Sun Jun 16 22:57:47 1996 Jeffrey A. Law <law@rtl.cygnus.com>
2254
2255 * config/tc-hppa.c (md_pseudo_table): Add ".level" pseudo op.
2256 (pa_level): New function.
2257
2258 Fri Jun 14 20:06:44 1996 Ian Lance Taylor <ian@cygnus.com>
2259
2260 * listing.c (listing_newline): Don't do anything if listing is 0.
2261
2262 Thu Jun 13 17:50:54 1996 Ian Lance Taylor <ian@cygnus.com>
2263
2264 * subsegs.c (section_symbol): If symbol_table_frozen is set, call
2265 symbol_create, not symbol_new.
2266
2267 Wed Jun 12 14:10:44 1996 Ian Lance Taylor <ian@cygnus.com>
2268
2269 * write.c (adjust_reloc_syms): Don't set sy_used_in_reloc for an
2270 absolute symbol unless TC_FORCE_RELOCATION returns true.
2271
2272 * config/obj-coff.c (previous_file_symbol): Remove BFD_ASSEMBLER
2273 version.
2274 (c_dot_file_symbol): BFD_ASSEMBLER version: Don't set the value of
2275 the symbol to a pointer. Don't set previous_file_symbol.
2276 Simplify symbol list rearrangement.
2277 (coff_frob_symbol): Don't do anything with C_FILE symbols.
2278 (coff_adjust_symtab): Don't check previous_file_symbol.
2279
2280 Mon Jun 10 14:52:29 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2281
2282 * config/tc-ppc.c (ppc_elf_lcomm): New function for .lcomm
2283 directive.
2284 (md_pseudo_table): Add ppc_elf_lcomm.
2285
2286 Mon Jun 10 11:45:51 1996 Ian Lance Taylor <ian@cygnus.com>
2287
2288 * config/tc-m68k.c (m68k_ip): Accept ABSL for 'O', so that `bfextu
2289 d0{24:1},d0' works without an immediate prefix on the bit numbers.
2290 (md_begin): Add digits to alt_notend_table.
2291 (md_parse_option): Make s a const pointer.
2292
2293 * config/tc-sparc.c (md_pseudo_table): Add "empty".
2294 (s_empty): New static function.
2295
2296 * config/obj-coff.c (struct filename_list): Only define if not
2297 BFD_ASSEMBLER.
2298 (filename_list_head, filename_list_tail): Likewise.
2299 (c_section_symbol): Remove unused BFD_ASSEMBLER version.
2300 (obj_coff_endef, BFD_ASSEMBLER version): Don't set the debugging
2301 flag for C_MOS, C_MOE, C_MOU, or C_EOS symbols, since they should
2302 have a section of N_ABS rather than N_DEBUG. If we do a merge,
2303 remove the new symbol from the list.
2304 (obj_coff_endef, both versions): Call tag_insert even if there is
2305 an old symbol with the same name, if the old symbol does not
2306 happen to be a tag.
2307 (coff_frob_symbol): Check SF_GET_TAG, C_EOF, and C_FILE outside of
2308 the SF_GET_DEBUG condition. Don't call SA_SET_SYM_ENDNDX with a
2309 symbol that will be moved to the end of the symbol list.
2310 (coff_adjust_section_syms): Always call section_symbol for .text,
2311 .data, and .bss.
2312 (coff_frob_section): Likewise. Also, remove unused variable
2313 strname.
2314
2315 * config/tc-ns32k.c (convert_iif): Call frag_grow rather than
2316 manipulating frags directly.
2317 (md_number_to_field): Adjust mem_ptr correctly if ENDIAN is
2318 defined.
2319
2320 * app.c (do_scrub_chars): If '/' is LINE_COMMENT_START, check
2321 whether the next character is '*' before checking whether we are
2322 at the start of a line. Permit LINE_COMMENT_START to start a
2323 comment in state 1 (seen some whitespace) as well, to match the
2324 documentation.
2325
2326 * gasp.c (do_align): Permit a fill value for .align.
2327
2328 Wed Jun 5 17:09:26 1996 Ian Lance Taylor <ian@cygnus.com>
2329
2330 * read.c (next_char_of_string): Warn if a newline is seen in the
2331 middle of a string. Call bump_line_counters when appropriate.
2332
2333 Wed Jun 5 17:08:36 1996 Richard Henderson <rth@tamu.edu>
2334
2335 * symbols.c (colon): Use LOCAL_LABEL.
2336
2337 Tue Jun 4 10:55:16 1996 Tom Tromey <tromey@csk3.cygnus.com>
2338
2339 * Makefile.in (install): Don't check to see if tooldir exists.
2340 Make $(tooldir) and $(tooldir)/bin.
2341
2342 Tue Jun 4 10:14:53 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2343
2344 * config/ppc-sol.mt (TDEFINES): Don't turn on -mregnames by
2345 default.
2346
2347 Mon Jun 3 11:34:41 1996 Ian Lance Taylor <ian@cygnus.com>
2348
2349 * config/tc-mips.c (mips_ip): Don't call as_warn if we are setting
2350 insn_error. Don't put the string "ERROR" in insn_error. Set
2351 insn_error rather than calling as_warn for an unsupported opcode.
2352
2353 Sat Jun 1 21:51:55 1996 Ian Lance Taylor <ian@cygnus.com>
2354
2355 * config/tc-mips.c (md_parse_option): Check for a 64 bit format
2356 before permitting -64.
2357 * output-file.c (output_file_create): Remove duplicate
2358 bfd_perror.
2359
2360 Fri May 31 01:08:06 1996 Ian Lance Taylor <ian@cygnus.com>
2361
2362 * config/tc-mips.c (md_begin): If -64, create a .MIPS.options
2363 section rather than a .reginfo section.
2364 (mips_elf_final_processing): If -64, write out 64 bit RegInfo
2365 information.
2366
2367 * config/tc-mips.c (load_register): If mips_isa < 3, permit a 32
2368 bit value with the high bit set.
2369
2370 Thu May 30 19:00:19 1996 Ian Lance Taylor <ian@cygnus.com>
2371
2372 * read.c (s_lcomm): Set section flags for .sbss section.
2373
2374 * config/tc-mips.c (mips_64): New static variable.
2375 (mips_target_format): If mips_64, return elf64 targets rather than
2376 elf32 ones.
2377 (md_longopts): Add "32" and "64".
2378 (md_parse_option): Handle -32 and -64.
2379 (md_show_usage): Mention -32 and -64.
2380 (cons_fix_new_mips): If mips_64, don't convert an 8 byte reloc to
2381 a 4 byte one.
2382
2383 Thu May 30 10:36:19 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2384
2385 * config/tc-ppc.c (comment_chars): Make '!' a comment character
2386 for Solaris compatibility.
2387
2388 * stabs.c (s_stab_generic): Under PowerPC Solaris, convert a
2389 .stabd with 4 arguments into a .stabn.
2390
2391 Wed May 29 16:43:16 1996 Ian Lance Taylor <ian@cygnus.com>
2392
2393 * config/tc-mips.c (macro): When passing X_add_number to
2394 macro_build, cast it to int first.
2395
2396 Tue May 28 13:29:39 1996 Ian Lance Taylor <ian@cygnus.com>
2397
2398 * config/tc-z8k.c (md_apply_fix): Handle fx_r_type of 0, as
2399 created by emit_expr.
2400
2401 * symbols.c (symbol_create): If bfd_make_empty_symbol fails, call
2402 as_perror rather than assert.
2403
2404 Fri May 24 18:24:11 1996 Ian Lance Taylor <ian@cygnus.com>
2405
2406 * config/tc-mips.c (mips_ip): Mark sections created to hold
2407 floating point information as read only.
2408
2409 Fri May 24 12:07:54 1996 David Edelsohn <edelsohn@mhpcc.edu>
2410
2411 * config/tc-ppc.c (ppc_set_cpu): Change defaults to match AIX.
2412
2413 Thu May 23 17:34:24 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2414
2415 * read.c (potable): Add .skip as a synonym for .space.
2416
2417 * stabs.c (s_stab_generic): For PowerPC ELF, allow .stabd to take
2418 4 arguments, providing the 4th argument is 0, to allow
2419 compatibility with the Solaris assembler.
2420
2421 Thu May 16 15:51:48 1996 Ian Lance Taylor <ian@cygnus.com>
2422
2423 * config/tc-sh.h (struct sh_segment_info_type): Define.
2424 (TC_SEGMENT_INFO_TYPE): Define.
2425 (sh_frob_label): Declare.
2426 (tc_frob_label): Define.
2427 (sh_flush_pending_output): Declare.
2428 (md_flush_pending_output): Define.
2429 * config/tc-sh.c (md_assemble): If relaxing, emit a R_SH_CODE
2430 reloc before the instruction if necessary.
2431 (sh_frob_label): New function.
2432 (sh_flush_pending_output): New function.
2433 (sh_coff_frob_file): Ignore ALIGN, CODE, DATA, and LABEL relocs
2434 when looking for the reloc for the target of .uses.
2435 (md_convert_frag): Fix printf format (%0xlx to 0x%lx).
2436 (sh_force_relocation): Force CODE, DATA, and LABEL relocs to be
2437 emitted.
2438 (md_apply_fix): Ignore CODE, DATA, and LABEL relocs.
2439 (sh_coff_reloc_mangle): Force CODE, DATA, and LABEL relocs to use
2440 the absolute symbol.
2441
2442 * subsegs.h (segment_info_type): Add tc_segment_info_data field if
2443 TC_SEGMENT_INFO_TYPE is defined.
2444
2445 Wed May 15 12:23:53 1996 Ian Lance Taylor <ian@cygnus.com>
2446
2447 * config/tc-i386.c (md_assemble): Make sure the opcode suffix
2448 matches the register size.
2449
2450 Wed May 15 08:33:37 1996 Jeffrey A Law (law@cygnus.com)
2451
2452 * config/obj-coff.c (count_entries_in_chain): Ignore Fixups with
2453 fx_done set.
2454 (do_relocs_for): Likewise.
2455 (fixup_segment): Don't just quit if linkrelax is set. Try to
2456 apply non pc-relative sym1-sym2 fixups, even if linkrelax is
2457 nonzero.
2458
2459 Fri May 10 14:16:59 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2460
2461 * config/tc-ppc.c (ppc_elf_validate_fix): Allow GOT and section
2462 relative relocations with -mrelocatable. Also allow unfixed
2463 relocs in .ex_shared.
2464
2465 Tue May 7 11:24:10 1996 Ian Lance Taylor <ian@cygnus.com>
2466
2467 * config/obj-coff.c (yank_symbols): Check that FNAME_OFFSET is
2468 non-zero before assuming this is a long file name.
2469 (w_strings): Likewise.
2470 (c_dot_file_symbol): Set FNAME_OFFSET to 1 for a long file name.
2471
2472 * config/obj-coff.c (w_strings): Move declaration of i inside
2473 #ifdef block which uses it.
2474
2475 Tue May 7 00:49:58 1996 Jeffrey A Law (law@cygnus.com)
2476
2477 * config/tc-h8300.c (do_a_fix_imm): Rename last argument to
2478 "relaxmode". Output relocs which identify various relaxing
2479 possibilities for mov.[bwl] instructions.
2480 (build_bytes): Pass in a relaxing mode to do_a_fix_imm.
2481
2482 Mon May 6 15:26:28 1996 Doug Evans <dje@canuck.cygnus.com>
2483
2484 * config/tc-arm.h (TC_HANDLES_FX_DONE): Define.
2485 (MD_APPLY_FIX3): Define.
2486 * config/tc-arm.c (my_get_expression): Only watch for bad segments
2487 if OBJ_AOUT.
2488 (md_apply_fix3): Renamed from md_apply_fix.
2489 If pcrel reloc and symbol is in different section, undo effects
2490 of md_pcrel_from.
2491
2492 Sat May 4 12:49:35 1996 Jeffrey A Law (law@cygnus.com)
2493
2494 * config/tc-hppa.c (hppa_fix_adjustable): Don't adjust
2495 any reloc with an LR% or RR% field selector for SOM.
2496
2497 Sat May 4 11:26:19 1996 Ian Lance Taylor <ian@cygnus.com>
2498
2499 * Makefile.in: Add subsegs.h to appropriate TARG_CPU_DEP_*
2500 variables.
2501
2502 Fri May 3 17:58:31 1996 Ian Lance Taylor <ian@cygnus.com>
2503
2504 * config/obj-coff.c (coff_frob_symbol): Don't merge a symbol with
2505 SF_GET_STATICS set.
2506 (yank_symbols): Likewise.
2507
2508 Wed May 1 13:38:17 1996 Ian Lance Taylor <ian@cygnus.com>
2509
2510 * subsegs.h (segment_info_type): If MANY_SEGMENTS and not
2511 BFD_ASSEMBLER, add name field.
2512 * config/obj-coff.c: Include "libiberty.h".
2513 (coff_header_append): Handle long section names.
2514 (crawl_symbols): Just use the name field for the symbol name,
2515 without worrying about null byte termination.
2516 (w_strings): Handle long section names.
2517 (write_object_file): Likewise. Also, use the name field, rather
2518 than scnhdr.s_name.
2519 (obj_coff_add_segment): Permit long section names.
2520 (obj_coff_init_stab_section): Use the name field, rather than
2521 scnhdr.s_name.
2522 (adjust_stab_section): Likewise.
2523 * config/te-pe.h (COFF_LONG_SECTION_NAMES): Define.
2524
2525 * config/tc-i960.c (brtab_emit): Don't set fx_im_disp field.
2526 (mem_fmt): Likewise.
2527 (md_apply_fix): Don't check fx_im_disp field.
2528
2529 Thu Apr 25 11:39:51 1996 Ian Lance Taylor <ian@cygnus.com>
2530
2531 * configure.in: Add * after sparc*-*-vxworks.
2532 * configure: Rebuild.
2533
2534 * app.c (do_scrub_begin): If tc_comment_chars is not defined,
2535 define it to comment_chars. Use tc_comment_chars rather than
2536 comment_chars.
2537 (do_scrub_chars): Use tc_comment_chars rather than comment_chars.
2538 * config/tc-m68k.h (tc_comment_chars): Define.
2539 (m68k_comment_chars): Declare.
2540 * config/tc-m68k.c (m68k_comment_chars): Rename from
2541 comment_chars. Change into a pointer rather than an array.
2542 (md_longopts): Add "bitwise-or".
2543 (md_parse_option): Handle OPTION_BITWISE_OR.
2544 (md_show_usage): Mention --bitwise-or.
2545 * doc/c-m68k.texi: Document --bitwise-or.
2546
2547 Wed Apr 24 11:28:38 1996 Ian Lance Taylor <ian@cygnus.com>
2548
2549 * config/tc-m68k.c (m68k_ip): Prevent attempts to use long offsets
2550 in 68000 mode.
2551
2552 * config/obj-coff.c (obj_coff_section): BFD_ASSEMBLER version:
2553 call demand_empty_rest_of_line. Non BFD_ASSEMBLER version:
2554 correct handling of input line pointer, and call
2555 demand_empty_rest_of_line.
2556
2557 Mon Apr 22 18:02:37 1996 Doug Evans <dje@blues.cygnus.com>
2558
2559 * config/tc-sparc.c (in_bitfield_range): New static function.
2560 (sparc_ip): New cases X,Y. Use SPARC_OPCODE_ARCH_V9_P.
2561 (md_apply_fix, cases BFD_RELOC_32_PCREL_S2,
2562 BFD_RELOC_SPARC_{WDISP16,WDISP19}): Fix undefined code.
2563 (md_apply_fix): New cases BFD_RELOC_SPARC_[56].
2564 (tc_gen_reloc): New cases BFD_RELOC_SPARC_[56].
2565
2566 Thu Apr 18 18:58:33 1996 Ian Lance Taylor <ian@cygnus.com>
2567
2568 * config/obj-coff.c: BFD_ASSEMBLER:
2569 (coff_last_bf): New static variable.
2570 (coff_frob_symbol): Set endndx of a .bf symbol.
2571 Non BFD_ASSEMBLER:
2572 (obj_coff_endef): Call SF_SET_PROCESS on a .bf symbol.
2573 (last_bfP): New static variable.
2574 (yank_symbols): Set endndx of a .bf symbol.
2575
2576 Thu Apr 18 11:53:58 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2577
2578 * config/tc-ppc.c (md_parse_option): Add support for Solaris's -le
2579 and -s options. Add -be for good measure.
2580
2581 Wed Apr 17 12:31:01 1996 Ian Lance Taylor <ian@cygnus.com>
2582
2583 * read.c (s_space): Support non-constant fill value. Handle fill
2584 value correctly for a size other than 1.
2585
2586 Tue Apr 16 15:17:40 1996 Doug Evans <dje@canuck.cygnus.com>
2587
2588 * config/tc-arm.c (my_get_float_expression): Update call to
2589 gen_to_words, X_PRECISION changed from 6 to 5.
2590
2591 Tue Apr 16 10:25:42 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2592
2593 * config/tc-ppc.c (register_name,reg_name_search): Move register
2594 name lookup from PE specific code to all targets. Add support for
2595 -mregnames/-mno-regnames to control whether register names are
2596 expanded or not.
2597 (md_assemble): Call register_name for all platforms.
2598 (md_parse_option): Add support for -mregnames/-mno-regnames.
2599
2600 * configure.in (powerpcle*-*-solaris): Add support.
2601 (powerpc*-*-linux): Ditto.
2602 * configure: Regenerate.
2603
2604 * config/ppc-sol.mt: New config file for PowerPC Solaris.
2605
2606 Mon Apr 15 12:26:33 1996 Ian Lance Taylor <ian@cygnus.com>
2607
2608 * config/tc-mips.c (mips_frob_file): Permit multiple %hi relocs to
2609 be associated with a single %lo reloc.
2610
2611 * config/tc-mips.c (load_address): Cast X_add_number to valueT
2612 before comparing against MAX_GPREL_OFFSET, so that negative
2613 numbers are handled correctly.
2614 (macro): Likewise.
2615
2616 Thu Apr 11 12:39:02 1996 Ian Lance Taylor <ian@cygnus.com>
2617
2618 * config/tc-sparc.c (last_insn): New static variable.
2619 (md_assemble): Warn about putting floating point branches in a
2620 delay slot. If architecture is less than v9, insert NOP
2621 instructions between floating point instructions and floating
2622 point branches. (The SunOS assembler does both these operations.)
2623 Save the last instruction opcode.
2624 (sparc_ip): Add pinsn parameter. Change caller.
2625
2626 * config/tc-m68k.c (md_estimate_size_before_relax): Correct check
2627 for byte jump to next instruction to skip empty frags.
2628
2629 Wed Apr 10 16:48:12 1996 Ian Lance Taylor <ian@cygnus.com>
2630
2631 * config/tc-alpha.c (alpha_ip): If we are going to call emit_add64
2632 for addq with a 16 bit signed value, just emit a lda instruction
2633 instead.
2634
2635 Wed Apr 10 14:34:49 1996 Jeffrey A Law (law@cygnus.com)
2636
2637 * config/tc-h8300.c (do_a_fix_imm): Don't cut off high bits
2638 of a 32bit operand.
2639
2640 Mon Apr 8 14:42:53 1996 Ian Lance Taylor <ian@cygnus.com>
2641
2642 * configure.in: Permit --enable-shared to specify a list of
2643 directories.
2644 * configure: Rebuild.
2645
2646 Fri Apr 5 17:01:35 1996 Jeffrey A Law (law@cygnus.com)
2647
2648 * config/tc-h8300.c (get_specific): Remove some #if 0 code.
2649 (build_bytes): Remove all ABSMOV related code; it's unnecessary.
2650
2651 Fri Apr 5 15:13:10 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
2652
2653 * config/atof-ieee.c: Fix handling of denormalized extended
2654 precision numbers and overflow/underflow detection.
2655 (MAX_PRECISION, X_PRECISION, P_PRECISION): Changed from 6 to 5, to
2656 not include the 16 bit gap in the m68k extended precision format.
2657
2658 Fri Apr 5 14:29:23 1996 Ian Lance Taylor <ian@cygnus.com>
2659
2660 * configure.in: Add i386-*-freebsdelf* target; from John Polstra
2661 <jdp@polstra.com>.
2662 * configure: Rebuild.
2663
2664 Fri Apr 5 18:39:28 1996 James G. Smith <jsmith@cygnus.co.uk>
2665
2666 * config/tc-mips.c: Allow non-zero offsets from .sdata symbols to
2667 be accessed using the $gp register.
2668 * config/tc-mips.h (MAX_GPREL_OFFSET): Added.
2669
2670 Wed Apr 3 10:56:14 1996 Doug Evans <dje@canuck.cygnus.com>
2671
2672 * config/tc-sparc.c (sparc_md_end): Set bfd machine number to
2673 bfd_mach_sparc_sparclet if current_architecture is sparclet.
2674
2675 Mon Apr 1 16:55:44 1996 Ian Lance Taylor <ian@cygnus.com>
2676
2677 * read.c (get_line_sb): Bump line counters based on
2678 input_line_pointer[-1], not *input_line_pointer. Don't bother to
2679 call LISTING_NEWLINE.
2680 (s_macro): Don't call demand_empty_rest_of_line.
2681 * app.c (do_scrub_chars): When handling C style comments, unget
2682 ch2 rather than ch.
2683
2684 Fri Mar 29 16:15:06 1996 Ian Lance Taylor <ian@cygnus.com>
2685
2686 * read.h (enum linkonce_type): Define.
2687 (s_linkonce): Declare.
2688 * read.c (potable): Add "linkonce".
2689 (s_linkonce): New function.
2690 * subsegs.h (segment_info_type): Add linkonce field to
2691 MANY_SEGMENTS && ! BFD_ASSEMBLER section.
2692 * config/obj-coff.h (obj_handle_link_once): Define if TE_PE.
2693 (obj_coff_pe_handle_link_once): Declare if TE_PE.
2694 * config/obj-coff.c: If TE_PE and not BFD_ASSEMBLER, #include
2695 "coff/pe.h".
2696 (obj_coff_pe_handle_link_once): New function, defined if TE_PE.
2697 (c_section_symbol): If TE_PE, set the x_comdat field in the aux
2698 entry based on the linkonce field in segment_info.
2699 * doc/as.texinfo: Document .linkonce.
2700
2701 Fri Mar 29 11:31:27 1996 J.T. Conklin (jtc@lisa.cygnus.com)
2702
2703 * doc/as.1: Changed to be recognized by catman -w on Solaris.
2704
2705 Thu Mar 28 15:27:47 1996 Ian Lance Taylor <ian@cygnus.com>
2706
2707 * stabs.c (s_stab_generic): Call the listing functions before
2708 doing the rest of the processing, which may involve freeing the
2709 string. Pass string, not string + stroff, to OBJ_PROCESS_STAB in
2710 SEPARATE_STAB_SECTIONS case.
2711
2712 * config/tc-hppa.c: Remove nested comment.
2713 (tc_gen_reloc): Move label done inside the ifdef in which it is
2714 used.
2715 (md_apply_fix): Pass pointers to correct types to libhppa.h
2716 functions. Always return a value.
2717
2718 * config/tc-mips.h (tc_frob_file): Define.
2719 (mips_frob_file): Declare.
2720 * config/tc-mips.c (struct mips_hi_fixup): Define.
2721 (mips_hi_fixup_list): New static variable.
2722 (imm_unmatched_hi): New static variable.
2723 (md_assemble): Clear imm_reloc, imm_unmatched_hi, and
2724 offset_reloc. Pass imm_unmatched_hi to append_insn.
2725 (append_insn): Add unmatched_hi parameter. If it is set, add the
2726 new fixup to mips_hi_fixup_list. Change all callers.
2727 (mips_ip): Set imm_unmatched_hi when appropriate.
2728 (mips_frob_file): New function.
2729
2730 Thu Mar 28 11:47:59 1996 Doug Evans <dje@canuck.cygnus.com>
2731
2732 * configure.in (sparc-*-solaris2*): Renamed from sparc*-*-solaris2*.
2733 * configure: Regenerated.
2734
2735 Tue Mar 26 18:19:12 1996 Ian Lance Taylor <ian@cygnus.com>
2736
2737 * as.c (main): Call bfd_set_error_program_name.
2738
2739 Fri Mar 22 11:13:00 1996 Ian Lance Taylor <ian@cygnus.com>
2740
2741 * as.h (strdup): Don't declare.
2742 * stabs.c: Include libiberty.h
2743 (get_stab_string_offset): Use xstrdup rather than strdup.
2744 (s_stab_generic): Likewise.
2745 * as.c (parse_args): Likewise.
2746 * read.c (s_mri_sect): Likewise.
2747
2748 * gasp.c (change_base): Recognize \(...) construct documented to
2749 pass through enclosed characters literally through to the output.
2750 (process_assigns): Likewise. Also, be more careful to avoid
2751 looking past the end of the buffer.
2752
2753 Thu Mar 21 13:18:43 1996 Ian Lance Taylor <ian@cygnus.com>
2754
2755 * config/tc-i386.c (md_parse_option): If OBJ_ELF, ignore -k for
2756 FreeBSD compatibility. From John Polstra <jdp@polstra.com>.
2757
2758 Wed Mar 20 18:13:32 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
2759
2760 * doc/as.texinfo, doc/c-i960.texi: Fix typos.
2761
2762 Wed Mar 20 17:05:16 1996 David Mosberger-Tang <davidm@azstarnet.com>
2763
2764 * config/alpha-opcode.h: Added cvtst instruction.
2765
2766 Mon Mar 18 13:12:46 1996 Ian Lance Taylor <ian@cygnus.com>
2767
2768 * ecoff.c (ecoff_stab): Don't try to make a symbol out of the stab
2769 string. Extract the addend from the result of expression.
2770
2771 Fri Mar 15 17:10:43 1996 Ian Lance Taylor <ian@cygnus.com>
2772
2773 * app.c (do_scrub_chars): If whitespace is seen in state 11, and
2774 LABELS_WITHOUT_COLONS is not defined, and we are not in m68k MRI
2775 mode, change the state to 3 rather than 1.
2776
2777 Thu Mar 14 18:18:25 1996 Ian Lance Taylor <ian@cygnus.com>
2778
2779 * config/obj-coff.h (C_REGISTER_SECTION): Change from 20 to 50, to
2780 correspond to 11 March change.
2781
2782 Thu Mar 14 15:27:10 1996 Jeffrey A Law (law@cygnus.com)
2783
2784 * config/tc-h8300.c (build_bytes, MEMIND case): Generate
2785 an R_MEM_INDIRECT reloc rather than R_RELBYTE.
2786
2787 Tue Mar 12 12:21:10 1996 Ian Lance Taylor <ian@cygnus.com>
2788
2789 * configure: Rebuild with autoconf 2.8.
2790
2791 Mon Mar 11 18:57:12 1996 Ian Lance Taylor <ian@cygnus.com>
2792
2793 * config/atof-ieee.c (gen_to_words): Improve handling of
2794 X_PRECISION numbers. Based on patches from Andreas Schwab
2795 <schwab@issan.informatik.uni-dortmund.de>.
2796
2797 Mon Mar 11 09:59:53 1996 Steve Chamberlain <sac@slash.cygnus.com>
2798
2799 * as.h (SEG_NORMAL, SEG_LIST): Bump segment limit from 10 to 40.
2800 (SEG_LAST): New.
2801 * subsegs.c (MANY_SEGMENTS): Increase segment limit.
2802 * obj-coff.c (seg_N_TYPE, seg_info_off_by_4): Likewise.
2803 (do_relocs_for, w_symbols, obj_coff_add_segment, do_linenos_for,
2804 crawl_symbols, coff_header_append): Loop to SEG_LAST rather than
2805 SEG_E9.
2806
2807 Thu Mar 7 15:17:39 1996 Doug Evans <dje@charmed.cygnus.com>
2808
2809 * config/tc-sparc.c (sparc_ip): Handle operand char 'O' (neg reg).
2810
2811 Thu Mar 7 09:19:15 1996 Jeffrey A Law (law@cygnus.com)
2812
2813 * config/tc-hppa.c (SUBSEG_MILLI): Define.
2814 (pa_def_subspaces): Add $MILLICODE$.
2815 (pa_spaces_begin): Set section flags for $MILLICODE$.
2816
2817 Wed Mar 6 14:11:30 1996 Ian Lance Taylor <ian@cygnus.com>
2818
2819 * config/obj-elf.c (obj_elf_section): Only SEC_LOAD if the type is
2820 not SHT_NOBITS. Don't tamper with flags based on type if a
2821 special section was found (revert Feb 29 change).
2822
2823 * config/tc-sh.c (sh_do_align): Only align using the nop pattern
2824 if aligning to a longword boundary or greater.
2825
2826 Tue Mar 5 15:10:43 1996 Jim Wilson <wilson@chestnut.cygnus.com>
2827
2828 * config/tc-sh.c (sh_do_align): Pass 1 not 2 to frag_align.
2829
2830 Mon Mar 4 20:50:57 1996 Steve Chamberlain <sac@slash.cygnus.com>
2831
2832 * configure.in (i386-*-cygwin32): Don't use bfd_gas.
2833 * configure: Regenerated.
2834
2835 Mon Mar 4 10:13:06 1996 Jeffrey A Law (law@cygnus.com)
2836
2837 * config/tc-hppa.c: Add default definitions for R_N0SEL and
2838 R_N1SEL since they're not defined for old versions of hpux.
2839
2840 * config/tc-hppa.c (tc_gen_reloc): Fix typo in R_COMP2 code.
2841 Set "sym_ptr_ptr" and "addend" fields to dummy values for
2842 R_N0SEL and R_N1SEL.
2843
2844 Fri Mar 1 10:20:52 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
2845
2846 * flonum-konst.c: Add two more constants for 1e+-2048 and
2847 1e+-4096, and correct the other constants.
2848
2849 * symbols.c (resolve_symbol_value): Handle O_logical_not.
2850
2851 Thu Feb 29 13:58:35 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2852
2853 * config/obj-elf.c (obj_elf_section): Allow predefined section
2854 types to set the nobits type. Avoid a shadowed declaration.
2855
2856 Wed Feb 28 15:38:56 1996 Jeffrey A Law (law@cygnus.com)
2857
2858 * config/tc-hppa.c (hppa_fix_adjustable): For SOM, don't
2859 reduce relocs using e_nlrsel field selectors.
2860
2861 * write.c (fix_new_exp): Don't use #elif. Some compilers
2862 don't handle it.
2863
2864 * config/tc-hppa.c (selector_table): Add "n", "nl", and "nlr" to
2865 the selector table.
2866 (pa_chk_field_selector): Handle new field selectors for SOM.
2867
2868 Tue Feb 27 14:42:27 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
2869
2870 * configure.in (m68k-*-linux*aout*, m68k-*-linux*): New targets.
2871 * configure: Rebuild.
2872 * config/te-linux.h (LOCAL_LABELS_FB): Define.
2873 * config/tc-m68k.h (TARGET_FORMAT) [TE_LINUX]: Define to
2874 "a.out-m68k-linux".
2875 * config/tc-m68k.c (comment_chars): Don't include '#' if TE_LINUX
2876 is defined.
2877
2878 Mon Feb 26 18:58:58 1996 Stan Shebs <shebs@andros.cygnus.com>
2879
2880 * mpw-make.sed: Update to handle shared library support.
2881
2882 Mon Feb 26 10:34:10 1996 Doug Evans <dje@charmed.cygnus.com>
2883
2884 * config/tc-sparc.c (sparc_ip): Print all architectures that support
2885 the insn on mismatch.
2886
2887 Fri Feb 23 21:44:39 1996 Rob Savoye <rob@chinadoll.cygnus.com>
2888
2889 * configure.in: Add support for a29-coff.
2890 * configure: Rebuild.
2891
2892 Thu Feb 22 16:39:43 1996 Ian Lance Taylor <ian@cygnus.com>
2893
2894 * config/tc-sh.c (sh_coff_frob_file): Don't consider the address
2895 of the section when looking for the R_SH_USES fixup, because the
2896 frag addresses have not yet been adjusted.
2897
2898 * gdbinit.in: Set a breakpoint on as_warn_where.
2899
2900 * config/tc-mips.c (macro): Add missing arguments to macro_build
2901 omitted in last change. From Jim Wilson <wilson@cygnus.com>.
2902
2903 Wed Feb 21 17:00:32 1996 Ian Lance Taylor <ian@cygnus.com>
2904
2905 * config/tc-h8300.c (tc_reloc_mangle): Change reloc based on size
2906 if it is TC_CONS_RELOC. Set a size of 4 to R_RELLONG.
2907
2908 Wed Feb 21 09:25:39 1996 Doug Evans <dje@charmed.cygnus.com>
2909
2910 * config/tc-sparc.c (sparc_ip): Recognize %asr0 for v8.
2911
2912 Tue Feb 20 21:48:03 1996 Doug Evans <dje@charmed.cygnus.com>
2913
2914 * config/tc-sparc.c (parse_keyword_arg): Accept leading '%'.
2915 (sparc_ip): Accept %asr[1..31] for v8 and %asr[%16..31] for v9.
2916 Recognize [uU] format args as sparclet cpregs.
2917
2918 Tue Feb 20 22:25:55 1996 Ian Lance Taylor <ian@cygnus.com>
2919
2920 * config/tc-sh.c (sh_handle_align): Don't emit R_SH_ALIGN relocs
2921 in bss_section.
2922
2923 Mon Feb 19 14:16:24 1996 Ian Lance Taylor <ian@cygnus.com>
2924
2925 * config/tc-sparc.h (TC_RELOC_RTSYM_LOC_FIXUP): Check S_IS_WEAK as
2926 well as S_IS_EXTERNAL.
2927 (tc_fix_adjustable): Likewise.
2928 * config/tc-sparc.c (md_apply_fix): In OBJ_ELF case, check for
2929 S_IS_WEAK as well as S_IS_EXTERNAL when deciding whether to return
2930 early.
2931 (tc_gen_reloc): Check S_IS_WEAK as wel as S_IS_EXTERNAL when
2932 deciding whether to convert BFD_RELOC_32_PCREL_S2 if PIC.
2933
2934 Mon Feb 19 02:15:57 1996 Doug Evans <dje@charmed.cygnus.com>
2935
2936 * config/tc-sparc.c (max_architecture): Change to sparclite for
2937 32 bit arch.
2938 (default_compatible): Delete.
2939 (sparc_ffs): New function.
2940 (md_begin): Only call SPARC_OPCODE_CONFLICT_P once.
2941 (sparc_ip): Rewrite architecture match and bump logic.
2942
2943 Sun Feb 18 15:03:50 1996 Ian Lance Taylor <ian@cygnus.com>
2944
2945 * configure.in: Check for 'do not mix' from native linker before
2946 trying to use -rpath.
2947 * configure: Rebuild.
2948
2949 Fri Feb 16 16:53:31 1996 Ian Lance Taylor <ian@cygnus.com>
2950
2951 * config/obj-coff.h (SF_ADJ_LNNOPTR): Define (non BFD_ASSEMBLER).
2952 (SF_GET_ADJ_LNNOPTR): Define (non BFD_ASSEMBLER).
2953 (SF_SET_ADJ_LNNOPTR): Define (non BFD_ASSEMBLER).
2954 * config/obj-coff.c (obj_coff_endef): Set ADJ_LNNOPTR when LNNOPTR
2955 is set.
2956 (w_symbols): If ADJ_LNNOPTR is set, add the section lnnoptr field
2957 to the symbol lnnoptr field, to get the correct file offset.
2958
2959 Thu Feb 15 14:48:38 1996 Michael Meissner <meissner@tiktok.cygnus.com>
2960
2961 * config/obj-elf.c (elf_frob_symbol): On the PowerPC, force all
2962 symbols that are not function, file, or section symbols to be
2963 object types.
2964
2965 Thu Feb 15 11:20:18 1996 Ian Lance Taylor <ian@cygnus.com>
2966
2967 * configure: Set and substitute RPATH_ENVVAR.
2968 * configure: Rebuild.
2969 * Makefile.in (RPATH_ENVVAR): New variable.
2970 (check): Use $(RPATH_ENVVAR) rather than LD_LIBRARY_PATH.
2971
2972 * configure.in: Accept i686. From H.J. Lu <hjl@zoom.com>: i386
2973 doesn't need opcodes. If configuring shared, opcodes needs bfd.
2974 * configure: Rebuild.
2975
2976 Wed Feb 14 16:33:12 1996 Martin Anantharaman <martin@mail.imech.uni-duisburg.de>
2977
2978 * read.c (s_mri_sect): Don't return '\0' in type. Set all
2979 appropriate flags in BFD section.
2980
2981 * configure.in (m68k-*-psos*): New target.
2982 * configure: Rebuild.
2983 * config/te-psos.h: New file.
2984 * config/tc-m68k.c (comment_chars): Don't include '#' if TE_PSOS
2985 is defined.
2986
2987 Wed Feb 14 13:43:24 1996 Ian Lance Taylor <ian@cygnus.com>
2988
2989 From Alan Modra <alan@spri.levels.unisa.edu.au>:
2990 * configure.in: Remove duplicate setting of cpu_type. Check
2991 whether opcodes library is required for on all targets, not just
2992 primary one.
2993 * configure: Rebuild.
2994
2995 * config/tc-mips.c (mips_big_got): New static variable.
2996 (s_extern): Don't declare.
2997 (reg_needs_delay): New static function.
2998 (macro_build): Permit GOT/CALL_HI/LO relocs.
2999 (macro_build_lui): If place is not NULL, use the number in the
3000 expression.
3001 (load_address): Handle mips_big_got case.
3002 (macro): Handle mips_big_got for M_LA_AB, M_JAL_A, and load and
3003 store macros.
3004 (OPTION_XGOT): Define.
3005 (md_longopts): Add "xgot" if OBJ_ELF.
3006 (md_parse_option): Handle -xgot.
3007 (md_show_usage): Mention -xgot.
3008 (md_apply_fix): Permit GOT/CALL_HI/LO relocs.
3009 (tc_gen_reloc): Handle GOT/CALL_HI/LO relocs.
3010
3011 Wed Feb 14 11:22:27 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
3012
3013 * config/tc-m68k.c (m68k_ip) [operand kind '#']: When fixing
3014 the byte relocation, point it to the low byte of the word.
3015
3016 Tue Feb 13 15:31:18 1996 Ian Lance Taylor <ian@cygnus.com>
3017
3018 * configure.in: Set HDLFLAGS for *-*-hpux with --enable-shared.
3019 * configure: Rebuild.
3020
3021 Mon Feb 12 15:53:46 1996 Doug Evans <dje@charmed.cygnus.com>
3022
3023 * configure.in: Recognize any sparc* cpu.
3024 * configure: Regenerated.
3025
3026 Mon Feb 12 15:41:21 1996 Ian Lance Taylor <ian@cygnus.com>
3027
3028 * read.c (potable): Add "mri" and ".mri".
3029 (s_mri): New function.
3030 * read.h (s_mri): Declare.
3031 * app.c (scrub_m68k_mri): New static variable.
3032 (mri_pseudo): New static variable.
3033 (do_scrub_begin): Add m68k_mri parameter. Use it rather than
3034 flag_m68k_mri. Initialize scrub_m68k_mri.
3035 (mri_state, mri_last_ch): New static variables.
3036 (struct app_save): Add scrub_m68k_mri, mri_state, and mri_last_ch
3037 fields.
3038 (app_push): Save new fields.
3039 (app_pop): Restore new fields.
3040 (do_scrub_chars): Check scrub_m68k_mri rather than flag_mri_mri.
3041 If TC_M68K, use a trivial state machine to look for occurrences of
3042 the .mri pseudo-op, and change the mode appropriately.
3043 * as.h (do_scrub_begin): Update prototype.
3044 * input-scrub.c (input_scrub_begin): Pass flag_m68k_mri to
3045 do_scrub_begin.
3046 * config/tc-m68k.c (reg_prefix_optional_seen): New static
3047 variable.
3048 (m68k_mri_mode_change): New function.
3049 (md_parse_option): Set reg_prefix_optional_seen.
3050 * config/tc-m68k.h (m68k_mri_mode_change): Declare.
3051 (MRI_MODE_CHANGE): Define.
3052 * doc/as.texinfo: Document .mri pseudo-op.
3053
3054 * app.c (do_scrub_chars): In MRI mode, don't treat '#' as a
3055 comment character.
3056
3057 Mon Feb 12 15:16:29 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
3058
3059 Support for OBJ_ELF on m68k, mostly inside #ifdef OBJ_ELF:
3060 * config/m68k-parse.h (enum pic_relocation): Define.
3061 (struct m68k_exp): Add pic_reloc field.
3062 * config/tc-m68k.h (TC_RELOC_RTSYM_LOC_FIXUP): Define.
3063 (tc_fix_adjustable): Define to call tc_m68k_fix_adjustable.
3064 (NO_RELOC): Define to BFD_RELOC_NONE if BFD_ASSEMBLER, to zero
3065 otherwise.
3066 * config/tc-m68k.c: Delete definition of NO_RELOC.
3067 (struct m68k_it): Add pic_reloc field.
3068 (add_fix): Copy over pic_reloc field.
3069 (md_pseudo_table): Interpret .align parameter as byte count.
3070 (mote_pseudo_table): Likewise.
3071 (tc_m68k_fix_adjustable): New function.
3072 (get_reloc_code): New function.
3073 (md_assemble): Use it as last argument to fix_new_exp.
3074 (md_apply_fix_2): For a relocation against a symbol don't put the
3075 addend into the data.
3076 (tc_gen_reloc): Different addend computation for OBJ_ELF.
3077 (m68k_ip): Don't relax an operand that requires pic relocation.
3078 (md_begin): Align .text, .data and .bss on 4 byte boundary by
3079 default.
3080 * write.c (fixup_segment): Don't add symbol value to addend if
3081 TC_M68K and OBJ_ELF.
3082 * config/m68k-parse.y (yylex): Handle @PLTPC, etc.
3083 (motorola_operand): Add rule for `(zapc, EXPR)'.
3084
3085 Mon Feb 12 10:07:33 1996 David Mosberger-Tang <davidm@azstarnet.com>
3086
3087 * ecoff.c (ecoff_directive_weakext): Fixed so that whitespace
3088 *really* is permissible before the comma.
3089
3090 Mon Feb 12 00:12:13 1996 Ian Lance Taylor <ian@cygnus.com>
3091
3092 * config/tc-sh.c (sh_do_align): Align to a 2 byte boundary before
3093 inserting nop instructions.
3094
3095 Fri Feb 9 10:54:19 1996 Ian Lance Taylor <ian@cygnus.com>
3096
3097 * config/te-aux.h: Change include of aux.h to aux-coff.h.
3098
3099 Thu Feb 8 20:02:58 1996 Ian Lance Taylor <ian@cygnus.com>
3100
3101 * config/tc-i960.c (tc_coff_symbol_emit_hook): Correct storage
3102 class setting for a CALLNAME symbol in COFF.
3103
3104 * read.c (potable): Pass negative numbers for new .balign[wl] and
3105 .p2align[wl] pseudo-ops.
3106 (s_align_bytes): Treat a negative argument as specifying the fill
3107 length.
3108 (s_align_ptwo): Likewise.
3109
3110 Wed Feb 7 14:12:03 1996 Ian Lance Taylor <ian@cygnus.com>
3111
3112 * read.c (potable): Add balignw, balignl, p2alignw, and p2alignl.
3113 (do_align): Take new len parameter. Change all callers. Pass it
3114 to md_do_align.
3115 (s_align_bytes): Arg now indicates the length of the fill pattern.
3116 (s_align_ptwo): Likewise.
3117 * config/obj-coff.c (write_object_file): Pass length to
3118 md_do_align.
3119 * config/tc-i386.h (md_do_align): Take new len parameter.
3120 * config/tc-m88k.h (md_do_align): Likewise.
3121 * config/tc-m88k.c (m88k_do_align): Likewise.
3122 * config/tc-sh.h (md_do_align): Likewise.
3123 * config/tc-sh.c (sh_do_align): Likewise.
3124 * doc/as.texinfo: Document new pseudo-ops.
3125
3126 * config/obj-coff.c (fixup_mdeps): Divide offset by fr_var, as is
3127 done in cvt_frag_to_fill.
3128
3129 * config/tc-sh.h (sh_do_align): Declare.
3130 (md_do_align): Define.
3131 * config/tc-sh.c (sh_do_align): New function.
3132
3133 * ecoff.c (ecoff_build_lineno): Don't try to store the address
3134 difference if the next address is before the current one.
3135
3136 * config/tc-m68k.c (struct m68k_cpu): Add alias field.
3137 (archs): Initialize new field.
3138 (m68k_ip): Don't list alias names when listing CPUs which support
3139 an instruction.
3140
3141 * as.c (main): Call parse_args before read_begin.
3142 * app.c (do_scrub_chars): If flag_m68k_mri, don't put a dot in
3143 front of generated pseudo-ops.
3144 * read.c (potable): Ignore "name".
3145 (s_app_file): Permit a single quote after the string, since one
3146 may appear in m68k MRI mode.
3147
3148 * configure.in: Check for --enable-shared. If linking against
3149 shared BFD and opcodes, fix library name on SunOS, and try to set
3150 -rpath reasonably.
3151 * configure: Rebuild.
3152
3153 Tue Feb 6 15:16:17 1996 Ian Lance Taylor <ian@cygnus.com>
3154
3155 * as.h (flag_m68k_mri): Declare.
3156 * as.c (parse_args): If TC_M68K, set flag_m68k_mri for -M.
3157 * Many files: For MRI syntax that is specific to the m68k MRI
3158 assembler, check flag_m68k_mri rather than flag_mri or
3159 MRI_MODE_NEEDS_PSEUDO_DOT.
3160
3161 Mon Feb 5 16:29:11 1996 Ian Lance Taylor <ian@cygnus.com>
3162
3163 * config/tc-i960.c (ARCH_HX): Define.
3164 (arch_tab): Add HX.
3165 (targ_has_sfr): Handle ARCH_HX.
3166 (targ_has_iclass): Handle ARCH_HX.
3167 (tc_coff_fix2rtype): Add return 0 to avoid warning.
3168 (tc_headers_hook): If the architecture was specified explicitly,
3169 use it when setting the flags. Set the extern variable coff_flags
3170 rather than headers->filehdr.f_flags, since the latter is set
3171 unconditionally in obj-coff.c.
3172 (i960_handle_align): Remove unused variable fixp.
3173
3174 Support for building bfd and opcodes as shared libraries, based on
3175 patches from Alan Modra <alan@spri.levels.unisa.edu.au>:
3176 * configure.in: Set OPCODES and BFD to search directories.
3177 Substitute OPCODES_DEP and BFDDEP. On SunOS, set HLDFLAGS.
3178 * configure: Rebuild.
3179 * Makefile.in (LDFLAGS, HLDFLAGS): New variables.
3180 (LIBDEPS): New variable.
3181 (as.new0: Depend upon $(LIBDEPS) rather than $(LIBS). Use
3182 $(HLDFLAGS) in link.
3183 (check): Set LD_LIBRARY_PATH in the environment.
3184
3185 Fri Feb 2 17:41:53 1996 Michael Meissner <meissner@wogglebug.tiac.net>
3186
3187 * config/tc-ppc.h (ELF_TC_SPECIAL_SECTIONS): Make .sdata2, .sbss2,
3188 .PPC.EMB.sdata0, and .PPC.EMB.sbss0 sections all default to
3189 read-only, not read/write.
3190
3191 Fri Feb 2 14:09:25 1996 Alan Modra <alan@spri.levels.unisa.edu.au>
3192
3193 * Makefile.in (INSTALL_XFORM): Remove -e.
3194
3195 Fri Feb 2 12:32:15 1996 Ian Lance Taylor <ian@cygnus.com>
3196
3197 * write.c (write_relocs): Use S_IS_DEFINED and S_IS_COMMON rather
3198 than comparing S_GET_SEGMENT to undefined_section.
3199 (write_object_file): Skip symbols which were equated to an
3200 undefined or common symbol.
3201 * symbols.c (resolve_symbol_value): Use S_IS_DEFINED and
3202 S_IS_COMMON rather than comparing S_GET_SEGMENT to
3203 undefined_section.
3204 (S_GET_VALUE): Likewise. Avoid recursion problems if S_IS_DEFINED
3205 or S_IS_COMMON call S_GET_VALUE.
3206 * config/obj-aout.h (S_IS_COMMON): Define if not BFD_ASSEMBLER.
3207 * config/obj-aout.c (obj_emit_relocations): If a reloc is equated
3208 to an undefined or common symbol, convert the reloc to be against
3209 the target symbol.
3210 (obj_crawl_symbol_chain): Skip symbols which were equated to an
3211 undefined or common symbol.
3212 * config/obj-bout.h (S_IS_COMMON): Define if not BFD_ASSEMBLER.
3213 * config/obj-bout.c (obj_emit_relocations): If a reloc is equated
3214 to an undefined or common symbol, convert the reloc to be against
3215 the target symbol.
3216 (obj_crawl_symbol_chain): Skip symbols which were equated to an
3217 undefined or common symbol.
3218 * config/obj-coff.c (do_relocs_for): Use S_IS_DEFINED and
3219 S_IS_COMMON rather than comparing S_GET_SEGMENT to
3220 undefined_section.
3221 (yank_symbols): Skip symbols which were equated to an undefined or
3222 common symbol.
3223
3224 Thu Feb 1 15:34:32 1996 Ian Lance Taylor <ian@cygnus.com>
3225
3226 * config/obj-aout.h (S_IS_LOCAL): Check for \002 as well as \001.
3227 * config/obj-bout.h (S_IS_LOCAL): Likewise.
3228
3229 * configure.in: Make sure we only add m68k-parse.o to
3230 ${extra_objects} once, no matter how many m68k targets have been
3231 enabled.
3232 * configure: Rebuild.
3233
3234 Wed Jan 31 18:31:46 1996 Steve Chamberlain <sac@slash.cygnus.com>
3235
3236 * configure.in (i386-*-cygwin32, ppc-*-cygwin32): New.
3237 * configure: Rebuild.
3238
3239 Wed Jan 31 14:03:17 1996 Richard Henderson <rth@tamu.edu>
3240
3241 * config/tc-m68k.c (md_pseudo_table): Add "extend" and "ldouble".
3242 * doc/c-m68k.texi: Document .extend and .ldouble.
3243
3244 * configure.in (m68*-apple-aux*): New target.
3245 * config/te-aux.h: New file.
3246 * config/obj-coff.c (compare_external_relocs): New static function
3247 if TE_AUX.
3248 (do_relocs_for): Sort relocs if TE_AUX.
3249 (fixup_segment): If TE_AUX, store common symbol value in segment.
3250 * config/tc-m68k.h (TARGET_FORMAT): Define if TE_AUX.
3251
3252 Wed Jan 31 12:24:58 1996 Ian Lance Taylor <ian@cygnus.com>
3253
3254 * config/obj-coff.h (S_IS_LOCAL): Check for \002 as well as \001.
3255
3256 * config/tc-mips.c (s_mips_globl): Set BSF_OBJECT if it is not
3257 BSF_FUNCTION.
3258 (s_cpload): Set BSF_OBJECT for _gp_disp symbol.
3259 * read.c (s_lcomm): If S_SET_SIZE is defined, set the size of the
3260 symbol.
3261 * ecoff.c (add_procedure): Set the BSF_FUNCTION flag.
3262 (ecoff_build_symbols): If S_SET_SIZE is defined, set the size of
3263 an undefined symbol and the size of a function symbol.
3264 * config/obj-elf.c (elf_frob_symbol): If TC_MIPS, set BSF_OBJECT
3265 for all common symbols.
3266
3267 Tue Jan 30 12:35:24 1996 Ken Raeburn <raeburn@cygnus.com>
3268
3269 * config/tc-i960.c (parse_memop): In MRI mode, don't use implicit
3270 scaling of index.
3271
3272 * expr.c (operand): Accept 0x hex constants in MRI mode if not on
3273 m68k.
3274
3275 Mon Jan 29 12:21:30 1996 Ian Lance Taylor <ian@cygnus.com>
3276
3277 * config/obj-elf.c (obj_elf_type): Set BSF_OBJECT flag for a type
3278 of object. From Ronald F. Guilmette <rfg@monkeys.com>.
3279
3280 * ecoff.c (localsym_t): Add addend field.
3281 (add_ecoff_symbol): Add addend argument. Change all callers.
3282 (coff_sym_value): Make static.
3283 (coff_sym_addend): New static variable.
3284 (ecoff_directive_def): Initialize coff_sym_addend.
3285 (ecoff_directive_val): Accept symbol + constant.
3286 (ecoff_directive_endef): Pass coff_sym_addend to add_ecoff_symbol.
3287 (ecoff_build_symbols): Include the addend in the symbol value.
3288
3289 Fri Jan 26 19:28:52 1996 Kim Knuttila <krk@cygnus.com>
3290
3291 * config/tc-ppc.c (md_assemble): Ignore overflow on
3292 BFD_RELOC_16_GOTOFF and BFD_RELOC_PPC_TOC16.
3293
3294 Fri Jan 26 16:14:17 1996 Michael Meissner <meissner@tiktok.cygnus.com>
3295
3296 * config/tc-ppc.c (md_apply_fix3): SDA21 relocations are now 4
3297 bytes in size, so offset appropriately in big endian mode when
3298 writing the bottom 2 bytes.
3299
3300 Thu Jan 25 20:26:23 1996 Doug Evans <dje@charmed.cygnus.com>
3301
3302 * config/tc-sparc.c (default_compatible): New static local.
3303 (md_begin): Initialize it. Rewrite warn_on_bump handling.
3304 (sparc_ip): If no architecture or -bump specified, don't mark as
3305 mismatched those in default_compatible.
3306
3307 Thu Jan 25 12:21:53 1996 Ian Lance Taylor <ian@cygnus.com>
3308
3309 SCO ELF support from Robert Lipe <robertl@arnet.com>:
3310 * configure.in (i386-*-sco*elf*): Use fmt elf, targ sco5.
3311 * configure: Rebuild.
3312 * config/sco5.mt: New file; set TDEFINES to -DSCO_ELF.
3313 * config/tc-i386.c (sco_id): New function, if SCO_ELF.
3314 * config/tc-i386.h (tc_init_after_args): Define if SCO_ELF.
3315 (sco_id): Declare if SCO_ELF.
3316
3317 Thu Jan 25 03:10:53 1996 Doug Evans <dje@charmed.cygnus.com>
3318
3319 * config/tc-sparc.c (initial_architecture,can_bump_v9_p): Deleted.
3320 ({max,warn_after}_architecture): New static locals.
3321 (md_begin): Replace NUMOPCODES with sparc_num_opcodes.
3322 If both architecture and -bump requested, set max_architecture to max.
3323 (sparc_md_end): Simplify.
3324 (sparc_ip): Replace references to can_bump_v9_p with max_architecture.
3325 Rewrite code to bump architecture and check for conflicts.
3326 (md_longopts): Recognize -xarch={v8plus,v8plusa} for compatibility
3327 with Solaris assembler.
3328 (md_parse_option): Likewise. Call sparc_opcode_lookup_arch.
3329 (md_show_usage): Update.
3330
3331 Wed Jan 24 22:11:03 1996 Doug Evans <dje@charmed.cygnus.com>
3332
3333 * Makefile.in (RUNTEST): Fix reference to $${srcdir}.
3334
3335 Mon Jan 22 09:21:36 1996 Doug Evans <dje@charmed.cygnus.com>
3336
3337 * config/tc-sparc.h (TARGET_FORMAT): Use #ifdef SPARC_ARCH64 instead of
3338 #ifdef sparcv9 when choosing value.
3339 (ENV64): Delete.
3340 (md_end): Define.
3341 (sparc_md_end): Declare.
3342 * config/tc-sparc.c (SPARC_V9): Renamed from sparcv9.
3343 (initial_architecture): New static local.
3344 (can_bump_v9_p): Likewise.
3345 (NO_V9): Delete all occurrences.
3346 (sparc_md_end): New function.
3347 (sparc_ip): New local v9_arg_p. Rework fp reg number test.
3348 Don't bump architecture to v9 unless can_bump_v9_p set.
3349 (md_parse_option): -A<arch> passed, set can_bump_v9_p accordingly.
3350 * configure.in (sparc64 target cpu): Don't set obj_format here.
3351 (SPARC_V9): Renamed from sparcv9.
3352 (sparc64-*-elf*): Define SPARC_ARCH64.
3353 * configure: Regenerated.
3354 * acconfig.h (SPARC_V9): Renamed from sparcv9.
3355 (SPARC_ARCH64): Add.
3356 * conf.in: Regenerated.
3357 * config/vmsconf.h: Update.
3358
3359 Mon Jan 22 17:24:47 1996 James G. Smith <jsmith@cygnus.co.uk>
3360
3361 * config/tc-mips.c (load_register): Optimise "dli" loads.
3362 (md_show_usage): add "-mcpu=vr4100" to help text.
3363
3364 Mon Jan 22 11:53:00 1996 Ian Lance Taylor <ian@cygnus.com>
3365
3366 * symbols.c (resolve_symbol_value): If a symbol is equated to an
3367 undefined symbol, preserve the X_op of O_symbol.
3368 (S_GET_VALUE): Fix check to permit this case.
3369 * write.c (write_relocs): If a reloc is against an undefined
3370 symbol equated to another symbol, change the reloc to be against
3371 the latter symbol.
3372 * config/obj-coff.c (do_relocs_for): Likewise.
3373
3374 * config/tc-ppc.c (ppc_csect): An unnamed csect is storage class
3375 XMC_PR.
3376
3377 Mon Jan 22 10:59:48 1996 Michael Meissner <meissner@tiktok.cygnus.com>
3378
3379 * config/obj-elf.c (elf/ppc.h): Include elf/ppc.h if target
3380 computer is PowerPC.
3381
3382 * config/tc-ppc.c (md_apply_fix3): Add more embedded relocations.
3383
3384 * config/tc-ppc.h (ELF_TC_SPECIAL_SECTIONS): Add sections
3385 mentioned in the eabi.
3386
3387 Thu Jan 18 17:58:19 1996 Kim Knuttila <krk@cygnus.com>
3388
3389 * config/tc-ppc.c (ppc_reldata): Changed alignement on reldata_section
3390 * config/tc-ppc.c (ppc_pdata): Changed the alignment on pdata_section
3391
3392 Mon Jan 15 17:43:42 1996 Michael Meissner <meissner@tiktok.cygnus.com>
3393
3394 * config/tc-ppc.c (mapping): Add more relocation suffixes.
3395
3396 Sun Jan 14 21:29:36 1996 Michael Meissner <meissner@tiktok.cygnus.com>
3397
3398 * config/tc-ppc.c (ppc_elf_validate_fix): Allow .gcc_except_table
3399 as a section it is ok to have unadorned -mrelocatable pointers in.
3400
3401 Sat Jan 13 11:09:08 1996 Michael Meissner <meissner@tiktok.cygnus.com>
3402
3403 * config/tc-ppc.c (ppc_section*): Wrap these functions inside
3404 #ifdef OBJ_ELF.
3405
3406 Fri Jan 12 15:32:07 1996 Michael Meissner <meissner@tiktok.cygnus.com>
3407
3408 * config/obj-elf.c (obj_elf_section): Add hooks so machine
3409 dependent section attributes can be handled.
3410
3411 * config/tc-ppc.h: (md_elf_section_{letter,type,word,flags}): New
3412 macros to add support for exclude section flag and ordered section
3413 type.
3414
3415 * config/tc-ppc.c (ppc_elf_section_{letter,type,word,flags}): New
3416 functions to add support for exclude section flag and ordered
3417 section type.
3418
3419 Fri Jan 12 12:04:00 1996 Ian Lance Taylor <ian@cygnus.com>
3420
3421 * subsegs.c (section_symbol): Don't try to look up the section
3422 symbol in the hash table. It should be possible to have a symbol
3423 with the same name as a section, but no connection to it.
3424
3425 * read.c (cons_worker): Only call mri_comment_end from flag_mri.
3426 From James Carlson <carlson@xylogics.com>.
3427
3428 * expr.c (operand): Skip whitespace after a close parenthesis.
3429 From James Carlson <carlson@xylogics.com>.
3430
3431 Tue Jan 2 12:43:23 1996 Jim Wilson <wilson@chestnut.cygnus.com>
3432
3433 * config/tc-sh.c (md_apply_fix): Call as_bad_where instead of
3434 as_warn_where for relocation overflow.
3435 (parse_reg): Accept register name only if next character is
3436 not alphanumeric.
3437
3438 Sat Dec 30 23:42:51 1995 Jeffrey A Law (law@cygnus.com)
3439
3440 * ecoff.c (ecoff_stab): Simplify. Correctly handle sym + offset
3441 addresses for static variables.
3442
3443 Thu Dec 21 12:54:32 1995 Michael Meissner <meissner@tiktok.cygnus.com>
3444
3445 * config/tc-ppc.c (mapping): Make @got give a real GOT relocation,
3446 and xgot give the old toc16 relocation.
3447 (md_apply_fix3): Support all GOT relocations.
3448
3449 Wed Dec 20 14:57:17 1995 Ian Lance Taylor <ian@cygnus.com>
3450
3451 * config/tc-mips.c (load_address): Correctly handle a constant in
3452 SVR4_PIC case. From Richard Kenner <kenner@vlsi1.ultra.nyu.edu>.
3453
3454 Fri Dec 15 14:25:07 1995 J.T. Conklin <jtc@rtl.cygnus.com>
3455
3456 * config/tc-sh.c (parse_reg): Recognize SH3 registers.
3457 (get_specific): Handle A_SSR, A_SPC and A_REG_B.
3458 (build_Mbytes): Handle REG_B.
3459
3460 Fri Dec 15 16:07:25 1995 Ian Lance Taylor <ian@cygnus.com>
3461
3462 * ecoff.c (ecoff_build_aux): Use new bfd_big_endian macro.
3463
3464 Fri Dec 15 12:11:48 1995 Raymond Jou <rjou@mexican.cygnus.com>
3465
3466 * mpw-make.sed: If linking, edit ALL_CFLAGS to CFLAGS.
3467
3468 Thu Dec 14 15:09:52 1995 Ian Lance Taylor <ian@cygnus.com>
3469
3470 * config/obj-coff.c (write_object_file): Set the s_align field to
3471 the number of bytes, rather than to the power of 2.
3472
3473 Tue Dec 12 12:19:37 1995 Ian Lance Taylor <ian@cygnus.com>
3474
3475 * Makefile.in (DISTCLEAN_HERE): New variable.
3476 (distclean): Use it.
3477 (maintainer-clean): Depend upon clean-here rather than clean,
3478 distclean, and clean-info. Run make maintainer-clean in doc.
3479 Remove files listed in DISTCLEAN_HERE.
3480 * doc/Makefile.in (maintainer-clean realclean): Split out from
3481 distclean. Depend upon clean-info and distclean.
3482
3483 Mon Dec 11 16:23:51 1995 Stan Shebs <shebs@andros.cygnus.com>
3484
3485 * mac-as.r: Fix copyright and version strings.
3486 (cfrg): Use PROG_NAME instead of literal name.
3487
3488 Mon Dec 11 14:14:08 1995 Ian Lance Taylor <ian@cygnus.com>
3489
3490 * read.c (read_a_source_file): If tc_unrecognized_line is defined,
3491 call it.
3492 * config/tc-a29k.h (tc_unrecognized_line): Define.
3493 * config/tc-a29k.c (a29k_unrecognized_line): New function.
3494 (md_operand): Handle a29k style local dollar labels.
3495
3496 Wed Dec 6 17:52:52 1995 Ian Lance Taylor <ian@cygnus.com>
3497
3498 * config/obj-multi.h: If OBJ_MAYBE_ELF, define OBJ_SYMFIELD_TYPE.
3499
3500 Tue Dec 5 13:26:34 1995 Ken Raeburn <raeburn@cygnus.com>
3501
3502 * read.c (s_fill): If md_flush_pending_output is defined, call
3503 it.
3504
3505 Mon Dec 4 15:10:53 1995 Ken Raeburn <raeburn@cygnus.com>
3506
3507 * config/obj-coff.c (size_section, fill_section, fixup_mdeps):
3508 Treat rs_align_code like rs_align.
3509
3510 Sun Dec 3 16:46:54 1995 Richard Earnshaw (rearnsha@armltd.co.uk)
3511
3512 * config/tc-arm.c (cp_address_required_here): Set pre_inc when
3513 converting an absolute address into a PC-relative one.
3514
3515 Fri Dec 1 11:57:56 1995 Stan Shebs <shebs@andros.cygnus.com>
3516
3517 * mpw-config.in: Don't always use te-generic.h for emulation.
3518 (powerpc-apple-macos): Use emulation te-macos.h.
3519 start-sanitize-gm
3520 (mips-gm-magic): New configuration.
3521 end-sanitize-gm
3522 * mpw-make.sed (install, install-only): Edit in Mac-specific
3523 install procedure.
3524
3525 Fri Dec 1 10:59:25 1995 Ian Lance Taylor <ian@cygnus.com>
3526
3527 * configure.in: Improve message about unsupported ELF targets.
3528 * configure: Rebuild.
3529
3530 * config/tc-m88k.c (m88k_do_align): Correct check for whether fill
3531 pattern is zero. From Manfred Hollstein.
3532
3533 Thu Nov 30 13:25:49 1995 Kim Knuttila <krk@cygnus.com>
3534
3535 * config/tc-ppc.c (ppc_pe_section): To get the alignment right for
3536 the various idata sections, we check the name on the .section pseudo.
3537
3538 Thu Nov 30 11:23:42 1995 Manfred Hollstein KS/EF4A 60/1F/110 #40283 <manfred@lts.sel.alcatel.de>
3539
3540 * config/obj-coff.c (fixup_segment): If TC_M88K is defined, do not
3541 add section's paddr to add_number; compatibility to native as and
3542 ld forbids.
3543
3544 Wed Nov 29 23:14:27 1995 Ken Raeburn <raeburn@cygnus.com>
3545
3546 * configure.in: Treat m68k-sysv4 like m68k-elf, not m68k-sysv3.
3547
3548 * hash.c (struct hash_entry): Moved here...
3549 * hash.h (struct hash_entry): ...from here.
3550
3551 * config/obj-elf.c (elf_frob_symbol): Don't free and clear sy_obj
3552 if it's already known to be null.
3553
3554 Wed Nov 29 13:00:20 1995 Michael Meissner <meissner@tiktok.cygnus.com>
3555
3556 * config/tc-ppc.c (md_apply_fix3): Don't adjust the value for 32
3557 bit relocs converted to PC relative relocs. This turned out to
3558 add the offset from the beginning of .text twice.
3559
3560 Tue Nov 28 10:42:36 1995 Ken Raeburn <raeburn@cygnus.com>
3561
3562 * stabs.c (s_stab_generic): In 's' case, free string from
3563 obstack.
3564
3565 * config/obj-elf.h (ELF_TARGET_SYMBOL_FIELDS): Remove unused field
3566 sy_name_offset.
3567 * config/obj-multi.h (ELF_TARGET_SYMBOL_FIELDS) [OBJ_MAYBE_ELF]:
3568 Ditto.
3569
3570 * subsegs.h (segment_info_type): Make bitfields unsigned.
3571
3572 * expr.h (struct expressionS): Make X_op and X_unsigned bitfields,
3573 and move them together. On most systems this will reduce the
3574 structure size by one word.
3575 (operatorT): Define O_max.
3576 * expr.c (expr_begin): Verify that X_op is wide enough to hold
3577 O_max.
3578
3579 * read.c (pop_insert): Print error returned by hash table
3580 insertion code.
3581
3582 * as.c (dump_statistics): Split out from main; dump some hash
3583 table stats and target-specific stats.
3584 (start_time): No longer automatic to main.
3585 (main): Set file-level start_time and call dump_statistics at
3586 exit. Exit by calling xexit.
3587 (show_usage): Make --statistics description less specific.
3588 * subsegs.c (subsegs_print_statistics): New function.
3589 * write.c (write_print_statistics): New function.
3590 (n_fixups): New static variable.
3591 (fix_new_internal): Increment it.
3592 * read.c (read_print_statistics): New function.
3593 * read.h (read_print_statistics): Declare.
3594 * symbol.c (symbol_print_statistics): New function.
3595 * symbol.h (symbol_print_statistics): Declare.
3596 * hash.c (hash_print_statistics): New function.
3597 * hash.h (hash_print_statistics): Declare.
3598 * config/tc-i386.c (i386_print_statistics): New function.
3599 * config/tc-i386.h (i386_print_statistics): Declare.
3600 (tc_print_statistics): New macro.
3601 * messages.c (as_fatal, as_assert, as_abort): Use xexit, not
3602 exit.
3603
3604 * hash.c (DELETED): Rewrite to use a valid but unique address.
3605 (START_POWER): Reduce to 10.
3606 (enum stat_enum): New enumerator, replacing STAT_* index macros.
3607 Add new values for counting strcmp calls.
3608 (GROW_FACTOR): New macro.
3609 (hash_grow): Use GROW_FACTOR. Rewrite for quick returns instead
3610 of nesting blocks.
3611 (FULL_VALUE): New macro. Use 1/4 of table size instead of 1/2.
3612 (hash_new): Use FULL_VALUE.
3613 (struct hash_control): Definition moved here.
3614 (hash_code): Don't mask to low bits.
3615 (hash_ask): Mask returned hash code here. Check hash value before
3616 calling strcmp; count strcmp calls.
3617 * hash.h (struct hash_control): Declare, don't define, here.
3618 (HASH_STATLENGTH): Deleted.
3619 (struct hash_entry): Add field for hash code.
3620 (hash_say, hash_apply): Don't declare.
3621
3622 * hash.c (destroy): Return void.
3623 (applicatee): Ditto.
3624 (main): Fix declarations.
3625 (hash_apply): Return void. Argument `function' returns void. Put
3626 inside "#ifdef TEST".
3627 (hash_say): Define only if TEST is defined.
3628 * hash.h (hash_apply, hash_say): Declarations deleted.
3629
3630 Mon Nov 27 13:18:25 1995 Ian Lance Taylor <ian@cygnus.com>
3631
3632 * configure: Rebuild with autoconf 2.7.
3633
3634 Tue Nov 21 18:39:01 1995 Ian Lance Taylor <ian@cygnus.com>
3635
3636 * aclocal.m4 (AC_PROG_CC): Remove local definition.
3637 * configure: Rebuild with autoconf 2.6.
3638
3639 Mon Nov 20 17:26:00 1995 Ian Lance Taylor <ian@cygnus.com>
3640
3641 * config/tc-ppc.c (ppc_debug_name_section_size): Remove.
3642 (ppc_stabx): Don't increment ppc_debug_name_section_size.
3643 (ppc_bc): Likewise.
3644 (ppc_frob_file): Remove.
3645 * config/tc-ppc.h (tc_frob_file): Don't define.
3646 (ppc_frob_file): Don't declare.
3647
3648 Mon Nov 20 13:37:05 1995 Ken Raeburn <raeburn@cygnus.com>
3649
3650 * Makefile.in (TARG_CPU_DEP_alpha): Mention alpha-opcode.h.
3651 * config/alpha-opcode.h: Include one-operand variants of jmp and
3652 jsr.
3653
3654 * config/te-delt88.h: Renamed from te-delta88.h, to avoid conflict
3655 with te-delta.h in 8.3 file systems.
3656 * configure.in: Adjusted.
3657
3658 Thu Nov 16 12:49:38 1995 Ian Lance Taylor <ian@cygnus.com>
3659
3660 * config/tc-mips.c (s_err): Remove; just use the one in read.c.
3661
3662 * config/m68k-parse.y (yylex): In MRI mode, '@' can start an octal
3663 number.
3664 * expr.c (operand): Handle MRI suffixes after unadorned 0.
3665
3666 Thu Nov 16 00:21:44 1995 Ken Raeburn <raeburn@cygnus.com>
3667
3668 Version 2.6 released.
3669 * Makefile.in (VERSION): Updated to 2.6.
3670
3671 * config/obj-coff.c (write_object_file): Change use of md_do_align
3672 to pass a pointer rather than a fill value, to match other uses.
3673
3674 Wed Nov 15 03:52:00 1995 Ken Raeburn <raeburn@cygnus.com>
3675
3676 * config/tc-ns32k.h (TC_FIX_TYPE): Add missing semicolon.
3677
3678 * as.c (main): Move md_end call to just after call to
3679 perform_an_assembly_pass. Delete cpu-specific code here.
3680 * config/tc-i960.h (md_end): New macro, calls brtab_emit.
3681 * config/tc-arm.c (md_end): Unused function deleted.
3682 * config/tc-ns32k.c (md_end): Ditto.
3683
3684 * config/tc-i386.c (i386_align_code): New function, moved here
3685 from HANDLE_ALIGN macro.
3686 * config/tc-i386.h (HANDLE_ALIGN): Call it.
3687
3688 Mon Jul 31 14:53:19 1995 Alan Modra <alan@spri.levels.unisa.edu.au>
3689
3690 * config/tc-i386.h (md_do_align): cast fill and 0x90 to char
3691 before comparing
3692
3693 Mon May 1 10:91:49 1995 Alan Modra <alan@spri.levels.unisa.edu.au>
3694
3695 * config/tc-i386.h (md_do_align): Make ".align n,0x90" generate
3696 multi-byte nops to avoid changing gcc. The necessary gcc change
3697 might break old assemblers.
3698
3699 Sat Apr 22 20:53:05 1995 Alan Modra <alan@spri.levels.unisa.edu.au>
3700
3701 * config/tc-i386.h (md_do_align, HANDLE_ALIGN): Add macros to
3702 generate optimal multi-byte nop instructions for ".align n"
3703 ".align n,0x90", and aligns requiring more than 15 bytes of
3704 padding still generate multiple 0x90's as before.
3705
3706 Mon Nov 13 17:40:21 1995 Ian Lance Taylor <ian@cygnus.com>
3707
3708 * config/tc-m68k.c (s_mri_until): Call pop_mri_control.
3709
3710 Mon Nov 13 20:39:06 1995 Stan Shebs <shebs@andros.cygnus.com>
3711
3712 * configure.in (ppc-*-macos*, ppc-*-mpw*): New configurations.
3713 * configure: Update.
3714 * mpw-make.sed: Reorder commands to make sed happier.
3715 * config/te-macos.h: New file.
3716 * config/tc-ppc.h (TARGET_FORMAT): Set correctly for PowerMac.
3717
3718 Sun Nov 12 21:14:56 1995 Jeffrey A Law (law@cygnus.com)
3719
3720 * config/tc-hppa.c (pa_ip): Fix off-by-2 bug in length check for
3721 conditional branches.
3722 (md_apply_fix): Likewise.
3723
3724 Thu Nov 9 16:14:01 1995 Ian Lance Taylor <ian@cygnus.com>
3725
3726 * config/tc-a29k.c (md_apply_fix): Warn if an attempt is made to
3727 generate a reloc which the linker will not handle correctly. Fix
3728 overflow checking--R_IREL is 18 bits, not 17.
3729
3730 Wed Nov 8 19:59:36 1995 Ian Lance Taylor <ian@cygnus.com>
3731
3732 * config/obj-coff.c (fixup_segment): Don't subtract md_pcrel_from
3733 from a PC relative reloc if TC_A29K.
3734
3735 * config/tc-a29k.c (line_separator_chars): Restore '@'. Existing
3736 code depends upon it.
3737
3738 * config/tc-a29k.c (md_operand): Handle $float, $double, and
3739 $extend. Based on code from Eric Freudenthal
3740 <freudenthal@nyu.edu>.
3741 * config/tc-a29k.h (LEX_DOLLAR): Define.
3742 * read.c (LEX_DOLLAR): Define if not defined.
3743 (lex_type): Use LEX_DOLLAR.
3744
3745 Wed Nov 8 16:38:14 1995 Eric Freudenthal <freudenthal@nyu.edu>
3746
3747 * configure.in (a29k-nyu-sym1): New target, just like other a29k
3748 targets.
3749
3750 Wed Nov 8 11:38:48 1995 Ian Lance Taylor <ian@cygnus.com>
3751
3752 * config/obj-coff.c (c_dot_file_symbol): Cast xmalloc return.
3753
3754 Tue Nov 7 09:14:35 1995 Kim Knuttila <krk@cygnus.com>
3755
3756 * config/tc-ppc.c (md_apply_fix3): Added BFD_RELOC_RVA. Currently
3757 used only by "dlltool.c".
3758
3759 Mon Nov 6 18:51:26 1995 Ian Lance Taylor <ian@cygnus.com>
3760
3761 * config/tc-alpha.c: Undefine inline if not __GNUC__.
3762 (md_pseudo_table): Don't define "extern".
3763
3764 Sat Nov 4 00:51:21 1995 Ian Lance Taylor <ian@cygnus.com>
3765
3766 * config/tc-ppc.c (ppc_biei): Force symbol into text_section.
3767
3768 * config/tc-ppc.c (md_show_usage): Put backslash at end of line.
3769
3770 Fri Nov 3 13:02:59 1995 Ian Lance Taylor <ian@cygnus.com>
3771
3772 * macro.c (macro_expand_body): Don't warn about == with a
3773 nonexistent parameter, in case it is in a comment field.
3774
3775 * as.c (main): On TC_A29K, call macro_init with macro_alternate
3776 set to 1.
3777 * macro.c (get_any_string): Don't keep quotes if macro_strip_at is
3778 set, even if macro_alternate is set.
3779 (get_apost_token): If macro_strip_at, only skip kind if it is '@'.
3780 (sub_actual): If macro_strip_at, and kind is '@', don't look up
3781 the token unless it ended in '@'.
3782 * config/tc-a29k.c (line_separator_chars): Remove '@'.
3783 * doc/c-a29k.texi: Document macro usage on A29K.
3784
3785 Thu Nov 2 23:07:57 1995 Ian Lance Taylor <ian@cygnus.com>
3786
3787 * config/tc-m68k.c (m68k_ip): Handle new 'W' place, meaning a
3788 signed word.
3789 (install_operand): Likewise.
3790
3791 * config/obj-elf.c (ecoff_debug_pseudo_table): Add "extern".
3792
3793 Wed Nov 1 15:17:02 1995 Manfred Hollstein KS/EF4A 60/1F/110 #40283 <manfred@lts.sel.alcatel.de>
3794
3795 * configure.in (m88k-motorola-sysv*): New target.
3796 * configure: Rebuild.
3797 * config/te-delta88.h: New file.
3798 * config/obj-coff.c (write_object_file): Use md_do_align if it is
3799 defined.
3800 * config/tc-m88k.h (SUB_SEGMENT_ALIGN): Define.
3801 (md_do_align): Define.
3802 * config/tc-m88k.c: Include "subsegs.h".
3803 (m88k_do_align): New function.
3804
3805 * config/te-delta.h (STRIP_UNDERSCORE): Don't define.
3806 (COFF_NOLOAD_PROBLEM): Define.
3807 (LOCAL_LABELS_DOLLAR, LOCAL_LABELS_FB): Define.
3808
3809 Wed Nov 1 16:07:43 1995 Ken Raeburn <raeburn@cygnus.com>
3810
3811 * config/tc-i386.c (md_assemble): For a jump instruction with
3812 non-constant target, require 7 available bytes in the current
3813 frag, not 6.
3814
3815 Tue Oct 31 15:37:16 1995 Fred Fish <fnf@rtl.cygnus.com>
3816
3817 * config/obj-elf.h: Include bfd/elf-bfd.h rather than
3818 bfd/libelf.h.
3819
3820 Tue Oct 31 16:34:28 1995 David Mosberger-Tang <davidm@azstarnet.com>
3821
3822 * configure.in (alpha-*-linux*): Use ecoff.
3823 * configure: Rebuild.
3824 * ecoff.c (ecoff_directive_extern): New function.
3825 (ecoff_directive_weakext): New function.
3826 (ecoff_build_symbols): Handle weak symbols.
3827 (ecoff_setup_ext): Likewise.
3828 (ecoff_frob_symbol): Warn about weak common symbols.
3829 * ecoff.h (ecoff_directive_extern): Declare.
3830 (ecoff_directive_weakext): Declare.
3831 * symbols.c (S_IS_WEAK): New function.
3832 * symbols.h (S_IS_WEAK): Declare.
3833 * config/obj-ecoff.c (obj_pseudo_table): Add "extern" and
3834 "weakext".
3835 * config/tc-mips.c (mips_pseudo_table): Remove "extern".
3836 (s_extern): Remove.
3837
3838 Tue Oct 31 13:29:08 1995 Ian Lance Taylor <ian@cygnus.com>
3839
3840 * config/tc-ppc.c (ppc_lglobl): Do the right thing.
3841
3842 * config/tc-ppc.c (ppc_bb): Call SF_SET_PROCESS.
3843 (ppc_eb): Likewise. Set the storage class to C_BLOCK, not C_FCN.
3844 (ppc_frob_symbol): Don't change C_BLOCK symbols to C_HIDEXT.
3845 * config/obj-coff.c (coff_frob_symbol): Don't call
3846 SA_SET_SYM_ENDNDX with the current symbol; call it with the next
3847 one. If OBJ_XCOFF, try to figure out whether the symbol is going
3848 to be dropped.
3849
3850 * config/tc-ppc.c (md_pseudo_table): Add "bc" and "ec".
3851 (ppc_stab_symbol): New static variable.
3852 (ppc_change_csect): Check that ppc_toc_csect is not NULL.
3853 (ppc_stabx): Set ppc_stab_symbol around call to symbol_make. Set
3854 sy_tc.real_name to the stab string.
3855 (ppc_bc, ppc_ec): New static functions.
3856 (ppc_canonicalize_symbol_name): If ppc_stab_symbol is set, don't
3857 do anything.
3858 (ppc_symbol_new_hook): If ppc_stab_symbol is set, don't look for a
3859 suffix.
3860 (ppc_frob_symbol): Set BSF_NOT_AT_END for symbols with csect aux
3861 entries.
3862
3863 * input-scrub.c (input_scrub_push): Reset sb_index.
3864
3865 Mon Oct 30 17:52:46 1995 Ian Lance Taylor <ian@cygnus.com>
3866
3867 * listing.c (listing_newline): Don't create a frag in the absolute
3868 section.
3869
3870 Sat Oct 28 01:02:05 1995 Ian Lance Taylor <ian@cygnus.com>
3871
3872 * config/tc-ppc.c (md_pseudo_table): Add "data" and "text".
3873 (ppc_csect): Move most of the code to ppc_change_csect, and call
3874 it.
3875 (ppc_change_csect): New static function, taken from ppc_csect.
3876 (ppc_section): New static function.
3877 (ppc_saw_abs): New static varable.
3878 (ppc_frob_symbol): Create aux entry for absolute symbols. Warn if
3879 a symbol has no csect.
3880 (ppc_adjust_symtab): New function.
3881 * config/tc-ppc.h (tc_adjust_symtab): Define if OBJ_XCOFF.
3882 (ppc_adjust_symtab): Declare if OBJ_XCOFF.
3883
3884 * write.c (write_object_file): If tc_adjust_symtab is defined,
3885 call it just before the call to obj_adjust_symtab.
3886
3887 * symbols.c (symbol_find_or_make): Change name to be const.
3888 * symbols.h (symbol_find_or_make): Update declaration.
3889
3890 Thu Oct 26 19:18:27 1995 Ken Raeburn <raeburn@cygnus.com>
3891
3892 * doc/as.texinfo (Align): Mention SH.
3893 * doc/c-m68k.texi (M68K-Directives, .even): Describe behavior, not
3894 .align value.
3895 * doc/c-z8k.texi (Z8000 Directives, global): Fix minor typo.
3896 (Z8000 Directives, even): Don't give numeric align value, instead
3897 explain behavior.
3898
3899 Thu Oct 26 11:45:03 1995 Richard Earnshaw (rearnsha@armltd.co.uk)
3900
3901 * tc-arm.c (do_ldst): Assemble ldr/str r0, [r1] as a pre-increment
3902 instruction.
3903
3904 Wed Oct 25 11:59:24 1995 Per Bothner <bothner@kalessin.cygnus.com>
3905
3906 * Makefile.in (diststuff): Also make info.
3907 (maintainer-clean realclean): Also make clean-info.
3908
3909 Tue Oct 24 15:21:33 1995 Jeffrey A Law (law@cygnus.com)
3910
3911 * config/tc-hppa.c (md_pseudo_table): Add new ".nsubspa" opcode.
3912 (pa_subspace): For ".nsubspa", always create a new subspace
3913 with the given attributes, even if one already exists with the
3914 same name.
3915
3916 Tue Oct 24 14:50:38 1995 Michael Meissner <meissner@tiktok.cygnus.com>
3917
3918 * config/tc-ppc.h (TC_FORCE_RELOCATION_SECTION): Rename from
3919 TC_FORCE_RELOCATION, taking an additional section argument. If
3920 the section of the target symbol is not the same as the current
3921 section, always force the relocation to be used.
3922 (MD_PCREL_FROM_SECTION): New macro to call md_pcrel_from_section.
3923
3924 * config/tc-ppc.c (md_pcrel_from_section): Rename from the
3925 md_pcrel_from function, taking an additional section argument.
3926 Invoke TC_FORCE_RELOCATION_SECTION instead of TC_FORCE_RELOCATION.
3927
3928 * write.c (TC_FORCE_RELOCATION_SECTION): Define in terms of the
3929 older TC_FORCE_RELOCATION if not defined.
3930 (MD_PCREL_FROM_SECTION): If not defined, invoke md_pcrel_from.
3931 (fixup_segment): Use MD_PCREL_FROM_SECTION instead of
3932 md_pcrel_from, and TC_FORCE_RELOCATION_SECTION instead of
3933 TC_FORCE_RELOCATION.
3934
3935 Mon Oct 23 16:20:04 1995 Ken Raeburn <raeburn@cygnus.com>
3936
3937 * input-scrub.c (as_where): Set name to null pointer if we don't
3938 have a file name.
3939 * messages.c (identify): Only print filename if non-null.
3940 (as_show_where): Ditto, for line number too.
3941 (as_warn_internal, as_bad_internal): Ditto.
3942
3943 * input-file.c (input_file_open): If the input file can't be
3944 opened, consider it an error.
3945
3946 Mon Oct 23 11:15:44 1995 James G. Smith <jsmith@pasanda.cygnus.co.uk>
3947
3948 * config/tc-mips.c: Added mips_4100 control, and support for
3949 accepting the 4100 as a MIPS architecture variant (md_begin,
3950 macro_build, mips_ip, md_parse_option). Adding suitable
3951 command-line OPTIONs, and updating the help text (md_show_usage).
3952
3953 Wed Oct 18 13:20:32 1995 Ken Raeburn <raeburn@cygnus.com>
3954
3955 * subsegs.c (subseg_begin): Only set absolute_frchain.fix_* when
3956 BFD_ASSEMBLER is defined.
3957
3958 * Use one active frag and one obstack per frag chain:
3959 * frags.c (frags): Variable deleted.
3960 (frag_alloc): New function.
3961 (frag_grow, frag_more, frag_variant, frag_now_fix,
3962 frag_append_1_char): Refer to frchain_now->frch_obstack instead of
3963 frags variable.
3964 (frag_new): Ditto. Verify that frch_last and frag_now match on
3965 entry and exit, and that old frag_now has non-zero type. Replace
3966 "know" uses with "assert". Use frag_alloc instead of mucking with
3967 obstack alignment.
3968 * frags.h (frags): Declaration deleted.
3969 * subsegs.h (struct frchain): Add new field frch_frag_now.
3970 * subsegs.c (frchains, dummy_frag, absolute_frchain): New static
3971 variables.
3972 (subsegs_begin): Initialize frchains obstack. Under gcc, don't
3973 give it any stricter alignment than frchainS structures need. Do
3974 not initialize frags obstack. Set frag_now to point to
3975 dummy_obstack. Initialize absolute_frchain.
3976 (subseg_set_rest): Save and restore frag_now in frch_frag_now
3977 field of frchainS. Don't create new frags on section switch, and
3978 use frag_alloc when creating a new frag chain. For absolute
3979 section, set frchain_now to absolute_frchain. Verify that
3980 frch_last and frag_now match on entry and exit. Initialize
3981 per-chain obstack, and under gcc, set required alignment to that
3982 needed by fragS structure.
3983
3984 * write.c (chain_frchains_together_1): Verify fr_type is nonzero.
3985
3986 * stabs.c (get_stab_string_offset): Only copy input string if a
3987 fresh copy is needed, not if the section already exists.
3988 (s_stab_generic): Cache stab section name to bypass lookups, since
3989 usually it will match. Could be made faster still by changing the
3990 memory allocation rules.
3991 (s_xstab): Cache section name to bypass repeated string
3992 allocation.
3993
3994 * frags.c (frag_new): Deleted register declarations.
3995
3996 * listing.c (frag_now): Don't declare.
3997
3998 * as.c (chunksize): New variable.
3999 (debug_memory): New variable.
4000 (main): If debug_memory is set, reduce chunksize and
4001 _bfd_chunksize.
4002 * as.h (chunksize): Declare it.
4003 * read.c (read_begin): Use it.
4004
4005 * config/tc-alpha.c (md_shortopts): Include 'g'.
4006 (md_parse_option): Ignore it.
4007
4008 * Makefile.in (distclean): Remove Makefile and config.status from
4009 testsuite directory.
4010 (clean-here): Don't delete testsuite. Instead, delete only the
4011 files within it that would be generated by running tests.
4012
4013 * config/tc-hppa.c (hppa_elf_mark_end_of_function): Call
4014 frag_now_fix instead of accessing obstack info directly.
4015 * config/tc-arm.c (s_ltorg): Ditto.
4016 (md_assemble): Ditto.
4017
4018 * config/tc-i386.c (md_assemble): Call frag_grow instead of
4019 obstack_room.
4020
4021 Wed Oct 18 12:22:59 1995 Ken Raeburn <raeburn@cygnus.com>
4022
4023 * stabs.c (aout_process_stab): Insert debug symbol into symbol
4024 chain after parsing value expression, if any, to avoid separating
4025 continued .stabs lines.
4026
4027 Mon Oct 16 10:56:41 1995 Ian Lance Taylor <ian@cygnus.com>
4028
4029 * config/tc-mips.c (mips_elf_pseudo_table): Remove.
4030 (mips_pop_insert): Don't call pop_insert on mips_elf_pseudo_table.
4031
4032 Mon Oct 16 07:07:37 1995 Michael Meissner <meissner@wogglebug.tiac.net>
4033
4034 * config/tc-ppc.c (md_begin): Use new flags PPC_OPCODE_COMMON for
4035 -mcom support and PPC_OPCODE_ANY for -many.
4036 (md_parse_option): Ditto.
4037 (ppc_arch): Ditto.
4038 (md_begin): For duplicate instructions, print all duplicates
4039 before aborting.
4040
4041 Sun Oct 15 22:06:14 1995 Michael Meissner <meissner@cygnus.com>
4042
4043 * config/tc-ppc.c (md_parse_option): Support for -mcom to turn on
4044 common mode operation.
4045 (md_show_usage): Add -mcom to usage message.
4046
4047 Fri Oct 13 13:32:45 1995 steve chamberlain <sac@slash.cygnus.com>
4048
4049 * expr.c (op_rank): Add O_symbol_rva.
4050 * expr.h (operatorT): Add O_symbol_rva.
4051 * read.c (cons_worker): Set O_symbol_rva when necessary.
4052 * write.c (fix_new_exp): Understand O_symbol_rva.
4053
4054 Tue Oct 10 11:34:14 1995 Ian Lance Taylor <ian@cygnus.com>
4055
4056 * config/tc-mips.c: Correct s_cons arguments. From Michael
4057 Joosten <joost@ori.cadlab.de>.
4058
4059 Mon Oct 9 19:59:53 1995 Ian Lance Taylor <ian@cygnus.com>
4060
4061 * config/tc-ppc.c (ppc_macro): Make count unsigned.
4062 (ppc_biei): Set segment to now_seg and value to coff_n_line_nos.
4063 (ppc_frob_symbol): Handle C_BINCL and C_EINCL symbols by setting
4064 the fix_line field.
4065 * config/obj-coff.c (coff_n_line_nos): Rename from n_line_nos, and
4066 make non-static. Change all users.
4067 * config/obj-coff.h (coff_n_line_nos): Declare.
4068
4069 Fri Oct 6 16:24:27 1995 Ken Raeburn <raeburn@cygnus.com>
4070
4071 Mon Sep 25 22:49:32 1995 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
4072
4073 * configure.in (AC_ARG_WITH(bfd-assembler)): Fix help message.
4074
4075 * config/obj-elf.c (obj_elf_common): Convert specified byte
4076 alignment to power of two. Set size of local bss symbol.
4077
4078 * config/tc-m68k.c (tc_gen_reloc): Fix typo in variable name.
4079
4080 Fri Oct 6 15:22:25 1995 Ian Lance Taylor <ian@cygnus.com>
4081
4082 * sb.c, macro.c: Decide whether to include <string.h> or
4083 <strings.h> just as as.h does.
4084
4085 Fri Oct 6 09:55:33 1995 Doug Evans <dje@canuck.cygnus.com>
4086
4087 * Makefile.in (site.exp): Fix setting of $srcdir.
4088
4089 * config/tc-arm.c (md_atof): Fix little-endian output.
4090 * config/tc-arm.h (ARM_BI_ENDIAN): Move definition so defined for
4091 all coff targets.
4092
4093 Thu Oct 5 20:17:30 1995 Ken Raeburn <raeburn@cygnus.com>
4094
4095 * doc/as.texinfo: Split out the NS32k family documentation,
4096 despite its being commented out for now.
4097 * doc/c-ns32k.texi: New file.
4098
4099 * sb.c, macro.c: Include string.h.
4100
4101 * Makefile.in (comparison): Only check *.o; we don't care if
4102 timestamps inserted by the native linker differ.
4103
4104 * config/tc-alpha.c (alpha_align): Only fill with a no-op pattern
4105 if alignment stricter than 4 bytes is requested; in that case,
4106 align to a 4-byte boundary first.
4107
4108 Thu Sep 28 19:35:27 1995 Pat Rankin <rankin@eql.caltech.edu>
4109
4110 * config/obj-vms.c (VMS_RSYM_Parse): eliminate "might be used
4111 uninitialized" warning for `Max_Source_Offset'.
4112
4113 Wed Oct 4 16:17:02 1995 Kim Knuttila <krk@cygnus.com>
4114
4115 * config/tc-ppc.c (parse_toc_entry): New function to parse [toc]
4116 qualifiers and detect errors if present.
4117 (md_assemble): Add call to parse_toc_entry. Also added some support
4118 for the [tocv] qualifier.
4119 (ppc_pe_tocd): New function to support data in the toc section.
4120
4121 Wed Oct 4 14:03:39 1995 Ian Lance Taylor <ian@cygnus.com>
4122
4123 * config/tc-ppc.c (ppc_frob_symbol): Don't create an aux entry for
4124 an absolute symbol.
4125
4126 Tue Oct 3 12:18:19 1995 Ian Lance Taylor <ian@cygnus.com>
4127
4128 * config/tc-m68k.c (isword): Accept all values from -65536 to
4129 +65535, so ~VAL will not be rejected.
4130
4131 * cond.c (s_endif): Call demand_empty_rest_of_line. In MRI mode,
4132 skip characters after the pseudo-op.
4133 (s_else): Likewise.
4134 * read.c (get_line_sb): Don't look past buffer_limit.
4135 (s_include): In MRI mode, skip characters after the file name.
4136
4137 Mon Oct 2 16:15:27 1995 Ian Lance Taylor <ian@cygnus.com>
4138
4139 * config/m68k-parse.y (m68k_reg_parse): In MRI mode, permit
4140 periods in register names.
4141
4142 For older changes see ChangeLog.1.