diff options
author | Carlos O'Donell <carlos@redhat.com> | 2018-08-30 11:01:33 -0400 |
---|---|---|
committer | Carlos O'Donell <carlos@redhat.com> | 2018-08-30 12:33:22 -0400 |
commit | d330f31af68f96dde82840d1e9343b479a8c179e (patch) | |
tree | f6d4ae91e32004816e10c8e704a7f258240e7d4c | |
parent | 2bda273aa37e47bb5afdaf122605440391dac7c5 (diff) | |
download | glibc-d330f31af68f96dde82840d1e9343b479a8c179e.zip glibc-d330f31af68f96dde82840d1e9343b479a8c179e.tar.gz glibc-d330f31af68f96dde82840d1e9343b479a8c179e.tar.bz2 |
Fix test failure with -DNDEBUG.
The elf/tst-dlopen-aout.c test uses asserts to verify properties of the
test execution. Instead of using assert it should use xpthread_create
and xpthread_join to catch errors starting the threads and fail the
test. This shows up in Fedora 28 when building for i686-pc-linux-gnu
and using gcc 8.1.1.
Tested on i686, and fixes a check failure with -DNDEBUG.
Signed-off-by: Carlos O'Donell <carlos@redhat.com>
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | elf/tst-dlopen-aout.c | 12 |
2 files changed, 11 insertions, 6 deletions
@@ -1,3 +1,8 @@ +2018-08-30 Carlos O'Donell <carlos@redhat.com> + + * elf/tst-dlopen-aout.c: Include support/xthread.h. Use + xpthread_create and xpthread_join. + 2018-08-30 Florian Weimer <fweimer@redhat.com> * stdlib/stdlib.h (reallocarray): Make available under __USE_MISC. diff --git a/elf/tst-dlopen-aout.c b/elf/tst-dlopen-aout.c index 9038e20..b026451 100644 --- a/elf/tst-dlopen-aout.c +++ b/elf/tst-dlopen-aout.c @@ -27,6 +27,7 @@ #include <dlfcn.h> #include <stdio.h> #include <pthread.h> +#include <support/xthread.h> __thread int x; @@ -45,7 +46,6 @@ do_test (int argc, char *argv[]) { pthread_t thr; void *p; - int rc; p = dlopen (argv[0], RTLD_LAZY); if (p != NULL) @@ -53,11 +53,11 @@ do_test (int argc, char *argv[]) fprintf (stderr, "dlopen unexpectedly succeeded\n"); return 1; } - rc = pthread_create (&thr, NULL, fn, NULL); - assert (rc == 0); - - rc = pthread_join (thr, NULL); - assert (rc == 0); + /* We create threads to force TLS allocation, which triggers + the original bug i.e. running out of surplus slotinfo entries + for TLS. */ + thr = xpthread_create (NULL, fn, NULL); + xpthread_join (thr); } return 0; |