diff options
author | Ian Lance Taylor <ian@airs.com> | 1995-08-08 21:41:30 +0000 |
---|---|---|
committer | Ian Lance Taylor <ian@airs.com> | 1995-08-08 21:41:30 +0000 |
commit | 1356d77df3d5860b008035d6ad2f4f1f7093b0fe (patch) | |
tree | d866efd6be56cdd01d68b15d4c1e94755dfff025 /gas/write.c | |
parent | 7aaec27bc740ff6c5a1377744ec0faac6edca74a (diff) | |
download | gdb-1356d77df3d5860b008035d6ad2f4f1f7093b0fe.zip gdb-1356d77df3d5860b008035d6ad2f4f1f7093b0fe.tar.gz gdb-1356d77df3d5860b008035d6ad2f4f1f7093b0fe.tar.bz2 |
* struc-symbol.h (struct symbol): Add sy_mri_common bit.
* read.h (mri_comon_symbol): Declare.
(s_mri_common): Declare.
* read.c (mri_line_label): New static variable.
(mri_common_symbol): New global variable.
(potable): Add "common" and "common.s".
(read_a_source_file): In MRI mode, set mri_line_label for a label
at the start of a line.
(s_mri_common): New function.
(s_space): Handle mri_common_symbol.
* symbols.c (colon): Change return value from void to symbolS *,
and return new symbol. If mri_common_symbol is set, attach the
new symbol to it.
(resolve_symbol_value): Handle an sy_mri_common symbol.
* symbols.h (colon): Change return value in declaration.
* subsegs.c (subseg_set_rest): Clear mri_common_symbol.
(subseg_set (both versions)): Likewise.
* frags.c (frag_more): Warn if mri_common_symbol is not NULL.
* write.c (adjust_reloc_syms): Skip sy_mri_common symbols.
(write_object_file): Discard sy_mri_common symbols.
(fixup_segment): Change relocations against sy_mri_common symbols
to be against the common symbol itself.
* config/obj-coff.c (yank_symbols): Discard sy_mri_common symbols.
(fixup_segment): Change relocations against sy_mri_common symbols
to be against the common symbol itself.
* config/obj-aout.c (obj_crawl_symbol_chain): Discard
sy_mri_common symbols.
Diffstat (limited to 'gas/write.c')
-rw-r--r-- | gas/write.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/gas/write.c b/gas/write.c index df8f66e..f9ec214 100644 --- a/gas/write.c +++ b/gas/write.c @@ -630,6 +630,12 @@ adjust_reloc_syms (abfd, sec, xxx) sym = fixp->fx_addsy; symsec = sym->bsym->section; + if (sym->sy_mri_common) + { + /* These symbols are handled specially in fixup_segment. */ + goto done; + } + /* If it's one of these sections, assume the symbol is definitely going to be output. The code in md_estimate_size_before_relax in tc-mips.c uses this test @@ -1578,6 +1584,15 @@ write_object_file () int punt = 0; const char *name; + if (symp->sy_mri_common) + { + if (S_IS_EXTERNAL (symp)) + as_bad ("%s: global symbols not supported in common sections", + S_GET_NAME (symp)); + symbol_remove (symp, &symbol_rootP, &symbol_lastP); + continue; + } + name = S_GET_NAME (symp); if (name) { @@ -2154,6 +2169,14 @@ fixup_segment (fixP, this_segment_type) pcrel = fixP->fx_pcrel; plt = fixP->fx_plt; + if (add_symbolP->sy_mri_common) + { + know (add_symbolP->sy_value.X_op == O_symbol); + add_number += S_GET_VALUE (add_symbolP); + fixP->fx_offset = add_number; + add_symbolP = fixP->fx_addsy = add_symbolP->sy_value.X_add_symbol; + } + if (add_symbolP) add_symbol_segment = S_GET_SEGMENT (add_symbolP); |