Fix CU overrun in scan_unit_for_symbols
authorTom Tromey <tromey@adacore.com>
Wed, 14 Aug 2019 20:01:57 +0000 (14:01 -0600)
committerTom Tromey <tromey@adacore.com>
Thu, 15 Aug 2019 13:37:31 +0000 (07:37 -0600)
A customer program had a DWARF CU that consisted of just a CU DIE,
without any children.  In this situation, scan_unit_for_symbols will
try to read past the end of the current CU, and will take use the
first bytes of the next CU as an abbrev, printing an error message.

This patch fixes the bug by changing scan_unit_for_symbols to stop at
the end of the CU rather than the end of the .debug_info section.

bfd/ChangeLog
2019-08-15  Tom Tromey  <tromey@adacore.com>

* dwarf2.c (scan_unit_for_symbols): Check for end of CU, not end
of section.

bfd/ChangeLog
bfd/dwarf2.c

index 8a028cf..ad750bc 100644 (file)
@@ -1,3 +1,8 @@
+2019-08-15  Tom Tromey  <tromey@adacore.com>
+
+       * dwarf2.c (scan_unit_for_symbols): Check for end of CU, not end
+       of section.
+
 2019-08-14  Alan Modra  <amodra@gmail.com>
 
        PR 24623
index 057fd91..d56244b 100644 (file)
@@ -3072,7 +3072,7 @@ scan_unit_for_symbols (struct comp_unit *unit)
 {
   bfd *abfd = unit->abfd;
   bfd_byte *info_ptr = unit->first_child_die_ptr;
-  bfd_byte *info_ptr_end = unit->stash->info_ptr_end;
+  bfd_byte *info_ptr_end = unit->end_ptr;
   int nesting_level = 0;
   struct nest_funcinfo {
     struct funcinfo *func;