]> git.ipfire.org Git - thirdparty/elfutils.git/commitdiff
libdw: Initialize dirarray early in read_srclines.
authorMark Wielaard <mjw@redhat.com>
Mon, 8 Jun 2015 22:31:25 +0000 (00:31 +0200)
committerMark Wielaard <mjw@redhat.com>
Wed, 10 Jun 2015 12:14:57 +0000 (14:14 +0200)
We might jump to "out" early on error. Help gcc see that isn't an issue
by initializing dirarray to dirstack early.

Signed-off-by: Mark Wielaard <mjw@redhat.com>
libdw/ChangeLog
libdw/dwarf_getsrclines.c

index e9b81f6d683056aa683125b46f8045905c8c6d05..487e34a70c6f6e70c6922f0a6fbb71e37d95ad54 100644 (file)
@@ -1,3 +1,7 @@
+2015-06-08  Mark Wielaard  <mjw@redhat.com>
+
+       * dwarf_getsrclines.c (read_srclines): Initialize dirarray early.
+
 2015-06-06  Mark Wielaard  <mjw@redhat.com>
 
        * dwarf_getsrclines.c (read_srclines): Initialize filelist early.
index ba9649a697c092d66afd10c170a5c43359336ecc..389c824de90c31722940d4114612c1b89ef554d4 100644 (file)
@@ -111,6 +111,14 @@ read_srclines (Dwarf *dbg,
 #define MAX_STACK_FILES (MAX_STACK_ALLOC / 4)
 #define MAX_STACK_DIRS  (MAX_STACK_ALLOC / 16)
 
+  struct dirlist
+  {
+    const char *dir;
+    size_t len;
+  };
+  struct dirlist dirstack[MAX_STACK_DIRS];
+  struct dirlist *dirarray = dirstack;
+
   if (unlikely (linep + 4 > lineendp))
     {
     invalid_data:
@@ -186,11 +194,7 @@ read_srclines (Dwarf *dbg,
 
   /* First comes the list of directories.  Add the compilation
      directory first since the index zero is used for it.  */
-  struct dirlist
-  {
-    const char *dir;
-    size_t len;
-  } comp_dir_elem =
+  struct dirlist comp_dir_elem =
     {
       .dir = comp_dir,
       .len = comp_dir ? strlen (comp_dir) : 0,
@@ -209,11 +213,7 @@ read_srclines (Dwarf *dbg,
     }
 
   /* Arrange the list in array form.  */
-  struct dirlist dirstack[MAX_STACK_DIRS];
-  struct dirlist *dirarray;
-  if (ndirlist < MAX_STACK_DIRS)
-    dirarray = dirstack;
-  else
+  if (ndirlist >= MAX_STACK_DIRS)
     {
       dirarray = (struct dirlist *) malloc (ndirlist * sizeof (*dirarray));
       if (unlikely (dirarray == NULL))