aboutsummaryrefslogtreecommitdiff
path: root/gdb/testsuite/gdb.base/print-symbol-loading.exp
diff options
context:
space:
mode:
authorDoug Evans <dje@google.com>2014-03-31 12:07:48 -0700
committerDoug Evans <dje@google.com>2014-03-31 12:07:48 -0700
commit770e7fc78c3c94195cacf2d7698a252d410886a1 (patch)
tree665ce89a8c46f3a619e945f5c90cdffe21157aea /gdb/testsuite/gdb.base/print-symbol-loading.exp
parent76f0cad6f4e0fdfc4cfeee135b44b6a090919c60 (diff)
downloadgdb-770e7fc78c3c94195cacf2d7698a252d410886a1.zip
gdb-770e7fc78c3c94195cacf2d7698a252d410886a1.tar.gz
gdb-770e7fc78c3c94195cacf2d7698a252d410886a1.tar.bz2
New option "set print symbol-loading".
* NEWS: Mention it. * solib.c (solib_read_symbols): Only print symbol loading messages if requested. (solib_add): If symbol loading is in "brief" mode, notify user symbols are being loaded. (reload_shared_libraries_1): Ditto. * symfile.c (print_symbol_loading_off): New static global. (print_symbol_loading_brief): New static global. (print_symbol_loading_full): New static global. (print_symbol_loading_enums): New static global. (print_symbol_loading): New static global. (print_symbol_loading_p): New function. (symbol_file_add_with_addrs): Only print symbol loading messages if requested. (_initialize_symfile): Register "print symbol-loading" set/show command. * symfile.h (print_symbol_loading_p): Declare. doc/ * gdb.texinfo (Symbols): Document set/show print symbol-loading. testsuite/ * gdb.base/print-symbol-loading-lib.c: New file. * gdb.base/print-symbol-loading-main.c: New file. * gdb.base/print-symbol-loading.exp: New file.
Diffstat (limited to 'gdb/testsuite/gdb.base/print-symbol-loading.exp')
-rw-r--r--gdb/testsuite/gdb.base/print-symbol-loading.exp144
1 files changed, 144 insertions, 0 deletions
diff --git a/gdb/testsuite/gdb.base/print-symbol-loading.exp b/gdb/testsuite/gdb.base/print-symbol-loading.exp
new file mode 100644
index 0000000..a080ce1
--- /dev/null
+++ b/gdb/testsuite/gdb.base/print-symbol-loading.exp
@@ -0,0 +1,144 @@
+# Copyright 2012-2014 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/>.
+
+# Test the "print symbol-loading" option.
+
+if {[skip_shlib_tests]} {
+ return 0
+}
+
+standard_testfile print-symbol-loading-main.c
+set libfile print-symbol-loading-lib
+set srcfile_lib ${libfile}.c
+set binfile_lib [standard_output_file ${libfile}.so]
+set gcorefile ${binfile}.gcore
+set objfile [standard_output_file ${testfile}.o]
+
+if { [gdb_compile_shlib ${srcdir}/${subdir}/${srcfile_lib} ${binfile_lib} {debug}] != ""
+ || [gdb_compile ${srcdir}/${subdir}/${srcfile} ${objfile} object {debug}] != "" } {
+ untested ${testfile}.exp
+ return -1
+}
+set opts [list debug shlib=${binfile_lib}]
+if { [gdb_compile ${objfile} ${binfile} executable $opts] != "" } {
+ untested ${testfile}.exp
+ return -1
+}
+
+clean_restart ${binfile}
+gdb_load_shlibs ${binfile_lib}
+
+# Does this gdb support gcore?
+set test "help gcore"
+gdb_test_multiple $test $test {
+ -re "Undefined command: .gcore.*\r\n$gdb_prompt $" {
+ # gcore command not supported -- nothing to test here.
+ unsupported "gdb does not support gcore on this target"
+ return -1
+ }
+ -re "Save a core file .*\r\n$gdb_prompt $" {
+ pass $test
+ }
+}
+
+if ![runto lib] {
+ return -1
+}
+
+if {![gdb_gcore_cmd $gcorefile "save a corefile"]} {
+ return -1
+}
+
+proc test_load_core { print_symbol_loading } {
+ global binfile binfile_lib gcorefile srcdir subdir
+ with_test_prefix "core ${print_symbol_loading}" {
+ gdb_exit
+ gdb_start
+ gdb_reinitialize_dir $srcdir/$subdir
+ gdb_test_no_output "set print symbol-loading $print_symbol_loading"
+ if { ${print_symbol_loading} != "off" } {
+ gdb_test "file $binfile" "Reading symbols from.*done\\." "file"
+ } else {
+ gdb_test_no_output "file $binfile" "file"
+ }
+ # Rename the shared lib so gdb can't find it.
+ remote_exec host "mv -f ${binfile_lib} ${binfile_lib}.save"
+ gdb_test "core ${gcorefile}" "Core was generated by .*" \
+ "re-load generated corefile"
+ # Now put it back and use "set solib-search-path" to trigger
+ # loading of symbols.
+ remote_exec host "mv -f ${binfile_lib}.save ${binfile_lib}"
+ set test_name "load shared-lib"
+ switch "${print_symbol_loading}" {
+ "off" {
+ gdb_test_no_output "set solib-search-path [file dirname ${binfile_lib}]" \
+ ${test_name}
+ }
+ "brief" {
+ gdb_test "set solib-search-path [file dirname ${binfile_lib}]" \
+ "Loading symbols for shared libraries\\." \
+ ${test_name}
+ }
+ "full" {
+ gdb_test "set solib-search-path [file dirname ${binfile_lib}]" \
+ "Reading symbols from.*Loaded symbols for.*" \
+ ${test_name}
+ }
+ }
+ gdb_test "frame" "#0 \[^\r\n\]* lib .*" "library got loaded"
+ }
+}
+
+test_load_core off
+test_load_core brief
+test_load_core full
+
+# Now test the sharedlibrary command.
+
+proc test_load_shlib { print_symbol_loading } {
+ global binfile
+ with_test_prefix "shlib ${print_symbol_loading}" {
+ clean_restart ${binfile}
+ gdb_test_no_output "set auto-solib-add off"
+ if ![runto_main] {
+ return -1
+ }
+ gdb_test_no_output "set print symbol-loading $print_symbol_loading"
+ set test_name "load shared-lib"
+ switch ${print_symbol_loading} {
+ "off" {
+ gdb_test_no_output "sharedlibrary .*" \
+ ${test_name}
+ }
+ "brief" {
+ gdb_test "sharedlibrary .*" \
+ "Loading symbols for shared libraries: \\.\\*" \
+ ${test_name}
+ }
+ "full" {
+ gdb_test "sharedlibrary .*" \
+ "Reading symbols from.*Loaded symbols for.*" \
+ ${test_name}
+ }
+ }
+ gdb_breakpoint "lib"
+ gdb_continue_to_breakpoint "lib"
+ gdb_test "frame" "#0 \[^\r\n\]* lib .*" "library got loaded"
+ }
+}
+
+test_load_shlib off
+test_load_shlib brief
+test_load_shlib full