diff options
author | Pedro Alves <palves@redhat.com> | 2015-03-04 09:13:49 +0000 |
---|---|---|
committer | Pedro Alves <palves@redhat.com> | 2015-03-04 09:13:49 +0000 |
commit | 511aee7c3906063902415391f288460a2c116f26 (patch) | |
tree | 215ddcacd49360c76ac72b8ba3b9b040d15a4d5b | |
parent | e09ab7ac788fd5509adc40b86a3631a3028c1d33 (diff) | |
download | gdb-511aee7c3906063902415391f288460a2c116f26.zip gdb-511aee7c3906063902415391f288460a2c116f26.tar.gz gdb-511aee7c3906063902415391f288460a2c116f26.tar.bz2 |
gdb.threads/clone-thread_db.c: Add missing includes and fix pthread_join call
This fixes:
> gdb compile failed, /gdb/testsuite/gdb.threads/clone-thread_db.c: In function 'main':
> /gdb/testsuite/gdb.threads/clone-thread_db.c:67:3: warning: implicit declaration of function 'alarm' [-Wimplicit-function-declaration]
> alarm (300);
> ^
> /gdb/testsuite/gdb.threads/clone-thread_db.c:69:3: warning: implicit declaration of function 'pthread_create' [-Wimplicit-function-declaration]
> pthread_create (&child, NULL, thread_fn, NULL);
> ^
> /gdb/testsuite/gdb.threads/clone-thread_db.c:70:3: warning: implicit declaration of function 'pthread_join' [-Wimplicit-function-declaration]
> pthread_join (child);
> ^
And then adding the missing headers revealed the pthread_join call was
incorrect. This probably fixes the crash we see on ppc64be, e.g., at
https://sourceware.org/ml/gdb-testers/2015-q1/msg04415.html
the logs there show:
...
Program received signal SIGSEGV, Segmentation fault.
[Switching to Thread 0x3fffb7ff54a0 (LWP 9275)]
0x00003fffb7f3ce74 in .pthread_join () from /lib64/libpthread.so.0
(gdb) FAIL: gdb.threads/clone-thread_db.exp: continue to end
...
Tested on x86_64 Fedora 20.
gdb/testsuite/
2015-03-04 Pedro Alves <palves@redhat.com>
* gdb.threads/clone-thread_db.c: Include unistd.h and pthread.h.
(main): Pass missing retval argument to pthread_join call.
-rw-r--r-- | gdb/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gdb/testsuite/gdb.threads/clone-thread_db.c | 4 |
2 files changed, 8 insertions, 1 deletions
diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index 3b7bf7d..eb1b9ea 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2015-03-04 Pedro Alves <palves@redhat.com> + + * gdb.threads/clone-thread_db.c: Include unistd.h and pthread.h. + (main): Pass missing retval argument to pthread_join call. + 2015-03-02 Pedro Alves <palves@redhat.com> * gdb.threads/thread-execl.exp (do_test): Handle non-stop. diff --git a/gdb/testsuite/gdb.threads/clone-thread_db.c b/gdb/testsuite/gdb.threads/clone-thread_db.c index 4356d2f..e8dc7c3 100644 --- a/gdb/testsuite/gdb.threads/clone-thread_db.c +++ b/gdb/testsuite/gdb.threads/clone-thread_db.c @@ -24,6 +24,8 @@ #include <stdlib.h> #include <sys/types.h> #include <sys/wait.h> +#include <unistd.h> +#include <pthread.h> #define STACK_SIZE 0x1000 @@ -67,7 +69,7 @@ main (int argc, char **argv) alarm (300); pthread_create (&child, NULL, thread_fn, NULL); - pthread_join (child); + pthread_join (child, NULL); return 0; } |