forked from Imagelibrary/binutils-gdb
The problem reported in PR mi/25055 is that the output of the backtrace
command, when executed as breakpoint command does not show when executing
using the MI interpreter:
...
$ gdb a.out
Reading symbols from a.out...
(gdb) break main
Breakpoint 1 at 0x4003c0: file test.c, line 19.
(gdb) commands
Type commands for breakpoint(s) 1, one per line.
End with a line saying just "end".
>bt
>end
(gdb) interpreter-exec mi "-exec-run"
^done
Breakpoint 1, main () at test.c:19
19 return foo (4);
(gdb)
...
Interestingly, the function print_frame is called twice during -exec-run:
- once during tui_on_normal_stop where the ui_out is temporarily set to
tui->interp_ui_out (), resulting in the part after the comma in
"Breakpoint 1, main () at test.c:19"
- once during execute_control_command, where the ui_out is the default for the
current interpreter: mi_ui_out, which ignores calls to output text.
The commit 3a87ae656c "Use console uiout when executing breakpoint commands"
fixes the problem by temporarily switching to the ui_out of INTERP_CONSOLE in
execute_control_command.
This however caused a regression in redirection (escaping '#' using '\' for
git commit message convenience):
...
$ rm -f gdb.txt; gdb a.out
Reading symbols from a.out...
(gdb) break main
Breakpoint 1 at 0x4003c0: file test.c, line 19.
(gdb) commands
Type commands for breakpoint(s) 1, one per line.
End with a line saying just "end".
>bt
>end
(gdb) set logging redirect on
(gdb) set logging on
Redirecting output to gdb.txt.
Copying debug output to gdb.txt.
(gdb) run
\#0 main () at test.c:19
(gdb) q
A debugging session is active.
Inferior 1 [process 22428] will be killed.
Quit anyway? (y or n) y
$ cat gdb.txt
Starting program: /data/gdb_versions/devel/a.out
Breakpoint 1, main () at test.c:19
19 return foo (4);
...
The problem is that the '#0 main () at test.c:19' ends up in the gdb output
output rather than in gdb.txt. This is due to the fact that the redirect is
setup for the current ui_out (which is tui->interp_ui_out ()), while the
backtrace output is printed to the INTERP_CONSOLE ui_out.
Fix this by limiting switching to INTERP_CONSOLE ui_out to when INTERP_MI is
active.
Tested on x86_64-linux.
gdb/ChangeLog:
2019-11-21 Tom de Vries <tdevries@suse.de>
PR gdb/24956
* cli/cli-script.c (execute_control_command): Only switch to
INTERP_CONSOLE's ui_out when INTERP_MI is active.
gdb/testsuite/ChangeLog:
2019-11-21 Tom de Vries <tdevries@suse.de>
PR gdb/24956
* gdb.base/ui-redirect.exp: Test output of user-defined command.
Change-Id: Id1771e7fcc9496a7d97ec2b2ea6b1487596f1ef7
136 lines
4.3 KiB
Plaintext
136 lines
4.3 KiB
Plaintext
# Copyright (C) 2010-2019 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/>.
|
|
|
|
# Do not run if gdb debug is enabled as it will interfere with log redirect.
|
|
if [gdb_debug_enabled] {
|
|
untested "debug is enabled"
|
|
return 0
|
|
}
|
|
|
|
if { [prepare_for_testing "failed to prepare" ui-redirect start.c] } {
|
|
return -1
|
|
}
|
|
|
|
if ![runto_main] {
|
|
fail "can't run to main"
|
|
return -1
|
|
}
|
|
|
|
set test "commands"
|
|
gdb_test_multiple $test $test {
|
|
-re "End with a line saying just \"end\"\\.\r\n>$" {
|
|
pass $test
|
|
}
|
|
}
|
|
|
|
set test "print 1"
|
|
gdb_test_multiple $test $test {
|
|
-re "\r\n>$" {
|
|
pass $test
|
|
}
|
|
}
|
|
gdb_test_no_output "end"
|
|
|
|
gdb_breakpoint "foo"
|
|
gdb_breakpoint "bar"
|
|
|
|
set cmds [multi_line_input \
|
|
"break main" \
|
|
" commands" \
|
|
" print 1" \
|
|
" end" \
|
|
"break foo" \
|
|
"break bar"]
|
|
set cmds "$cmds\n"
|
|
set outdir [standard_output_file {}]
|
|
set cmds_file "$outdir/cmds.txt"
|
|
|
|
with_test_prefix "userdefined" {
|
|
set test "define userdefined"
|
|
gdb_test_multiple $test $test {
|
|
-re "End with a line saying just \"end\"\\.\r\n>$" {
|
|
pass $test
|
|
}
|
|
}
|
|
|
|
set test "bt"
|
|
gdb_test_multiple $test $test {
|
|
-re "\r\n>$" {
|
|
pass $test
|
|
}
|
|
}
|
|
|
|
gdb_test_no_output "end"
|
|
}
|
|
|
|
with_test_prefix "logging" {
|
|
gdb_test_no_output "set logging file /dev/null"
|
|
gdb_test "set logging on" \
|
|
"Copying output to /dev/null.*Copying debug output to /dev/null\\."
|
|
gdb_test "save breakpoints $cmds_file" "Saved to file '$cmds_file'\\." \
|
|
"save breakpoints cmds.txt"
|
|
cmp_file_string "$cmds_file" "$cmds" "cmds.txt"
|
|
gdb_test "userdefined" "#0 main ().*"
|
|
gdb_test "set logging off" "Done logging to /dev/null\\."
|
|
gdb_test "help" "List of classes of commands:.*"
|
|
}
|
|
|
|
with_test_prefix "redirect" {
|
|
gdb_test "set logging redirect on"
|
|
gdb_test "set logging on" \
|
|
"Redirecting output to /dev/null.*Copying debug output to /dev/null\\."
|
|
gdb_test_no_output "save breakpoints $cmds_file" "save breakpoints cmds.txt"
|
|
cmp_file_string "$cmds_file" "$cmds" "cmds.txt"
|
|
gdb_test_no_output "userdefined"
|
|
gdb_test "set logging off" "Done logging to /dev/null\\."
|
|
gdb_test "help" "List of classes of commands:.*"
|
|
}
|
|
|
|
with_test_prefix "redirect while already logging" {
|
|
gdb_test_no_output "set logging redirect off"
|
|
gdb_test "set logging on" \
|
|
"Copying output to /dev/null.*Copying debug output to /dev/null\\."
|
|
gdb_test "set logging redirect on" \
|
|
".*warning: Currently logging .*Turn the logging off and on to make the new setting effective.*"
|
|
gdb_test "save breakpoints $cmds_file" "Saved to file '$cmds_file'\\." \
|
|
"save breakpoints cmds.txt"
|
|
cmp_file_string "$cmds_file" "$cmds" "cmds.txt"
|
|
gdb_test "userdefined" "#0 main ().*"
|
|
gdb_test "set logging off" "Done logging to /dev/null\\."
|
|
gdb_test "help" "List of classes of commands:.*"
|
|
gdb_test_no_output "set logging redirect off"
|
|
}
|
|
|
|
with_test_prefix "debugging" {
|
|
gdb_test "set debug infrun 1"
|
|
gdb_test "set logging on" \
|
|
"Copying output to /dev/null.*Copying debug output to /dev/null\\."
|
|
gdb_test "continue" "Continuing.*infrun:.*infrun:.*Breakpoint \[0-9\]+, foo.*"
|
|
gdb_test "set debug infrun 0"
|
|
gdb_test "set logging off" "Done logging to /dev/null\\."
|
|
gdb_test "help" "List of classes of commands:.*"
|
|
}
|
|
|
|
with_test_prefix "redirect debugging" {
|
|
gdb_test_no_output "set logging debugredirect on"
|
|
gdb_test "set debug infrun 1"
|
|
gdb_test "set logging on" \
|
|
"Copying output to /dev/null.*Redirecting debug output to /dev/null\\."
|
|
gdb_test "continue" "Continuing.*((?!infrun).).*Breakpoint \[0-9\]+, bar.*"
|
|
gdb_test "set debug infrun 0"
|
|
gdb_test "set logging off" "Done logging to /dev/null\\."
|
|
gdb_test "help" "List of classes of commands:.*"
|
|
}
|