diff options
author | Jim Wilson <wilson@tuliptree.org> | 1997-02-21 18:28:36 +0000 |
---|---|---|
committer | Jim Wilson <wilson@tuliptree.org> | 1997-02-21 18:28:36 +0000 |
commit | e2e5acfa756c4de80a904e7525264c24f103f514 (patch) | |
tree | c1374c612c593ebdab27e1222641d09ab39b1fbd | |
parent | 830ce6319a8fed54013413cce741a0bc079f12d0 (diff) | |
download | gdb-e2e5acfa756c4de80a904e7525264c24f103f514.zip gdb-e2e5acfa756c4de80a904e7525264c24f103f514.tar.gz gdb-e2e5acfa756c4de80a904e7525264c24f103f514.tar.bz2 |
Fix linker relocation overflow errors for the NEC vr4300/ddb toolchain.
These changes are related to Ian's gas/libgloss changes of Dec 13/Dec 18.
* tc-mips.c (mips_ip): If configured for an embedded ELF system,
don't set the section alignment to 2**4.
* mips/ddb.ld: Align the location counter before setting _gp, and
before setting edata. Remove ALIGN from _gp computation.
* mips/idt.ld, mips/pmon.ld: Before setting _gp, use ALIGN(8) instead
of ALIGN(16). Remove ALIGN from _gp computation.
-rw-r--r-- | gas/ChangeLog | 5 | ||||
-rw-r--r-- | gas/config/tc-mips.c | 28 |
2 files changed, 16 insertions, 17 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog index 08c512f..8743f22 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,8 @@ +Fri Feb 21 10:08:25 1997 Jim Wilson <wilson@cygnus.com> + + * tc-mips.c (mips_ip): If configured for an embedded ELF system, + don't set the section alignment to 2**4. + Fri Feb 21 11:55:03 1997 Ian Lance Taylor <ian@cygnus.com> * app.c (LEX_IS_TWOCHAR_COMMENT_2ND): Don't define. diff --git a/gas/config/tc-mips.c b/gas/config/tc-mips.c index 322bfe7..1eb151f 100644 --- a/gas/config/tc-mips.c +++ b/gas/config/tc-mips.c @@ -6227,20 +6227,11 @@ mips_ip (str, ip) insn_error = NULL; - for (s = str; islower (*s) || (*s >= '0' && *s <= '3') || *s == '6' || *s == '.'; ++s) + for (s = str; *s != '\0' && !isspace(*s); ++s) continue; - switch (*s) - { - case '\0': - break; - - case ' ': - *s++ = '\0'; - break; - - default: - as_fatal ("Unknown opcode: `%s'", str); - } + if ( isspace(*s) ) + *s++ = '\0'; + if ((insn = (struct mips_opcode *) hash_find (op_hash, str)) == NULL) { insn_error = "unrecognized opcode"; @@ -6767,8 +6758,9 @@ mips_ip (str, ip) | SEC_LOAD | SEC_READONLY | SEC_DATA)); - frag_align (*args == 'l' ? 2 : 3, 0); - if (OUTPUT_FLAVOR == bfd_target_elf_flavour) + frag_align (*args == 'l' ? 2 : 3, 0, 0); + if (OUTPUT_FLAVOR == bfd_target_elf_flavour + && strcmp (TARGET_OS, "elf") != 0) record_alignment (new_seg, 4); else record_alignment (new_seg, *args == 'l' ? 2 : 3); @@ -8815,7 +8807,7 @@ mips_align (to, fill, label) symbolS *label; { mips_emit_delays (false); - frag_align (to, fill); + frag_align (to, fill, 0); record_alignment (now_seg, to); if (label != NULL) { @@ -9618,7 +9610,9 @@ mips16_extended_frag (fragp, sec, stretch) { fragS *f; - /* Adjust stretch for any alignment frag. */ + /* Adjust stretch for any alignment frag. FIXME: This + doesn't handle the fr_subtype field, which specifies a + maximum number of bytes to skip when doing an alignment. */ for (f = fragp; f != fragp->fr_symbol->sy_frag; f = f->fr_next) { assert (f != NULL); |