testsuite: Fix race condition in check-libthread-db
authorAlan Hayward <alan.hayward@arm.com>
Wed, 26 Sep 2018 13:06:54 +0000 (14:06 +0100)
committerAlan Hayward <alan.hayward@arm.com>
Thu, 27 Sep 2018 09:48:20 +0000 (10:48 +0100)
It is possible for the created thread to reach the breakpoint before
the main thread has set errno to 23.

Prevent this using a pthread barrier.

* gdb.threads/check-libthread-db.c (thread_routine): Use a
pthread barrier.
(main): Likewise.

gdb/testsuite/ChangeLog
gdb/testsuite/gdb.threads/check-libthread-db.c

index 2b4b0973ef22edeb4478d3023093a6c9b6ff0e08..2072705fd5360f2bc08425dbe14f3724810b73a7 100644 (file)
@@ -1,3 +1,9 @@
+2018-09-27  Alan Hayward  <alan.hayward@arm.com>
+
+       * gdb.threads/check-libthread-db.c (thread_routine): Use a
+       pthread barrier.
+       (main): Likewise.
+
 2018-09-26  Andrew Burgess  <andrew.burgess@embecosm.com>
 
        * gdb.base/large-frame-1.c: New file.
index 85a97a93af98df1953c55f163707612bdfc00487..2d9aec4bb445309ad72d2d89d176771f96c5c90d 100644 (file)
 #include <pthread.h>
 #include <errno.h>
 
+/* This barrier ensures we only reach the initial breakpoint after both threads
+   have set errno.  */
+pthread_barrier_t start_threads_barrier;
+
 static void
 break_here (void)
 {
@@ -32,6 +36,7 @@ static void *
 thread_routine (void *arg)
 {
   errno = 42;
+  pthread_barrier_wait (&start_threads_barrier);
 
   break_here ();
 
@@ -47,6 +52,8 @@ main (int argc, char *argv)
   pthread_t the_thread;
   int err;
 
+  pthread_barrier_init (&start_threads_barrier, NULL, 2);
+
   err = pthread_create (&the_thread, NULL, thread_routine, NULL);
   if (err != 0)
     {
@@ -55,6 +62,7 @@ main (int argc, char *argv)
     }
 
   errno = 23;
+  pthread_barrier_wait (&start_threads_barrier);
 
   err = pthread_join (the_thread, NULL);
   if (err != 0)