
This patch is another attempt to fix PR cli/19551. Unlike my previous attempt, it doesn't print progress. Instead, it just changes some messages and adds newlines to make the output a bit nicer. It also removes the "done." text that was previously emitted. The idea here is that it is obvious when gdb is done reading debug info, as it starts then doing something else; and that while this message did not provide much benefit to users, it did make it harder to make the output clean. After this change the output from "./gdb -iex 'set complaint 1' -nx ./gdb" reads: Reading symbols from ./gdb... .debug_ranges entry has start address of zero [in module /home/tromey/gdb/build/gdb/gdb] DW_AT_low_pc 0x0 is zero for DIE at 0x17116c1 [in module /home/tromey/gdb/build/gdb/gdb] .debug_line address at offset 0xa22f5 is 0 [in module /home/tromey/gdb/build/gdb/gdb] During symbol reading, unsupported tag: 'DW_TAG_unspecified_type'. During symbol reading, const value length mismatch for 'std::ratio<1, 1000000000>::num', got 8, expected 0. gdb/ChangeLog 2018-10-04 Tom Tromey <tom@tromey.com> PR cli/19551: * symfile.c (symbol_file_add_with_addrs): Update output. * psymtab.c (require_partial_symbols): Update output. gdb/testsuite/ChangeLog 2018-10-04 Tom Tromey <tom@tromey.com> PR cli/19551: * lib/mi-support.exp (mi_gdb_file_cmd): Update. * lib/gdb.exp (gdb_file_cmd): Update. * gdb.stabs/weird.exp (print_weird_var): Update. * gdb.server/solib-list.exp: Update. * gdb.multi/remove-inferiors.exp (test_remove_inferiors): Update. * gdb.mi/mi-cli.exp: Update. * gdb.linespec/linespec.exp: Update. * gdb.dwarf2/dw2-stack-boundary.exp: Update. * gdb.dwarf2/dw2-objfile-overlap.exp: Update. * gdb.cp/cp-relocate.exp: Update. * gdb.base/sym-file.exp: Update. * gdb.base/relocate.exp: Update. * gdb.base/readnever.exp: Update. * gdb.base/print-symbol-loading.exp (test_load_core): Update. * gdb.base/kill-detach-inferiors-cmd.exp: Update. * gdb.base/dbx.exp (gdb_file_cmd): Update. * gdb.base/code_elim.exp: Update. * gdb.base/break-unload-file.exp (test_break): Update. * gdb.base/break-interp.exp (test_attach_gdb): Update. * gdb.base/break-idempotent.exp (force_breakpoint_re_set): Update. * gdb.base/attach.exp (do_attach_tests): Update. * gdb.base/sepdebug.exp: Update. * gdb.python/py-section-script.exp: Update.
154 lines
4.6 KiB
Text
154 lines
4.6 KiB
Text
# Copyright (C) 2010-2018 Free Software Foundation, Inc.
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
# This file is part of the GDB testsuite. It tests automagic loading of
|
|
# scripts specified in the .debug_gdb_scripts section.
|
|
|
|
# This test can only be run on targets which support ELF and use gas.
|
|
# For now pick a sampling of likely targets.
|
|
if {![istarget *-*-linux*]
|
|
&& ![istarget *-*-gnu*]
|
|
&& ![istarget *-*-elf*]
|
|
&& ![istarget *-*-openbsd*]
|
|
&& ![istarget arm*-*-eabi*]
|
|
&& ![istarget arm*-*-symbianelf*]
|
|
&& ![istarget powerpc-*-eabi*]} {
|
|
verbose "Skipping py-section-script.exp because of lack of support."
|
|
return
|
|
}
|
|
|
|
standard_testfile
|
|
|
|
# Make this available to gdb before the program starts, it is
|
|
# automagically loaded by gdb.
|
|
set remote_python_file [gdb_remote_download host \
|
|
${srcdir}/${subdir}/${testfile}.py]
|
|
|
|
set quoted_name "\"$remote_python_file\""
|
|
|
|
if {[build_executable $testfile.exp $testfile $srcfile \
|
|
[list debug \
|
|
additional_flags=-I${srcdir}/../../include \
|
|
additional_flags=-DSCRIPT_FILE=$quoted_name]] == -1} {
|
|
return -1
|
|
}
|
|
|
|
# Start with a fresh gdb.
|
|
gdb_exit
|
|
gdb_start
|
|
|
|
# Skip all tests if Python scripting is not enabled.
|
|
if { [skip_python_tests] } { continue }
|
|
|
|
gdb_reinitialize_dir $srcdir/$subdir
|
|
|
|
# Try first with a restrictive safe-path.
|
|
|
|
gdb_test_no_output "set auto-load safe-path /restricted" \
|
|
"set restricted auto-load safe-path"
|
|
gdb_load ${binfile}
|
|
|
|
# Verify gdb did not load the scripts.
|
|
set test_name "verify scripts not loaded"
|
|
gdb_test_multiple "info auto-load python-scripts" "$test_name" {
|
|
-re "Yes.*${testfile}.py.*Yes.*inlined-script.*$gdb_prompt $" {
|
|
fail "$test_name"
|
|
}
|
|
-re "No.*${testfile}.py.*No.*inlined-script.*$gdb_prompt $" {
|
|
pass "$test_name"
|
|
}
|
|
}
|
|
|
|
# Try again with a working safe-path.
|
|
|
|
gdb_exit
|
|
gdb_start
|
|
gdb_reinitialize_dir $srcdir/$subdir
|
|
|
|
gdb_test_no_output "set auto-load safe-path ${remote_python_file}:${binfile}" \
|
|
"set auto-load safe-path"
|
|
gdb_load ${binfile}
|
|
|
|
# Verify gdb loaded each script and they appear once in the list.
|
|
set test_name "verify scripts loaded"
|
|
gdb_test_multiple "info auto-load python-scripts" "$test_name" {
|
|
-re "${testfile}.py.*${testfile}.py.*$gdb_prompt $" {
|
|
fail "$test_name"
|
|
}
|
|
-re "inlined-script.*inlined-script.*$gdb_prompt $" {
|
|
fail "$test_name"
|
|
}
|
|
-re "Yes.*${testfile}.py.*Yes.*inlined-script.*$gdb_prompt $" {
|
|
pass "$test_name"
|
|
}
|
|
}
|
|
|
|
# Again, with a regexp this time.
|
|
gdb_test "info auto-load python-scripts ${testfile}" "Yes.*${testfile}.py.*"
|
|
|
|
# Again, with a regexp that matches no scripts.
|
|
gdb_test "info auto-load python-scripts no-script-matches-this" \
|
|
"No auto-load scripts matching no-script-matches-this."
|
|
|
|
if ![runto_main] {
|
|
perror "couldn't run to main"
|
|
return
|
|
}
|
|
|
|
gdb_test "b [gdb_get_line_number {break to inspect} ${testfile}.c ]" \
|
|
".*Breakpoint.*"
|
|
gdb_test "continue" ".*Breakpoint.*"
|
|
|
|
gdb_test "print ss" " = a=<1> b=<2>"
|
|
|
|
gdb_test "test-cmd 1 2 3" "test-cmd output, arg = 1 2 3"
|
|
|
|
|
|
# eu-strip creates NOBITS .debug_gdb_scripts sections in the debug files.
|
|
# Make sure those are ignored silently.
|
|
|
|
with_test_prefix "sepdebug" {
|
|
gdb_exit
|
|
|
|
set result [catch "exec eu-strip -g -f ${binfile}.debug ${binfile}" output]
|
|
verbose "result is $result"
|
|
verbose "output is $output"
|
|
if {$result != 0 || $output != ""} {
|
|
unsupported "cannot produce separate debug info files"
|
|
return
|
|
}
|
|
|
|
gdb_start
|
|
gdb_reinitialize_dir $srcdir/$subdir
|
|
|
|
gdb_test_no_output "set auto-load safe-path ${remote_python_file}:${binfile}" \
|
|
"set auto-load safe-path"
|
|
set test "load sepdebug"
|
|
gdb_test_multiple "file $binfile" $test {
|
|
-re "\r\nwarning: Invalid entry in \\.debug_gdb_scripts section.*\r\n$gdb_prompt $" {
|
|
fail $test
|
|
}
|
|
-re "\r\n$gdb_prompt $" {
|
|
pass $test
|
|
}
|
|
}
|
|
|
|
# Again, with a regexp this time.
|
|
gdb_test "info auto-load python-scripts ${testfile}" "Yes.*${testfile}.py.*"
|
|
|
|
# Again, with a regexp that matches no scripts.
|
|
gdb_test "info auto-load python-scripts no-script-matches-this" \
|
|
"No auto-load scripts matching no-script-matches-this."
|
|
}
|