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