* elf64-ppc.c (ppc64_elf_get_synthetic_symtab): Return -1 on errors
authorAlan Modra <amodra@gmail.com>
Fri, 1 Apr 2005 02:35:41 +0000 (02:35 +0000)
committerAlan Modra <amodra@gmail.com>
Fri, 1 Apr 2005 02:35:41 +0000 (02:35 +0000)
rather than 0.

bfd/ChangeLog
bfd/elf64-ppc.c

index bc8d44c..08bc6ee 100644 (file)
@@ -1,3 +1,8 @@
+2005-04-01  Alan Modra  <amodra@bigpond.net.au>
+
+       * elf64-ppc.c (ppc64_elf_get_synthetic_symtab): Return -1 on errors
+       rather than 0.
+
 2005-03-31  H.J. Lu  <hongjiu.lu@intel.com>
 
        * elf.c (assign_section_numbers): Fix a typo.
index ca23f23..5a5e3a2 100644 (file)
@@ -2687,7 +2687,7 @@ ppc64_elf_get_synthetic_symtab (bfd *abfd,
 
   syms = bfd_malloc ((symcount + 1) * sizeof (*syms));
   if (syms == NULL)
-    return 0;
+    return -1;
 
   if (!relocatable && static_count != 0 && dyn_count != 0)
     {
@@ -2758,11 +2758,15 @@ ppc64_elf_get_synthetic_symtab (bfd *abfd,
 
       slurp_relocs = get_elf_backend_data (abfd)->s->slurp_reloc_table;
       relcount = (opd->flags & SEC_RELOC) ? opd->reloc_count : 0;
-
-      if (! relcount
-         || ! (*slurp_relocs) (abfd, opd, static_syms, FALSE))
+      if (relcount == 0)
        goto done;
 
+      if (!(*slurp_relocs) (abfd, opd, static_syms, FALSE))
+       {
+         count = -1;
+         goto done;
+       }
+
       size = 0;
       for (i = secsymend, r = opd->relocation; i < opdsymend; ++i)
        {
@@ -2794,7 +2798,7 @@ ppc64_elf_get_synthetic_symtab (bfd *abfd,
       s = *ret = bfd_malloc (size);
       if (s == NULL)
        {
-         count = 0;
+         count = -1;
          goto done;
        }
 
@@ -2847,6 +2851,7 @@ ppc64_elf_get_synthetic_symtab (bfd *abfd,
            free_contents_and_exit:
              free (contents);
            }
+         count = -1;
          goto done;
        }
 
@@ -2866,10 +2871,7 @@ ppc64_elf_get_synthetic_symtab (bfd *abfd,
 
       s = *ret = bfd_malloc (size);
       if (s == NULL)
-       {
-         count = 0;
-         goto free_contents_and_exit;
-       }
+       goto free_contents_and_exit;
 
       names = (char *) (s + count);