forked from Imagelibrary/binutils-gdb
gdb/dwarf: change read_loclist_index complaints into errors
Unlike read_rnglists_index, read_loclist_index uses complaints when it detects an inconsistency (a DW_FORM_loclistx value without a .debug_loclists section or an offset outside of the section). I really think they should be errors, since there's no point in continuing if this situation happens, we will likely segfault or read garbage. gdb/ChangeLog: * dwarf2/read.c (read_loclist_index): Change complaints into errors. Change-Id: Ic3a1cf6e682d47cb6e739dd76fd7ca5be2637e10
This commit is contained in:
committed by
Simon Marchi
parent
288ff897b1
commit
767fbfe95e
@@ -1,3 +1,8 @@
|
||||
2021-02-02 Simon Marchi <simon.marchi@efficios.com>
|
||||
|
||||
* dwarf2/read.c (read_loclist_index): Change complaints into
|
||||
errors.
|
||||
|
||||
2021-01-08 Tom de Vries <tdevries@suse.de>
|
||||
|
||||
PR gdb/26881
|
||||
|
||||
@@ -19534,19 +19534,22 @@ read_loclist_index (struct dwarf2_cu *cu, ULONGEST loclist_index)
|
||||
|
||||
section->read (objfile);
|
||||
if (section->buffer == NULL)
|
||||
complaint (_("DW_FORM_loclistx used without .debug_loclists "
|
||||
"section [in module %s]"), objfile_name (objfile));
|
||||
error (_("DW_FORM_loclistx used without .debug_loclists "
|
||||
"section [in module %s]"), objfile_name (objfile));
|
||||
|
||||
struct loclists_rnglists_header header;
|
||||
read_loclists_rnglists_header (&header, section);
|
||||
if (loclist_index >= header.offset_entry_count)
|
||||
complaint (_("DW_FORM_loclistx pointing outside of "
|
||||
".debug_loclists offset array [in module %s]"),
|
||||
objfile_name (objfile));
|
||||
error (_("DW_FORM_loclistx pointing outside of "
|
||||
".debug_loclists offset array [in module %s]"),
|
||||
objfile_name (objfile));
|
||||
|
||||
if (loclist_base + loclist_index * cu->header.offset_size
|
||||
>= section->size)
|
||||
complaint (_("DW_FORM_loclistx pointing outside of "
|
||||
".debug_loclists section [in module %s]"),
|
||||
objfile_name (objfile));
|
||||
error (_("DW_FORM_loclistx pointing outside of "
|
||||
".debug_loclists section [in module %s]"),
|
||||
objfile_name (objfile));
|
||||
|
||||
const gdb_byte *info_ptr
|
||||
= section->buffer + loclist_base + loclist_index * cu->header.offset_size;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user