From a4fd3de5d3170b2c22c9fe4cf236cc31305ef103 Mon Sep 17 00:00:00 2001 From: Alan Modra Date: Tue, 26 Jun 2012 01:40:59 +0000 Subject: * elf64-ppc.c (ppc64_elf_next_toc_section): Don't error if input file has multiple .got/.toc sections and all don't fit in current toc group. --- bfd/elf64-ppc.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'bfd/elf64-ppc.c') diff --git a/bfd/elf64-ppc.c b/bfd/elf64-ppc.c index 46e8247..68ae03c 100644 --- a/bfd/elf64-ppc.c +++ b/bfd/elf64-ppc.c @@ -10554,7 +10554,9 @@ ppc64_elf_next_toc_section (struct bfd_link_info *info, asection *isec) if (!htab->second_toc_pass) { /* Keep track of the first .toc or .got section for this input bfd. */ - if (htab->toc_bfd != isec->owner) + bfd_boolean new_bfd = htab->toc_bfd != isec->owner; + + if (new_bfd) { htab->toc_bfd = isec->owner; htab->toc_first_sec = isec; @@ -10582,7 +10584,8 @@ ppc64_elf_next_toc_section (struct bfd_link_info *info, asection *isec) /* Die if someone uses a linker script that doesn't keep input file .toc and .got together. */ - if (elf_gp (isec->owner) != 0 + if (new_bfd + && elf_gp (isec->owner) != 0 && elf_gp (isec->owner) != off) return FALSE; -- cgit v1.1