diff options
author | Joel Brobecker <brobecker@gnat.com> | 2004-07-31 00:14:49 +0000 |
---|---|---|
committer | Joel Brobecker <brobecker@gnat.com> | 2004-07-31 00:14:49 +0000 |
commit | d805bdac4f94a87f46dc7e82598d86bcf505b7d2 (patch) | |
tree | fad26ee1266e04739d318eac80a046ca936b61c9 | |
parent | 9684a39dbd716ff4d7b3e09c8f0bd945abe5a8e7 (diff) | |
download | gdb-d805bdac4f94a87f46dc7e82598d86bcf505b7d2.zip gdb-d805bdac4f94a87f46dc7e82598d86bcf505b7d2.tar.gz gdb-d805bdac4f94a87f46dc7e82598d86bcf505b7d2.tar.bz2 |
* elfxx-mips.c (_bfd_mips_elf_symbol_processing): Handle
SHN_MIPS_TEXT and SHN_MIPS_DATA.
-rw-r--r-- | bfd/ChangeLog | 6 | ||||
-rw-r--r-- | bfd/elfxx-mips.c | 30 |
2 files changed, 32 insertions, 4 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index b300f86..c1c4470 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2004-07-31 Joel Brobecker <brobecker@gnat.com> + Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de> + + * elfxx-mips.c (_bfd_mips_elf_symbol_processing): Handle + SHN_MIPS_TEXT and SHN_MIPS_DATA. + 2004-07-09 H.J. Lu <hongjiu.lu@intel.com> PR 240 diff --git a/bfd/elfxx-mips.c b/bfd/elfxx-mips.c index a18ac84..3505f62 100644 --- a/bfd/elfxx-mips.c +++ b/bfd/elfxx-mips.c @@ -4192,15 +4192,37 @@ _bfd_mips_elf_symbol_processing (bfd *abfd, asymbol *asym) asym->section = bfd_und_section_ptr; break; -#if 0 /* for SGI_COMPAT */ case SHN_MIPS_TEXT: - asym->section = mips_elf_text_section_ptr; + { + asection *section = bfd_get_section_by_name (abfd, ".text"); + + BFD_ASSERT (SGI_COMPAT (abfd)); + if (section != NULL) + { + asym->section = section; + /* MIPS_TEXT is a bit special, the address is not an offset + to the base of the .text section. So substract the section + base address to make it an offset. */ + asym->value -= section->vma; + } + } break; case SHN_MIPS_DATA: - asym->section = mips_elf_data_section_ptr; + { + asection *section = bfd_get_section_by_name (abfd, ".data"); + + BFD_ASSERT (SGI_COMPAT (abfd)); + if (section != NULL) + { + asym->section = section; + /* MIPS_DATA is a bit special, the address is not an offset + to the base of the .data section. So substract the section + base address to make it an offset. */ + asym->value -= section->vma; + } + } break; -#endif } } |