diff options
author | Yao Qi <yao@codesourcery.com> | 2012-09-18 11:33:43 +0000 |
---|---|---|
committer | Yao Qi <yao@codesourcery.com> | 2012-09-18 11:33:43 +0000 |
commit | 201b4506b3d34c274cdc5ec5ffb8f6e43fc982a9 (patch) | |
tree | 3315adad7b15dc81c715d0e28da3778dbde9e49c /gdb/testsuite | |
parent | fbdc86d9c9e5fe451861a34381bf5483aec43bf1 (diff) | |
download | gdb-201b4506b3d34c274cdc5ec5ffb8f6e43fc982a9.zip gdb-201b4506b3d34c274cdc5ec5ffb8f6e43fc982a9.tar.gz gdb-201b4506b3d34c274cdc5ec5ffb8f6e43fc982a9.tar.bz2 |
gdb/doc:
* observer.texi (GDB Observers): New observer 'traceframe_changed'.
* gdb.texinfo (GDB/MI Async Records): Mention new MI notification
'=traceframe-changed'.
gdb:
* tracepoint.c (tfind_1): Call observer_notify_traceframe_changed
if traceframe changed.
* mi/mi-cmds.c (mi_cmd mi_cmds): Adjust for command
"trace-find".
* mi/mi-interp.c: Declare 'mi_traceframe_changed'.
(mi_interpreter_init): Hook mi_traceframe_changed to observer
'traceframe_changed'.
(mi_traceframe_changed): New.
* mi/mi-main.h (struct mi_suppress_notification) <traceframe>:
New field.
* NEWS: Mention the new MI notification.
gdb/testsuite:
* gdb.trace/mi-traceframe-changed.exp: New.
Diffstat (limited to 'gdb/testsuite')
-rw-r--r-- | gdb/testsuite/ChangeLog | 4 | ||||
-rw-r--r-- | gdb/testsuite/gdb.trace/mi-traceframe-changed.exp | 136 |
2 files changed, 140 insertions, 0 deletions
diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index b458aba..cba29fb 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2012-09-18 Yao Qi <yao@codesourcery.com> + + * gdb.trace/mi-traceframe-changed.exp: New. + 2012-09-17 Yao Qi <yao@codesourcery.com> * gdb.base/list.exp (set_listsize): Don't set arg to "unlimited" diff --git a/gdb/testsuite/gdb.trace/mi-traceframe-changed.exp b/gdb/testsuite/gdb.trace/mi-traceframe-changed.exp new file mode 100644 index 0000000..b587d10 --- /dev/null +++ b/gdb/testsuite/gdb.trace/mi-traceframe-changed.exp @@ -0,0 +1,136 @@ +# Copyright 2012 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/>. + +load_lib trace-support.exp +load_lib mi-support.exp +set MIFLAGS "-i=mi" + +standard_testfile tfile.c +set executable $testfile + +if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" \ + executable {debug nowarnings}] != "" } { + untested ${testfile}.exp + return -1 +} + +# Make sure we are starting fresh. +remote_file host delete basic.tf +remote_file target delete basic.tf + +remote_exec target "$binfile" +# Copy tracefile from target to host. +remote_download host [remote_upload target basic.tf] basic.tf + +proc test_tfind_tfile { } { with_test_prefix "tfile" { + global binfile + global decimal + + if [mi_gdb_start] { + return + } + mi_gdb_load ${binfile} + + mi_gdb_test "-target-select tfile basic.tf" \ + ".*=breakpoint-created,bkpt=\{number=\"${decimal}\",type=\"tracepoint\",disp=\"keep\",enabled=\"y\",.*,func=\"write_basic_trace_file\".*\\^connected" \ + "select trace file" + + mi_gdb_test "tfind 0" \ + ".*=traceframe-changed,num=\"0\",tracepoint=\"${decimal}\".*\\^done" \ + "tfind 0" + + # No MI notification is sent because traceframe is not changed. + mi_gdb_test "tfind 0" \ + "\\&\"tfind 0\\\\n\"\r\n\~\"Found.*\\^done" \ + "tfind 0 again" + + mi_gdb_test "tfind end" \ + ".*=traceframe-changed,end.*\\^done" \ + "tfind end" + + # No MI notification is send because request is from MI command. + mi_gdb_test "-trace-find frame-number 0" \ + "-trace-find frame-number 0\r\n\\^done,found=\"1\",tracepoint=\"${decimal}\",traceframe=\"0\",frame=\{.*" \ + "-trace-find frame-number 0" + + mi_gdb_exit +}} + +test_tfind_tfile + +# Change to a different test case in order to run it on target, and get +# several traceframes. +standard_testfile status-stop.c +set testfile ${testfile}-1 +set binfile ${objdir}/${subdir}/${testfile} +set executable $testfile + +if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" \ + executable {debug nowarnings}] != "" } { + untested ${testfile}.exp + return -1 +} + +# Test target supports tracepoints or not. + +clean_restart $executable + +if ![runto_main] { + fail "Can't run to main to check for trace support" + return -1 +} + +if ![gdb_target_supports_trace] { + unsupported "Current target does not support trace" + return -1; +} + +gdb_exit + +proc test_tfind_remote { } { with_test_prefix "remote" { + global decimal + + if [mi_gdb_start] { + return + } + mi_run_to_main + + mi_gdb_test "-break-insert end" "\\^done.*" "break end" + mi_gdb_test "-break-insert -a func2" "\\^done.*" "break func2" + mi_gdb_test "-trace-start" "\\^done.*" "trace start" + + mi_execute_to "exec-continue" "breakpoint-hit" end "" ".*" ".*" \ + { "" "disp=\"keep\"" } \ + "continue to end" + mi_gdb_test "-trace-stop" "\\^done.*" "trace stop" + + mi_gdb_test "tfind 0" \ + ".*=traceframe-changed,num=\"0\",tracepoint=\"${decimal}\".*\\^done" \ + "tfind 0" + + mi_gdb_test "tfind" \ + ".*=traceframe-changed,num=\"1\",tracepoint=\"${decimal}\".*\\^done" \ + "tfind" + + mi_gdb_test "tfind end" \ + ".*=traceframe-changed,end.*\\^done" \ + "tfind end" + + mi_gdb_exit +}} + +test_tfind_remote + +return 0 |