aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--bfd/ChangeLog5
-rw-r--r--bfd/elf32-arm.c5
-rw-r--r--ld/ChangeLog5
-rw-r--r--ld/ldlang.c10
4 files changed, 22 insertions, 3 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog
index 3dd9ed0..3d2b2d9 100644
--- a/bfd/ChangeLog
+++ b/bfd/ChangeLog
@@ -7,6 +7,11 @@
2005-05-17 Nick Clifton <nickc@redhat.com>
+ * elf32-arm.c (elf32_arm_final_link_relocate): Gracefully handle
+ the situation where a symbols's section is not known but a section
+ relative R_ARM_RELATIVE reloc has to be generated for the Symbian
+ OS.
+
* elf32-v850.c (v850_elf_relocate_section): Move code to test for
the presence of a symbol table to just before the symbol table is
actually used.
diff --git a/bfd/elf32-arm.c b/bfd/elf32-arm.c
index 2e5ca4c..73554cf 100644
--- a/bfd/elf32-arm.c
+++ b/bfd/elf32-arm.c
@@ -2692,7 +2692,10 @@ elf32_arm_final_link_relocate (reloc_howto_type * howto,
the section symbol as it is convenient. (We
cannot use the symbol given by "h" directly as it
will not appear in the dynamic symbol table.) */
- symbol = elf_section_data (sym_sec->output_section)->dynindx;
+ if (sym_sec)
+ symbol = elf_section_data (sym_sec->output_section)->dynindx;
+ else
+ symbol = elf_section_data (input_section->output_section)->dynindx;
BFD_ASSERT (symbol != 0);
}
else
diff --git a/ld/ChangeLog b/ld/ChangeLog
index 342b939..27654cb 100644
--- a/ld/ChangeLog
+++ b/ld/ChangeLog
@@ -1,3 +1,8 @@
+2005-05-17 Julian Brown <julian@codesourcery.com>
+
+ * ldlang.c (print_assignment): Do not rely upon a valid result
+ having a section associated with it.
+
2005-05-17 Nick Clifton <nickc@redhat.com>
* ldlang.c (Scan_for_self_assignment): Check an assignment tree to
diff --git a/ld/ldlang.c b/ld/ldlang.c
index 19b986a..ee85422 100644
--- a/ld/ldlang.c
+++ b/ld/ldlang.c
@@ -3219,7 +3219,10 @@ print_assignment (lang_assignment_statement_type *assignment,
if (computation_is_valid)
{
- value = result.value + result.section->bfd_section->vma;
+ value = result.value;
+
+ if (result.section)
+ value += result.section->bfd_section->vma;
minfo ("0x%V", value);
if (is_dot)
@@ -3233,7 +3236,10 @@ print_assignment (lang_assignment_statement_type *assignment,
FALSE, FALSE, TRUE);
if (h)
{
- value = h->u.def.value + result.section->bfd_section->vma;
+ value = h->u.def.value;
+
+ if (result.section)
+ value += result.section->bfd_section->vma;
minfo ("[0x%V]", value);
}