Add support for decoding DWARF v5 DW_AT_addr_base tags.
authorTom de Vries <tdevries@suse.de>
Fri, 26 Feb 2021 15:52:39 +0000 (15:52 +0000)
committerNick Clifton <nickc@redhat.com>
Fri, 26 Feb 2021 15:52:39 +0000 (15:52 +0000)
* dwarf.c (display_debug_addr): Handle dwarf-5 .debug_addr bits.

binutils/ChangeLog
binutils/dwarf.c

index a73c60d3699ca0ed4e5d652c384e0914d8037a95..0a89ac2f914a29b5c9aa20d7f8b58b305304b5e0 100644 (file)
@@ -1,3 +1,7 @@
+2021-02-26  Tom de Vries  <tdevries@suse.de>
+
+       * dwarf.c (display_debug_addr): Handle dwarf-5 .debug_addr bits.
+
 2021-02-26  Tom de Vries  <tdevries@suse.de>
 
        PR 27390
index 9cc51c282fd1e6f4a0f0bf4d13a47317ff0115c3..555e5e04b94b60824078c9eccdecb331631b843c 100644 (file)
@@ -6063,8 +6063,8 @@ display_debug_macro (struct dwarf_section *section,
       SAFE_BYTE_GET_AND_INC (version, curr, 2, end);
       if (version != 4 && version != 5)
        {
-         error (_("Only GNU extension to DWARF 4 or 5 of %s is currently supported.\n"),
-                section->name);
+         error (_("Expected to find a version number of 4 or 5 in section %s but found %d instead\n"),
+                section->name, version);
          return 0;
        }
 
@@ -7416,6 +7416,7 @@ display_debug_addr (struct dwarf_section *section,
   unsigned char *end;
   unsigned int i;
   unsigned int count;
+  unsigned char * header;
 
   if (section->size == 0)
     {
@@ -7456,6 +7457,7 @@ display_debug_addr (struct dwarf_section *section,
   debug_addr_info [count]->addr_base = section->size;
   qsort (debug_addr_info, count, sizeof (debug_info *), comp_addr_base);
 
+  header = section->start;
   for (i = 0; i < count; i++)
     {
       unsigned int idx;
@@ -7466,7 +7468,38 @@ display_debug_addr (struct dwarf_section *section,
 
       printf (_("\tIndex\tAddress\n"));
       entry = section->start + debug_addr_info [i]->addr_base;
-      end = section->start + debug_addr_info [i + 1]->addr_base;
+      if (debug_addr_info [i]->dwarf_version >= 5)
+       {
+         size_t           header_size = entry - header;
+         unsigned char *  curr_header = header;
+         dwarf_vma        length;
+         int              version;
+         int              segment_selector_size;
+
+         if (header_size != 8 && header_size != 16)
+           {
+             warn (_("Corrupt %s section: expecting header size of 8 or 16, but found %ld instead\n"),
+                   section->name, (long) header_size);
+             return 0;
+           }
+
+         SAFE_BYTE_GET_AND_INC (length, curr_header, 4, entry);
+         if (length == 0xffffffff)
+           SAFE_BYTE_GET (length, curr_header, 8, entry);
+         end = curr_header + length;
+
+         SAFE_BYTE_GET_AND_INC (version, curr_header, 2, entry);
+         if (version != 5)
+           warn (_("Corrupt %s section: expecting version number 5 in header but found %d instead\n"),
+                 section->name, version);
+
+         SAFE_BYTE_GET_AND_INC (address_size, curr_header, 1, entry);
+         SAFE_BYTE_GET_AND_INC (segment_selector_size, curr_header, 1, entry);
+         address_size += segment_selector_size;
+       }
+      else
+       end = section->start + debug_addr_info [i + 1]->addr_base;
+      header = end;
       idx = 0;
       while (entry < end)
        {
This page took 0.029558 seconds and 4 git commands to generate.