]> git.ipfire.org Git - thirdparty/elfutils.git/commitdiff
tests/allfcts.c: Install alternate debug information
authorFlorian Weimer <fweimer@redhat.com>
Tue, 15 Apr 2014 14:58:39 +0000 (16:58 +0200)
committerMark Wielaard <mjw@redhat.com>
Thu, 24 Apr 2014 12:45:41 +0000 (14:45 +0200)
This change also adds more error checking and reporting.

Signed-off-by: Florian Weimer <fweimer@redhat.com>
tests/ChangeLog
tests/allfcts.c

index 3e702055ccac6d1f3b8a8dd4d3848a5cc3b97a29..1c30778d6e67fcd1411ea7a62ad8235da8d2afaa 100644 (file)
@@ -1,3 +1,9 @@
+2014-04-24  Florian Weimer  <fweimer@redhat.com>
+
+       * allfcts.c (setup_alt): New function.
+       (main): Call it.  Implementation additional error checking and
+       reporting.
+
 2014-04-24  Florian Weimer  <fweimer@redhat.com>
 
        * debugaltlink.c, run-debugaltlink.sh: New files.
index 10e0f07b8927ef8903119af3ebd979c1ae2b7362..d3c8d26ad539b0c13f0cade2228e289c9f7ec537 100644 (file)
 # include <config.h>
 #endif
 
+#include <err.h>
 #include <fcntl.h>
 #include ELFUTILS_HEADER(dw)
+#include ELFUTILS_HEADER(dwelf)
 #include <stdio.h>
 #include <unistd.h>
 
@@ -37,6 +39,28 @@ cb (Dwarf_Die *func, void *arg __attribute__ ((unused)))
   return DWARF_CB_ABORT;
 }
 
+static Dwarf *
+setup_alt (Dwarf *main)
+{
+  const char *alt_name;
+  const void *build_id;
+  ssize_t ret = dwelf_dwarf_gnu_debugaltlink (main, &alt_name, &build_id);
+  if (ret == 0)
+    return NULL;
+  if (ret == -1)
+    errx (1, "dwelf_dwarf_gnu_debugaltlink: %s", dwarf_errmsg (-1));
+  int fd = open (alt_name, O_RDONLY);
+  if (fd < 0)
+    err (1, "open (%s)", alt_name);
+  Dwarf *dbg_alt = dwarf_begin (fd, DWARF_C_READ);
+  if (dbg_alt == NULL)
+    errx (1, "dwarf_begin (%s): %s", alt_name, dwarf_errmsg (-1));
+  if (elf_cntl (dwarf_getelf (dbg_alt), ELF_C_FDREAD) != 0)
+    errx (1, "elf_cntl (%s, ELF_C_FDREAD): %s", alt_name, elf_errmsg (-1));
+  close (fd);
+  dwarf_setalt (main, dbg_alt);
+  return dbg_alt;
+}
 
 int
 main (int argc, char *argv[])
@@ -44,6 +68,8 @@ main (int argc, char *argv[])
   for (int i = 1; i < argc; ++i)
     {
       int fd = open (argv[i], O_RDONLY);
+      if (fd < 0)
+       err (1, "open (%s)", argv[i]);
 
       Dwarf *dbg = dwarf_begin (fd, DWARF_C_READ);
       if (dbg != NULL)
@@ -51,6 +77,7 @@ main (int argc, char *argv[])
          Dwarf_Off off = 0;
          size_t cuhl;
          Dwarf_Off noff;
+         Dwarf *dbg_alt = setup_alt (dbg);
 
          while (dwarf_nextcu (dbg, off, &noff, &cuhl, NULL, NULL, NULL) == 0)
            {
@@ -62,14 +89,20 @@ main (int argc, char *argv[])
              do
                {
                  doff = dwarf_getfuncs (die, cb, NULL, doff);
+                 if (dwarf_errno () != 0)
+                   errx (1, "dwarf_getfuncs (%s): %s",
+                         argv[i], dwarf_errmsg (-1));
                }
-             while (doff != 0 && dwarf_errno () == 0);
+             while (doff != 0);
 
              off = noff;
            }
 
+         dwarf_end (dbg_alt);
          dwarf_end (dbg);
        }
+      else
+       errx (1, "dwarf_begin (%s): %s", argv[i], dwarf_errmsg (-1));
 
       close (fd);
     }