diff options
author | Ulf Carlsson <ulfc@engr.sgi.com> | 2000-12-07 01:05:04 +0000 |
---|---|---|
committer | Ulf Carlsson <ulfc@engr.sgi.com> | 2000-12-07 01:05:04 +0000 |
commit | a9922e52c74ef38d79817330f60af92b872e249a (patch) | |
tree | 7a77fe5dc89e456ab6ae00b40187c53a8d191845 /bfd/elf32-mips.c | |
parent | 69da3468fdc2f3ae407f56dd3ab64e3cbcf8842a (diff) | |
download | gdb-a9922e52c74ef38d79817330f60af92b872e249a.zip gdb-a9922e52c74ef38d79817330f60af92b872e249a.tar.gz gdb-a9922e52c74ef38d79817330f60af92b872e249a.tar.bz2 |
2000-12-06 Ulf Carlsson <ulfc@engr.sgi.com>
From Ralf Baechle <ralf@gnu.org>
* elf32-mips.c (elf32_mips_merge_private_bfd_data): Always permit
BFDs containing no sections or empty .text, .data or .bss sections
to be merged, regardless of their flags.
Diffstat (limited to 'bfd/elf32-mips.c')
-rw-r--r-- | bfd/elf32-mips.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/bfd/elf32-mips.c b/bfd/elf32-mips.c index edb708a..4a44ae2 100644 --- a/bfd/elf32-mips.c +++ b/bfd/elf32-mips.c @@ -2497,6 +2497,8 @@ _bfd_mips_elf_merge_private_bfd_data (ibfd, obfd) flagword old_flags; flagword new_flags; boolean ok; + boolean null_input_bfd = true; + asection *sec; /* Check if we have the same endianess */ if (_bfd_generic_verify_endian_match (ibfd, obfd) == false) @@ -2536,6 +2538,27 @@ _bfd_mips_elf_merge_private_bfd_data (ibfd, obfd) if (new_flags == old_flags) return true; + /* Check to see if the input BFD actually contains any sections. + If not, its flags may not have been initialised either, but it cannot + actually cause any incompatibility. */ + for (sec = ibfd->sections; sec != NULL; sec = sec->next) + { + /* Ignore synthetic sections and empty .text, .data and .bss sections + which are automatically generated by gas. */ + if (strcmp (sec->name, ".reginfo") + && strcmp (sec->name, ".mdebug") + && ((!strcmp (sec->name, ".text") + || !strcmp (sec->name, ".data") + || !strcmp (sec->name, ".bss")) + && sec->_raw_size != 0)) + { + null_input_bfd = false; + break; + } + } + if (null_input_bfd) + return true; + ok = true; if ((new_flags & EF_MIPS_PIC) != (old_flags & EF_MIPS_PIC)) |