aboutsummaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
authorTom Tromey <tromey@redhat.com>2013-08-22 13:59:55 +0000
committerTom Tromey <tromey@redhat.com>2013-08-22 13:59:55 +0000
commitf3a764545a704c61e2a4f4316a539b43aa0fa6b0 (patch)
tree271b7cf082b1049c7e8e00dbb1ca802b70f5b5b8 /gdb
parentde5f37e1db1f860e2bd07cbd45307734e75cac9b (diff)
downloadgdb-f3a764545a704c61e2a4f4316a539b43aa0fa6b0.zip
gdb-f3a764545a704c61e2a4f4316a539b43aa0fa6b0.tar.gz
gdb-f3a764545a704c61e2a4f4316a539b43aa0fa6b0.tar.bz2
convert one more caching proc
I noticed that skip_btrace_tests is a classic "caching proc" that I missed when I added gdb_caching_proc. This patch converts it. Built and regtested on x86-64 Fedora 18. * lib/gdb.exp (skip_btrace_tests): Use gdb_caching_proc and standard_temp_file.
Diffstat (limited to 'gdb')
-rw-r--r--gdb/testsuite/ChangeLog5
-rw-r--r--gdb/testsuite/lib/gdb.exp38
2 files changed, 22 insertions, 21 deletions
diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog
index fa1b321..fc21eac 100644
--- a/gdb/testsuite/ChangeLog
+++ b/gdb/testsuite/ChangeLog
@@ -1,5 +1,10 @@
2013-08-22 Tom Tromey <tromey@redhat.com>
+ * lib/gdb.exp (skip_btrace_tests): Use gdb_caching_proc and
+ standard_temp_file.
+
+2013-08-22 Tom Tromey <tromey@redhat.com>
+
* gdb.arch/amd64-byte.exp: Use standard_testfile,
clean_restart.
* gdb.arch/amd64-disp-step.exp: Use standard_testfile.
diff --git a/gdb/testsuite/lib/gdb.exp b/gdb/testsuite/lib/gdb.exp
index 52d369c..7be4f9d 100644
--- a/gdb/testsuite/lib/gdb.exp
+++ b/gdb/testsuite/lib/gdb.exp
@@ -2074,27 +2074,20 @@ gdb_caching_proc skip_vsx_tests {
# Run a test on the target to see if it supports btrace hardware. Return 0 if so,
# 1 if it does not. Based on 'check_vmx_hw_available' from the GCC testsuite.
-proc skip_btrace_tests {} {
- global skip_btrace_tests_saved
+gdb_caching_proc skip_btrace_tests {
global srcdir subdir gdb_prompt inferior_exited_re
- # Use the cached value, if it exists.
set me "skip_btrace_tests"
- if [info exists skip_btrace_tests_saved] {
- verbose "$me: returning saved $skip_btrace_tests_saved" 2
- return $skip_btrace_tests_saved
- }
-
if { ![istarget "i?86-*-*"] && ![istarget "x86_64-*-*"] } {
verbose "$me: target does not support btrace, returning 1" 2
- return [set skip_btrace_tests_saved 1]
+ return 1
}
# Set up, compile, and execute a test program.
# Include the current process ID in the file names to prevent conflicts
# with invocations for multiple testsuites.
- set src [standard_output_file btrace[pid].c]
- set exe [standard_output_file btrace[pid].x]
+ set src [standard_temp_file btrace[pid].c]
+ set exe [standard_temp_file btrace[pid].x]
set f [open $src "w"]
puts $f "int main(void) { return 0; }"
@@ -2107,38 +2100,41 @@ proc skip_btrace_tests {} {
if ![string match "" $lines] then {
verbose "$me: testfile compilation failed, returning 1" 2
file delete $src
- return [set skip_btrace_tests_saved 1]
+ return 1
}
# No error message, compilation succeeded so now run it via gdb.
- clean_restart btrace[pid].x
+ gdb_exit
+ gdb_start
+ gdb_reinitialize_dir $srcdir/$subdir
+ gdb_load $exe
if ![runto_main] {
file delete $src
- return [set skip_btrace_tests_saved 1]
+ return 1
}
file delete $src
# In case of an unexpected output, we return 2 as a fail value.
- set skip_btrace_tests_saved 2
+ set skip_btrace_tests 2
gdb_test_multiple "record btrace" "check btrace support" {
-re "You can't do that when your target is.*\r\n$gdb_prompt $" {
- set skip_btrace_tests_saved 1
+ set skip_btrace_tests 1
}
-re "Target does not support branch tracing.*\r\n$gdb_prompt $" {
- set skip_btrace_tests_saved 1
+ set skip_btrace_tests 1
}
-re "Could not enable branch tracing.*\r\n$gdb_prompt $" {
- set skip_btrace_tests_saved 1
+ set skip_btrace_tests 1
}
-re "^record btrace\r\n$gdb_prompt $" {
- set skip_btrace_tests_saved 0
+ set skip_btrace_tests 0
}
}
gdb_exit
remote_file build delete $exe
- verbose "$me: returning $skip_btrace_tests_saved" 2
- return $skip_btrace_tests_saved
+ verbose "$me: returning $skip_btrace_tests" 2
+ return $skip_btrace_tests
}
# Skip all the tests in the file if you are not on an hppa running