88bbeca9d5
After a previous patch that was committed by Pedro (0000e5cc
), trying
to set a dprintf with with a GDBserver that doesn't support agent
commands at all now throws an error. But the dprintf tests still fail
with some GDBserver targets because they doesn't try to handle the
case of the server reporting support for breakpoint commands, but not
be able to use those in combination with Z0 (because Z0 isn't actually
supported, for example):
FAIL: gdb.base/dprintf.exp: 1st dprintf, agent
FAIL: gdb.base/dprintf.exp: 2nd dprintf, agent
FAIL: gdb.base/dprintf.exp: dprintf info 2 (pattern 4)
Similarly for the MI test.
This patch makes the tests handle this scenario.
Tested with native, and native gdbserver on x86_64 Fedora 17.
Also tested with the native-gdbserver.exp board hacked with:
set GDBFLAGS "${GDBFLAGS} -ex \"set remote breakpoint-commands off\""
(actually, "set remote breakpoint-commands off" is presently broken,
so this was on top of a fix for that command.)
which results in:
(gdb) PASS: gdb.base/dprintf.exp: 2nd dprintf, gdb
set dprintf-style agent
warning: Target cannot run dprintf commands, falling back to GDB printf
warning: Target cannot run dprintf commands, falling back to GDB printf
(gdb) UNSUPPORTED: gdb.base/dprintf.exp: set dprintf style to agent
gdb.sum:
Running target native-gdbserver
Running ../../../src/gdb/testsuite/gdb.base/dprintf.exp ...
PASS: gdb.base/dprintf.exp: dprintf
PASS: gdb.base/dprintf.exp: dprintf foo
PASS: gdb.base/dprintf.exp: dprintf 29
PASS: gdb.base/dprintf.exp: dprintf foo,"At foo entry\n"
PASS: gdb.base/dprintf.exp: ignore $bpnum 1
PASS: gdb.base/dprintf.exp: dprintf 26,"arg=%d, g=%d\n", arg, g
PASS: gdb.base/dprintf.exp: dprintf info 1
PASS: gdb.base/dprintf.exp: break 27
PASS: gdb.base/dprintf.exp: 1st dprintf, gdb
PASS: gdb.base/dprintf.exp: 2nd dprintf, gdb
UNSUPPORTED: gdb.base/dprintf.exp: set dprintf style to agent
PASS: gdb.base/dprintf.exp: Set dprintf style to an unrecognized type
And also with the native-gdbserver.exp board hacked with:
set GDBFLAGS "${GDBFLAGS} -ex \"set remote Z-packet off\""
which results in:
(gdb) continue
Continuing.
Warning:
Cannot insert breakpoint 3: Target doesn't support breakpoints that have target side commands.
Cannot insert breakpoint 4: Target doesn't support breakpoints that have target side commands.
(gdb) UNSUPPORTED: gdb.base/dprintf.exp: 1st dprintf, agent
gdb.sum:
Running target native-gdbserver
Running ../../../src/gdb/testsuite/gdb.base/dprintf.exp ...
PASS: gdb.base/dprintf.exp: dprintf
PASS: gdb.base/dprintf.exp: dprintf foo
PASS: gdb.base/dprintf.exp: dprintf 29
PASS: gdb.base/dprintf.exp: dprintf foo,"At foo entry\n"
PASS: gdb.base/dprintf.exp: ignore $bpnum 1
PASS: gdb.base/dprintf.exp: dprintf 26,"arg=%d, g=%d\n", arg, g
PASS: gdb.base/dprintf.exp: dprintf info 1
PASS: gdb.base/dprintf.exp: break 27
PASS: gdb.base/dprintf.exp: 1st dprintf, gdb
PASS: gdb.base/dprintf.exp: 2nd dprintf, gdb
PASS: gdb.base/dprintf.exp: set dprintf style to agent
UNSUPPORTED: gdb.base/dprintf.exp: 1st dprintf, agent
PASS: gdb.base/dprintf.exp: Set dprintf style to an unrecognized type
(One of the new comments mentions breakpoint always-inserted mode.
Actually testing with breakpoint always-inserted mode fails these
dprintf tests, due to the way they are written. But that'll take a
more substancial rewrite of the tests, so I'm leaving that for another
day.)
gdb/testsuite/
2014-03-24 Hui Zhu <hui@codesourcery.com>
Pedro Alves <palves@redhat.com>
PR breakpoints/16101
* gdb.base/dprintf.exp: Use unsupported rather than changing the
test pass/fail messages. Detect missing support for dprintf when
breakpoints are actually inserted.
* gdb.base/mi-dprintf.exp: Detect missing support for dprintf when
breakpoints are actually inserted.
* lib/mi-support.exp (mi_run_cmd_full): Return -1 if continue
fails.
155 lines
4.5 KiB
Text
155 lines
4.5 KiB
Text
# Copyright (C) 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/>.
|
|
|
|
|
|
if { [prepare_for_testing dprintf.exp "dprintf" {} {debug}] } {
|
|
return -1
|
|
}
|
|
|
|
set srcfile dprintf.c
|
|
|
|
set bp_location1 [gdb_get_line_number "set breakpoint 1 here"]
|
|
set dp_location1 [gdb_get_line_number "set dprintf 1 here"]
|
|
|
|
if ![runto main] {
|
|
return -1
|
|
}
|
|
|
|
gdb_test "dprintf" "Format string required"
|
|
|
|
gdb_test "dprintf foo" "Format string required"
|
|
|
|
gdb_test "dprintf 29" "Format string required"
|
|
|
|
delete_breakpoints
|
|
|
|
gdb_breakpoint "main"
|
|
|
|
gdb_test "dprintf foo,\"At foo entry\\n\"" \
|
|
"Dprintf .*"
|
|
|
|
gdb_test "ignore \$bpnum 1" ".*Will ignore next crossing of breakpoint.*"
|
|
|
|
gdb_test "dprintf $dp_location1,\"arg=%d, g=%d\\n\", arg, g" \
|
|
"Dprintf .*"
|
|
|
|
gdb_test_sequence "info breakpoints" "dprintf info 1" {
|
|
"\[\r\n\]Num Type Disp Enb Address +What"
|
|
"\[\r\n\]2 breakpoint"
|
|
"\[\r\n\]3 dprintf"
|
|
"\[\r\n\] printf \"At foo entry\\\\n\""
|
|
"\[\r\n\]4 dprintf"
|
|
"\[\r\n\] printf \"arg=%d, g=%d\\\\n\", arg, g"
|
|
}
|
|
|
|
gdb_test "break $bp_location1" \
|
|
"Breakpoint .*"
|
|
|
|
gdb_run_cmd
|
|
|
|
gdb_test "" "Breakpoint"
|
|
|
|
gdb_test "continue" "arg=1234, g=1234.*" "1st dprintf, gdb"
|
|
|
|
gdb_test "continue" "At foo entry.*arg=1235, g=2222.*" "2nd dprintf, gdb"
|
|
|
|
# The "call" style depends on having I/O functions available, so test.
|
|
|
|
if ![target_info exists gdb,noinferiorio] {
|
|
|
|
# Now switch styles and rerun; in the absence of redirection the
|
|
# output should be the same.
|
|
|
|
gdb_test_no_output "set dprintf-style call" "Set dprintf style to call"
|
|
|
|
gdb_run_cmd
|
|
|
|
gdb_test "" "Breakpoint"
|
|
|
|
gdb_test "continue" "At foo entry.*arg=1234, g=1234.*" "1st dprintf, call"
|
|
|
|
gdb_test "continue" "At foo entry.*arg=1235, g=2222.*" "2nd dprintf, call"
|
|
|
|
gdb_test_no_output "set dprintf-function fprintf" "Set dprintf function"
|
|
gdb_test_no_output "set dprintf-channel stderr" "Set dprintf channel"
|
|
|
|
gdb_run_cmd
|
|
|
|
gdb_test "" "Breakpoint"
|
|
|
|
gdb_test "continue" "At foo entry.*arg=1234, g=1234.*" \
|
|
"1st dprintf, fprintf"
|
|
|
|
gdb_test "continue" "At foo entry.*arg=1235, g=2222.*" \
|
|
"2nd dprintf, fprintf"
|
|
}
|
|
|
|
# Now test the "agent" style.
|
|
|
|
set target_can_dprintf 1
|
|
set msg "set dprintf style to agent"
|
|
gdb_test_multiple "set dprintf-style agent" $msg {
|
|
-re "warning: Target cannot run dprintf commands.*\r\n$gdb_prompt $" {
|
|
|
|
# The target reports that it doesn't support target side
|
|
# commands at all.
|
|
set target_can_dprintf 0
|
|
unsupported "$msg"
|
|
}
|
|
-re ".*$gdb_prompt $" {
|
|
pass "$msg"
|
|
}
|
|
}
|
|
|
|
if $target_can_dprintf {
|
|
gdb_run_cmd
|
|
|
|
gdb_test "" "Breakpoint"
|
|
|
|
# Even if the the target reports that it does support target side
|
|
# commands, we can only tell that it supports them in combination
|
|
# with a particular breakpoint type (Z0, Z1, etc.) when we try to
|
|
# insert the breakpoint. When "set breakpoint always-inserted is
|
|
# off", that'll be on next continue.
|
|
set msg "1st dprintf, agent"
|
|
gdb_test_multiple "continue" $msg {
|
|
-re "Warning:.*Target doesn't support breakpoints that have target side commands.*\r\n$gdb_prompt $" {
|
|
set target_can_dprintf 0
|
|
unsupported "$msg"
|
|
}
|
|
-re "Breakpoint \[0-9\]+, foo .*$gdb_prompt $" {
|
|
pass "$msg"
|
|
}
|
|
}
|
|
|
|
if $target_can_dprintf {
|
|
gdb_test "continue" "Breakpoint \[0-9\]+, foo .*" "2nd dprintf, agent"
|
|
|
|
gdb_test_sequence "info breakpoints" "dprintf info 2" {
|
|
"\[\r\n\]Num Type Disp Enb Address +What"
|
|
"\[\r\n\]2 breakpoint"
|
|
"\[\r\n\]\tbreakpoint already hit 2 times"
|
|
"\[\r\n\]3 dprintf"
|
|
"\[\r\n\]\tbreakpoint already hit 2 times"
|
|
"\[\r\n\] agent-printf \"At foo entry\\\\n\""
|
|
"\[\r\n\]4 dprintf"
|
|
"\[\r\n\]\tbreakpoint already hit 2 times"
|
|
"\[\r\n\] agent-printf \"arg=%d, g=%d\\\\n\", arg, g"
|
|
}
|
|
}
|
|
}
|
|
|
|
gdb_test "set dprintf-style foobar" "Undefined item: \"foobar\"." \
|
|
"Set dprintf style to an unrecognized type"
|