summaryrefslogtreecommitdiff
path: root/src/thread/pthread_create.c
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2013-09-16 10:56:01 -0400
committerRich Felker <dalias@aerifal.cx>2013-09-16 10:56:01 -0400
commit271c21194467838d6ca63d83faeebc966e204c03 (patch)
treed39e5cff3eba29c406a4175c9fb3a49c26063e41 /src/thread/pthread_create.c
parentf68a3468d48f85ccf12a03e0b610f6cffbda58fa (diff)
downloadmusl-271c21194467838d6ca63d83faeebc966e204c03.tar.gz
musl-271c21194467838d6ca63d83faeebc966e204c03.tar.bz2
musl-271c21194467838d6ca63d83faeebc966e204c03.tar.xz
musl-271c21194467838d6ca63d83faeebc966e204c03.zip
omit CLONE_PARENT flag to clone in pthread_create
CLONE_PARENT is not necessary (CLONE_THREAD provides all the useful parts of it) and Linux treats CLONE_PARENT as an error in certain situations, without noticing that it would be a no-op due to CLONE_THREAD. this error case prevents, for example, use of a multi-threaded init process and certain usages with containers.
Diffstat (limited to 'src/thread/pthread_create.c')
-rw-r--r--src/thread/pthread_create.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/thread/pthread_create.c b/src/thread/pthread_create.c
index fc666fc5..ee6c31c4 100644
--- a/src/thread/pthread_create.c
+++ b/src/thread/pthread_create.c
@@ -130,7 +130,7 @@ int pthread_create(pthread_t *restrict res, const pthread_attr_t *restrict attrp
struct pthread *self = pthread_self(), *new;
unsigned char *map = 0, *stack = 0, *tsd = 0, *stack_limit;
unsigned flags = CLONE_VM | CLONE_FS | CLONE_FILES | CLONE_SIGHAND
- | CLONE_PARENT | CLONE_THREAD | CLONE_SYSVSEM | CLONE_SETTLS
+ | CLONE_THREAD | CLONE_SYSVSEM | CLONE_SETTLS
| CLONE_PARENT_SETTID | CLONE_CHILD_CLEARTID | CLONE_DETACHED;
int do_sched = 0;
pthread_attr_t attr = {0};