+2017-02-27 Nick Clifton <nickc@redhat.com>
+
+ PR ld/21180
+ * elf32-microblaze.c (microblaze_elf_finish_dynamic_symbol): Avoid
+ generating a seg-fault when encountering a symbol that has been
+ deleted by garbage collection.
+
2017-02-25 Alan Modra <amodra@gmail.com>
* elf32-arc.c (struct dynamic_sections): Delete.
|| h->dynindx == -1))
{
asection *sec = h->root.u.def.section;
+ bfd_vma value;
+
+ value = h->root.u.def.value;
+ if (sec->output_section != NULL)
+ /* PR 21180: If the output section is NULL, then the symbol is no
+ longer needed, and in theory the GOT entry is redundant. But
+ it is too late to change our minds now... */
+ value += sec->output_section->vma + sec->output_offset;
+
microblaze_elf_output_dynamic_relocation (output_bfd,
srela, srela->reloc_count++,
/* symindex= */ 0,
R_MICROBLAZE_REL, offset,
- h->root.u.def.value
- + sec->output_section->vma
- + sec->output_offset);
+ value);
}
else
{