aboutsummaryrefslogtreecommitdiff
path: root/htl
diff options
context:
space:
mode:
Diffstat (limited to 'htl')
-rw-r--r--htl/pt-create.c20
-rw-r--r--htl/pt-internal.h3
2 files changed, 22 insertions, 1 deletions
diff --git a/htl/pt-create.c b/htl/pt-create.c
index 0b3237f..090d394 100644
--- a/htl/pt-create.c
+++ b/htl/pt-create.c
@@ -59,7 +59,17 @@ entry_point (struct __pthread *self, void *(*start_routine) (void *), void *arg)
__pthread_startup ();
- __pthread_exit (start_routine (arg));
+ if (self->c11)
+ {
+ /* The function pointer of the c11 thread start is cast to an incorrect
+ type on __pthread_create call, however it is casted back to correct
+ one so the call behavior is well-defined (it is assumed that pointers
+ to void are able to represent all values of int). */
+ int (*start)(void*) = (int (*) (void*)) start_routine;
+ __pthread_exit ((void*) (uintptr_t) start (arg));
+ }
+ else
+ __pthread_exit (start_routine (arg));
}
/* Create a thread with attributes given by ATTR, executing
@@ -99,6 +109,14 @@ __pthread_create_internal (struct __pthread **thread,
if (err)
goto failed;
+ if (attr == ATTR_C11_THREAD)
+ {
+ attr = NULL;
+ pthread->c11 = true;
+ }
+ else
+ pthread->c11 = false;
+
/* Use the default attributes if ATTR is NULL. */
setup = attr ? attr : &__pthread_default_attr;
diff --git a/htl/pt-internal.h b/htl/pt-internal.h
index 274223c..9147b87 100644
--- a/htl/pt-internal.h
+++ b/htl/pt-internal.h
@@ -100,6 +100,9 @@ struct __pthread
/* Resolver state. */
struct __res_state res_state;
+ /* Indicates whether is a C11 thread created by thrd_creat. */
+ bool c11;
+
/* Thread context. */
struct pthread_mcontext mcontext;