summaryrefslogtreecommitdiff
path: root/bfd/elf64-ppc.c
diff options
context:
space:
mode:
authorAlan Modra <amodra@bigpond.net.au>2006-01-17 13:00:16 +0000
committerAlan Modra <amodra@bigpond.net.au>2006-01-17 13:00:16 +0000
commit4131f0d88d2a95979c142c4f97e5d040aeffab88 (patch)
treef90fbfb85243708ca0323cc49063e9c9402132fe /bfd/elf64-ppc.c
parentbabbe0de0aa4bb6a26946fef9be8279a881c1c4e (diff)
downloadgdb-4131f0d88d2a95979c142c4f97e5d040aeffab88.tar.gz
* elf64-ppc.c (ppc64_elf_gc_mark_hook): Don't hang forever in loop.
Diffstat (limited to 'bfd/elf64-ppc.c')
-rw-r--r--bfd/elf64-ppc.c5
1 files changed, 1 insertions, 4 deletions
diff --git a/bfd/elf64-ppc.c b/bfd/elf64-ppc.c
index a2cfaacdb2e..501d4b7f87d 100644
--- a/bfd/elf64-ppc.c
+++ b/bfd/elf64-ppc.c
@@ -4958,7 +4958,7 @@ ppc64_elf_gc_mark_hook (asection *sec,
struct bfd_sym_chain *sym = info->gc_sym_list;
info->gc_sym_list = NULL;
- do
+ for (; sym != NULL; sym = sym->next)
{
struct ppc_link_hash_entry *eh;
@@ -4988,10 +4988,7 @@ ppc64_elf_gc_mark_hook (asection *sec,
rsec = eh->elf.root.u.def.section;
if (!rsec->gc_mark)
_bfd_elf_gc_mark (info, rsec, ppc64_elf_gc_mark_hook);
-
- sym = sym->next;
}
- while (sym != NULL);
}
/* Syms return NULL if we're marking .opd, so we avoid marking all