blob: 49ad1176b4950fa4e9fdfcfe304fa0418ff32549 [file] [log] [blame]
2005-12-30 Sterling Augustine <>
Bob Wilson <>
* config/tc-xtensa.c (op_placement_info_struct): Delete single,
single_size, widest, and widest_size fields. Add narrowest_slot.
(xg_emit_insn_to_buf): Remove fmt parameter and compute it here.
Use xg_get_single_slot to find the slot.
(finish_vinsn): Use emit_single_op instead of bundle_single_op.
(bundle_single_op): Rename this to....
(bundle_tinsn): ...this function, which builds a vliw_insn but does
not call finish_vinsn.
(emit_single_op): Use bundle_tinsn instead of bundle_single_op.
(relax_frag_immed): Get num_slots from cur_vinsn.
(convert_frag_narrow): Update call to xg_emit_insn_to_buf.
(convert_frag_immed): Likewise. Also, get num_slots from cur_vinsn.
(init_op_placement_info_table): Set narrowest_slot field. Remove
code for deleted fields.
(xg_get_single_size): Return narrowest_size field, not single_size.
(xg_get_single_format): Return narrowest field, not single.
(xg_get_single_slot): New.
(tinsn_to_insnbuf): Rewrite to use tinsn_to_slotbuf.
* config/xtensa-relax.c (widen_spec_list): Add wide branch relaxations.
(transition_applies): Check wide branch option availability.
2005-12-29 Sterling Augustine <>
* config/tc-xtensa.h (MAX_MEM_FOR_RS_ALIGN_CODE): Define.
2005-12-29 Sterling Augustine <>
* config/tc-xtensa.c (tinsn_to_slotbuf): Do not zero slotbuf.
2005-12-27 Nathan Sidwell <>
* config/tc-mt.c (mt_arch): Default to ms1_16_002.
(md_parse_options): Only allow lowercase.
(md_show_usage): Update.
2005-12-27 Leif Ekblad <>
* configure.tgt: Add support for RDOS targets.
2005-12-27 James Troup <>
PR 1300
* config/tc-arm.c (md_apply_fix): Fix casts to match type in
printf format.
2005-12-27 Alan Modra <>
* Run "make dep-am".
* Regenerate.
* po/ Regenerate.
2005-12-22 Jan Beulich <>
* symbols.h (snapshot_symbol): First parameter is now pointer
to pointer to symbolS.
* symbols.c (snapshot_symbol): Likewise. Store resulting symbol
there. Use symbol_equated_p.
* expr.c (resolve_expression): Change first argument to
snapshot_symbol. Track possibly changed add_symbol consistently
across function. Resolve more special cases with known result.
Also update final_val when replacing add_symbol.
2005-12-13 Jan-Benedict Glaw <>
* config/tc-vax.c: Convert to ISO C90 format. Fix formatting and
white space usage as well.
2005-12-20 Sterling Augustine <>
* config/tc-xtensa.c (xtensa_mark_narrow_branches): Set
is_aligning_branch flag.
(find_address_of_next_align_frag): Limit by xtensa_fetch_width.
(future_alignment_required): Except for frags with is_aligning_branch
flag set, call frag_wane for frags that do not need to be reexamined
for aligning.
(relax_frag_immed): Replace orig_vinsn with cur_vinsn to fix a leak.
(convert_frag_immed): Likewise.
(convert_frag_narrow): Check is_aligning_branch flag.
* config/tc-xtensa.h (xtensa_frag_type): Add is_aligning_branch flag.
2005-12-20 Sterling Augustine <>
* config/tc-xtensa.c (xg_find_narrowest_format): Optimize 1 slot case.
(xg_init_vinsn): Remove redundant initialization.
(xg_clear_vinsn): Zero all the slots with a single memset.
* config/xtensa-istack.h (vliw_insn): Move insnbuf field after slots.
2005-12-20 Nathan Sidwell <>
* doc/t-mt.texi: Update MS1 to MT.
2005-12-16 Nathan Sidwell <>
Second part of ms1 to mt renaming.
* configure: Rebuilt.
* (mt): Remove special case.
* config/tc-mt.c (opcodes/mt-desc.h, opcodes/mt-opc.h): Change
(mt_insn, mt_mach, mt_mach_bitmask, mt_flags, mt_architectures):
Rename, adjust.
(md_parse_option, md_show_usage, md_begin, md_assemble,
md_cgen_lookup_reloc, md_atof): Adjust.
(mt_force_relocation, mt_apply_fix, mt_fix_adjustable): Rename, adjust.
* config/tc-mt.h (TC_MT): Rename.
(md_apply_fix): Adjust.
(mt_apply_fix, mt_fix_adjustable, mt_force_relocation): Rename.
(TC_FORCE_RELOCATION, tc_fix_adjustable): Adjust.
2005-12-14 Jan Beulich <>
* config/tc-i386.c (add_prefix): More fine-grained handling of
REX prefixes. Or new prefix value into i.prefix instead of
2005-12-13 DJ Delorie <>
* config/tc-m32c.c (m32c_md_end): Only pad code sections.
2005-12-12 Paul Brook <>
* config/tc-arm.c (do_branch): Generate EABI branch relocations.
(do_bl): New function.
(do_blx): Generate BFD_RELOC_ARM_PCREL_CALL relocation.
(do_t_blx): Generate BFD_RELOC_THUMB_PCREL_BRANCH23.
(insns): Use do_bl.
(md_pcrel_from_section): Add BFD_RELOC_ARM_PCREL_CALL and
(md_apply_fix): Merge BFD_RELOC_ARM_PCREL_BRANCH and
(tc_gen_reloc): Handle BFD_RELOC_ARM_PCREL_CALL and
2005-12-12 Nathan Sidwell <>
* Replace ms1 arch with mt arch.
* configure: Rebuilt.
* configure.tgt: Replace ms1 arch with mt arch.
* config/tc-mt.c: Renamed from tc-ms1.c: Update include files.
* doc/ (CPU_DOCS): Replace ms1 files with mt files.
* doc/ Rebuilt.
2005-12-07 Hans-Peter Nilsson <>
Change 32-bit-branch expansion for --pic.
* config/tc-cris.c (STATE_COND_BRANCH_PIC): New relaxation state.
(md_cris_relax_table): Add entry for STATE_COND_BRANCH_PIC.
(cris_any_v0_v10_long_jump_size_pic): New macro.
(md_estimate_size_before_relax): Handle STATE_COND_BRANCH_PIC.
(md_convert_frag): Similar.
(md_create_long_jump): Change 32-bit-branch expansion for --pic.
(md_assemble, gen_cond_branch_32): Adjust similarly.
(md_parse_option) <case OPTION_PIC>: Adjust md_long_jump_size.
<case OPTION_ARCH>: Similar, if --pic.
2005-12-06 H.J. Lu <>
PR gas/1874
* config/tc-i386.c (match_template): Handle monitor.
(process_suffix): Likewise.
2005-12-05 John David Anglin <>
Bug gas/1948
* symbols.c (colon): Also check if now_seg is bss_section when a symbol
is being redefined.
2005-12-02 Arnold Metselaar <>
* config/tc-z80.c (emit_ldreg): fix bug in ld rr,<xx>
2005-11-26 Arnold Metselaar <>
* config/tc-z80.c (z80_start_line_hook): issue an error when
redefining a symbol with equ
* doc/as.texinfo(equ<z80>): mention difference with .equiv
* doc/as.texinfo(err): fix typo
* doc/c-z80.texi(equ): redefining a symbol with equ is no longer
2005-11-24 John David Anglin <>
Bug gas/1896
* config/tc-hppa.c (hppa_fix_adjustable): Don't reject for reduction
R_HPPA relocations that are 32-bits wide.
2005-11-23 Daniel Jacobowitz <>
Thiemo Seufer <>
* config/tc-mips.c (append_insn): Handle BFD_RELOC_16_PCREL_S2.
(macro_build): Complain for invalid branch displacements.
(mips_validate_fix): Delete.
(md_apply_fix): Re-add pcrel support for branches. Use consistent
text for misaligned branch targets.
(tc_gen_reloc: Re-add pcrel support for branches. Handle strange
BFD pcrel processing. Remove error for unresolved branches.
* config/tc-mips.h (TC_VALIDATE_FIX, mips_validate_fix): Delete.
2005-11-22 James E Wilson <>
* config/tc-ia64.c (emit_one_bundle): Perform last_slot < 0 check
even when manual_bundling isn't set.
* config/tc-ia64.c (slot_index): Emit an error instead of a warning
when the frag chain is broken by section switching.
2005-11-18 Jie Zhang <>
* config/bfin-defs.h (IS_BREG, IS_LREG): New macros.
* config/bfin-parse.y (asm_1): Check register type for load immediate
2005-11-17 Alexandre Oliva <>
* config/tc-ppc.c (ppc_frob_file_before_adjust): Do not reference
* write.c (write_object_file): Do not remove used weakrefd.
2005-11-17 Jan Beulich <>
* dw2gencfi.c (dot_cfi): Put argument parsing for cases
DW_CFA_restore and DW_CFA_undefined in a loop.
2005-11-17 Jan Beulich <>
* symbols.h (S_CLEAR_VOLATILE): Declare.
* symbols.c (colon): Also accept redefinable symbols for
redefinition. Clone them before modifying.
* cond.c (s_ifdef): Also test for equated symbols.
* read.c (s_comm_internal): Also exclude non-redefinable
equated symbols. Clone redefinable ones before modifying.
(s_weakref): Clone redefinable symbols before modifying.
* doc/internals.texi: Document sy_volatile, sy_forward_ref,
2005-11-16 Alan Modra <>
* config/tc-hppa.c (pa_comm): Set bfd_com_section segment.
2005-11-16 Alan Modra <>
* configure.tgt (i386-*-gnu*): Set em=gnu.
* config/te-gnu.h: New file.
* config/tc-i386.c: Don't use '/' as comment char for TE_GNU.
2005-11-16 Alan Modra <>
* config/tc-ppc.c (ppc_pe_comm): Set bfd_com_section segment.
* config/tc-alpha.c (s_alpha_comm): Likewise. Also, remove
redundant check.
* read.c (s_lsym): Remove non-BFD assembler sym handling.
2005-11-16 Alan Modra <>
* read.c (s_comm_internal): Set bfd_com_section segment.
(s_mri_common): Likewise.
* write.c (write_object_file): Remove non-BFD assembler common
sym handling.
2005-11-15 Daniel Jacobowitz <>
* config/tc-arm.c (s_arm_unwind_save_core): Don't emit an extra
opcode if r4-r15 are not saved.
2005-11-15 Alan Modra <>
* symbols.c (S_GET_VALUE): Remove non-BFD assembler recursion guard.
2005-11-14 Jan Beulich <>
* config/tc-ia64.c (AR_FCR, AR_EFLAG, AR_CSD, AR_SSD, AR_CFLG,
(ar): Use AR_* instead of literals.
CR_PMV, CR_CMCV): Define.
(cr): Use CR_* instead of literals.
2005-11-14 Jan Beulich <>
* config/tc-ia64.c (md): Rename regsym to indregsym and move
it to the end of the structure.
(ar): Field regnum is unsigned.
(cr): Likewise:
(indirect_reg): Likewise.
(declare_register_set): Parameter regnum is unsigned.
(declare_register): Parameter numregs and base_regnum are
unsigned. So is the local loop variable.
(md_begin): Restrict scope of local variable regnum, which
also is unsigned. Replace loops with function calls where
possible. Re-order things so that register groups are kept
together. Remove all uses of regsym except for indirect
registers. Replace use of regsym by indregsym for indirect
(ia64_optimize_expr): Replace use of regsym by indregsym for
indirect registers, with appropriate bias.
2005-11-14 David Ung <>
* config/tc-mips.c (mips16_ip): Add handling of 'm' and 'M' codes
for the MIPS16e save/restore instructions.
2005-11-11 Jan Beulich <>
* doc/ Make asconfig.texi writeable before trying
to write to it.
* doc/ Refresh.
2005-11-10 Jan Beulich <>
* config/tc-i386.c (intel_e11): Don't special-case segment
registers in brackets.
2005-11-10 Nick Clifton <>
* config/tc-arm.c (BAD_ADDR_MODE): Define.
(arm_reg_parse_multi): Return NULL rather than FAIL.
(arm_reg_parse): Fix comment, the function returns FAIL rather
than NULL if it is unable to parse the register name.
(do_ldrex): Use BAD_ADDR_MODE.
Change error message for PC-relative addressing.
(do_strex): Likewise.
(do_t_ldrex): Use BAD_ADDR_MODE.
(do_t_strex): Likewise.
2005-11-08 Jean-Jacques Metayer <>
* config/tc-sparc.c (isoctal): Fix thinko.
2005-11-08 Arnold Metselaar <>
* expr.c (operand <case '$'>): Use DOLLAR_AMBIGU rather than
flag_mri_m68k as condition for parsing the '$' as a prefix.
* as.h (DOLLAR_AMBIGU): Define if needed.
2005-11-08 Nathan Sidwell <>
Add ms2 support.
* config/tc-ms1.c (ms1_mach_bitmask): Initialize to MS1.
(ms1_architectures): Add ms2.
(md_parse_option): Add ms2.
(md_show_usage): Add ms2.
(md_assemble): Add JAL_HAZARD detection logic.
(md_cgen_lookup_reloc): Add MS1_OPERAND_LOOPSIZE case.
* doc/c-ms1.texi: New.
* doc/all.texi: Add MS1.
* doc/ (CPU_DOCS): Add c-ms1.texi.
* doc/ Rebuilt.
* doc/Makefile: Rebuilt.
2005-11-07 Steve Ellcey <>
* configure: Regenerate after modifying bfd/warning.m4.
2005-11-07 John David Anglin <>
PR gas/1804
* config/tc-hppa.c (md_apply_fix): Use number_to_chars_bigendian to
output constant data.
2005-11-07 Mark Mitchell <>
* doc/ (asconfig.texi): Set top_srcdir.
* doc/ Regenerated.
* doc/as.texinfo: Document "@FILE".
2005-11-07 Nick Clifton <>
PR binutils/1568
* config/obj-coff.c (obj_coff_section): Set readonly flag with the
'x' attribute. Remember the actions of the 'w' and 'n' attributes
and do not allow the 'x','s' or 'd' attributes to change them.
2005-11-07 John Levon <>
* config/tc-i386.h (tc_comment_chars): Define.
* config/tc-i386.c (line_comment_chars): Use '/' unconditionally.
(i386_comment_chars): Add.
(md_parse_options): Process OPTION_DIVIDE.
(md_show_usage): Describe --divide option.
* doc/c-i386.texi: Document --divide option.
2005-11-07 Arnold Metselaar <>
* expr.c (op_encoding): Map '=' to O_SINGLE_EQ, if defined.
* config/tc-z80.h: Define O_SINGLE_EQ as O_eq.
2005-11-07 Alan Modra <>
* macro.c (buffer_and_nest): Skip labels regardless of
NO_PSEUDO_DOT and flag_m68k_mri.
2005-11-07 Arnold Metselaar <>
* expr.c (integer_constant): Match only 'B' as binary suffix if
2005-11-04 Alexandre Oliva <>
* read.c (s_weakref): Do not permit redefinitions.
* symbols.c (colon): Do not permit redefinitions of equated
2005-11-01 Thiemo Seufer <>
PR gas/1299
* Disable -Werror for the itbl-lex.o rule.
* Regenerate.
2005-11-01 Thiemo Seufer <>
* config/tc-mips.c (md_parse_option): Fix typo in comment.
2005-10-30 Mark Mitchell <>
* as.c (show_usage): Document "@FILE".
2005-10-30 H.J. Lu <>
* (OBJ_FORMATS): Remove vms.
Run "make dep-am".
* Regenerated.
* dep-in.sed: Replace " ./" with " ".
2005-10-28 Dave Brolley <>
Contribute the following change:
2005-09-19 Dave Brolley <>
* config/tc-m32c.c (default_isa): New static variable.
(m32c_isa): Now of type CGEN_BITSET.
(md_begin): Pass &m32c_isa to m32c_cgen_cpu_open.
2005-10-28 Paul Brook <>
* config/tc-arm.c (aeabi_set_public_attributes): Use selected_cpu
instead of mcpu_cpu_opt.
2005-10-27 Sterling Augustine <>
* config/tc-xtensa.c (find_vinsn_conflicts): Change error messages to
refer to "ports" instead of "queues".
(check_t1_t2_reads_and_writes): Pass correct interface values to
2005-10-27 Jan Beulich <>
* read.c (assign_symbol): Also consider equates already defined.
* symbols.c (symbol_clone): Also clone the underlying BFD symbol.
* config/obj-coff.h (obj_symbol_clone_hook): New.
(coff_obj_symbol_clone_hook): Declare.
* config/obj-coff.c (coff_obj_symbol_clone_hook): New.
2005-10-26 DJ Delorie <>
* config/tc-m32c.c (md_relax_table, subtype_mappings,
md_convert_frag): Add jsr.w support.
* config/tc-m32c.c (md_assemble): Don't use errmsg as the format
(md_cgen_lookup_reloc): Add m32c bitbase operands. Add 8-s24
and imm-8-HI operands.
2005-10-26 Paul Brook <>
* config/tc-arm.c (insns): Correct "sel" entry.
2005-10-26 Jan Beulich <>
* config/tc-i386.c (i386_operand): Don't check register prefix here.
(parse_real_register): Rename from parse_register.
(parse_register): New.
(i386_parse_name): New.
(md_operand): New.
(intel_e11): Don't tolerate registers in offset expressions anymore.
(intel_get_token): Don't check register prefix here. Copy the actual
register token, not the canonical register name.
* config/tc-i386.h (md_operand): Delete.
(i386_parse_name): Declare.
(md_parse_name): Define.
2005-10-25 Arnold Metselaar <>
* Add Z80 cpu.
* Regenerated.
* app.c (do_scrub_chars)<TC_Z80>: Correctly scrub "ex af,af'"
and disallow newlines in quoted strings.
* configure.tgt: Add z80-*-coff.
* config/obj-coff.h: Add format "coff-z80".
* doc/ Add c-z80.texi.
* doc/ Regenerated.
* doc/all.texi: Add Z80.
* doc/c-z80.texi: New file
* doc/as.texinfo: Add z80 options and some z80-related remarks.
* config/tc-z80.c: New file
* config/tc-z80.h: New file
* NEWS: Mention new support.
2005-10-25 H.J. Lu <>
* write.c (adjust_reloc_syms): Undo the change made on
2005-04-26 to allow local symbol set to undefined symbol.
2005-10-24 H.J. Lu <>
* ( Removed.
(bfin-parse.h): Added.
* Regenerated.
2005-10-25 Alan Modra <>
* po/ Regenerate.
* po/gas.pot: Regenerate.
2005-10-24 Bernd Schmidt <>
* config/tc-bfin.c (Expr_Node_Gen_Reloc): If have symbol + constant,
make a single reloc with an offset rather than a stack.
* config/tc-bfin.h (MD_APPLY_SYM_VALUE): Define to 0.
2005-10-24 Alexandre Oliva <>
* read.c (potable): Add weakref.
(s_weakref): New.
* read.h (s_weakref): Declare.
* struc-symbol.h (struct symbol): Add sy_weakrefr and sy_weakrefd.
* symbols.c (colon): Clear weakrefr.
(symbol_find_exact): Rename to, and reimplement in terms of...
(symbol_find_exact_noref): ... new function.
(symbol_find): Likewise...
(symbol_find_noref): ... ditto.
(resolve_symbol_value): Resolve weakrefr without setting their
(S_SET_WEAK): Call hook.
(S_GET_VALUE): Follow weakref link.
(S_SET_VALUE): Clear weakrefr.
(S_IS_WEAK): Follow weakref link.
(symbol_set_value_expression, symbol_set_frag): Clear weakrefr.
(symbol_mark_used): Follow weakref link.
(print_symbol_value_1): Print weak, weakrefr and weakrefd.
* symbols.h (symbol_find_noref, symbol_find_exact_noref): Declare.
* write.c (adust_reloc_syms): Follow weakref link. Do not
complain if target is undefined.
(write_object_file): Likewise. Remove weakrefr symbols. Drop
unreferenced weakrefd symbols.
* config/obj-coff.c (obj_frob_symbol): Do not force WEAKREFD
symbols EXTERNAL.
(pecoff_obj_set_weak_hook, pecoff_obj_clear_weak_hook): New.
* config/obj-coff.h (obj_set_weak_hook, obj_clear_weak_hook): Define.
* doc/as.texinfo: Document weakref.
* doc/internals.texi: Document new struct members, internal
functions and hooks.
2005-10-24 Jie Zhang <>
* (bfin-parse.h): Renamed from
(EXTRA_DIST): Add bfin-parse.h and bfin-lex.c.
* Regenerate.
* config/bfin-lex.l: Include bfin-parse.h instead of
* config/tc-bfin.c (md_chars_to_number): Change the type of first
argument from unsigned char * to char * to remove signedness warnings.
2005-10-24 Jan Beulich <>
* config/tc-ia64.c (enum reg_symbol): Delete IND_MEM.
(dot_rot): Change type of num_* variables. Check for positive count.
(ia64_optimize_expr): Re-structure.
(md_operand): Check for general register.
2005-10-24 Jan Beulich <>
* config/tc-ia64.c (declare_register): Call symbol_create.
(md_begin): Remove local variables total, ar_base, and cr_base.
Start loops for registers at their respective first one. Don't
update md.regsym for alias names. Generate alias name tp for r13.
2005-10-21 DJ Delorie <>
* config/tc-m32c.c (md_cgen_lookup_reloc): Add more relocs. Print
names unstead of numbers.
2005-10-19 David Ung <>
* config/tc-mips.c (append_insn): Convert MIPS16 jr/jalr jumps
into jrc/jalrc versions if ISA_MIPS32+ and not doing the swap,
hence avoiding to emit a nop.
2005-10-19 Jie Zhang <>
* config/tc-bfin.c (md_begin): Let the lex_type of '(' be
(bfin_start_line_hook): Remove the workaround for LSETUP(.
(bfin_name_is_register): Remove the workarounds for LSETUP(
and SAA(.
(bfin_start_label): Ditto.
2005-10-18 Bob Wilson <>
* config/tc-xtensa.c (xtensa_end_directive): Restore
default_lit_sections regardless of use_literal_section.
2005-10-18 Jie Zhang <>
* (bfin-lex.c): Update ylwrap invocation.
* Regenerated.
2005-10-18 Arnold Metselaar <>
* doc/as.texinfo (.loc) Fix placement of '@end table'.
2005-10-17 Bob Wilson <>
* config/xtensa-istack.h (TInsn): Replace dwarf2_line_info with an
unsigned line number. Do not include "dwarf2dbg.h".
* config/tc-xtensa.c (md_pseudo_table): Remove entry for "loc".
(xtensa_dwarf2_directive_loc, xtensa_dwarf2_emit_insn): Delete.
(xg_build_to_insn, xg_build_token_insn): Update TInsn uses.
(md_assemble): Use as_where instead of dwarf2_where.
(xg_assemble_vliw_tokens): Use unsigned line numbers instead of
dwarf2_line_infos. Change to call new_logical_line followed by
2005-10-14 Mike Frysinger <>
* doc/as.texinfo (Section): Add missing ']' to .section example.
2005-10-12 John David Anglin <>
PR binutils/941
* config/tc-hppa.c (pa_ip): Use as_bad instead of as_fatal when an
unknown opcode is found.
2005-10-12 Mark Mitchell <>
* NEWS: Mention @file.
2005-10-12 Nick Clifton <>
* config/tc-avr.c: Convert to ISO C90 format. Fix formatting and
generally tidy up the code.
* config/tc-avr.h: Likewise.
2005-10-12 Jan Beulich <>
* config/tc-ia64.c (dot_reg_val): Use expression_and_evaluate.
(dot_pred_rel): Likewise.
(parse_operand): Likewise.
(ia64_unrecognized_line): Likewise.
(md_operand): Likewise.
2005-10-11 Jan Beulich <>
* expr.h (enum expr_mode): New.
(expression): Pass third argument to expr.
(expression_and_evaluate): New.
(deferred_expression): New.
(expr): Add third parameter.
(resolve_expression): New.
* struc-symbol.h (struct symbol): New members sy_volatile and
* symbols.c, symbols.h (symbol_clone): New.
(symbol_clone_if_forward_ref): New.
(snapshot_symbol): New.
* as.c (macro_expr): Use expression_and_evaluate.
* cond.c (s_if): Likewise.
(s_elseif): Likewise.
* dw2gencfi.c (cfi_parse_reg): Likewise.
* expr.c (operand): Add second parameter. Optionally call
deferred_expression. Pass mode argument to itself and md_parse_name.
Check mode before trying to evaluate symbol. Call
symbol_clone_if_forward_ref for both operands.
(expr): Add third parameter. Pass mode to operand and itself.
Optionally call resolve_expression.
(resolve_expression): New.
(get_single_number): Pass second argument to operand.
* read.c (potable): New entry for .eqv.
(read_a_source_file): Handle new == operator.
(get_absolute_expr): Use expression_and_evaluate.
(s_lsym): Likewise.
(assign_symbol): Rename second parameter. Call symbol_clone on
legal and illegal redefinition. Call S_SET_VOLATILE and
S_SET_FORWARD_REF depending on mode.
(s_set): Update description.
(s_space): Call resolve_expression.
(pseudo_set): Optionally call deferred_expression. Check
S_IS_FORWARD_REF before trying to simplify/resolve an expression.
(equals): Handle ==.
* config/tc-ia64.h (md_parse_name): Add mode parameter.
* config/tc-arc.c (arc_parse_cons_expression): Likewise.
* config/tc-m32r.h (md_parse_name): Likewise.
(m32r_parse_name): Likewise.
* config/tc-mmix.h (md_parse_name): Likewise.
* config/tc-mn10300.h (md_parse_name): Likewise.
(mn10300_parse_name): Likewise.
* config/tc-ppc.h (md_parse_name): Likewise.
* config/tc-sh.h (md_parse_name): Likewise.
(sh_parse_name): Likewise.
* config/tc-sh64.h (md_parse_name): Likewise.
(sh64_consume_datalabel): Likewise.
* config/tc-tic54x.h (md_parse_name): Likewise.
* config/tc-m32r.c (m32r_parse_name): Add mode parameter. Check it
before trying to evaluate symbol.
* config/tc-mn10300.c (mn10300_parse_name): Likewise.
* config/tc-sh.c (sh_parse_name): Likewise.
* config/tc-sh64.c (sh64_consume_datalabel): Add mode parameter. Pass
second argument to operandf. Pass mode parameter to sh_parse_name.
* doc/as.texinfo: Document .eqv and the == assignment operator.
2005-10-10 Ian Lance Taylor <>
* (EXTRA_DIST): Remove bfin-lex.l and bfin-defs.h.
* Regenerate.
2005-10-10 Arnold Metselaar <>
* expr.c (operator): Allow "!=" as a synonym for "<>".
* doc/as.texinfo (Infix Op): Mention "!=".
2005-10-08 John David Anglin <>
* config/tc-hppa.c (strict): Don't initialize. Update comment.
(pa_ip): Promote from PA 1.0 to 1.1 immediately when 1.1 match is
found. Simplify handling of "ma" and "mb" completers.
2005-10-08 Paul Brook <>
* config/tc-arm.c: Don't provide fallback default for CPU_DEFAULT.
(arm_arch_used, thumb_arch_used, selected_cpu, selected_cpu_name):
New variables.
(arm_cpu_option_table): Add canonical_name.
(arm_cpus): Populate canonical_name field.
(s_arm_eabi_attribute, s_arm_arch, s_arm_cpu, s_arm_fpu,
aeabi_set_public_attributes, arm_md_end): New functions.
(md_pseudo_table): Add "cpu", "arch", "fpu" and "eabi_attribute".
(md_assemble): Set thumb_arch_used and arm_arch_used.
(md_begin): Set defaut cpu if CPU_DEFAULT not defined.
* config/tc-arm.h (md_end): Define.
* doc/c-arm.texi: Document .cpu, .arch, .fpu and .eabi_attribute.
2005-10-06 Khem Raj <>
NIIBE Yutaka <>
* config/tc-sh.c (allow_dollar_register_prefix): New variable.
(parse_reg_without_prefix): New function.
(parse_reg): Check for '$' register prefix if --allow-reg-prefix is
(option md_longopts): Add allow-reg-prefix option.
* doc/c-sh.texi: Document --allow-reg-prefix option.
* NEWS: Mention the new switch.
2005-10-03 Arnold Metselaar <>
* doc/as.texinfo (Infix Ops): '<' and '>' are not shift
2005-09-30 Sterling Augustine <>
Bob Wilson <>
* config/tc-xtensa.c (xtensa_frob_label): Disallow labels in bundles.
2005-09-30 H.J. Lu <>
* Run "make dep-am".
* Regenerated.
* aclocal.m4: Likewise.
2005-09-30 Mark Mitchell <>
* as.c (main): Use expandargv.
2005-09-30 Jan Beulich <>
* config/tc-tic4x.c (tic4x_set): Advance input_line_pointer past
(removed) comma.
2005-09-30 Catherine Moore <>
* Bfin support.
* Regenerated.
* aclocal.m4: Regenerated.
* configure: Regenerated.
* Bfin support.
* configure.tgt: Bfin support.
* config/bfin-aux.h: New file.
* config/bfin-defs.h: New file.
* config/bfin-lex.l: New file.
* config/bfin-parse.y: New file.
* config/tc-bfin.c: New file.
* config/tc-bfin.h: New file.
* doc/ Recognize c-bfin.texi.
* doc/ Regenerated.
* doc/all.texi: Bfin support.
* doc/as.texinfo: Likewise.
* doc/c-bfin.texi: Document bfin-specific syntax and
2005-09-30 Paul Brook <>
* config/tc-arm.c (opcode_tag): Add OT_cinfix3_legacy.
(opcode_lookup): Handle OT_cinfix3_legacy. Revert earlier change for
normal infix conditions.
(C3E): Include Thumb-2 definition.
(CL, cCL): Define.
(insns): Use them for legacy mnemonics.
2005-09-30 Matthias Kurz <>
* asintl.h: Prevent the inclusion of <libintl.h> from the Solaris
version of <locale.h> when ENABLE_NLS is not defined.
2005-09-29 Jan Beulich <>
* config/tc-ia64.c (parse_operands): Always parse first operand of
2005-09-29 Arnold Metselaar <>
Alan Modra <>
* app.c (do_scrub_chars): Match open and close quote of strings.
Remove redundant EOF test in case 7.
2005-09-28 Jan Beulich <>
* config/tc-i386.c (reloc): Disable signedness check for 4-byte
relocations in 16- and 32-bit modes.
(i386_displacement): Make pc-relative branch handling dependent
upon operand (rather than address) size.
2005-09-28 Jan Beulich <>
* dw2gencfi.c (dot_cfi): Call ignore_rest_of_line when not fully
parsing the input.
(dot_cfi_startproc): Likewise.
(dot_cfi_endproc): Likewise. Also check no extra input was given.
(dot_cfi_escape): Likewise.
2005-09-28 Jan Beulich <>
* config/tc-i386.h (x86_cons_fix_new): Declare unconditionally.
(TC_CONS_FIX_NEW): Define unconditionally.
(x86_pe_cons_fix_new): Remove.
* config/tc-i386.c (signed_cons): New.
(md_pseudo_table): Add slong.
(x86_cons_fix_new): Declare unconditionally.
(x86_pe_cons_fix_new): Merge into x86_cons_fix_new.
(tc_gen_reloc): Also consider BFD_RELOC_X86_64_32S for gotpc
2005-09-28 Arnold Metselaar <>
* app.c (do_scrub_chars <LEX_IS_SYMBOL_COMPONENT>): Check for full
buffer after copying string.
2005-09-27 Paul Brook <>
* config/arm.c (arm_cpus): Add more cpu names.
* doc/c-arm.texi: Document them.
2005-09-21 Alan Modra <>
* read.c (pseudo_set): Don't set undefined symbols to expr_section.
2005-09-20 Richard Henderson <>
* dwarf2dbg.c (process_entries): Fix uninitialized variable warning.
2005-09-20 Richard Henderson <>
* dwarf2dbg.c (struct line_entry): Replace frag and frag_ofs
with label.
(dwarf2_loc_mark_labels): New.
(dwarf2_gen_line_info_1): Split out of ...
(dwarf2_gen_line_info): ... here. Create the temp symbol here.
(dwarf2_emit_label): New.
(dwarf2_directive_loc_mark_labels): New.
(out_set_addr): Take a symbol instead of frag+ofs.
(relax_inc_line_addr): Likewise.
(emit_inc_line_addr): Assert delta non-negative.
(process_entries): Remove dead code. Update to work with temp
symbols instead of frag+ofs.
* dwarf2dbg.h (dwarf2_directive_loc_mark_labels): Declare.
(dwarf2_emit_label, dwarf2_loc_mark_labels): Declare.
* config/obj-elf.c (elf_pseudo_tab): Add loc_mark_labels.
* config/obj-elf.h (obj_frob_label): New.
* config/tc-alpha.c (alpha_define_label): Call dwarf2_emit_label.
* config/tc-arm.c, config/tc-hppa.c, config/tc-m68k.c,
config/tc-mips.c, config/tc-ppc.c, config/tc-sh.c, config/tc-xtensa.c:
Similarly in the respective tc_frob_label implementation functions.
* config/tc-i386.c (md_pseudo_table): Move file and loc to
non-elf section; add loc_mark_labels.
* config/tc-ia64.c (struct label_fix): Add dw2_mark_labels.
(ia64_flush_insns): Check for marked labels; emit line entry if so.
(emit_one_bundle): Similarly.
(ia64_frob_label): Record marked labels.
* config/tc-m68hc11.h (tc_frob_label): Remove.
* config/tc-ms1.c (md_pseudo_table): Remove file and loc.
* config/tc-sh.h (tc_frob_label): Pass sym to sh_frob_label.
* config/tc-sh64.h (tc_frob_label): Likewise.
* doc/as.texinfo (LNS directives): Docuement .loc_mark_blocks.
2005-09-20 Alan Modra <>
* read.c (pseudo_set): Set segment of expression syms to expr_section.
2005-09-14 Jan Beulich <>
* config/tc-i386.c (tc_x86_regname_to_dw2regnum): Add selector
registers, floating point control and status words, and mxcsr as
well as (for 64-bit code) segment base registers and rflags.
2005-09-09 Dmitry Diky <>
* config/tc-msp430.c (msp430_operands): Undo last changes. Instead...
(msp430_relax_frag): add a guard check to ensure that final fr_subtype
has been reached.
2005-09-08 Chao-ying Fu <>
* doc/as.texinfo: Document -mdsp and -mno-dsp options.
* doc/c-mips.texi: Likewise, and document ".set dsp" and ".set nodsp"
2005-09-08 Paul Brook <>
* config/tc-arm.c (do_smi, do_t_smi): Rename ...
(do_smc, do_t_smc): ... to this.
(insns): Remane smi to smc.
(md_apply_fix, tc_gen_reloc): Rename BFD_RELOC_ARM_SMI to
2005-09-07 Richard Henderson <>
* dwarf2dbg.c (dwarf2_where): Set line->isa.
(dwarf2_set_isa): New.
(dwarf2_directive_loc): Rearrange to allow all options on one line.
* dwarf2dbg.h (dwarf2_set_isa): Declare.
* doc/as.texinfo: Update .loc documentation.
2005-09-07 Richard Henderson <>
* dwarf2dbg.c: Include safe-ctype.h.
(current): Initialize.
(dwarf2_emit_insn): Clear DWARF2_FLAG_BASIC_BLOCK,
(dwarf2_directive_file): Cope with invalid filename.
(dwarf2_directive_loc): Add handling for basic_block, prologue_end,
epilogue_begin, is_stmt, isa.
(emit_inc_line_addr): Move line_delta == 0, addr_delta == 0 special
case down lower.
(process_entries): Handle isa, DWARF2_FLAG_PROLOGUE_END,
(out_debug_line): Emit sizes for DW_LNS_set_prologue_end,
DW_LNS_set_epilogue_begin, DW_LNS_set_isa.
* dwarf2dbg.h (DWARF2_FLAG_IS_STMT): Rename from DWARF2_FLAG_BEGIN_STMT.
(struct dwarf2_line_info): Add isa member.
* doc/as.texinfo (LNS directives): New node.
2005-09-07 David Ung <>
* config/tc-mips.c (append_insn): Undo last change. Instead add
guard to suppress calling frag_grow if the current instruction is
one that allows a delay slot.
2005-09-06 Chao-ying Fu <>
* config/tc-mips.c (mips_set_options): Add ase_mt for MT instructions.
(mips_opts): Add -1 to initialize ase_mt.
(file_ase_mt): New variable for -mmt.
(CPU_HAS_MT): New define.
(validate_mips_insn): Add supports for +t, +T, !, $, *, &, g operand
(mips_ip): Check ase_mt to enable MT instructions.
Handle !, $, *, &, +T, +t, g operand formats.
For "mftc1", "mfthc1", "cftc1", "mttc1", "mtthc1", "cttc1", we allow
odd float registers.
(OPTION_MT, OPTION_NO_MT): New define.
(OPTION_COMPAT_ARCH_BASE): Change because of inserting MT define.
(md_parse_option): Parse OPTION_MT and OPTION_NO_MT.
(mips_after_parse_args): Set ase_mt based on CPU.
(s_mipsset): Handle ".set mt" and ".set nomt".
(mips_elf_final_processing): Remind of adding new flag for MT ASE.
(md_show_usage): Show usage of -mmt and -mno-mt.
* doc/as.texinfo: Document -mmt and -mno-mt options.
* doc/c-mips.texi: Likewise, and document ".set mt" and ".set nomt"
2005-09-06 Paul Brook <>
* config/tc-arm.c (arm_it): Add relax field.
(T16_32_TAB): Add addi, addis, add_pc, add_sp, dec_sp, inc_sp,
b, bcond, ldr_pc, ldr_pc2, ldr_sp, str_sp, subi, subis.
(do_t_add_sub, do_t_addr, do_t_branch, do_t_ldst,
do_t_mov_cmp): Allow relaxation.
(output_relax_insn): New function.
(put_thumb32_insn): New function.
(output_inst): Use new functions.
(md_assemble): Don't throw error on relaxable instructions.
(insns): Change "b" entry from TCE(...) to tCE(...).
(md_estimate_size_before_relax): Return 2.
(md_convert_frag, relax_immediate, relax_adr, relax_addsub,
relax_branch, arm_relax_frag): New functions.
(arm_force_relocation): Return 0 for Thumb-2 immediate operand
* config/tc-arm.h (md_convert_frag): Remove definition.
(md_relax_frag): Define.
(arm_relax_frag): Add prototype.
2005-09-02 Paul Brook <>
* config/tc-arm.c (do_rn_rd): Enforce SWP operand constraints.
2005-09-02 Paul Brook <>
* config/tc-arm.c (encode_arm_cp_address): Use
BFD_RELOC_ARM_T32_CP_OFF_IMM in thumb mode.
(do_iwmmxt_wldstbh): Use BFD_RELOC_ARM_T32_CP_OFF_IMM_S2 in thumb
(md_assemble): Only allow coprocessor instructions when Thumb-2 is
(cCE, cC3): Define.
(insns): Use them for coprocessor instructions.
(md_pcrel_from_section): Handle BFD_RELOC_ARM_T32_CP_OFF_IMM.
(get_thumb32_insn): New function.
(put_thumb32_insn): New function.
(md_apply_fix): Handle BFD_RELOC_ARM_T32_CP_OFF_IMM and
2005-09-02 Paul Brook <>
* config/tc-arm.c (opcode_lookup): Look for infix opcode when
incorrect suffix matches.
2005-09-01 David Ung <>
* config/tc-mips.c (append_insn): Correctly handle mips16 case
when the frags are different for the 2 instructions we want to
swap. If the lengths of the 2 instructions are not the same, we
won't do the swap but emit an nop.
2005-09-01 Dmitry Diky <>
* config/tc-msp430.c (msp430_operands): Emit dwarf2_emit_insn()
as appropriate. Change frag_variant() to frag_var() for relaxes.
2005-08-29 Nick Clifton <>
* write.c (generic_force_reloc): Do not call S_FORCE_RELOC if
there is no symbol.
2005-08-26 Jan Beulich <>
* config/tc-i386.c (intel_e09): Set JumpAbsolute when seeing a PTR-
qualified operand of a branch.
(intel_bracket_expr): Set JumpAbsolute here...
(intel_e11): ... rather than here.
2005-08-26 Christian Groessler <>
* configure.tgt: Set bfd_gas also for z8k cpu.
* config/tc-z8k.c (s_segm): Use bfd_set_arch_mach to set machine
(newfix): Adapt to bfd reloc types.
(build_bytes): Adapt to bfd reloc types. Ensure that enough space
is available in the current frag.
(md_convert_frag): Adapt function parameters.
(tc_gen_reloc): New function.
(md_section_align): Use bfd_get_section_alignment.
(md_apply_fix): Adapt to bfd reloc types. Fix handling of
* config/tc-z8k.h (TARGET_ARCH): Define.
(tc_fix_adjustable): Define.
2005-08-25 Chao-ying Fu <>
* config/tc-mips.c (mips_set_options): Add ase_dsp for DSP instructions.
(mips_opts): Add -1 to initialize ase_dsp.
(file_ase_dsp): New variable for -mdsp.
(CPU_HAS_DSP): New define.
(validate_mips_insn): Add supports for 3, 4, 5, 6, 7, 8, 9, 0, ', :, @
operand formats.
(mips_ip): Add min_range and max_range for checking singed numbers.
Check ase_dsp to enable DSP instructions.
Handle 3, 4, 5, 6, 7, 8, 9, 0, ', :, @ operand formats.
(OPTION_COMPAT_ARCH_BASE): Change because of inserting DSP define.
(md_parse_option): Parse OPTION_DSP and OPTION_NO_DSP.
(mips_after_parse_args): Set ase_dsp based on CPU.
(s_mipsset): Handle ".set dsp" and ".set nodsp".
(mips_elf_final_processing): Remind of adding new flag for DSP ASE.
(md_show_usage): Show usage of -mdsp and -mno-dsp.
2005-08-23 David Ung <>
* config/tc-mips.c (mips_cpu_info_table): Add 5kf to the table of
cpu names.
2005-08-23 Alan Modra <>
PR 1036
* config/tc-ppc.c (ppc_symbol_chars): Add '%' and '['.
2005-08-23 Phil Edwards <>
* configure.tgt (*-*-vxworks): Match vxworks* instead.
2005-08-22 Jan Beulich <>
* config/tc-i386.c (object_64bit): New.
(i386_target_format): Initialize it.
(output_disp): Use object_64bit for relocation type determination.
(output_imm): Likewise.
(i386_validate_fix): Likewise.
(tc_gen_reloc): Likewise.
(lex_got): Likewise. Remove static mode_name. Change array size
of gotrel's rel field, and adjust its initializer. Adjust diagnostic.
(x86_cons): Use object_64bit for deciding whether quad fields can
have relocations.
2005-08-18 Christian Groessler <>
* config/tc-h8300.h: Remove TC_RELOC_MANGLE/tc_reloc_mangle.
* config/tc-mcore.h: Likewise.
* config/tc-z8k.h: Likewise.
* config/tc-z8k.c: Likewise.
* config/tc-sh.h: Remove TC_RELOC_MANGLE and
sh_coff_reloc_mangle declaration.
* config/tc-sh.c: (md_apply_fix): Fix comment for case
2005-08-18 Kaz Kojima <>
* config/tc-sh64.c (sh64_target_format): Check preset_target_arch
to confirm that no ISA is specified.
2005-08-18 Nick Clifton <>
* write.c (relax_segment): Count the number of frags being
processed and use this to compute a maximum limit on the number of
iterations that will be allowed when attempting to relax the
2005-08-17 Danny Smith <>
* config/obj-coff.c (obj_coff_weak): Set auxiliary record
2005-08-16 Alan Modra <>
* config/tc-ppc.c (ppc_set_cpu): Don't select 64-bit based on
default cpu.
2005-08-15 Paul Brook <>
* config/tc-arm.c (do_t_mov_cmp): Fix encoding of i16-bit conditional
(do_t_mvn_tst, do_t_neg, do_t_shift): Ditto.
2005-08-15 Daniel Jacobowitz <>
* config/tc-ppc.c (parse_cpu): Add -me300 support.
(md_show_usage): Likewise.
* doc/c-ppc.texi (PowerPC-Opts): Document it.
2005-08-12 Martin Schwidefsky <>
* config/tc-s390.c (md_parse_option): Add cpu type z9-109.
(md_gather_operands): Add support for optional operands.
2005-08-12 Dmitry Diky <>
* config/tc-msp430.c (msp430_enable_relax): New flag.
(msp430_enable_polys): Likewise.
(OPTION_RELAX): New option.
(md_longopts): New long options.
(md_show_usage): Updated.
(md_parse_option): Add new options handler.
(msp430_operands): Add check if polymorph insns are enabled.
(msp430_force_relocation_local): New function.
(md_apply_fix): Now delete relocs according to new flags combination.
(msp430_relax_frag): Convert long branches to short branches only if
flag msp430_enable_relax is set.
* config/tc-msp430.h (TC_FORCE_RELOCATION_LOCAL): Defined.
(msp430_force_relocation_local): Likewise.
* doc/c-msp430.texi: Describe new options.
2005-08-11 Ian Lance Taylor <>
* ($(srcdir)/ Remove target.
( Likewise.
(EXTRA_DIST): Remove from list.
(MOSTLYCLEANFILES): Remove from list.
* Regenerate.
2005-08-11 Hans-Peter Nilsson <>
* subsegs.c (subseg_change): Move declaration of seginfo to before
first statement.
2005-08-11 Alan Modra <>
* README-vms: Delete.
* Delete.
* makefile.vms: Delete.
* Delete.
* config/atof-tahoe.c: Delete.
* config/m88k-opcode.h: Delete.
* config/obj-bout.c: Delete.
* config/obj-bout.h: Delete.
* config/obj-hp300.c: Delete.
* config/obj-hp300.h: Delete.
* config/tc-a29k.c: Delete.
* config/tc-a29k.h: Delete.
* config/tc-h8500.c: Delete.
* config/tc-h8500.h: Delete.
* config/tc-m88k.c: Delete.
* config/tc-m88k.h: Delete.
* config/tc-tahoe.c: Delete.
* config/tc-tahoe.h: Delete.
* config/tc-tic80.c: Delete.
* config/tc-tic80.h: Delete.
* config/tc-w65.c: Delete.
* config/tc-w65.h: Delete.
* config/te-aux.h: Delete.
* config/te-delt88.h: Delete.
* config/te-delta.h: Delete.
* config/te-dpx2.h: Delete.
* config/te-hp300.h: Delete.
* config/te-ic960.h: Delete.
* config/vms-a-conf.h: Delete.
* doc/c-a29k.texi: Delete.
* doc/c-h8500.texi: Delete.
* doc/c-m88k.texi: Delete.
* README: Remove obsolete examples, and list of supported targets.
* Remove a29k, h8500, m88k, tahoe, tic80, w65,
bout and hp300 support.
* Remove --enable-bfd-assembler, need_bfd,
* configure.tgt: Remove a29k, h8300-coff, h8500-*, i960 non-elf,
m68k non bfd, m88k, or32-coff, tic80-*, vax non-bfd, w65k-*, *-nindy.
* as.c: Remove all non-BFD_ASSEMBLER code, support for above targets.
* as.h: Likewise.
* dw2gencfi.c: Likewise.
* dwarf2dbg.c: Likewise.
* ehopt.c: Likewise.
* input-file.c: Likewise.
* listing.c: Likewise.
* literal.c: Likewise.
* messages.c: Likewise.
* obj.h: Likewise.
* output-file.c: Likewise.
* read.c: Likewise.
* stabs.c: Likewise.
* struc-symbol.h: Likewise.
* subsegs.c: Likewise.
* subsegs.h: Likewise.
* symbols.c: Likewise.
* symbols.h: Likewise.
* tc.h: Likewise.
* write.c: Likewise.
* write.h: Likewise.
* config/aout_gnu.h: Likewise.
* config/obj-aout.c: Likewise.
* config/obj-aout.h: Likewise.
* config/obj-coff.c: Likewise.
* config/obj-coff.h: Likewise.
* config/obj-evax.h: Likewise.
* config/obj-ieee.h: Likewise.
* config/tc-arm.c: Likewise.
* config/tc-arm.h: Likewise.
* config/tc-avr.c: Likewise.
* config/tc-avr.h: Likewise.
* config/tc-crx.h: Likewise.
* config/tc-d10v.h: Likewise.
* config/tc-d30v.h: Likewise.
* config/tc-dlx.h: Likewise.
* config/tc-fr30.h: Likewise.
* config/tc-frv.h: Likewise.
* config/tc-h8300.c: Likewise.
* config/tc-h8300.h: Likewise.
* config/tc-hppa.h: Likewise.
* config/tc-i370.h: Likewise.
* config/tc-i386.c: Likewise.
* config/tc-i386.h: Likewise.
* config/tc-i860.h: Likewise.
* config/tc-i960.c: Likewise.
* config/tc-i960.h: Likewise.
* config/tc-ip2k.h: Likewise.
* config/tc-iq2000.h: Likewise.
* config/tc-m32c.h: Likewise.
* config/tc-m32r.h: Likewise.
* config/tc-m68hc11.h: Likewise.
* config/tc-m68k.c: Likewise.
* config/tc-m68k.h: Likewise.
* config/tc-maxq.c: Likewise.
* config/tc-maxq.h: Likewise.
* config/tc-mcore.c: Likewise.
* config/tc-mcore.h: Likewise.
* config/tc-mn10200.h: Likewise.
* config/tc-mn10300.c: Likewise.
* config/tc-mn10300.h: Likewise.
* config/tc-ms1.h: Likewise.
* config/tc-msp430.c: Likewise.
* config/tc-msp430.h: Likewise.
* config/tc-ns32k.c: Likewise.
* config/tc-ns32k.h: Likewise.
* config/tc-openrisc.h: Likewise.
* config/tc-or32.c: Likewise.
* config/tc-or32.h: Likewise.
* config/tc-ppc.c: Likewise.
* config/tc-ppc.h: Likewise.
* config/tc-s390.h: Likewise.
* config/tc-sh.c: Likewise.
* config/tc-sh.h: Likewise.
* config/tc-sparc.c: Likewise.
* config/tc-tic30.c: Likewise.
* config/tc-tic30.h: Likewise.
* config/tc-tic4x.c: Likewise.
* config/tc-tic4x.h: Likewise.
* config/tc-tic54x.c: Likewise.
* config/tc-tic54x.h: Likewise.
* config/tc-v850.h: Likewise.
* config/tc-vax.c: Likewise.
* config/tc-vax.h: Likewise.
* config/tc-xstormy16.h: Likewise.
* config/tc-xtensa.h: Likewise.
* config/tc-z8k.c: Likewise.
* config/tc-z8k.h: Likewise.
* config/vms-a-conf.h
* doc/ Likewise.
* doc/all.texi: Likewise.
* doc/as.texinfo: Likewise.
* doc/internals.texi: Likewise.
* doc/ Regenerate.
* Regenerate.
* configure: Regenerate.
* Regenerate.
* po/ Regenerate.
2005-08-09 Nick Clifton <>
PR 1070
* macro.c (getstring): Do not treat round parentheses exactly the
same as angle brackets - the parentheses need to be preserved and
passed on to the macro processing code.
2005-08-08 Nick Clifton <>
* config/tc-msp430.c (MSP430_ISA_21): Define.
(mcu_types): Add entries for msp430x21xx variants.
2005-08-08 Nick Clifton <>
PR 1070
* macro.c (getstring): Treat round parentheses in the same way as
angle brackets.
(get_any_string): Likewise.
2005-08-07 H.J. Lu <>
PR gas/1118
* as.c (parse_args): Handle -al=<FILE>.
2005-08-07 Nick Clifton <>
* read.c (s_app_line): Accept a line number of 0 for compatibility
with gcc's output for assembler-with-cpp files.
2005-08-05 Paul Brook <>
* config/tc-arm.c (current_it_mask, current_cc): New variables.
(do_t_add_sub): Use correct encodings inside IT block.
(do_t_arit3c): Ditto.
(do_t_it): Simplify logic. Set current_it_mask and current_cc.
(md_assemble): Verify conditional suffixes agains IT blocks.
2005-08-05 Paul Brook <>
* config/tc-arm.c (encode_thumb32_immediate): Only accept shifted
(encode_thumb32_shifted_operand): Prohibit register shifts.
(encode_thumb32_addr_mode): Fix typo.
(insns): Correct thumb2 ldm and stm opcodes.
2005-08-02 Khem Raj <>
* config/tc-arm.c (do_iwmmxt_wldstd): Correct the offset range for
WLDRD/WSTRD instruction.
2005-08-02 Alan Modra <>
* config/tc-ppc.c (md_apply_fix <ELF>): Don't warn on overflow
if emitting a reloc.
2005-07-29 Thiemo Seufer <>
* config/tc-mips.c (s_mips_globl): Allow multiple symbols per .globl.
2005-07-29 Paul Brook <>
* config/tc-arm.c (T16_32_TAB): Add "addr". Fix encoding of push and
(do_t_addr): Implement 32-bit variant.
(do_t_push_pop): Make some errors warnings. Handle single register
32-bit case.
(insns): Use tCE for adr.
(md_pcrel_from_section): Handle BFD_RELOC_ARM_T32_ADD_PC12.
(md_apply_fix): Ditto.
2005-07-29 Paul Brook <>
* config/tc-arm.c (parse_tb): New function.
(enum operand_parse_code): Add OP_TB.
(parse_operands): Handle OP_TB.
(do_t_add_sub_w, do_t_tb): New functions.
(insns): Add entries for addw, subw, tbb and tbh.
(md_apply_fix): Handle BFD_RELOC_ARM_T32_IMM12.
2005-07-29 Kazuhiro Inaoka <>
* config/tc-m32r.c (m32r_check_fixup): Fixed X_op check.
2005-07-27 H.J. Lu <>
* config/tc-i386.c (handle_large_common): Declare only for ELF.
2005-07-27 Jan Beulich <>
* config/tc-ia64.h (unw_r_record): Change type of fr_mem to unsigned
(unw_p_record): Remove unused/redundant fields imask and rmask.
Combine spoff and pspoff into a union. Combine gr and br into a
union. Change type of grmask and brmask to unsigned char. Change type
of frmask to unsigned int.
(unw_x_record): Combine spoff, pspoff, and treg into a union.
* config/tc-ia64.c (unwind): New field 'pending_saves'.
(check_pending_save): New.
(alloc_record): Clear out entire record.
(output_psp_gr): Use renamed structure fields.
(output_psp_sprel): Likewise.
(output_rp_gr): Likewise.
(output_rp_br): Likewise.
(output_rp_psprel): Likewise.
(output_rp_sprel): Likewise.
(output_pfs_gr): Likewise.
(output_pfs_psprel): Likewise.
(output_pfs_sprel): Likewise.
(output_preds_gr): Likewise.
(output_preds_psprel): Likewise.
(output_preds_sprel): Likewise.
(output_spill_base): Likewise.
(output_unat_gr): Likewise.
(output_unat_psprel): Likewise.
(output_unat_sprel): Likewise.
(output_lc_gr): Likewise.
(output_lc_psprel): Likewise.
(output_lc_sprel): Likewise.
(output_fpsr_gr): Likewise.
(output_fpsr_psprel): Likewise.
(output_fpsr_sprel): Likewise.
(output_priunat_gr): Likewise.
(output_priunat_psprel): Likewise.
(output_priunat_sprel): Likewise.
(output_bsp_gr): Likewise.
(output_bsp_psprel): Likewise.
(output_bsp_sprel): Likewise.
(output_bspstore_gr): Likewise.
(output_bspstore_psprel): Likewise.
(output_bspstore_sprel): Likewise.
(output_rnat_gr): Likewise.
(output_rnat_psprel): Likewise.
(output_rnat_sprel): Likewise.
(output_spill_psprel): Likewise.
(output_spill_sprel): Likewise.
(output_spill_reg): Likewise.
(output_fr_mem): Likewise. Allocate one unwind record per set mask
(output_frgr_mem): Likewise.
(output_gr_mem): Likewise.
(output_br_mem): Likewise.
(output_gr_gr): Likewise.
(output_br_gr): Likewise.
(fixup_unw_records): Likewise.
(process_one_record): Use renamed structure fields. For gr_gr and
br_gr, collect mask from chain of records before output.
(in_prologue): Simplify and eliminate early returns. Call
(in_body): Simplify and eliminate early returns.
(dot_body): Call check_pending_save.
(md_assemble): Update comment. Deal with pending saves.
2005-07-26 Jan Beulich <>
* config/tc-i386.c (optimize_imm): Calculate candidate immediates
mask from guessed suffix, but mask out other immediate types only
if at least on candidate is valid for the insn.
2005-07-25 DJ Delorie <>
* config/tc-m32c.c (md_cgen_lookup_reloc): Add 8 bit operands.
Support %mod() modifiers from opcodes.
* doc/c-m32c.texi (M32C-Modifiers): New section.
2005-07-25 Jan Hubicka <>
H.J. Lu <>
* config/obj-elf.c: Include "elf/x86-64.h" if TC_I386 is
(elf_com_section_ptr): New.
(elf_begin): Set elf_com_section_ptr to bfd_com_section_ptr.
(elf_common_parse): Make it global. Use elf_com_section_ptr
instead of bfd_com_section_ptr.
(obj_elf_change_section): Handle x86-64 large bss sections.
* config/obj-elf.h (elf_com_section_ptr): New.
(elf_common_parse): New.
* config/tc-i386.c (handle_large_common): New.
(md_pseudo_table): Add "largecomm".
(x86_64_section_letter): New.
(x86_64_section_word): New.
* config/tc-i386.h (x86_64_section_word): New.
(x86_64_section_letter): New.
(md_elf_section_letter): New. Defined.
(md_elf_section_word): Likewise.
2005-07-21 Ralf Corsepius <>
* configure.tgt: Remove i386-*-rtemself*.
Remove sparc-*-rtemself*.
2005-07-21 Ben Elliston <>
* config/tc-m68k.h: Remove TE_LYNX conditional code.
2005-07-21 Paul Brook <>
* config/tc-arm.c (encode_thumb32_addr_mode): Don't set
2005-07-20 Tavis Ormandy <>
* messages.c: Use vsnprintf instead of vsprintf.
2005-07-20 Kazuhiro Inaoka <>
* config/tc-m32r.c (tc_gen_reloc): Check BFD_RELOC_32_PCREL and
BFD_RELOC_16_PCREL to Support R_M32R_REL32.
2005-07-18 Nick Clifton <>
* configure.tgt: Restore alpha ordering to list of arches.
2005-07-18 John David Anglin <>
* tc-hppa.c (pa_ip): Reject match for '#' immediate if not pa20.
2005-07-18 Jan Beulich <>
* config/tc-i386.c (md_begin): Use IS_ELF.
(tc_i386_fix_adjustable): Likewise.
(md_estimate_size_before_relax): Likewise.
(md_apply_fix): Likewise.
(i386_target_format): Likewise.
(lex_got): Define to NULL when not ELF or when LEX_AT. Check IS_ELF.
(i386_immediate): Remove #ifdef LEX_AT.
(i386_displacement): Likewise.
* config/tc-i386.h (x86_cons): Prototype only when ELF and when not
2005-07-18 Jan Beulich <>
* config/tc-i386.c (reloc): Convert to ISO C90. Change first
parameter to unsigned. Parameter sign now is tristate - zero/
positive mean unsigned/signed, negative means signedness doesn't
matter. Check field size,
signedness, and pcrel-ness are in agreement between relocated field
and relocation type. Adjust diagnostics.
(optimize_imm): And type mask of operand instead of overwriting it.
(lex_got): Convert to ISO C90. Add third parameter. Add new field to
local structure and initialize gotrel accordingly. Pass caller as
mask of types that the operator can match.
(x86_cons_fix_new): Let reloc know that signedness of relocation
doesn't matter.
(x86_pe_cons_fix_new): Likewise.
(x86_cons): Pass additional argument to lex_got.
(i386_immediate): New local variable 'types'. Pass its address as
additional argument to lex_got. Mask out operand types not supported
befoe returning.
(i386_displacement): Likewise. Set bigdisp to all types supported in
64-bit mode, combining the previously split initialization.
2005-07-18 Jan Beulich <>
* config/tc-i386.c (parse_insn): Reject prefix if unavailable in
current mode.
2005-07-16 John David Anglin <>
* config/tc-hppa.c (pa_ip): Search entire mnemonic before considering
promoted match.
2005-07-16 Alan Modra <>
* Run "make dep-am".
* Regenerate.
2005-07-15 H.J. Lu <>
* gas/config/tc-i386.h (CpuVMX): New.
(CpuUnknownFlags): Add CpuVMX.
2005-07-14 Jim Blandy <>
Add support for the Renesas M32C.
* (CPU_TYPES): List m32c.
(TARGET_CPU_CFILES): List config/tc-m32c.c.
(TARGET_CPU_HFILES): List config/tc-m32c.h.
* Add case for m32c.
* configure.tgt: Add cases for m32c and m32c-*-elf.
* configure: Regenerated.
* config/tc-m32c.c, config/tc-m32c.h: New files.
* doc/ (CPU_DOCS): Add c-m32c.texi.
* doc/ Regenerated.
* doc/all.texi: Set M32C.
* doc/as.texinfo: Add text for the M32C-specific options and line
comment characters, and refer to c-m32c.texi.
* doc/c-m32c.texi: New file.
2005-07-14 Nick Clifton <>
PR 1069
* config/tc-crx.c (reset_vars): Use strncpy to prevent overflowing
the ins_parse buffer.
2005-07-10 Ralf Corsepius <>
* configure.tgt: Remove a29k-*-rtems*, hppa*-*-rtems*,i386-go32-rtems*,
i386-*-rtemscoff*, sparc-*-rtemsaout*.
2005-07-10 H.J. Lu <>
* config/tc-i386.c (optimize_disp): Optimize signed 32bit
2005-07-08 Ben Elliston <>
* frags.h: Remove ANSI_PROTOTYPES conditional code.
* config/obj-elf.h: Likewise.
* config/tc-h8300.h: Likewise.
* config/tc-h8500.h: Likewise.
* config/tc-i370.h: Likewise.
* config/tc-i386.h: Likewise.
* config/tc-m68hc11.h: Likewise.
* config/tc-m68k.h: Likewise.
* config/tc-ppc.h: Likewise.
* config/tc-s390.h: Likewise.
* config/tc-sh.h: Likewise.
* config/tc-sparc.h: Likewise.
* config/tc-tic30.c: Likewise.
* config/tc-w65.h: Likewise.
* config/tc-xtensa.h: Likewise.
2005-07-08 Hans-Peter Nilsson <>
PR gas/1049
* config/tc-cris.h (MD_APPLY_SYM_VALUE): Define.
2005-07-07 Kaveh R. Ghazi <>
* config/tc-tic30.c (debug): Add format attribute. Fix format
2005-07-06 H.J. Lu <>
* config/tc-i386.c (cpu_arch): Add sse3.
* config/tc-i386.h (CpuSSE3): Renamed from ...
(CpuPNI): This. Defined as CpuSSE3.
* doc/c-i386.texi: Document .sse3.
2005-07-06 Jan Beulich <>
* config/tc-ia64.c (nop): Use zero for L-unit pseudo-nop.
2005-07-05 Nick Clifton <>
* config/tc-pdp11.c (md_apply_fix): Cast first argument to
md_chars_to_numbers to an unsigned pointer in order to avoid a
compile time warning.
2005-07-05 Paul Brook <>
* config/tc-ppc.c (ppc_target_format): Add VxWorks.
2005-07-05 Aldy Hernandez <>
* config/tc-ms1.c: New.
* config/tc-ms1.h: New.
2005-07-05 Jan Beulich <>
* config/tc-i386.h (CpuSVME): New.
(CpuUnknownFlags): Include CpuSVME.
* config/tc-i386.c (cpu_arch): Add .pacifica and .svme. Add opteron
as alias of sledgehammer.
(md_assemble): Include invlpga in the check for insns with two source
(process_operands): Include SVME insns in the check for ignored
segment overrides. Adjust diagnostic.
(i386_index_check): Special-case SVME insns with memory operands.
2005-07-04 Khem Raj <>
Nick Clifton <>
* tc-arm.c (struct arm_it): Make operands.imm signed to match its
use an immediate value.
(parse_vfp_reg_list): Make the 2nd parameter an unsigned pointer
since the register field of the operands structure is unsigned.
(s_arm_unwind_save_vfp): Make "reg" unsigned.
(parse_operands): Make the 2ns parameter an unsigned pointer to
match its use.
(do_ldrd): When using the imm field of the operands structure as a
second register field, treat it as unsigned.
2005-07-04 Alan Modra <>
PR 1004
* config/obj-elf.c (obj_elf_change_section): Use backend
2005-07-01 Jan Beulich <>
* config/tc-ia64.c (line_separator_chars): Add '{' and '}'.
(output_spill_psprel, output_spill_psprel_p): Combine.
(output_spill_sprel, output_spill_sprel_p): Combine.
(output_spill_reg, output_spill_regp_p): Combine.
(process_one_record): Handle psp_psprel.
(parse_predicate_and_operand): New.
(convert_expr_to_ab_reg): Two new parameters. Return void. Always
initialize output values. Emit diagnostic case here.
(convert_expr_to_xy_reg): Likewise. Don't allow r0, f0, and f1.
(add_unwind_entry): New second parameter. Allow first parameter to
be NULL. Parse optional tag, emit warning about further support for
it otherwise being missing. Check end-of-line when requested.
(dot_fframe): Clear operand when wrong. Allow tag.
(dot_vframe): Likewise.
(dot_vframesp): Likewise. Rename parameter, issue warning when psp
(dot_vframepsp): Remove.
(dot_altrp): Clear operand when wrong. Allow tag.
(dot_save): Likewise. Let default case also go through
(dot_savemem): Likewise.
(dot_restore): Don't return when wrong operand. Allow tag.
(dot_spillreg, dot_spillreg_p): Combine. Simplify by using
parse_predicate_and_operand and the new arguments to
convert_expr_to_ab_reg and convert_expr_to_xy_reg. Don't return
when wrong operand. Allow tag.
(dot_restorereg, dot_restorereg_p): Likewise.
(dot_spillmem, dot_spillmem_p): Likewise.
(dot_saveg): Clear operand when wrong. Perform tighter operand
checks. Allow tag.
(dot_savef): Likewise.
(dot_saveb): Likewise.
(dot_savegf): Likewise.
(dot_spill): Remove end-of-line check. Combine. Simplify by using
parse_predicate_and_operand and the new arguments to
convert_expr_to_ab_reg and convert_expr_to_xy_reg. Don't return
when wrong operand. Allow tag.
(popcount): New.
(dot_label_state): Don't return when wrong operand.
(dot_copy_state): Likewise.
(dot_unwabi): Likewise. Check if in prologue.
(dot_body): Don't call demand_empty_rest_of_line.
(dot_prologue): Type of mask and grsave is unsigned. Perform tighter
operand checks.
(md_pseudo_table): Also use dot_restorereg for .restorereg.p. Also
use dot_spillreg for .spillreg.p. Also use dot_spillmem for
.spillpsp.p and .spillsp.p. Also use dot_vframesp for .vframepsp.
(parse_operand): New second parameter. Don't deal with '}' here
anymore. Don't advance past end-of-line.
(parse_operands): Pass second argument to parse_operand.
(ia64_start_line): Prevent out-of-bounds access through
input_line_pointer. Deal with '}' here.
(ia64_unrecognized_line): Don't deal with '}' here.
(dot_alias): Use ignore_rest_of_line not its deprecated alias
2005-06-30 Zack Weinberg <>
* config/tc-arm.c (T_OPCODE_BRANCH, encode_arm_addr_mode_2)
(encode_arm_addr_mode_3, encode_arm_cp_address, do_blx, do_t_blx)
(do_t_branch, insns [b, bl]): Don't encode pipeline offset.
(do_branch): Always set inst.reloc.pc_rel.
(s_arm_elf_cons): Disallow use of (plt) suffix.
(do_adrl): Adjust X_add_number unconditionally.
(md_pcrel_from): Rename md_pcrel_from_section, add second segT
argument. Handle all adjustment for pipeline offset here.
(md_apply_fix): No need to undo work of md_pcrel_from. No
need to extract pre-encoded pipeline adjustments from various
branch instructions. Generally, assume instructions are already
all-bits-zero in the field being fixed up. Remove all OBJ_ELF
special cases. Handle BFD_RELOC_ARM_PLT32 like
(tc_gen_reloc): Remove OBJ_ELF special case.
* config/tc-arm.c: Define MD_PCREL_FROM_SECTION.
2005-06-30 Ben Elliston <>
* (check-DEJAGNU): Don't search for expect.
* Regenerate.
2005-06-30 Ben Elliston <>
* (EXPECT): Set to expect.
(RUNTEST): Likewise, set to runtest.
* Regenerate.
2005-06-23 Ben Elliston <>
* config/m68k-parse.h: Use ISO C90.
* config/m68k-parse.y: Likewise.
* config/tc-m68k.h: Likewise.
2005-06-20 H.J. Lu <>
PR 1013
* config/tc-i386.c (md_assemble): Don't call optimize_disp on
(optimize_disp): Optimize only if possible. Don't use 64bit
displacement on non-constants and do same on constants if
2005-06-17 Jan Beulich <>
* config/tc-i386.c (reloc): Also handle BFD_RELOC_64_PCREL.
(tc_i386_fix_adjustable): Include BFD_RELOC_X86_64_GOTOFF64,
(output_disp): Do GOTPC conversion also for BFD_RELOC_X86_64_32S
and BFD_RELOC_32_PCREL. Use BFD_RELOC_X86_64_GOTPC32 instead of
(output_imm): Do GOTPC conversion also for BFD_RELOC_X86_64_32S.
Use BFD_RELOC_X86_64_GOTPC32 instead of aborting.
(tc_gen_reloc): Do GOTPC conversion also for BFD_RELOC_32_PCREL.
Use BFD_RELOC_X86_64_GOTPC32 instead of aborting. Also handle
BFD_RELOC_X86_64_DTPOFF64, and BFD_RELOC_X86_64_TPOFF64. Also
convert 8-byte pc-relative relocations.
(lex_got): Use BFD_RELOC_X86_64_GOTOFF64 for 64-bit @gotoff.
(i386_validate_fix): Likewise.
(x86_cons): Also handle quad values in 64-bit mode.
(i386_displacement): Also handle BFD_RELOC_X86_64_GOTOFF64.
(md_apply_fix): Include BFD_RELOC_X86_64_DTPOFF64 and
BFD_RELOC_X86_64_TPOFF64 in the TLS check. Also convert BFD_RELOC_64
to pc-relative variant. Also check for BFD_RELOC_64_PCREL.
2005-06-13 Zack Weinberg <>
* config/tc-arm.c (find_real_start): Check S_IS_LOCAL on
symbolP as well as for names with a leading dot. Use ACONCAT.
(md_apply_fix): For branch relocations, only replace value
with fixP->fx_offset (under #ifdef OBJ_ELF) when !fixP->fx_done.
(arm_force_relocation): Remove #ifdef OBJ_ELF case.
* config/tc-arm.h (LOCAL_LABEL): Remove unnecessary parentheses.
(LOCAL_LABEL_PREFIX): Don't define.
2005-06-10 Alan Modra <>
* config/tc-hppa.c (pa_block): Allocate just one byte for the
fill pattern.
2005-06-08 James E Wilson <>
PR 994
* config/tc-ia64.c (slot_index): Revert last change. If first_frag
is NULL, then emit a warning, and return the current index.
2005-06-08 Tomas Hurka <>
PR 991
* config/tc-m68k.c (m68k_ip): Test for insn compatiblity using a
temporary copy of the operands array so that changes can be safely
backed out if the insn does not match.
(m68k_compare_opcode): Shortcut the test when the parameters are
the same. Return 1 if the names match but the second opcode is
further on in the array than the first.
2005-06-08 Nick Clifton <>
PR 994
* config/tc-ia64.c (slot_index): Check for a NULL first_frag.
2005-06-08 Kazuhiro Inaoka <>
* config/tc-m32r.c (use_parallel): Change default value from 1 to 0.
2005-06-07 Aldy Hernandez <>
Michael Snyder <>
Stan Cox <>
* Add ms1 case.
* configure: Regenerate.
* configure.tgt: Add ms1 case.
2005-06-07 Bob Wilson <>
* config/tc-xtensa.h (resource_table): Change units to unsigned chars.
* config/tc-xtensa.c (new_resource_table): Likewise.
(resize_resource_table): Likewise.
(release_resources): Fix assertion for unsigned values.
2005-06-07 Zack Weinberg <>
* cgen.c, cgen.h, tc.h, write.c, config/obj-coff.c
* config/tc-a29k.c, config/tc-alpha.c, config/tc-alpha.h
* config/tc-arc.c, config/tc-arc.h, config/tc-arm.c
* config/tc-arm.h, config/tc-avr.c, config/tc-avr.h
* config/tc-cris.c, config/tc-crx.c, config/tc-d10v.c
* config/tc-d10v.h, config/tc-d30v.c, config/tc-d30v.h
* config/tc-dlx.c, config/tc-dlx.h, config/tc-fr30.h
* config/tc-frv.c, config/tc-frv.h, config/tc-h8300.c
* config/tc-h8500.c, config/tc-hppa.c, config/tc-hppa.h
* config/tc-i370.c, config/tc-i370.h, config/tc-i386.c
* config/tc-i386.h, config/tc-i860.c, config/tc-i860.h
* config/tc-i960.c, config/tc-i960.h, config/tc-ia64.c
* config/tc-ip2k.c, config/tc-ip2k.h, config/tc-iq2000.c
* config/tc-iq2000.h, config/tc-m32r.c, config/tc-m32r.h
* config/tc-m68hc11.c, config/tc-m68hc11.h, config/tc-m68k.c
* config/tc-m68k.h, config/tc-m88k.c, config/tc-maxq.c
* config/tc-mcore.c, config/tc-mcore.h, config/tc-mips.c
* config/tc-mips.h, config/tc-mmix.c, config/tc-mn10200.c
* config/tc-mn10300.c, config/tc-msp430.c, config/tc-ns32k.c
* config/tc-openrisc.h, config/tc-or32.c, config/tc-or32.h
* config/tc-pdp11.c, config/tc-pj.c, config/tc-pj.h
* config/tc-ppc.c, config/tc-ppc.h, config/tc-s390.c
* config/tc-s390.h, config/tc-sh64.c, config/tc-sh.c
* config/tc-sh.h, config/tc-sparc.c, config/tc-sparc.h
* config/tc-tahoe.c, config/tc-tic30.c, config/tc-tic4x.c
* config/tc-tic54x.c, config/tc-tic80.c, config/tc-v850.c
* config/tc-v850.h, config/tc-vax.c, config/tc-vax.h
* config/tc-w65.c, config/tc-xstormy16.c, config/tc-xstormy16.h
* config/tc-xtensa.c, config/tc-z8k.c:
Replace all instances of the string "_apply_fix3" with
* po/, po/gas.pot: Regenerate.
2005-06-08 Alan Modra <>
* Run "make dep-am".
* Regenerate.
2005-06-07 David Ung <>
* config/tc-mips.c (mips_cpu_info_table): Add cpu names m4k, 24k,
24kc, 24kf and 24kfx under MIPS32 release 2.
2005-06-04 Nick Clifton <>
* config/tc-arm.c (CE, C3, CM, UE, UF): Redefine without reference
to their Thumb-enabled equivalents.
2005-06-01 Maciej W. Rozycki <>
* config/tc-mips.c (load_register): Add leading "0x" to the
output of sprintf_vma().
(macro): Likewise.
2005-06-01 Nick Clifton <>
* config/tc-arm.c (TxCE, TxC3, TxCM, TUE, TUF): Remove redundant
test for the presence of thumb version of the parsing functions
since they must always exist and the test generates a compile time
warning message.
2005-05-31 Richard Henderson <>
* config/tc-alpha.c (O_lituse_jsrdirect): New.
(alpha_reloc_op): Add it.
(debug_exp): Handle it.
(emit_insn): Handle it.
* doc/c-alpha.texi (Alpha-Relocs): Document lituse_jsrdirect.
2005-05-31 Christian Groessler <>
* write.c (dump_section_relocs): Convert to ISO-C.
(write_relocs): Avoid signed/unsigned and fprintf argument
warnings in debug code.
2005-05-26 Zack Weinberg <>
* config/tc-arm.h (TC_FIX_TYPE): Change to int.
(TC_INIT_FIX_DATA): Initialize to 0, not NULL.
* config/tc-arm.c (fix_new_arm): Remove now-unnecessary cast.
(md_apply_fix3): Delete fix_is_thumb variable; refer to
fixP->tc_fix_data directly in the sole place it was used.
Explicitly truncate value, *valP, fixP->fx_addnumber, and
fixP->fx_offset to 32 bits, for consistent behavior between 32-
and 64-bit hosts.
2005-05-27 Jan Beulich <>
* config/tc-ia64.c (struct proc_pending): New.
(unwind): Replace proc_start with proc_pending.
(unwind_diagnostic): Check unwind.proc_pending.sym.
(dot_proc): Replace unwind.proc_start with unwind.proc_pending.sym.
Check if previous proc not closed. Record all entry points.
(dot_endp): Replace unwind.proc_start with unwind.proc_pending.sym.
Set symbol sizes for entry points recorded in dot_proc. Check
arguments for consistency with respective .proc's.
(md_assemble): Replace unwind.proc_start with
2005-05-27 Jan Beulich <>
* config/tc-ia64.c (emit_one_bundle): Restrict scope of ptr, end_ptr,
and last_ptr. Check all in-use slots for first one with non-NULL
unwind_record. Don't reload end_ptr before second update round.
2005-05-26 James E Wilson <>
* config/tc-ia64.c (extra_goodness): Update comment.
(md_begin): Add debugging code to print best_template table.
2005-05-25 Jan Beulich <>
* config/tc-ia64.c (md_begin): Don't try to match slot 2 of an MLX
2005-05-25 Jan Beulich <>
* config/tc-ia64.c (ia64_gen_real_reloc_type): Also handle
BFD_RELOC_UNUSED when determining the width of the reloc.
2005-05-25 Jan Beulich <>
* config/tc-ia64.c (dot_endp): Clear out all three pointers in unwind
section entry.
2005-05-25 Jan Beulich <>
* config/tc-ia64.c (dot_radix): Rewrite.
2005-05-25 Jan Beulich <>
* config/tc-ia64.c (struct unw_rec_list): Remove next_slot_number
and next_slot_frag.
(alloc_record): Remove references to next_slot_number and
(emit_one_bundle): Likewise.
2005-05-22 Nick Clifton <>
* config/tc-v850.c (md_apply_fix3): Pass the address of the
message buffer when invoking the insert function.
2005-05-21 John David Anglin <>
* config/tc-hppa.c (pa_ip): Promote architecture from PA 1.0 to 1.1
only if an instruction match is found.
2005-05-20 Bob Wilson <>
* config/tc-xtensa.c (xg_assemble_vliw_tokens): Change subtraction
to addition in argument to xtensa_dwarf2_emit_insn.
2005-05-19 Zack Weinberg <>
* Have 'all' depend on 'info'.
* Regenerate.
2005-05-19 Alan Modra <>
* config/tc-ppc.c (ppc_force_relocation): Add BFD_RELOC_24_PLT_PCREL.
2005-05-19 Anton Blanchard <>
* config/tc-ppc.c (parse_cpu): Handle "-mpower5".
(md_show_usage): Document it.
(ppc_setup_opcodes): Insert POWER5 mnemonics.
* doc/c-ppc.texi (PowerPC-Opts): Document "-mpower5".
2005-05-19 Jan Beulich <>
* config/tc-ia64.c (dot_endp): Don't use global symbol for unwind
relocations in unwind section.
2005-05-18 Nick Clifton <>
* config/tc-v850.c (md_apply_fix3): Only use the insertion routine
if one exists. Ignore any error messages it may produce, just
allow it to perform the insertion.
2005-05-17 Zack Weinberg <>
* hash.c (hash_lookup): Add len parameter. All callers changed.
(hash_find_n): New interface.
* hash.h: Prototype hash_find_n.
* sb.c: Include as.h.
(scrub_from_sb, sb_to_scrub, scrub_position): New statics.
(sb_scrub_and_add_sb): New interface.
* sb.h: Prototype sb_scrub_and_add_sb.
* input-scrub.c (input_scrub_include_sb): Use sb_scrub_and_add_sb.
* config/tc-arm.h (TC_FORCE_RELOCATION_LOCAL): Remove
reference to BFD_RELOC_ARM_GOT12 which is never generated.
* config/tc-arm.c: Rewrite, adding Thumb-2 support.
2005-05-17 Daniel Jacobowitz <>
* doc/ (gasver.texi): Don't use $<.
* doc/ Regenerated.
2005-05-17 Nick Clifton <>
PR 876
* symbols.c (resolve_symbol_value): Do not move symbols whose
value expression has not been resolved or finalized into the
absolute section as this will confuse other parts of the assembler
into thinking that their value is zero.
2005-05-17 Jan Beulich <>
* read.c (_find_end_of_line): New.
(find_end_of_line): New.
(read_a_source_file): Use it.
(s_globl): Use it.
(s_macro): Use it.
(get_line_sb): Use it.
(s_errwarn): Replace discard_rest_of_line by ignore_rest_of_line.
(s_comm_internal): Likewise.
(s_lsym): Likewise.
(s_macro): Likewise.
(s_ignore): Use ignore_rest_of_line.
* read.h (find_end_of_line): Prototype.
(discard_rest_of_line): Remove prototype. #define to
2005-05-17 Nick Clifton <>
* config/tc-v850,h (TC_FIX_TYPE): Define.
* config/tc-v850.c (md_assemble): When creating a fix record the
operand in the tc_fix_data field.
(md_apply_fix3): When applying a resolved fix use the operand's
insertion procedure to store the value, if the operand has been
2005-05-15 Daniel Jacobowitz <>
* (m68k-parse.c, itbl-parse.c): Update ylwrap
* Regenerated.
2005-05-13 Sterling Augustine <>
Bob Wilson <>
* config/tc-xtensa.c (xtensa_insnbuf_set_operand): Clarify error
(xtensa_mark_zcl_first_insns): Fix incorrect nesting of conditional
2005-05-11 Alan Modra <>
* config/tc-ppc.c (md_apply_fix3): Allow pcrel forms of BFD_RELOC_16,
2005-05-10 Michael Matz <>
* frags.c (frag_grow): Don't be too greedy in allocating memory.
* config/tc-hppa.c (pa_block): Check arguments to .block[z].
2005-05-10 Hans-Peter Nilsson <>
PR binutils/886
* config/tc-mmix.c (mmix_handle_mmixal): Rearrange slightly.
Handle label-without-colon before ordinary dot-pseudo as an
ordinary label. Don't leak memory for label-without-colon alone
on a line. Don't mmixal-munge operands for dot-pseudos.
2005-05-10 Jan Beulich <>
* macro.c (get_any_string): Remove the two last parameters. Replace
references to the former expand parameter by using macro_alternate.
Simplify loop condition for checking for end-of-string.
(get_string): Remove redunant call to sb_skip_white.
(do_formals): Remove two last arguments to get_any_string.
(macro_expand): Likewise.
(expand_irp): Likewise.
2005-05-10 Jan Beulich <>
* read.c (s_macro): Move local variable 'local' to smaller scope.
Call sb_kill on it when done.
2005-05-09 Jan Beulich <>
* config/tc-i386.c (optimize_disp): Discard displacement entirely
when zero and not required by encoding constraints.
2005-05-09 H.J. Lu <>
PR 936
* config/tc-sh64.c (sh64_fake_label): New.
* config/tc-sh64.h (TC_FAKE_LABEL): New.
* doc/internals.texi (TC_FAKE_LABEL): Document.
* write.c (TC_FAKE_LABEL): New.
(adjust_reloc_syms): Use it.
(write_object_file): Likewise.
2005-05-09 Jan Beulich <>
* config/tc-i386.c (parse_insn): Disallow use of prefix separator
and comma in Intel mode.
2005-05-09 Jan Beulich <>
* config/tc-i386.c (tc_x86_regname_to_dw2regnum): Correct 64-bit mode
names to match ABI. Add more registers for 32-bit and 64-bit modes.
Make name array static and const. Adjust lookup to account for NULL
entries (standing for unused register numbers).
2005-05-09 Jan Beulich <>
* config/tc-i386.c (parse_insn): Consider all matching instructions
when checking for string instruction after string-only prefix.
2005-05-07 H.J. Lu <>
PR 940
* config/tc-ia64.c (start_unwind_section): Properly check
comdat group with SHF_GROUP.
2005-05-06 Bob Wilson <>
* doc/c-xtensa.texi (Literal Directive): Spelling correction.
2005-05-06 Bob Wilson <>
* config/tc-xtensa.c: Remove excess whitespace.
* config/tc-xtensa.h: Likewise.
* config/xtensa-istack.h: Likewise.
* config/xtensa-relax.c: Likewise.
* config/xtensa-relax.h: Likewise.
2005-05-06 Nick Clifton <>
* sb.h: Fix formatting of comments.
* sb.c: Fix formatting of comments.
2005-05-06 Jan Beulich <>
* sb.h (sb_add_buffer): Reintroduce.
* sb.c (sb_add_buffer): Likewise.
2005-05-06 Jan Beulich <>
* macro.c (new_formal, del_formal): New.
(do_formals): Use new_formal. Check for and parse qualifier. Warn if
required argument has default value. Stop looking for more formal
when there was a vararg one.
(macro_expand_body): Use new_formal and del_formal.
(macro_expand): Likewise. Initialize local variable err. Don't
return immediately when encountering an error. Warn when keyword
argument already had a value assigned. Eliminate duplicate clearing
of argument value. When current positional argument matches parameter
of vararg type, assign to it all the remaining arguments. Issue error
when required parameter does not have value.
(free_macro): Use del_formal.
(expand_irp): Initialize formal type. Free buffers associated with
formal prior to returning.
* macro.h (struct formal_struct): Add new field 'type' with new
enumeration type 'formal_type'.
* doc/as.texinfo: Document macro parameter qualifiers.
* NEWS: Mention new functionality.
2005-05-06 Jan Beulich <>
* cond.c (s_ifb): New.
* read.c (potable): Add s_ifb as handler for .ifb and .ifnb.
* read.h (s_ifb): Prototype.
* doc/as.texinfo: Document .ifb and .ifnb.
2005-05-05 Steve Ellcey <>
* config/tc-ia64.c (MIN): Undef.
2005-05-05 Paul Brook <>
* config/tc-i386.h (ELF_TARGET_FORMAT): Define for TE_VXWORKS.
2005-05-05 Matt Thomas <>
* config/tc-vax.c (md_assemble): Don't assume a valueT is 4
2005-05-05 Nick Clifton <>
* Update the address and phone number of the FSF organization in
the GPL notices in the following files:
COPYING, app.c, as.c, as.h, asintl.h, atof-generic.c, bignum.h,
bit_fix.h, cgen.c, cgen.h, cond.c, debug.c, depend.c, dw2gencfi.c,
dw2gencfi.h, dwarf2dbg.c, dwarf2dbg.h, ecoff.c, ecoff.h, ehopt.c,
emul-target.h, emul.h, expr.c, expr.h, flonum-copy.c,
flonum-konst.c, flonum.h, frags.c, frags.h, hash.c, hash.h,
input-file.c, input-file.h, input-scrub.c, itbl-lex.h, itbl-lex.l,
itbl-ops.c, itbl-ops.h, itbl-parse.y, listing.c, listing.h,
literal.c, macro.c, macro.h, messages.c, obj.h, output-file.c,
output-file.h, read.c, read.h, sb.c, sb.h, stabs.c,
struc-symbol.h, subsegs.c, subsegs.h, symbols.c, symbols.h, tc.h,
write.c, write.h, config/aout_gnu.h, config/atof-ieee.c,
config/atof-vax.c, config/itbl-mips.h, config/m68k-parse.h,
config/m68k-parse.y, config/m88k-opcode.h, config/obj-aout.c,
config/obj-aout.h, config/obj-bout.c, config/obj-bout.h,
config/obj-coff.c, config/obj-coff.h, config/obj-ecoff.c,
config/obj-ecoff.h, config/obj-elf.c, config/obj-elf.h,
config/obj-evax.c, config/obj-evax.h, config/obj-hp300.c,
config/obj-hp300.h, config/obj-ieee.c, config/obj-ieee.h,
config/obj-multi.h, config/obj-som.c, config/obj-som.h,
config/tc-a29k.c, config/tc-a29k.h, config/tc-alpha.c,
config/tc-alpha.h, config/tc-arc.c, config/tc-arc.h,
config/tc-arm.h, config/tc-avr.c, config/tc-avr.h,
config/tc-cris.c, config/tc-cris.h, config/tc-crx.c,
config/tc-crx.h, config/tc-d10v.c, config/tc-d10v.h,
config/tc-d30v.c, config/tc-d30v.h, config/tc-dlx.c,
config/tc-dlx.h, config/tc-fr30.c, config/tc-fr30.h,
config/tc-frv.c, config/tc-frv.h, config/tc-generic.c,
config/tc-generic.h, config/tc-h8300.c, config/tc-h8300.h,
config/tc-h8500.c, config/tc-h8500.h, config/tc-hppa.c,
config/tc-hppa.h, config/tc-i370.c, config/tc-i370.h,
config/tc-i386.c, config/tc-i386.h, config/tc-i860.c,
config/tc-i860.h, config/tc-i960.c, config/tc-i960.h,
config/tc-ia64.c, config/tc-ia64.h, config/tc-ip2k.c,
config/tc-ip2k.h, config/tc-iq2000.c, config/tc-iq2000.h,
config/tc-m32r.c, config/tc-m32r.h, config/tc-m68851.h,
config/tc-m68hc11.c, config/tc-m68hc11.h, config/tc-m68k.c,
config/tc-m68k.h, config/tc-m88k.c, config/tc-m88k.h,
config/tc-maxq.c, config/tc-maxq.h, config/tc-mcore.c,
config/tc-mcore.h, config/tc-mips.c, config/tc-mips.h,
config/tc-mmix.c, config/tc-mmix.h, config/tc-mn10200.c,
config/tc-mn10200.h, config/tc-mn10300.c, config/tc-mn10300.h,
config/tc-msp430.c, config/tc-msp430.h, config/tc-ns32k.c,
config/tc-ns32k.h, config/tc-openrisc.c, config/tc-openrisc.h,
config/tc-or32.c, config/tc-or32.h, config/tc-pdp11.c,
config/tc-pdp11.h, config/tc-pj.c, config/tc-pj.h,
config/tc-ppc.c, config/tc-ppc.h, config/tc-s390.c,
config/tc-s390.h, config/tc-sh.c, config/tc-sh.h,
config/tc-sh64.c, config/tc-sh64.h, config/tc-sparc.c,
config/tc-sparc.h, config/tc-tahoe.c, config/tc-tahoe.h,
config/tc-tic30.c, config/tc-tic30.h, config/tc-tic4x.c,
config/tc-tic4x.h, config/tc-tic54x.c, config/tc-tic54x.h,
config/tc-tic80.c, config/tc-tic80.h, config/tc-v850.c,
config/tc-v850.h, config/tc-vax.c, config/tc-vax.h,
config/tc-w65.c, config/tc-w65.h, config/tc-xstormy16.c,
config/tc-xstormy16.h, config/tc-xtensa.c, config/tc-xtensa.h,
config/tc-z8k.c, config/tc-z8k.h, config/te-386bsd.h,
config/te-freebsd.h, config/te-hp300.h, config/te-hppa.h,
config/te-ic960.h, config/te-irix.h, config/te-nbsd.h,
config/te-netware.h, config/te-sparcaout.h, config/te-sun3.h,
config/te-tmips.h, config/te-vxworks.h, config/vax-inst.h,
config/xtensa-istack.h, config/xtensa-relax.c,
config/xtensa-relax.h, doc/fdl.texi
2005-05-05 Nick Clifton <>
* config/tc-arm.c (arm_opts): Make -mlittle-endian switch set
the target_big_endian variable to false.
2005-05-04 Alan Modra <>
* config/obj-ecoff.c (ecoff_frob_file_before_fix): Correct section
list traversal. Use bfd_section_list_prepend.
* config/tc-mmix.c (mmix_frob_file): Don't needlessly iterate
over the section list.
* config/tc-xtensa.c (xtensa_remove_section): Delete.
(xtensa_insert_section): Delete.
(xtensa_move_seg_list_to_beginning): Use bfd_section_list_remove
and bfd_section_list_prepend.
(xtensa_reorder_seg_list): Use bfd_section_list_remove and
2005-05-03 Nick Clifton <>
* config/obj-ecoff.c (ecoff_frob_file_before_fix): Fix invocations
of bfd_section_list... macros.
* config/tc-mmix.c (mmix_frob_file): Likewise.
* config/tc-xtensa.c (xtensa_remove_section): Likewise.
(xtensa_insert_section): Likewise.
* macro.c (macro_hash): Remove static.
* macro.h (macro_hash): Provide an external declaration.
2005-05-02 H.J. Lu <>
* write.c (write_object_file): Use bfd_section_double_list_remove
to remove sections.
2005-05-02 Daniel Jacobowitz <>
* doc/ (gasver.texi): Correct quoting.
* doc/ Regenerated.
2005-04-29 Ralf Corsepius <>
* configure.tgt: Add h8300*-*-rtemscoff.
Switch h8300*-*-rtems* to elf.
2005-04-29 H.J. Lu <>
* hash.c: Undo the last change.
* hash.h: Likewise.
2005-04-29 Daniel Jacobowitz <>
* doc/ (gasver.texi): Depend on bfd/configure instead
of Makefile.
(MAINTAINERCLEANFILES): Add asconfig.texi.
* aclocal.m4,, doc/ Regenerated.
2005-04-29 Ben Elliston <>
* (GAS_CFILES): Remove bignum-copy.c.
(GENERIC_OBJS): Likewise, remove bignum-copy.o.
(bignum-copy.o): Remove.
* Regenerate.
* makefile.vms (OBJS): Remove bignum-copy.obj.
* symbols.h (local_symbol_make): Remove declaration.
(verify_symbol_chain_2): Likewise.
* symbols.c (local_symbol_make): Make static.
(max_indent_level): Likewise.
(verify_symbol_chain_2): Remove.
* macro.c (macro_hash): Make static.
* messages.c (fprint_value): Remove.
* read.h (get_absolute_expr): Remove.
(emit_leb128_expr): Likewise.
(do_s_func): Likewise.
* read.c (do_s_func): Make static.
(emit_leb128_expr): Likewise.
(get_absolute_expr): Likewise.
* as.h (as_howmuch): Remove declaration.
(fprint_value): Likewise.
* as.c (myname): Make static.
* input-scrub.c (as_howmuch): Remove.
(as_1_char): Likewise.
* input-file.h (input_file_is_open): Remove.
* input-file.c (input_file_is_open): Likewise.
* expr.h (expr_build_unary): Remove declaration.
(expr_build_binary): Likewise.
* expr.c (expr_build_unary): Remove.
(expr_build_binary): Likewise.
* hash.h (hash_replace): Remove declaration.
(hash_delete): Likewise.
* hash.c (hash_replace): Remove.
(hash_delete): Likewise.
* bignum-copy.c (bignum_copy): Move from here ..
* config/tc-vax.c (bignum_copy): .. to here.
* bignum.h (LOG_TO_BASE_2_OF_10): Remove.
(bignum_copy): Remove extern declaration.
* sb.h (string_count): Remove extern declaration.
(sb_build, sb_add_buffer, sb_print, sb_print_at): Likewise.
(sb_name): Likewise.
* sb.c (dsize): Replace preprocessor macro with static int.
(string_count): Make static.
(sb_build, sb_add_buffer, sb_print, sb_print_at): Likewise.
(sb_name): Likewise.
* config/obj-coff.c (dim_index): Make static.
* config/tc-i386.c (GOT_symbol): Likewise.
(output_invalid_buf): Likewise.
* doc/internals.texi (Warning and error messages): Remove the
prototype for fprint_value.
2005-04-27 Ben Elliston <>
* link.cmd: Remove.
2005-04-26 H.J. Lu <>
* config/obj-multi.h (FAKE_LABEL_NAME): Defined.
* read.c (pseudo_set): Disallow symbol set to common symbol.
PR 857
* write.c (write_object_file): Report common symbol name when
disallowing local symbol set to common symbol.
(adjust_reloc_syms): Disallow local symbol set to undefined
2005-04-25 Jan Beulich <>
* macro.c (macro_expand_body): Replace locals indicator parameters
with actual macro_entry. New local variables macro_line and err.
Don't return when encountering an error, just record the fact.
Detect local symbol name colliding with parameter. Track line number
inside of macro expansion.
(do_formals): Move local variable name to wider scope. Check
parameter of the same name doesn't already exist. In MRI mode, also
check it doesn't collide with the argument count pseudo-parameter).
(define_macro): Add file and line number parameters. Remove local
variable namestr. New local variable error. Initialize macro_entry
members file, line, and name. Don't return when encountering an
error, just record the fact. Use %s in some diagnostics for read.c
to insert the macro name. Free macro_entry on error.
(macro_expand): Pass macro_entry to macro_epand_body. Don't return
when encountering an error, just record the fact.
(expand_irp): Don't return when encountering an error, just record
the fact.
* macro.h (macro_struct): New members name, file, and line.
(define_macro): Add file and line number parameters.
* read.c (s_macro): Pass file and line to define_macro. Tag warning
regarding pseudo-op redefinition with the file/line that macro
definition started at.
2005-04-22 Bob Wilson <>
* config/tc-xtensa.c (LOOKAHEAD_ALIGNER): Delete macro.
(future_alignment_required): Remove ifdefs that use it.
2005-04-22 Bob Wilson <>
* config/tc-xtensa.c (xg_get_build_instr_size): Remove.
(xg_is_narrow_insn, xg_expand_narrow): Remove. Merge into...
(xg_is_single_relaxable_insn): Add "targ" and "narrow_only"
(xg_assembly_relax, xg_find_narrowest_format, relaxation_requirements,
convert_frag_narrow): Use new version of xg_is_single_relaxable_insn.
2005-04-21 Christian Groessler <>
* config/tc-z8k.c (md_assemble): Fix buffer overrun in operand[]
2005-04-20 H.J. Lu <>
* config/obj-aout.h (S_IS_EXTERN): Removed.
* config/obj-bout.h (S_IS_EXTERN): Likewise.
* config/obj-coff.h (S_IS_EXTERN): Likewise.
* symbols.c (S_IS_EXTERN): Likewise.
* symbols.h (S_IS_EXTERN): Likewise.
* config/tc-alpha.c (tc_gen_reloc): Replace S_IS_EXTERN with
* config/tc-d10v.c (md_apply_fix3): Likewise.
* config/tc-ia64.c (ia64_fix_adjustable): Likewise.
* config/tc-iq2000.c (iq2000_fix_adjustable): Likewise.
* config/tc-m32r.c (m32r_fix_adjustable): Likewise.
* config/tc-mmix.c (mmix_adjust_symtab): Likewise.
* config/tc-sh64.c (shmedia_frob_file_before_adjust): Likewise.
(shmedia_md_convert_frag): Likewise.
* symbols.c (print_symbol_value_1): Likewise.
* write.c (write_object_file): Likewise.
2005-04-20 Nick Clifton <>
* config/tc-xtensa.c (get_aligned_diff): Change type of
branch_align to offsetT so that its signedness matches that of
* config/tc-mips.c (macro): Use sprintf_vma to convert a > 32 bit
number into a readable string.
(load_register): Likewise.
2005-04-20 Andreas Schwab <>
* config/tc-ia64.c (specify_resource): Initialize all of tmpl.
2005-04-19 David S. Miller <>
* config/tc-sparc.c (md_assemble): If sparc_ip gives us a
NULL insn, exit early. Remove now spurious NULL checks.
(sparc_ip): Use as_bad for unknown opcode errors, set *pinsn
to NULL and exit.
2005-04-19 Jan Beulich <>
* symbols.h (symbol_find_base): Remove prototype.
* symbols.c (save_symbol_name): Remove code section conditional upon
(symbol_find): Remove.
(symbol_find_base): Rename to symbol_find.
* subsegs.c (section_symbol): Replace use of symbol_find_base with
* config/obj-coff.c (tag_insert): Remove code section conditional
(obj_coff_def): Likewise.
(obj_coff_endef): Replace use of symbol_find_base with symbol_find.
(coff_frob_symbol): Likewise.
(yank_symbols): Likewise.
(c_section_symbol): Likewise.
* config/obj-coff.h (DO_NOT_STRIP): Remove.
* config/tc-arm.c (symbol_locate): Remove code section conditional
* config/tc-h8300.h (DO_NOT_STRIP): Remove.
* config/tc-h8500.h (DO_NOT_STRIP): Remove.
* config/tc-sh.h (DO_NOT_STRIP): Remove.
* config/tc-w65.h (DO_NOT_STRIP): Remove.
* config/tc-z8k.h (DO_NOT_STRIP): Remove.
2005-04-19 Andreas Schwab <>
* config/tc-ia64.c (md_assemble): Fix error message for wrong
access to application registers.
2005-04-19 Jan Beulich <>
* config/te-sysv32.h: Remove.
* (TARG_ENV_HFILES): Remove reference to
* (TARG_ENV_HFILES): Likewise.
2005-04-19 Jan Beulich <>
* config/tc-ia64.c (ia64_canonicalize_symbol_name): Re-allow zero-
length symbols.
2005-04-18 Mark Kettenis <>
* config/tc-i386.c (md_begin): Allow hyphens in mnemonics.
2005-04-18 Maciej W. Rozycki <>
* config/tc-mips.c (normalize_constant_expr): Don't check for
(check_absolute_expr): Only call normalize_constant_expr() if
(mips_ip): Likewise.
* config/tc-mips.c (check_absolute_expr): Fix formatting.
2005-04-18 Jan Beulich <>
* macro.c (free_token): New, freeing all the memory associated with a
(do_formals): Move initializers to ...
(define_macro): ... here.
(delete_macro): Convert passed in name to lower case. Warn when
purging macro that doesn't exist. Use hash_jam instead of hash_delete.
2005-04-15 Maciej W. Rozycki <>
* config/tc-mips.c (normalize_constant_expr): Fix formatting.
2005-04-15 Jan Beulich <>
* config/obj-elf.c (obj_elf_struct): New.
(elf_pseudo_table). Use it for .offset and .struct.
2005-04-14 Bob Wilson <>
Sterling Augustine <>
* config/tc-xtensa.c (get_aligned_diff): Handle target_size larger
than the section alignment.
2005-04-14 Bob Wilson <>
H.J. Lu <>
* config/tc-xtensa.h (struct xtensa_frag_type): Add lit_frchain field.
* config/tc-xtensa.c (xg_translate_sysreg_op,
xtensa_find_unaligned_loops, xtensa_fix_close_loop_end_frags,
relax_frag_add_nop): Support 64-bit host.
(xtensa_mark_literal_pool_location, xtensa_move_literals): Use
tc_frag_data lit_frchain and lit_seg fields instead of fr_var.
2005-04-14 Mark Kettenis <>
* configure.tgt: Add support for OpenBSD/sparc ELF.
* configure.tgt: Set emulation for mips-*-openbsd*.
Remove broken mips-dec-openbsd* config.
* Set default ABI for mips64-*-openbsd*.
* configure: Regenerate.
2005-04-14 Maciej W. Rozycki <>
* config/tc-mips.c (macro) [ldd_std]: Don't attempt the GP
optimization for constant addresses.
2005-04-14 Nick Clifton <>
* as.c (main): Move parse_args before symbol_begin and frag_init
so that the hash table size can be set before it is used.
* hash.c: Use an unsigned long type for the size of the hash
* hash.h (set_gas_hash_table_size): Update the prototype.
2005-04-14 Alan Modra <>
* (NO_WERROR): Define. Use instead of -Wno-error.
* acinclude.m4: Include ../bfd/warning.m4.
* Regenerate.
* configure: Regenerate.
* doc/ Regenerate.
2005-04-13 Maciej W. Rozycki <>
* config/tc-mips.c (IS_ZEXT_32BIT_NUM): New macro.
(normalize_address_expr): New function to sign-extend address
offsets that fit into 32 bits in 32-bit mode.
(macro_build_ldst_constoffset): Use normalize_address_expr()
instead of a handcoded sequence.
(load_register): Likewise. Report oversized numbers in a useful
(macro) [ld_st, ldd_std]: Reject all oversized offsets, not only
for constant addresses. Report oversized numbers in a useful way.
(mips_ip): Use normalize_address_expr() for addresses.
2005-04-12 Mark Kettenis <>
* config/tc-i386.c (output_insn): Handle VIA PadLock instructions
similar to other instructions now that they're marked as ImmExt.
2005-04-12 Nick Clifton <>
* hash.c (DEFAULT_SIZE): Delete. Replace with:
(gas_hash_table_size): New static variable.
(set_gas_hash_table_size): New function: Records a requested size
for the hash tables.
(get_gas_hash_table_size): New function: Return a prime number
near the requested size of the hash table.
(hash_new): Use get_gas_hash_table_size.
* hash.h: Add a prototype for set_gas_hash_table_size.
* as.c (show_usage): Add description of new switches: --hash-size
and --reduce-memory-overheads.
(option_values): Add OPTION_HASH_TABLE_SIZE and
(std_longpopts): Add entries for the new options.
(parse_args): Handle the new options.
* Add a dependency of as.c on hash.h.
* Regenerate.
* doc/as.texinfo: Document the new switches.
* NEWS: Mention the new switches.
2005-04-12 Nick Clifton <>
PR gas/818
* config/tc-hppa.c (pre_defined_registers): Fix %farg[0-3]
2005-04-12 Alan Modra <>
* Run "make dep-am".
* Regenerate.
2005-04-11 Sterling Augustine <>
Bob Wilson <>
* config/tc-xtensa.c (check_t1_t2_reads_and_writes): Fix typo.
2005-04-11 Mark Kettenis <>
* configure.tgt (generic_target): Add support for OpenBSD/i386 ELF.
2005-04-11 Jan Beulich <>
* NEWS: Mention these changes and their effects.
* macro.c (get_token): Use is_name_beginner/is_part_of_name/
(check_macro): Likewise.
(buffer_and_nest): Likewise. Permit multiple labels. Don't discard
labels together with the closing pseudo-op.
(macro_expand_body): Adjust comment. Range-check input before use.
Adjust mis-spelled diagnostic. Use is_name_beginner.
* read.c (try_macro): New.
(read_a_source_file): New static variable last_eol. Don't list
macro expansion lines more than once. Call try_macro.
(s_macro): Set section of line_label to absolute instead of undefined.
* doc/as.texinfo: Add information on the caveats of these changes.
2005-04-11 Alan Modra <>
* symbols.c (symbol_X_add_number): Change return type to "offsetT *".
* symbols.h (symbol_X_add_number): Update prototype.
2005-04-10 Eric Christopher <>
* symbols.c (symbol_X_add_number): Fix warning.
2005-04-10 H.J. Lu <>
* config/tc-m68k.c (md_begin): Support 64bit host.
(get_num): Support 64bit BFD on 32bit host.
2005-04-10 H.J. Lu <>
* config/tc-mips.c (md_apply_fix3): Fix typos in BFD_RELOC_64.
2005-04-09 Alan Modra <>
* read.c (assign_symbol): Remove const from parm. Fix xcalloc
call. Don't do the COFF hacks for multi-emulation gas. Move
demand_empty_rest_of_line back to caller.
(s_set, equals): demand_empty_rest_of_line here.
PR gas/827
* as.h (rs_dummy): Define.
* symbols.c (symbol_X_add_number): New function.
* symbols.h (symbol_X_add_number): Declare.
* stabs.c (aout_process_stab): Tidy symbol frag setting.
* read.c (assign_symbol): New function, split out from s_set.
Use symbol_find_or_make. Leave fr_type of dummy frag as rs_dummy.
Fix COFF hacks for multi-emulation gas.
(s_set): Call assign_symbol. Remove "register" keyword.
(set_zero_frag): New function.
(pseudo_set): Always check for assignment to section syms.
Always set segment and frag of symbol, and likewise extern for
aout/bout. Handle assignment of sym=sym+/-const specially. Don't
special case exp.X_add_number non-zero for O_symbol expressions.
(equals): Use assign_symbol.
2005-04-08 Bob Wilson <>
* config/tc-xtensa.c (xtensa_create_xproperty_segments): Skip
SEC_MERGE sections.
2005-04-06 H.J. Lu <>
* config/tc-i386.c (tc_gen_reloc): Don't turn
BFD_RELOC_X86_64_32S into BFD_RELOC_32.
2005-04-06 Nick Clifton <>
* po/rw.po: New translation: Kinyarwanda
* (ALL_LINGUAS): Add rw
* configure: Regenerate.
2005-04-05 Sterling Augustine <>
Bob Wilson <>
* config/tc-xtensa.c (branch_align_power): New.
(xtensa_find_unaligned_branch_targets, get_aligned_diff,
future_alignment_required): Use branch_align_power to check section
alignment as well as xtensa_fetch_width when aligning branch targets.
2005-04-05 Bob Wilson <>
* config/tc-xtensa.c: Warning fixes throughout.
(xtensa_fetch_width): Change to unsigned.
(assemble_nop, xtensa_find_unaligned_branch_targets,
xtensa_find_unaligned_loops, xg_assemble_vliw_tokens,
is_narrow_branch_guaranteed_in_range, xtensa_fix_close_loop_end_frags,
min_bytes_to_other_loop_end, unrelaxed_frag_min_size,
unrelaxed_frag_max_size, xtensa_fix_short_loop_frags,
count_insns_to_loop_end, unrelaxed_frag_min_insn_count,
get_text_align_max_fill_size, get_text_align_nop_count,
get_text_align_nth_nop_size, get_noop_aligned_address,
get_aligned_diff, convert_frag_align_next_opcode,
convert_frag_immed_finish_loop, xtensa_create_property_segments,
xtensa_create_xproperty_segments, xt_block_aligned_size): Clean up
types, avoiding size_t and using offsetT and addressT appropriately.
(get_text_align_power): Clean up types. Avoid incorrect bound.
(get_text_align_fill_size): Clean up types. Restructure for clarity.
2005-04-04 H.J. Lu <>
* config/tc-ia64.c (start_unwind_section): Undo the change
of 2004-08-18.
(generate_unwind_image, dot_endp): Likewise.
2005-04-01 David Mosberger <>
* config/tc-ia64.c (ia64_handle_align): Move le_nop and
le_nop_stop arrays and initializers to file scope.
(md_begin): When generating code for anything other than
Itanium 1, use MMI instead of MFI NOP bundles as a filler.
2005-04-01 Jan Beulich <>
* config/tc-i386.c (output_imm): Also set sign flag for 64-bit push
2005-04-01 Jan-Benedict Glaw <>
* NEWS: Mention [fdgh]_floating.
* config/atof-vax.c: Fix some whitespace.
* config/tc-vax.c (md_pseudo_table): Add "[fdgh]_floating".
2005-04-01 Nick Clifton <>
* Add a check for <unistd.h> providing a prototype
for getopt() which is compatible with the one in
include/getopt.h. If so then define HAVE_DECL_GETOPT.
* configure: Regenerate.
2005-04-01 Jan Beulich <>
* config/tc-i386.c (s_bss): Call obj_elf_section_change_hook.
2005-04-01 Jan Beulich <>
* config/tc-i386.c (md_apply_fix3): Also handle BFD_RELOC_X86_64_32S.
(tc_gen_reloc): Handle BFD_RELOC_X86_64_32S in the default case.
2005-03-30 Julian Brown <>
* config/tc-arm.c (arm_adjust_symtab): Rename
bfd_elf32_is_arm_mapping_symbol_name to bfd_is_arm_mapping_symbol_name.
2005-03-30 Julian Brown <>
* config/tc-arm.c (mapping_state): Change documentation in function
comment to cross-reference spec instead. Change type of mapping symbols
(arm_adjust_symtab): Don't change type of mapping symbols here.
2005-03-30 Aaron W. LaFramboise <>
* as.h [NEED_DECLARATION_FFS] (ffs): Prototype and alphabetize.
* Regenerate.
* configure: Regenerate.
* Check for ffs decl and alphabetize.
2005-03-29 Daniel Jacobowitz <>
Phil Blundell <>
* config/tc-arm.c (arm_parse_reloc): Add TLS relocations.
(md_apply_fix3): Mark TLS symbols.
(tc_gen_reloc): Handle TLS relocations.
(arm_fix_adjustable): Ignore TLS relocations.
(s_arm_elf_cons): Support expressions after decorated symbols.
2005-03-29 Julian Brown <>
* config/tc-arm.c (marked_pr_dependency): New bitmap, bit N indicates
whether personality routine index N has been output for this section.
(mapping_state): tc_segment_info_data now struct not enum.
(arm_elf_change_section): Likewise, and marked_pr_dependency is now
handled on section change.
(create_unwind_entry): Previous code to output dependency removed.
(s_arm_unwind_fnend): Output dependency if it hasn't been done already
for this section.
* config/tc-arm.h (TC_SEGMENT_INFO_TYPE): Redefined as struct
(arm_segment_info_type): New struct.
2005-03-28 Sterling Augustine <>
Bob Wilson <>
* config/tc-xtensa.c (do_align_targets): Update comment.
(xtensa_frob_label): Compute "freq" before possibly switching frags.
Insert a LOOP_END frag before every loop target, and do not overload
DESIRE_ALIGN_IF_TARGET frags with loop end information.
(xg_assemble_vliw_tokens): Use do_align_targets.
(xtensa_fix_target_frags): Remove code to convert a
DESIRE_ALIGN_IF_TARGET frag to a LOOP_END frag when there is a
negatable branch at the end of a loop.
(frag_can_negate_branch): Delete.
2005-03-28 David Mosberger <>
H.J. Lu <>
PR 803
NEWS: Mention "-mtune=[itanium1|itanium2]".
* config/tc-ia64.c (md): Add tune.
(md_parse_option): Accepted "-mtune=[itanium1|itanium2]".
(md_show_usage): Add "-mtune=[itanium1|itanium2]".
(extra_goodness): Prefer M- and I-unit NOPs for itanium2. F and
B unit NOPs are discouraged for McKinley-derived cores.
(md_begin): Don't hardcode the "extra_goodness()" function in
the comment...
(ia64_init): Set md.tune to itanium2.
* doc/as.texinfo: Add -mtune=[itanium1|itanium2]".
* doc/c-ia64.texi: Likewise.
2005-03-27 Ian Lance Taylor <>
* config/obj-coff.c (coff_frob_symbol): When crashing because of a
bad C_EFCN symbol, print its name.
2005-03-25 Bob Wilson <>
* config/tc-xtensa.c (use_longcalls): Delete.
(xg_symbolic_immeds_fit): Check for direct calls and return TRUE if
the use_longcalls flag is set. Do this before checking the segment.
(xg_expand_assembly_insn): Rearrange to use new do_expand flag. Never
expand direct calls at this point.
(xtensa_set_frag_assembly_state): Set use_longcalls flag.
(xtensa_find_unmarked_state_frags): Likewise.
(md_assemble): Do not disable longcalls by setting is_specific_opcode.
(xg_assemble_vliw_tokens): Switch frags when use_longcalls changes.
(convert_frag_immed): Remove unnecessary check of is_specific_opcode.
* config/tc-xtensa.h (xtensa_frag_type): Add use_longcalls flag.
2005-03-25 Hans-Peter Nilsson <>
* config/tc-mmix.c, config/tc-mmix.h: Convert to ISO C90.
2005-03-25 Hans-Peter Nilsson <>
* config/tc-cris.h: Convert to ISO C90.
* config/tc-cris.c: Ditto.
(md_estimate_size_before_relax): Remove obsolete comment for
parameter "segment_type".
(md_begin): Document reason for cast of hash_insert argument.
(md_atof): Correct type of parameter "type".
2005-03-24 Nick Clifton <>
* write.h (bit_fix_new): Remove redundant prototype.
* config/atof-ieee.c: Convert to ISO-C90 and fix formatting.
* config/obj-aout.c: Convert to ISO-C90 and fix formatting.
* config/obj-aout.h: Convert to ISO-C90 and fix formatting.
* config/obj-bout.c: Convert to ISO-C90 and fix formatting.
* config/obj-bout.h: Convert to ISO-C90 and fix formatting.
* config/obj-ecoff.c: Convert to ISO-C90 and fix formatting.
* config/obj-ecoff.h: Convert to ISO-C90 and fix formatting.
* config/obj-som.c: Convert to ISO-C90 and fix formatting.
* config/obj-som.h: Convert to ISO-C90 and fix formatting.
* config/tc-a29k.c: Convert to ISO-C90 and fix formatting.
* config/tc-a29k.h: Convert to ISO-C90 and fix formatting.
* config/tc-alpha.c: Convert to ISO-C90 and fix formatting.
* config/tc-alpha.h: Convert to ISO-C90 and fix formatting.
* config/tc-arc.c: Convert to ISO-C90 and fix formatting.
* config/tc-arc.h: Convert to ISO-C90 and fix formatting.
* config/tc-d10v.c: Convert to ISO-C90 and fix formatting.
* config/tc-d10v.h: Convert to ISO-C90 and fix formatting.
* config/tc-d30v.c: Convert to ISO-C90 and fix formatting.
* config/tc-d30v.h: Convert to ISO-C90 and fix formatting.
* config/tc-dlx.c: Convert to ISO-C90 and fix formatting.
* config/tc-dlx.h: Convert to ISO-C90 and fix formatting.
* config/tc-fr30.c: Convert to ISO-C90 and fix formatting.
* config/tc-fr30.h: Convert to ISO-C90 and fix formatting.
* config/tc-h8500.c: Convert to ISO-C90 and fix formatting.
* config/tc-h8500.h: Convert to ISO-C90 and fix formatting.
* config/tc-i370.c: Convert to ISO-C90 and fix formatting.
* config/tc-i370.h: Convert to ISO-C90 and fix formatting.
* config/tc-i960.c: Convert to ISO-C90 and fix formatting.
* config/tc-ip2k.c: Convert to ISO-C90 and fix formatting.
* config/tc-ip2k.h: Convert to ISO-C90 and fix formatting.
* config/tc-m32r.c: Convert to ISO-C90 and fix formatting.
* config/tc-m32r.h: Convert to ISO-C90 and fix formatting.
* config/tc-m88k.c: Convert to ISO-C90 and fix formatting.
* config/tc-m88k.h: Convert to ISO-C90 and fix formatting.
* config/tc-mcore.c: Convert to ISO-C90 and fix formatting.
* config/tc-mcore.h: Convert to ISO-C90 and fix formatting.
* config/tc-mn10200.c: Convert to ISO-C90 and fix formatting.
* config/tc-ns32k.c: Convert to ISO-C90 and fix formatting.
* config/tc-ns32k.h: Convert to ISO-C90 and fix formatting.
* config/tc-openrisc.c: Convert to ISO-C90 and fix formatting.
* config/tc-openrisc.h: Convert to ISO-C90 and fix formatting.
* config/tc-or32.c: Convert to ISO-C90 and fix formatting.
* config/tc-or32.h: Convert to ISO-C90 and fix formatting.
* config/tc-pdp11.h: Convert to ISO-C90 and fix formatting.
* config/tc-pj.c: Convert to ISO-C90 and fix formatting.
* config/tc-pj.h: Convert to ISO-C90 and fix formatting.
* config/tc-tahoe.c: Convert to ISO-C90 and fix formatting.
* config/tc-tic80.c: Convert to ISO-C90 and fix formatting.
* config/tc-tic80.h: Convert to ISO-C90 and fix formatting.
* config/tc-v850.c: Convert to ISO-C90 and fix formatting.
* config/tc-v850.h: Convert to ISO-C90 and fix formatting.
* config/tc-w65.c: Convert to ISO-C90 and fix formatting.
* config/tc-w65.h: Convert to ISO-C90 and fix formatting.
* config/tc-xstormy16.c: Convert to ISO-C90 and fix formatting.
* config/tc-xstormy16.h: Convert to ISO-C90 and fix formatting.
2005-03-23 Jim Blandy <>
* config/tc-arm.c (arm_adjust_symtab): Fetch elf_sym's binding
attributes properly.
2005-03-23 Mike Frysinger <>
Nick Clifton <>
* configure.tgt: Accept any C library to accompany a GNU Linux
implementation, not just the GNU C library.
* Likewise.
* configure: Regenerate.
2005-03-23 Nick Clifton <>
* config/tc-tic30.c: Convert to ISO C90 formatting.
* config/tc-tic30.h: Convert to ISO C90 formatting.
* config/tc-pdp11.c: Convert to ISO C90 formatting.
* config/atof-vax.c: Convert to ISO C90 formatting.
2005-03-21 Maciej W. Rozycki <>
* config/tc-mips.c (mips_frob_file): Sort BFD_RELOC_MIPS16_LO16
relocations correctly as well.
(mips_fix_adjustable): Don't make BFD_RELOC_MIPS16_LO16
relocations in mergeable sections section-relative either.
2005-03-21 Bob Wilson <>
* config/tc-xtensa.c (md_apply_fix3): Recognize XTENSA_PLT relocations.
2005-03-21 Nick Clifton <>
* config/tc-sh.c (sh_elf_final_processing): Fix compile time
warning by providing a prototype for sh_symbian_find_elf_flags.
* cgen.c (gas_cgen_parse_operand): Fix typo introduced by
previous delta.
2005-03-21 Alan Modra <>
* configure.tgt: Handle setting of bfd_gas for fmt=multi targets
along with other formats that set bfd_gas. Remove unnecessary
setting of bfd_gas. Delete strongarm cases in generic_target
2005-03-21 Alan Modra <>
PR gas/780
* config/tc-m68k.c (TRUNC, SEXT): Define.
(issbyte, isubyte, issword, isuword, isbyte, isword): Use the above.
(m68k_ip): Truncate or sign extend expressions as appropriate.
(get_num): Likewise.
(md_apply_fix3): Use SEXT.
2005-03-21 Alan Modra <>
* (OBJ_FORMAT_CFILES): Prune config/obj-vms.c.
(OBJ_FORMAT_HFILES): Prune config/obj-vms.h.
(obj-vms.o): Delete rule.
Run "make dep-am".
* Regenerate.
* aclocal.m4: Regenerate.
* doc/ Regenerate.
* po/ Regenerate.
2005-03-18 C Jaiprakash <>
* config/tc-m68k.c (m68k_elf_final_processing): Set file specific
flag for coldfire v4e.
2005-03-17 Bob Wilson <>
* config/tc-xtensa.c (xg_apply_tentative_value): Rename to
xg_apply_fix_value and return a value to indicate success.
(md_pcrel_from): Skip check of fx_done. Return 0 if not PC-relative.
(xtensa_force_relocation): Remove checks for VTABLE relocs.
(xtensa_validate_fix_sub): New.
(xtensa_fix_adjustable): Remove check for external or weak symbols.
(tc_gen_reloc): Move code to handle difference of symbols and code to
apply tentative fix values to ...
(md_apply_fix3): Enable standard overflow checks for simple
8, 16, and 32 bit relocations. Apply fixes for slot-specific
relocations when linkrelax flag is not set.
* config/tc-xtensa.h (xtensa_validate_fix_sub): Add prototype.
2005-03-17 Jan Beulich <>
* config/tc-i386.c (i386_scale): Beautify error message.
(Intel syntax comments): Update.
(struct intel_parser_s): Add fields in_offset, in_bracket, and
(intel_e04_1, intel_e05_1, intel_e05_1, intel_e09_1, intel_e10_1):
Remove declarations.
(intel_bracket_expr): Declare.
(i386_intel_operand): Initialize new intel_parser fields. Wrap most
of the function body in a loop allowing to split an operand into two.
Replace calls to malloc and checks of it returning non-NULL with
calls to xmalloc/xstrdup.
(intel_expr): SHORT no longer handled here. Add comment indicating
comparison ops need implementation.
(intel_e04, intel_e04_1): Combine, replace recursion with loop.
Check right operand of - does not specify a register when parsing
the address of a memory reference.
(intel_e05, intel_e05_1): Combine, replace recursion with loop.
Check operands do not specify a register when parsing the address of
a memory reference.
(intel_e06, intel_e06_1): Likewise.
(intel_e09, intel_e09_1): Combine, replace recursion with loop. Also
handle SHORT as well as unary + and -. Don't accept : except for
segment overrides or in direct far jump/call insns.
(intel_brack_expr): New.
(intel_e10, intel_e10_1): Combine, replace recursion with loop. Use
(intel_e11): Replace chain of if/else-if by switch, alloing fall-
through in certain cases. Use intel_brack_expr. Add new diagnostics.
Allow symbolic constants as register scale value.
(intel_get_token): Replace call to malloc and check of return value
with call to xmalloc. Change handling for FLAT to match MASM's.
(intel_putback_token): Don't try to back up/free current token if
that is T_NIL.
2005-03-16 Daniel Jacobowitz <>
* configure.tgt: Set emulation for arm-*-eabi*.
* config/tc-arm.c (meabi_flags): Check EABI_DEFAULT.
* config/te-armeabi.h: New file.
* config/te-armlinuxeabi.h (EABI_DEFAULT): Define.
* config/te-symbian.h: Include "te-armeabi.h".
2005-03-16 Nick Clifton <>
* cgen.c (gas_cgen_parse_operand): Copy opinfo parameter into a
local variable in case it is clobbered by the setjmp.
2005-03-16 Nick Clifton <>
Ben Elliston <>
* (werror): New switch: Add -Werror to the
compiler command line. Enabled by default. Disable via
* configure: Regenerate.
2005-03-16 Nick Clifton <>
* config/obj-coff.h: Convert to ISO C90 formatting.
* config/obj-coff.c: Convert to ISO C90 formatting.
2005-03-15 Zack Weinberg <>
* config/tc-arm.c (do_mla): Rename to do_mlas, take second
is_mls parameter; do not diagnose Rm==Rd when is_mls.
(do_mla, do_mls, five_bit_unsigned_immediate, bfci_lsb_and_width)
(do_bfc, do_bfi, do_bfx, do_rbit, do_mov16, do_ldsttv4): New functions.
(insns): Add ARMv6T2 instructions:
bfc bfi mls movw movt rbit sbfx ubfx ldrht ldrsht ldrsbt strht.
(arm_archs): Add V6T2 variants.
2005-03-15 Nick Clifton <>
* NEWS: Add cutoff for changes in 2.16 release.
2005-03-15 Jan Beulich <>
* expr.c (operand): Merge handling of unary + into that for unary
-, !, and ~.
2005-03-14 Eric Christopher <>
* config/tc-mips.c: Include dw2gencfi.h.
(mips_cfi_frame_initial_instructions): New.
* config/tc-mips.h (TARGET_USE_CFIPOP): Define.
(tc_cfi_frame_initial_instructions): Ditto.
* Update dependencies.
* Regenerate.
2005-03-15 Alan Modra <>
* po/es.po: Commit new Spanish translation.
2005-03-14 Alan Modra <>
* po/tr.po: Commit new Turkish translation.
2005-03-12 Zack Weinberg <>
* config/tc-arm.c (tinsns): Add ARMv6K instructions sev, wfe,
wfi, yield.
2005-03-11 Daniel Jacobowitz <>
* Mark vax-vms as obsolete.
* Remove fmt=vms support.
* Regenerate.
* configure: Regenerate.
* config/obj-vms.h, config/obj-vms.c, config/vms-conf.h: Remove.
2005-03-10 Sterling Augustine <>
Bob Wilson <>
* config/tc-xtensa.c (finish_vinsn): Include the last instruction slot
when checking if xg_resolve_literals needs to be called.
* config/tc-xtensa.h: Fix spelling typo in a comment.
2005-03-10 Jan Beulich <>
* config/tc-tic54x.h (tic54x_macro_info): Change parameter type.
* config/tc-tic54x.c (tic54x_macro_info): Likewise. Replace hand-
crafted structure declarations with the types from macro.h.
2005-03-09 Richard Sandiford <>
* config/tc-mips.c (s_cpsetup): Use '__gnu_local_gp' instead of '_gp'
for -mno-shared optimization.
2005-03-09 Richard Sandiford <>
* config/tc-mips.c (MAX_VR4130_NOPS, MAX_DELAY_NOPS): New macros.
(MAX_NOPS): Bump to 4.
(mips_fix_vr4130): New variable.
(nops_for_vr4130): New function.
(nops_for_insn): Use MAX_DELAY_NOPS rather than MAX_NOPS. Use
nops_for_vr4130 if working around VR4130 errata.
(OPTION_FIX_VR4130, OPTION_NO_FIX_VR4130): New macros.
(md_longopts): Add -mfix-vr4130 and -mno-fix-vr4130.
(md_parse_option): Handle them.
(md_show_usage): Print them.
* doc/c-mips.texi: Document -mfix-vr4130 and -mno-fix-vr4130.
2005-03-09 Richard Sandiford <>
* config/tc-mips.c (append_insn): Remove cop_interlocks test from
branch delay code.
2005-03-09 Richard Sandiford <>
* config/tc-mips.h (mips_flush_pending_output): Delete.
(mips_emit_delays): Declare.
(md_flush_pending_output): Use mips_emit_delays.
* config/tc-mips.c (mips_no_prev_insn): Remove parameter; always forget
the previous instructions.
(md_begin, append_insn, md_parse_option): Update callers.
(mips_emit_delay): Remove parameter. Move INSNS != 0 code to
(mips_align, s_change_sec, s_cons, s_float_cons, s_gpword)
(s_gpdword): Update callers.
(start_noreorder, end_noreorder): New functions.
(macro, macro2, mips16_macro, s_mipsset): Use them instead of
manipulating mips_opts or prev_nop_frag directly.
(mips_flush_pending_output): Delete.
2005-03-09 Richard Sandiford <>
* config/tc-mips.c (mips_move_labels): New function, taken from...
(append_insn, mips_emit_delays):
2005-03-09 Richard Sandiford <>
* config/tc-mips.c (MAX_NOPS): New macro.
(history): Resize to 1 + MAX_NOPS.
(fix_vr4120_class): New enumeration.
(vr4120_conflicts): New variable.
(init_vr4120_conflicts): New function.
(md_begin): Call it.
(insn_uses_reg): Constify first argument.
(classify_vr4120_insn, insns_between, nops_for_insn, nops_for_sequence)
(nops_for_insn_or_target): New functions.
(append_insn): Use the new nops_for_* functions instead of inline
delay checks. Generalize prev_nop_frag handling to handle an
arbitrary history length. Insert nops into the history buffer
once the number of nops in prev_nop_frag is fixed.
(emit_delays): Use nops_for_insn instead of inline delay checks.
2005-03-09 Richard Sandiford <>
* config/tc-mips.c (append_insn): Remove now-redundant nops != 0
check from branch delay code. Remove unnecessary check for branches.
2005-03-09 Richard Sandiford <>
* config/tc-mips.c (dummy_opcode): Delete.
(nop_insn, mips16_nop_insn): New variables.
(NOP_INSN): New macro.
(insn_length, create_insn, install_insn, move_insn, add_fixed_insn)
(add_relaxed_insn, insert_into_history, emit_nop): New functions.
(md_begin): Initialize nop_insn and mips16_nop_insn.
(append_insn): Use the new emit_nop function to add nops, recording
them in the history buffer. Use add_fixed_insn or add_relaxed_insn
to reserve room for the instruction and install_insn to install the
final form. Use insert_into_history to record the instruction in
the history buffer. Use move_insn to do delay slot filling.
(mips_emit_delays): Use add_fixed_insn instead of the emit_nop macro.
(macro_build, mips16_macro_build, macro_build_lui, mips_ip)
(mips16_ip): Use create_insn to initialize mips_cl_insns.
2005-03-09 Richard Sandiford <>
(insn_uses_reg, reg_needs_delay, append_insn, macro_build)
(mips16_macro_build, macro_build_lui, mips16_macro, mips_ip)
(mips16_ip): Use the new macros instead of explicit masks and shifts.
2005-03-09 Richard Sandiford <>
* config/tc-mips.c (mips_cl_insn): Replace the valid_p, delay_slot_p
and extended_p fields with a single fixed_p field.
(append_insn, mips_no_prev_insn): Adjust accordingly.
2005-03-09 Richard Sandiford <>
* config/tc-mips.c (mips_cl_insn): Replace reloc_type array with
a single mips16_absolute_jump_p bit.
(append_insn): Adjust accordingly.
2005-03-09 Richard Sandiford <>
* config/tc-mips.h (mips_cl_insn): Move definition to...
* config/tc-mips.c (mips_cl_insn): Add new fields:
frag, where, fixp, reloc_type, valid_p, noreorder_p, delay_slot_p
and extended_p.
(history): New variable.
(prev_insn, prev_prev_insn, prev_insn_valid, prev_insn_frag)
(prev_insn_where, prev_insn_reloc_type, prev_insn_fixp)
(prev_insn_is_delay_slot, prev_insn_unreordered, prev_insn_extended)
(prev_prev_insn_unreordered): Delete.
(reg_needs_delay, append_insn, mips_no_prev_insn, mips_emit_delays)
(macro_start): Replace uses of prev_insn* with the equivalent history[]
2005-03-08 Daniel Jacobowitz <>
* doc/ Update dependencies.
* aclocal.m4,, doc/ Regenerated.
2005-03-08 Jan Beulich <>
* doc/as.texinfo: Add sentence to indicate redefining a macro is an
error, and point to .purgem documentation if someone really needs
* NEWS: Mention macro redefinition is now an error.
2005-03-08 Jan Beulich <>
* config/tc-ia64.c (emit_one_bundle): Track last slot user insn was
emitted to. Add more precise diagnostics for non-fitting insns based
on that. Eliminate now superfluous special casing of MLX. Clear out
slot information when dropping an insn.
2005-03-08 Jan Beulich <>
* config/tc-ia64.c (parse_section_name): Rename to...
(cross_section): In addition to separating the name from the rest of
the arguments, also carry out the operation.
(dot_xdata): Use cross_section.
(dot_float_cons): Likewise.
(dot_xstringer): Likewise.
(dot_xdata_ua): Likewise.
(dot_float_cons_ua): Likewise. Pass float_cons, not stmt_float_cons.
2005-03-05 Alan Modra <>
* po/gas.pot: Regenerate.
2005-03-04 David Daney <>
* config/tc-mips.c (macro_build_lui): Use '__gnu_local_gp'
instead of '_gp' for -mno-shared optimization.
(s_cpload): Ditto.
(s_abicalls): Document it in the comment.
(md_show_usage): Document the -mno-shared option.
2005-03-04 Richard Sandiford <>
* config/tc-mips.c (mips_set_options): Add sym32 field.
(mips_opts): Initialize it.
(HAVE_32BIT_ADDRESSES): Set to true if pointers are 32 bits wide.
(load_address): Use HAVE_64BIT_SYMBOLS instead of HAVE_64BIT_ADDRESSES
when deciding whether to use a symbolic %highest/%higher expansion.
(macro): Likewise. Remove o64/n32 linux hack. Always use
ADDRESS_ADD*_INSN for address addition in the expansion of "dla"
and "la". Handle constants separately from symbolic expressions in
the "ld_st:" case, using 64-bit arithmetic if HAVE_64BIT_ADDRESSES
and using load_register to load the high part of the address.
(OPTION_MSYM32, OPTION_NO_MSYM32): New macros.
(OPTION_ELF_BASE): Bump by 2.
(md_longopts): Add entries for -msym32 and -mno-sym32.
(md_parse_option): Handle them.
(usage): Document them.
(s_mipsset): Handle ".set sym32" and ".set nosym32".
(s_cpload, s_cpsetup): Use HAVE_64BIT_SYMBOLS instead of
HAVE_64BIT_ADDRESSES to detect 64-bit values of "_gp".
* doc/c-mips.texi: Document ".set sym32", ".set nosym32",
-msym32 and -mno-sym32.
2005-03-03 Thiemo Seufer <>
* config/tc-mips.c (load_address): Implement GP optimization
for 64bit address space non-PIC. Fix formatting.
(macro): Likewise. Simplify code.
(md_parse_option): Don't bail out if -G 0 is set for PIC code.
(mips_after_parse_args): Simplify code.
2005-03-03 Nick Clifton <>
* expr.c (operand): Remove redundant code enclosed by #ifdef
* config/tc-mn10200.c (tc_gen_reloc): Handle the case where the
reloc is the difference of two symbols defined in the same
* config/tc-iq2000.c (line_comment_chars): Include the # character
as otherwise this breaks #APP/#NO_APP processing.
2005-03-03 Ramana Radhakrishnan <>
* config/tc-arc.c(md_assemble): Remove dead code for handling
immediate indexing of ld and st .
2005-03-02 Daniel Jacobowitz <>
Joseph Myers <>
* config/tc-mips.c (percent_op): Add %tlsgd, %tlsldm, %dtprel_hi,
%dtprel_lo, %tprel_hi, %tprel_lo, and %gottprel.
(parse_relocation): Check for a word break after a relocation
(md_apply_fix3): Handle TLS relocations, and mark thread-local
2005-03-02 Alan Modra <>
* config/tc-ppc.c (ppc_fix_adjustable <ELF>): Remove bogus checks.
2005-03-02 Jan Beulich <>
* as.c (main): Use unlink_if_ordinary instead of unlink.
* messages.c (as_fatal): Likewise.
2005-03-02 Jan Beulich <>
* config/tc-i386.c (build_modrm_byte): Add lock prefix for cr8...15
(parse_register): Allow cr8...15 in all modes.
2005-03-02 Jan Beulich <>
* config/tc-i386.c (intel_e11): If not followed by T_PTR, treat T_BYTE
etc. like normal symbol references (T_ID).
2005-03-02 Alan Modra <>
* symbols.c (fb_label_name): Fix silly thinko in last change.
2005-03-02 Alan Modra <>
* expr.c (integer_constant): Remove TARGET_WORD_SIZE hack.
* config/tc-m68k.h (TARGET_WORD_SIZE): Delete.
* symbols.c (fb_label_name): Allow an augend of 2 for mmix.
2005-03-01 Ramana Radhakrishnan <>
PR gas/708
* config/tc-arc.c (md_assemble): Initialize suffix for extension
suffixes also.
2005-03-01 Alan Modra <>
* config/obj-coff.c (fixup_segment): Delete sy_mri_common assertion.
* as.h (assert): Warning fix.
* expr.c (expr): Correct assertion.
* read.c (s_comm_internal): Remove assertion.
* write.c (relax_segment): Enable vma assertion only for BFD_ASSEMBLER.
(fixup_segment): Remove assertion.
* config/tc-dlx.c (machine_ip): Remove untrue assertions.
(md_apply_fix3): Likewise.
* config/tc-i370.c (md_begin): Correct assertion.
(i370_macro): Warning fix for assertion.
2005-03-01 Alan Modra <>
* (AC_C_BIGENDIAN): Invoke.
* configure: Regenerate.
* write.c (write_object_file <!BFD_ASSEMBLER>): Don't use sizeof
host variable to set string header size.
* config/obj-aout.c (obj_header_append): Don't use host structs.
(obj_symbol_to_chars): Likewise.
(obj_emit_strings): Likewise. Use the passed in output pointer.
* config/obj-aout.h (H_GET_FILE_SIZE): Include H_GET_LINENO_SIZE.
* config/obj-bout.c (obj_emit_relocations): Use md_reloc_size,
not sizeof host struct.
(obj_header_append, obj_symbol_to_chars): Don't use host structs.
(obj_emit_strings): Likewise.
* config/obj-bout.h (EXEC_BYTES_SIZE): Define.
sizeof host struct.
(H_SET_SYMBOL_TABLE_SIZE): Hard code sym size rather than using
sizeof host struct.
(host_number_to_chars): Define.
* config/obj-hp300.c (hp300_header_append): Don't use sizeof
host internal struct to set header sizes.
* config/tc-i960.c (md_number_to_field): Warning fix.
(md_ri_to_chars): Use host byte order.
(get_cdisp, md_apply_fix3): Warning fix.
* config/tc-m68k.c (md_assemble): Don't use sizeof host short.
2005-02-28 Ramana Radhakrishnan <>
* doc/c-arc.texi: Update documentation about ARC's extension
2005-02-27 Svein E. Seldal <>
* config/tc-tic4x.c (tic4x_gen_to_words): Changed mail
address for myself.
2005-02-23 Alan Modra <>
* cgen.c: Warning fixes.
* config/tc-arc.c: Likewise.
* config/tc-arm.c: Likewise.
* config/tc-avr.c: Likewise.
* config/tc-d10v.c: Likewise.
* config/tc-d30v.c: Likewise.
* config/tc-frv.c: Likewise.
* config/tc-frv.h: Likewise.
* config/tc-h8300.c: Likewise.
* config/tc-h8500.c: Likewise.
* config/tc-i370.c: Likewise.
* config/tc-i960.c: Likewise.
* config/tc-ia64.c: Likewise.
* config/tc-ip2k.c: Likewise.
* config/tc-m68hc11.c: Likewise.
* config/tc-maxq.c: Likewise.
* config/tc-mcore.c: Likewise.
* config/tc-mips.c: Likewise.
* config/tc-msp430.c: Likewise.
* config/tc-pj.c: Likewise.
* config/tc-ppc.c: Likewise.
* config/tc-ppc.h: Likewise.
* config/tc-s390.c: Likewise.
* config/tc-sh.c: Likewise.
* config/tc-sh64.c: Likewise.
* config/tc-tic4x.c: Likewise.
* config/tc-tic80.c: Likewise.
* config/tc-v850.c: Likewise.
* config/tc-vax.c: Likewise.
* config/tc-w65.c: Likewise.
* config/tc-xstormy16.c: Likewise.
* config/tc-z8k.c: Likewise.
2005-02-22 Catherine Moore <>
* read.c (read_a_source_file): Reinstate TC_EQUAL_IN_INSN test.
* doc/internals.texi (TC_EQUAL_IN_INSN): Reinstate.
2005-02-22 Eric Christopher <>
* config/tc-mips.c (struct proc): Change isym to
func_sym. New member func_end_sym.
(s_mips_ent): Update.
(s_mips_end): Ditto. Add code to compute function size.
2005-02-22 Alan Modra <>
* read.c: Warning fixes.
* config/obj-elf.c: Likewise.
2005-02-22 Maciej W. Rozycki <>
* config/tc-mips.c (append_insn): Call dwarf2_emit_insn() before
emitting insn.
2005-02-21 H.J. Lu <>
* config/obj-coff.c (obj_coff_section): Replace SEC_SHARED with
* config/tc-tic54x.c (tic54x_bss): Replace SEC_BLOCK with
(demand_empty_rest_of_line): Likewise.
(tic54x_sblock): Likewise.
(tic54x_clink): Replace with SEC_CLINK with SEC_TIC54X_CLINK.
2005-02-21 Alan Modra <>
* read.c (address_bytes): New function.
(TC_ADDRESS_BYTES): Default for BSD_ASSEMBLER to address_bytes.
(potable): Add "dc.a".
(cons_worker): Handle "dc.a".
* doc/internals.texi (TC_ADDRESS_BYTES): Document.
2005-02-21 Alan Modra <>
* input-file.c (input_file_open): Rearrange to avoid warning.
2005-02-19 Alan Modra <>
* config/tc-hppa.h (TC_EQUAL_IN_INSN): Delete.
* read.c (read_a_source_file): Remove TC_EQUAL_IN_INSN test.
* doc/internals.texi (TC_EQUAL_IN_INSN): Delete.
2005-02-18 Thiemo Seufer <>
* config/tc-mips.c (macro_build_ldst_constoffset): Fail on $at
uses after .set noat.
(load_address): Likewise.
(macro): Likewise. Don't try to avoid $at use by sacrificing
the target register before it is stored, it won't work.
2005-02-17 James E Wilson <>
* config/tc-ia64.c (emit_one_bundle): Stop filling a bundle if we
see an instruction that specifies a template.
2005-02-18 Alan Modra <>
* config/tc-openrisc.c (openrisc_relax_frag): Delete unused function.
* config/tc-sparc.c (sparc_ip): Make op_exp static to silence warnings.
* config/tc-tic80.c (build_insn): Init insn[1] to silence warning.
2005-02-17 H.J. Lu <>
* NEWS: Mention "-mhint.b=[ok|warning|error]".
* config/tc-ia64.c (md): Add hint_b.
(emit_one_bundle): Handle md.hint_b for "hint".
(md_parse_option): Accepted "-mhint.b=[ok|warning|error]".
(md_show_usage): Add "-mhint.b=[ok|warning|error]".
(ia64_init): Set md.hint_b to error.
(md_assemble): Handle md.hint_b for "hint.b".
* doc/as.texinfo: Add "-mhint.b=[ok|warning|error]".
* doc/c-ia64.texi: Likewise.
2005-02-17 Alan Modra <>
* tc.h (struct relax_type, relax_typeS): Move from here..
* as.h: here. Make rlx_forward and rlx_backward an offsetT.
* ecoff.c (ecoff_new_file): Add appfile param.
* ecoff.h (ecoff_new_file): Likewise.
* itbl-lex.h: New file.
* itbl-lex.l: Include itbl-lex.h.
* itbl-parse.y: Likewise.
(insntbl_line, yyparse, yylex): Move to itbl-lex.h.
* read.c (s_app_file_string): Mark appfile possibly unused.
* subsegs.c (seg_not_empty_p): Make sec possibly unused.
* subsegs.h (struct seg_info_trash): Delete.
(seg_info): Use segment_info_type instead.
* config/obj-coff.c (struct filename_list): Make filename const char *.
* config/obj-ecoff.h (obj_app_file): Pass app to ecoff_new_file.
* config/obj-elf.c (elf_file_symbol): Similarly.
* config/tc-a29k.c (md_apply_fix3): Make val a valueT. Don't use
signed right shift.
* config/tc-arc.c (md_operand): Warning fix.
* config/tc-arm.c (arm_parse_reloc): Only define when OBJ_ELF.
(md_begin): Rearrange #if defined OBJ_COFF || defined OBJ_ELF.
* config/tc-cris.h (TC_IMPLICIT_LCOMM_ALIGNMENT): Use do while.
* config/tc-frv.c (frv_force_relocation): Warning fix.
* config/tc-m68k.c (md_parse_option): Delete unused var.
* config/tc-mcore.c (mylog2): Rename from log2 throughout.
* config/tc-sparc.c: Likewise.
(s_common): Warning fix.
* config/tc-mips.c (append_insn): Use unsigned long long expressions.
* config/tc-mmix.c (PUSHJSTUB_MAX, PUSHJSTUB_MIN): Define from
* config/tc-s390.c (s390_insn): Delete test of unsigned >= 0.
* config/tc-sh.c (sh_cfi_frame_initial_instructions,
sh_regname_to_dw2regnum): Only define for OBJ_ELF.
* config/tc-tic4x.c (tic4x_insert_reg): Use ISLOWER.
(tic4x_do_align): Use TIC_NOP_OPCODE.
* config/tc-tic4x.h (TIC_NOP_OPCODE): Rename from NOP_OPCODE.
* config/tc-vax.c: Include netinet/in.h.
(tc_headers_hook): Formatting.
* config/tc-xstormy16.c (md_pcrel_from_section): Correct parens.
2005-02-17 Jan Beulich <>
* config/tc-ia64.c (ia64_parse_name): Don't advance 'name' when
parsing inN, locN, outN. Set 'idx' to offset register number starts
at. Don't handle numbers with leading zeroes or beyond 95. Remove
pointless cast.
2005-02-16 Thiemo Seufer <>
* config/tc-mips.c (load_address): Fix formatting.
(macro): Don't use AT if .set noat is in effect. Fix formatting.
Catch macros which are unexpandable without AT. Remove duplicate
zeroing of used_at.
(macro2): Remove duplicate zeroing of used_at.
2005-02-16 Alan Modra <>
* dw2gencfi.c (output_cie, output_fde): Use DW_CFA_nop rather
than zero.
2005-02-15 Nigel Stephens <>
Maciej W. Rozycki <>
* config/tc-mips.c (reloc_needs_lo_p): Handle
(fixup_has_matching_lo_p): Handle BFD_RELOC_MIPS16_LO16.
(append_insn): Add BFD_RELOC_MIPS16_GPREL, BFD_RELOC_MIPS16_HI16_S
and BFD_RELOC_MIPS16_LO16 to relocs to suppress overflow
complaints on.
(mips16_ip): Resolve BFD_RELOC_MIPS16_HI16_S,
BFD_RELOC_MIPS16_HI16 and BFD_RELOC_MIPS16_LO16 for constants.
Call my_getSmallExpression() to parse percent operators.
(percent_op_match, mips_percent_op): Separate definitions.
(mips16_percent_op): Define percent operators for the MIPS16 mode.
(parse_relocation): Handle the MIPS16 mode using
(md_apply_fix3): Handle BFD_RELOC_MIPS16_HI16,
2005-02-15 Jan Beulich <>
* config/tc-ia64.c (md_apply_fix3): Call ia64_gen_real_reloc_type
instead of explicitly dealing with the translation; exclude
relocations that are already pcrel, however.
2005-02-15 Jan Beulich <>
* config/tc-ia64.c: Include limits.h (if available).
(gr_values[0]): Set path to INT_MAX.
(dot_reg_val): Don't allow changing value of r0. Limit range of
general registers at r127.
(specify_resource): Default resource index is -1. Don't set resource
index (in case IA64_RS_RSE) without setting the specific flag.
(note_register_values): Check operand is O_constant before tracking
input value of moves. Add tracking for dep.z with constant inputs.
(print_dependency): Resource index of specific resource may be zero.
(check_dependencies): Likewise.
2005-02-15 Jan Beulich <>
* config/tc-ia64.c (parse_operands): New local variables reg1, reg2,
reg_class. Check operands and emit diagnostics for illegal use of
2005-02-15 Jan Beulich <>
* config/tc-ia64.c (ia64_gen_real_reloc_type): Define and initialize
new variables type, suffix, and width. Handle
FUNC_DTP_RELATIVE case. Return incoming relocation type if
BFD_RELOC_IA64_IPLT[LM]SB in FUNC_IPLT_RELOC case. Generate warning
if unable to translate relocation type, using the new variables.
2005-02-15 Jan Beulich <>
* config/tc-ia64.h (ia64_symbol_chars): Declare.
(ty_symbol_chars): Define.
* config/tc-ia64.c (ia64_symbol_chars): Define.
2005-02-15 Jan Beulich <>
* config/tc-ia64.c (ia64_parse_name): Only update next character if
input_line_pointer was advanced.
2005-02-14 Kaz Kojima <>
* config/tc-sh.c (md_apply_fix3): Add parentheses around &
within |.
2005-02-13 Jan Beulich <>
* config/tc-ia64.c (md_parse_option): Handle -xnone and -xdebugn.
(md_show_usage): Add -xnone, -xdebugn, and -xdebugx. Relocate default
(ia64_init): Set md.detect_dv.
(ia64_start_line): New static variable warned. Warn only once when
encountering explicit stops in automatic mode.
* doc/c-ia64.texi: Describe -xnone, -xdebugn, and -xdebugx.
* NEWS: Mention new default mode.
2005-02-13 Jan Beulich <>
* config/tc-ia64.c (dot_rot): Add comment that name strings should
be freed when wiping out previous state. Canonicalize names before
use. Free name string when detecting redefinition.
(dot_pred_rel): Call generic expression parser to process arguments.
Handle O_register case for individual predicates and O_subtract for
(ia64_parse_name): Canonicalize name before looking it up in dynamic
register hash.
(ia64_canonicalize_symbol_name): Strip off all trailing # characters.
Warn if multiple found, issue error if resulting symbol name has zero
(dot_alias): Canonicalize name before use.
2005-02-11 H.J. Lu <>
* config/tc-ia64.c (unwind_diagnostic): Return -1 for warning
and 0 for error.
(in_procedure): Return -1 for warning.
(in_prologue): Likewise.
(in_body): Likewise.
2005-02-11 H.J. Lu <>
* config/tc-ia64.c (dot_xdata): Undo the last change.
(dot_float_cons): Likewise.
(dot_xstringer): Likewise.
(dot_xdata_ua): Likewise.
(dot_float_cons_ua): Likewise.
2005-02-11 H.J. Lu <>
* NEWS: Mention "-munwind-check=[warning|error]".
* config/tc-ia64.c (md): Add unwind_check.
(unwind_diagnostic): New.
(in_procedure): Call unwind_diagnostic when a directive isn't
in procedure.
(in_prologue): Call unwind_diagnostic when a directive isn't in
(in_body): Call unwind_diagnostic when a directive isn't in
body region.
(dot_endp): Set md.unwind_check to error before calling
in_procedure and restore it after. When the name is missing or
couldn't be found, use the one from the last .proc if
md.unwind_check isn't error. Warn if md.unwind_check is
(md_parse_option): Handle "-munwind-check=[warning|error]".
(md_show_usage): Add "-munwind-check=[warning|error]".
(ia64_init): Set md.unwind_check to warning.
* doc/as.texinfo: Add "-munwind-check=[none|warning|error]".
* doc/c-ia64.texi: Likewise.
2005-02-11 Jan Beulich <>
* config/tc-ia64.h (LEX_AT): Include LEX_BEGIN_NAME.
(LEX_QM): Likewise.
(ia64_parse_name): New third parameter.
(md_parse_name): Pass third argument.
* config/tc-ia64.c (pseudo_func): Placeholders use NULL as name.
(md_operand): Handling of '@'-prefixed symbols moved from here...
(ia64_parse_name): here.
2005-02-11 Jan Beulich <>
* config/tc-ia64.c (md): Remove last_groups and group_idx.
(errata_nop_necessary_p): Remove declaraction and definition.
(emit_one_bundle): Don't call errata_nop_necessary_p. Don't
update md.group_idx. Don't reset md.last_groups.
2005-02-11 Jan Beulich <>
* config/tc-ia64.c (parse_section_name): Handle non-quoted first
(dot_xdata): Free section name after use.
(dot_float_cons): Likewise.
(dot_xstringer): Likewise.
(dot_xdata_ua): Likewise.
(dot_float_cons_ua): Likewise.
(md_pseudo_table): Add xdata16 and
2005-02-10 H.J. Lu <>
* doc/all.texi: Add IA64.
* doc/as.texinfo: Likewise.
* doc/c-ia64.texi: Fix typos.
2005-02-10 Julian Brown <>
* config/tc-arm.c (do_t_ldmstm): Change BFD_RELOC_NONE to
(do_t_push_pop): Likewise.
(md_assemble): Likewise.
(md_apply_fix3): Handle BFD_RELOC_NONE correctly, make
BFD_RELOC_UNUSED same as previous meaning of BFD_RELOC_NONE.
(create_unwind_entry): Output dependency on the required personality
2005-02-07 Nathan Sidwell <>
* as.h (seg_not_empty_p): Return int, not bfd_boolean.
* subsegs.c (seg_not_empty_p): Likewise.
2005-02-07 Inderpreet Singh <>
* config/tc-maxq.c (md_estimate_size_before_relax): Correct the
relative jump calculation.
<md_convert_frag) : Likewise.
<output_disp): Likewise.
2005-02-07 Hans-Peter Nilsson <>
* write.c (write_object_file): Recognize warning-symbol construct
and skip object- and target- handling for the second symbol.
2005-02-02 Jan Beulich <>
* config/tc-ia64.c (dot_pred_rel): Update comment. Handle @-prefixed
designators along with quoted ones. Free copy of quoted designator
when done.
2005-02-01 Ben Elliston <>
* config/atof-ieee.c, config/obj-coff.c, config/obj-elf.c,
config/obj-ieee.c, config/obj-som.c, config/obj-vms.c,
config/tc-a29k.c, config/tc-alpha.c, config/tc-arc.c,
config/tc-arm.c, config/tc-d30v.c, config/tc-dlx.c,
config/tc-fr30.c, config/tc-h8300.c, config/tc-h8500.c,
config/tc-i370.c, config/tc-i386.c, config/tc-i960.c,
config/tc-ia64.c, config/tc-m32r.c, config/tc-m32r.h,
config/tc-m68hc11.c, config/tc-m68hc11.h, config/tc-mips.c,
config/tc-mn10200.c, config/tc-msp430.c, config/tc-ns32k.c,
config/tc-openrisc.c, config/tc-or32.c, config/tc-pdp11.c,
config/tc-pj.c, config/tc-sparc.h, config/tc-tic54x.c,
config/tc-tic80.c, config/tc-v850.c, config/tc-w65.c,
config/tc-xtensa.c, config/tc-z8k.c, config/xtensa-relax.c: Remove
#if 0'd code throughout.
2005-01-31 Nick Clifton <>
* as.c (parse_args): Bump copyright date reported by --version to
2005-01-31 Nick Clifton <>
* configure.tgt: Remove obsolete targets m68k-lynxos, sparc-lynxos
and vax-vms.
2005-01-31 Jan Beulich <>
* macro.c (buffer_and_nest): Allow 'from' being NULL; handle anything
that can end with .endr in that case. Make requiring/permitting
pseudo-ops without leading dot closer to the logic in read.c serving
the same purpose.
(expand_irp): Don't pass a mnemonic to buffer_and_nest as it will be
2005-01-31 Jan Beulich <>
* macro.c (do_formals): Adjust to no longer accept empty parameter
(define_macro): Adjust to no longer accept empty macro name, garbage
following the parameters, or macros that were previously defined.
* read.c (s_bad_end): Declare.
(potable): Add endm. Handler for endr and endm is s_bad_end.
(s_bad_end): Rename from s_bad_endr. Adjust to handle both .endm
and .endr.
* read.h (s_bad_endr): Remove.
2005-01-31 Jan Beulich <>
* config/tc-ia64.c (parse_operands): Parse all specified operands,
immediately discarding (but counting) those exceeding the maximum
possible amount. Track whether output and input operand counts ever
matched, and use this to better indicate which of the operands/
operand types was wrong; specifically don't default to pointing to
the first operand.
2005-01-31 Jan Beulich <>
* config/tc-ia64.c (unwind): Remove proc_end (now an automatic
variable in dot_endp). Add body and insn. Make prologue,
prologue_mask, body, and insn bitfields.
(fixup_unw_records): Remove spurious new-lines from end of diagnostic
(in_procedure, in_prologue, in_body): New.
(dot_fframe, dot_vframe, dot_vframesp, dot_vframepsp, dot_save,
dot_restore, dot_restorereg, dot_restorereg_p, dot_handlerdata,
dot_unwentry, dot_altrp, dot_savemem, dot_saveg, dot_savef, dot_saveb,
dot_savegf, dot_spill, dot_spillreg, dot_spillmem, dot_spillreg_p,
dot_spillmem_p, dot_label_state, dot_copy_state, dot_unwabi,
dot_personality): Use the appropriate one of the above.
(dot_proc): Clear unwind.proc_start; set to current location only if
none of the entry points were valid. Check for non-zero-length entry
point names. Check that entry points aren't defined, yet. Clear
unwind.prologue, unwind.body, and unwind.insn.
(dot_body): Call in_procedure. Check that first directive in procedure
had no insns emitted before. Set unwind.body.
(dot_prologue): Call in_procedure. Check that not already in prologue.
Check that first directive in procedure had no insns emitted before.
Clear unwind.body.
(dot_endp): Call in_procedure. Declare proc_end. Check for non-zero-
length entry point names. Check that entry points became defined.
(md_assemble): Set unwind.insn once unwind.proc_start is defined.
2005-01-31 Jan Beulich <>
* config/tc-ia64.c (emit_one_bundle): Snapshot manual bundling state
before actually using it. Don't generate an error in manual bundling
mode when looking at an insn requiring slot 2 but not yet at slot 2.
Don't generate an error in manual bundling mode when looking at an
insn required to be last in its group but the required slot hasn't
been reached, yet. Allow conversion from MII to MI;I for bundle
consisting of only 2 insns with the stop between them. Suppress
various meaningless errors resulting from detecting earlier ones.
2005-01-31 Jan Beulich <>
* config/tc-ia64.c (parse_operands): Also handle alloc without first
input being ar.pfs.
2005-01-28 Christian Groessler <>
* config/tc-z8k.c (md_assemble): Improve error detection.
2005-01-28 Jan Beulich <>
* config/tc-ia64.c (ia64_estimate_size_before_relax): Allocate space
for personality routine pointer only if there is one.
(ia64_convert_frag): Likewise.
(generate_unwind_image): Likewise.
2005-01-27 Christian Groessler <>
* config/tc-z8k.c (INSERT): Remove, not used anywhere.
(md_apply_fix3): Make relative branches out of range an error
instead of a warning. Display correct line number for out of
range branches/calls/memory accesses.
2005-01-27 Nathan Sidwell <>
* dwarf2dbg.c (dwarf2_finish): Correct logic for determining when
to emit .debug_line and other debug sections.
* as.h (seg_not_empty_p): Declare.
* subsegs.c (seg_not_empty_p): New predicate.
2005-01-27 Andrew Cagney <>
* configure: Regenerate to track ../gettext.m4 change.
2005-01-27 Jan Beulich <>
* config/tc-ia64.c (emit_one_bundle): Change "?imbf??" to "?ibmfxx".
2005-01-27 Jan Beulich <>
* config/tc-ia64.c (emit_one_bundle): Add late resolution of move
to/from application registers dynamic insns.
(md_assemble): Defer resolution of move to/from application registers
dynamic insns when they can be issued on either the I- or M-units.
2005-01-25 Alexandre Oliva <>
* config/tc-frv.c (md_apply_fix3): Mark TLS symbols as such.
2004-12-10 Alexandre Oliva <>
* config/tc-frv.c (frv_pic_ptr): Add tlsmoff support.
2004-11-10 Alexandre Oliva <>
* cgen.c (gas_cgen_parse_operand): Handle
* config/tc-frv.c (md_cgen_lookup_reloc): Handle TLS relocations.
(frv_force_relocation): Likewise. Fix handling of PIC
(md_apply_fix3): Likewise.
2005-01-21 Ben Elliston <>
* as.h: Remove #if 0'd code.
* atof-generic.c (atof_generic): Likewise.
* ecoff.c (ecoff_directive_frame): Likewise.
* frags.h (FRAG_APPEND_1_CHAR): Likewise.
* itbl-ops.c (itbl_add_reg): Likewise.
* listing.c (calc_hex): Likewise.
* read.c (MASK_CHAR): Likewise.
* subsegs.c (subsegs_print_statistics): Likewise.
* symbols.c (indent): Likewise.
* write.c (write_relocs): Likewise.
(write_object_file): Likewise.
(relax_frag): Likewise.
2005-01-20 Nick Clifton <>
* as.c (std_longopts): Add an entry for "--a" in order to prevent
getopt_long_only() from considering -a as an abbreviation for
(parse_args): Fix the parsing of -a=<file>.
2005-01-20 Alan Modra <>
PR gas/684
* read.c (s_incbin): Adjust default count for skip. Check validity
of count and skip rigorously.
2005-01-19 Fred Fish <>
* config/tc-mips.c (dummy_opcode): Add init for new struct member.
2005-01-19 Richard Sandiford <>
* read.c (convert_to_bignum): New function, split out from...
(emit_expr): Handle the case where X_add_number is
positive and the input value is negative.
(output_big_sleb128): Fix setting of continuation bit. Check whether
the final byte needs to be sign-extended. Fix size-shrinking loop.
(emit_leb128_expr): When generating a signed leb128, see whether the
sign of an O_constant's X_add_number matches the sign of the input
value. Use a bignum if not.
2005-01-17 Andrew Stubbs <>
* tc-sh.c (md_begin,md_parse_option): Change arch_sh1_up to
arch_sh_up in order to match the external name and make the
testsuite's job easier.
2005-01-14 H.J. Lu <>
PR 659
* config/tc-i386.c (i386_scale): Disallow 0 scale.
2005-01-12 Nick Clifton <>
* config/tc-iq2000.c (s_iq2000_set): Fix thinko parsing
ignored_arguments array.
2005-01-10 H.J. Lu <>
* write.c (write_object_file): Disallow a symbol equated to
common symbol.
2005-01-10 Inderpreet Singh <>
* tc-maxq.c: Replace constants 10 and 20 with bfd_mach_maxq10 and
(md_pseudo_table): Add new pseudo ops for maxq10 and maxq20.
(maxq_target): New function: Set the machine type.
2005-01-06 Paul Brook <>
* config/tc-arm.c (FPU_DEFAULT): Define for TE_VXWORKS.
(md_begin): Handle TE_VXWORKS for FP defaults.
(md_apply_fix3): Correct rela offsets.
(elf32_arm_target_format): Add VxWorks targets.
2005-01-06 Paul Brook <>
* configure.tgt: Set em=vxworks for *-*-vxworks.
* config/te-vxworks.h: New File.
2005-01-06 Paul Brook <>
* config/tc-arm.c (arm_cpus): Correct arch field for arm1026ej-s.
2005-01-04 Dmitry Diky <>
* config/tc-msp430.c (md_apply_fix3): Fix offset calculation for
global label.
2005-01-03 David Mosberger <>
* config/tc-ia64.c (md): Add member "loc_directive_seen".
(dot_loc): New function.
(md_pseudo_table): Add entry to map .loc to dot_loc().
(emit_one_bundle): Only call dwarf2_gen_line_info() if we have
seen a .loc directive or we're generating DWARF2 debug info for
assembly source.
For older changes see ChangeLog-2004
Copyright (C) 2005 Free Software Foundation, Inc.
Copying and distribution of this file, with or without modification,
are permitted in any medium without royalty provided the copyright
notice and this notice are preserved.
Local Variables:
mode: change-log
left-margin: 8
fill-column: 74
version-control: never