aboutsummaryrefslogtreecommitdiff
path: root/gdb/testsuite/gdb.threads/thread-specific.exp
diff options
context:
space:
mode:
authorPedro Alves <palves@redhat.com>2016-01-13 10:56:10 +0000
committerPedro Alves <palves@redhat.com>2016-01-13 11:03:19 +0000
commit663f6d42f47265d2deaa86c8a976e658fb13f820 (patch)
treebd245ce035bd243e40c05056a39ee0d28e8bc3c5 /gdb/testsuite/gdb.threads/thread-specific.exp
parentc84f6bbfe50ff13928360d3cc349d7c553867ce6 (diff)
downloadgdb-663f6d42f47265d2deaa86c8a976e658fb13f820.zip
gdb-663f6d42f47265d2deaa86c8a976e658fb13f820.tar.gz
gdb-663f6d42f47265d2deaa86c8a976e658fb13f820.tar.bz2
Add $_gthread convenience variable
This commit adds a new $_gthread convenience variable, that is like $_thread, but holds the current thread's global thread id. gdb/ChangeLog: 2016-01-13 Pedro Alves <palves@redhat.com> * NEWS: Mention $_gthread. * gdbthread.h (struct thread_info) <global_num>: Mention $_gthread. * thread.c (thread_num_make_value_helper): New function. (thread_id_make_value): Delete. (thread_id_per_inf_num_make_value, global_thread_id_make_value): New. (thread_funcs): Adjust. (gthread_funcs): New. (_initialize_thread): Register $_gthread variable. gdb/testsuite/ChangeLog: 2016-01-13 Pedro Alves <palves@redhat.com> * gdb.base/default.exp: Expect $_gthread as well. * gdb.multi/tids.exp: Test $_gthread. * gdb.threads/thread-specific.exp: Test $_gthread. gdb/doc/ChangeLog: 2016-01-13 Pedro Alves <palves@redhat.com> * gdb.texinfo (Threads): Document the $_gthread convenience variable. (Convenience Vars): Likewise.
Diffstat (limited to 'gdb/testsuite/gdb.threads/thread-specific.exp')
-rw-r--r--gdb/testsuite/gdb.threads/thread-specific.exp5
1 files changed, 5 insertions, 0 deletions
diff --git a/gdb/testsuite/gdb.threads/thread-specific.exp b/gdb/testsuite/gdb.threads/thread-specific.exp
index 2b75b60..8f61f88 100644
--- a/gdb/testsuite/gdb.threads/thread-specific.exp
+++ b/gdb/testsuite/gdb.threads/thread-specific.exp
@@ -66,7 +66,10 @@ clean_restart ${binfile}
gdb_test_no_output "set print sevenbit-strings"
gdb_test_no_output "set width 0"
+# As this test only runs a single inferior, $_thread and $_gthread
+# should match throughout.
gdb_test {print $_thread} ".* = 0" "thread var when not running"
+gdb_test {print $_gthread} ".* = 0" "gthread var when not running"
runto_main
@@ -82,6 +85,7 @@ if {[llength $threads] == 0} {
}
gdb_test {print $_thread} ".* = [lindex $threads 0]" "thread var in main"
+gdb_test {print $_gthread} ".* = [lindex $threads 0]" "gthread var in main"
gdb_test_multiple "break $line thread [lindex $threads 0]" \
"breakpoint $line main thread" {
@@ -120,6 +124,7 @@ if { $this_breakpoint != -1 } {
if { $this_thread != -1 } {
gdb_test {print $_thread} ".* = $this_thread" "thread var at break"
+ gdb_test {print $_gthread} ".* = $this_thread" "gthread var at break"
} else {
untested "thread var at break"
}