[PATCH] C11 threads: Fix inaccuracies in testsuite
Corinna Vinschen
vinschen@redhat.com
Sun Aug 30 11:44:36 GMT 2020
- tst-mtx-recursive.c: mtx_init fails to use mtx_plain. Per C11
specs, using mtx_recursive alone is not supported. This isn't
catched because mtx_plain is defined as 0.
- tst-thrd-sleep.c: thrd_sleep() returns 0 on success, a negative
value on failure. Testing against thrd_success is incorrect.
- tst-tss-basic.c: tss_set() is incorrectly checkd for a non-0
value. The test should test aginst C11 threads error codes.
This isn't catched because thrd_success is defined as 0.
Note that all three tests fail on FreeBSD, which defines all mutex type
values, as well as all C11 threads error codes with non-0 values.
Signed-off-by: Corinna Vinschen <vinschen@redhat.com>
---
sysdeps/pthread/tst-mtx-recursive.c | 2 +-
sysdeps/pthread/tst-thrd-sleep.c | 2 +-
sysdeps/pthread/tst-tss-basic.c | 2 +-
3 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/sysdeps/pthread/tst-mtx-recursive.c b/sysdeps/pthread/tst-mtx-recursive.c
index 6b471ac724df..aca8cee6eb99 100644
--- a/sysdeps/pthread/tst-mtx-recursive.c
+++ b/sysdeps/pthread/tst-mtx-recursive.c
@@ -27,7 +27,7 @@ do_test (void)
{
static mtx_t mutex;
- if (mtx_init (&mutex, mtx_recursive) != thrd_success)
+ if (mtx_init (&mutex, mtx_plain | mtx_recursive) != thrd_success)
FAIL_EXIT1 ("mtx_init failed");
if (mtx_lock (&mutex) != thrd_success)
diff --git a/sysdeps/pthread/tst-thrd-sleep.c b/sysdeps/pthread/tst-thrd-sleep.c
index 39d5fc707945..8cc4bb2690c4 100644
--- a/sysdeps/pthread/tst-thrd-sleep.c
+++ b/sysdeps/pthread/tst-thrd-sleep.c
@@ -27,7 +27,7 @@ static int
sleep_thrd (void *arg)
{
struct timespec const *tl = (struct timespec const *) arg;
- if (thrd_sleep (tl, NULL) != thrd_success)
+ if (thrd_sleep (tl, NULL) != 0)
FAIL_EXIT1 ("thrd_sleep failed");
thrd_exit (thrd_success);
diff --git a/sysdeps/pthread/tst-tss-basic.c b/sysdeps/pthread/tst-tss-basic.c
index 3b06abc5cfe5..5a2c1bd1ee3e 100644
--- a/sysdeps/pthread/tst-tss-basic.c
+++ b/sysdeps/pthread/tst-tss-basic.c
@@ -33,7 +33,7 @@ tss_thrd (void *arg)
if (tss_create (&key, NULL) != thrd_success)
FAIL_EXIT1 ("tss_create failed");
- if (tss_set (key, TSS_VALUE))
+ if (tss_set (key, TSS_VALUE) != thrd_success)
FAIL_EXIT1 ("tss_set failed");
void *value = tss_get (key);
--
2.26.2
More information about the Libc-alpha
mailing list