[gdb/symtab] Fix element type modification in read_array_type
When running test-case gdb.fortran/function-calls.exp with target board unix/gdb:debug_flags=-gdwarf-5, I run into: ... (gdb) PASS: gdb.fortran/function-calls.exp: \ p derived_types_and_module_calls::pass_cart(c) p derived_types_and_module_calls::pass_cart_nd(c_nd)^M ^M Program received signal SIGSEGV, Segmentation fault.^M 0x0000000000400f73 in derived_types_and_module_calls::pass_cart_nd \ (c=<error reading variable: Cannot access memory at address 0xc>) at \ function-calls.f90:130^M 130 pass_cart_nd = ubound(c%d,1,4)^M The program being debugged was signaled while in a function called from GDB.^M GDB has restored the context to what it was before the call.^M To change this behavior use "set unwindonsignal off".^M Evaluation of the expression containing the function^M (derived_types_and_module_calls::pass_cart_nd) will be abandoned.^M (gdb) FAIL: gdb.fortran/function-calls.exp: p ... The problem originates in read_array_type, when reading a DW_TAG_array_type with a dwarf-5 DW_TAG_generic_subrange child. This is not supported, and the fallout of this is that rather than constructing a new array type, the code proceeds to modify the element type. Fix this conservatively by issuing a complaint and bailing out in read_array_type when not being able to construct an array type, such that we have: ... (gdb) maint expand-symtabs function-calls.f90^M During symbol reading: unable to find array range \ - DIE at 0xe1e [in module function-calls]^M During symbol reading: unable to find array range \ - DIE at 0xe1e [in module function-calls]^M (gdb) KFAIL: gdb.fortran/function-calls.exp: no complaints in srcfile \ (PRMS: symtab/27388) ... Tested on x86_64-linux. gdb/ChangeLog: 2021-02-09 Tom de Vries <tdevries@suse.de> PR symtab/27341 * dwarf2/read.c (read_array_type): Return NULL when not being able to construct an array type. Add assert to ensure that element_type is not being modified. gdb/testsuite/ChangeLog: 2021-02-09 Tom de Vries <tdevries@suse.de> PR symtab/27341 * lib/gdb.exp (with_complaints): New proc, factored out of ... (gdb_load_no_complaints): ... here. * gdb.fortran/function-calls.exp: Add test-case.
This commit is contained in:
parent
03642b7189
commit
cf2b207529
5 changed files with 72 additions and 10 deletions
|
@ -1,3 +1,10 @@
|
||||||
|
2021-02-09 Tom de Vries <tdevries@suse.de>
|
||||||
|
|
||||||
|
PR symtab/27341
|
||||||
|
* dwarf2/read.c (read_array_type): Return NULL when not being able to
|
||||||
|
construct an array type. Add assert to ensure that element_type is
|
||||||
|
not being modified.
|
||||||
|
|
||||||
2021-02-09 Andrew Burgess <andrew.burgess@embecosm.com>
|
2021-02-09 Andrew Burgess <andrew.burgess@embecosm.com>
|
||||||
|
|
||||||
* gcore.c (struct gcore_collect_regset_section_cb_data): Delete.
|
* gcore.c (struct gcore_collect_regset_section_cb_data): Delete.
|
||||||
|
|
|
@ -17217,6 +17217,14 @@ read_array_type (struct die_info *die, struct dwarf2_cu *cu)
|
||||||
child_die = child_die->sibling;
|
child_die = child_die->sibling;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (range_types.empty ())
|
||||||
|
{
|
||||||
|
complaint (_("unable to find array range - DIE at %s [in module %s]"),
|
||||||
|
sect_offset_str (die->sect_off),
|
||||||
|
objfile_name (cu->per_objfile->objfile));
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/* Dwarf2 dimensions are output from left to right, create the
|
/* Dwarf2 dimensions are output from left to right, create the
|
||||||
necessary array types in backwards order. */
|
necessary array types in backwards order. */
|
||||||
|
|
||||||
|
@ -17246,6 +17254,8 @@ read_array_type (struct die_info *die, struct dwarf2_cu *cu)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gdb_assert (type != element_type);
|
||||||
|
|
||||||
/* Understand Dwarf2 support for vector types (like they occur on
|
/* Understand Dwarf2 support for vector types (like they occur on
|
||||||
the PowerPC w/ AltiVec). Gcc just adds another attribute to the
|
the PowerPC w/ AltiVec). Gcc just adds another attribute to the
|
||||||
array type. This is not part of the Dwarf2/3 standard yet, but a
|
array type. This is not part of the Dwarf2/3 standard yet, but a
|
||||||
|
|
|
@ -1,3 +1,10 @@
|
||||||
|
2021-02-09 Tom de Vries <tdevries@suse.de>
|
||||||
|
|
||||||
|
PR symtab/27341
|
||||||
|
* lib/gdb.exp (with_complaints): New proc, factored out of ...
|
||||||
|
(gdb_load_no_complaints): ... here.
|
||||||
|
* gdb.fortran/function-calls.exp: Add test-case.
|
||||||
|
|
||||||
2021-02-09 Abid Qadeer <abidh@codesourcery.com>
|
2021-02-09 Abid Qadeer <abidh@codesourcery.com>
|
||||||
|
|
||||||
* gdb.threads/signal-command-handle-nopass.exp: Call
|
* gdb.threads/signal-command-handle-nopass.exp: Call
|
||||||
|
|
|
@ -24,6 +24,21 @@ if {[prepare_for_testing ${testfile}.exp ${testfile} ${srcfile} {debug f90}]} {
|
||||||
return -1
|
return -1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
with_complaints 5 {
|
||||||
|
set cmd "maint expand-symtabs $srcfile"
|
||||||
|
set cmd_regexp [string_to_regexp $cmd]
|
||||||
|
set re_kfail [concat "During symbol reading:" \
|
||||||
|
" unable to find array range"]
|
||||||
|
gdb_test_multiple $cmd "no complaints in srcfile" {
|
||||||
|
-re -wrap "$re_kfail.*" {
|
||||||
|
kfail symtab/27388 $gdb_test_name
|
||||||
|
}
|
||||||
|
-re "^$cmd_regexp\r\n$gdb_prompt $" {
|
||||||
|
pass $gdb_test_name
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if {![runto [gdb_get_line_number "post_init"]]} then {
|
if {![runto [gdb_get_line_number "post_init"]]} then {
|
||||||
perror "couldn't run to breakpoint post_init"
|
perror "couldn't run to breakpoint post_init"
|
||||||
continue
|
continue
|
||||||
|
|
|
@ -5096,11 +5096,11 @@ proc gdb_load { arg } {
|
||||||
}
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
# gdb_load_no_complaints -- As gdb_load, but in addition verifies that
|
# with_complaints -- Execute BODY and set complaints temporary to N for the
|
||||||
# loading caused no symbol reading complaints.
|
# duration.
|
||||||
#
|
#
|
||||||
proc gdb_load_no_complaints { arg } {
|
proc with_complaints { n body } {
|
||||||
global gdb_prompt gdb_file_cmd_msg decimal
|
global decimal
|
||||||
|
|
||||||
# Save current setting of complaints.
|
# Save current setting of complaints.
|
||||||
set save ""
|
set save ""
|
||||||
|
@ -5112,16 +5112,39 @@ proc gdb_load_no_complaints { arg } {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# Fall back to regular gdb_load if we couldn't get the current setting
|
|
||||||
# of complaints.
|
|
||||||
if { $save == "" } {
|
if { $save == "" } {
|
||||||
return gdb_load $arg
|
perror "Did not manage to set complaints"
|
||||||
|
} else {
|
||||||
|
# Set complaints.
|
||||||
|
gdb_test_no_output "set complaints $n" ""
|
||||||
}
|
}
|
||||||
|
|
||||||
# Temporarily set complaint to a small non-zero number.
|
set code [catch {uplevel 1 $body} result]
|
||||||
gdb_test_no_output "set complaints 5" ""
|
|
||||||
|
|
||||||
gdb_load $arg
|
# Restore saved setting of complaints.
|
||||||
|
if { $save != "" } {
|
||||||
|
gdb_test_no_output "set complaints $save" ""
|
||||||
|
}
|
||||||
|
|
||||||
|
if {$code == 1} {
|
||||||
|
global errorInfo errorCode
|
||||||
|
return -code $code -errorinfo $errorInfo -errorcode $errorCode $result
|
||||||
|
} else {
|
||||||
|
return -code $code $result
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# gdb_load_no_complaints -- As gdb_load, but in addition verifies that
|
||||||
|
# loading caused no symbol reading complaints.
|
||||||
|
#
|
||||||
|
proc gdb_load_no_complaints { arg } {
|
||||||
|
global gdb_prompt gdb_file_cmd_msg decimal
|
||||||
|
|
||||||
|
# Temporarily set complaint to a small non-zero number.
|
||||||
|
with_complaints 5 {
|
||||||
|
gdb_load $arg
|
||||||
|
}
|
||||||
|
|
||||||
# Verify that there were no complaints.
|
# Verify that there were no complaints.
|
||||||
set re "^Reading symbols from \[^\r\n\]*\r\n$gdb_prompt $"
|
set re "^Reading symbols from \[^\r\n\]*\r\n$gdb_prompt $"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue