aboutsummaryrefslogtreecommitdiffstats
path: root/main/musl/1001-add-support-for-pthread_-get-set-attr_default_np-GNU.patch
diff options
context:
space:
mode:
Diffstat (limited to 'main/musl/1001-add-support-for-pthread_-get-set-attr_default_np-GNU.patch')
-rw-r--r--main/musl/1001-add-support-for-pthread_-get-set-attr_default_np-GNU.patch95
1 files changed, 0 insertions, 95 deletions
diff --git a/main/musl/1001-add-support-for-pthread_-get-set-attr_default_np-GNU.patch b/main/musl/1001-add-support-for-pthread_-get-set-attr_default_np-GNU.patch
deleted file mode 100644
index 93d939df76..0000000000
--- a/main/musl/1001-add-support-for-pthread_-get-set-attr_default_np-GNU.patch
+++ /dev/null
@@ -1,95 +0,0 @@
-From 8c9088d0fc253a0f53f206832714e9e5138a4438 Mon Sep 17 00:00:00 2001
-From: =?UTF-8?q?Timo=20Ter=C3=A4s?= <timo.teras@iki.fi>
-Date: Tue, 25 Oct 2016 17:00:54 +0300
-Subject: [PATCH 1001/1001] add support for pthread_{get,set}attr_default_np
- GNU extension
-
-While generally this is a bad API, it is the only existing API to
-affect c++ (std::thread) and c11 (thrd_create) thread stack size.
-This patch allows applications only to increate stack and guard
-page sizes.
----
- include/pthread.h | 2 ++
- src/thread/pthread_create.c | 7 +++++++
- src/thread/pthread_setattr_default_np.c | 31 +++++++++++++++++++++++++++++++
- 3 files changed, 40 insertions(+)
- create mode 100644 src/thread/pthread_setattr_default_np.c
-
-diff --git a/include/pthread.h b/include/pthread.h
-index 94ef919..bba9587 100644
---- a/include/pthread.h
-+++ b/include/pthread.h
-@@ -215,6 +215,8 @@ int pthread_getaffinity_np(pthread_t, size_t, struct cpu_set_t *);
- int pthread_setaffinity_np(pthread_t, size_t, const struct cpu_set_t *);
- int pthread_getattr_np(pthread_t, pthread_attr_t *);
- int pthread_setname_np(pthread_t, const char *);
-+int pthread_getattr_default_np(pthread_attr_t *);
-+int pthread_setattr_default_np(const pthread_attr_t *);
- int pthread_tryjoin_np(pthread_t, void **);
- int pthread_timedjoin_np(pthread_t, void **, const struct timespec *);
- #endif
-diff --git a/src/thread/pthread_create.c b/src/thread/pthread_create.c
-index 9f6b98e..28cf6d4 100644
---- a/src/thread/pthread_create.c
-+++ b/src/thread/pthread_create.c
-@@ -163,6 +163,8 @@ static void *dummy_tsd[1] = { 0 };
- weak_alias(dummy_tsd, __pthread_tsd_main);
-
- volatile int __block_new_threads = 0;
-+size_t __default_stacksize = 0;
-+size_t __default_guardsize = 0;
-
- static FILE *volatile dummy_file = 0;
- weak_alias(dummy_file, __stdin_used);
-@@ -204,6 +206,11 @@ int __pthread_create(pthread_t *restrict res, const pthread_attr_t *restrict att
- if (attrp && !c11) attr = *attrp;
-
- __acquire_ptc();
-+ if (!attrp || c11) {
-+ attr._a_stacksize = __default_stacksize;
-+ attr._a_guardsize = __default_guardsize;
-+ }
-+
- if (__block_new_threads) __wait(&__block_new_threads, 0, 1, 1);
-
- if (attr._a_stackaddr) {
-diff --git a/src/thread/pthread_setattr_default_np.c b/src/thread/pthread_setattr_default_np.c
-new file mode 100644
-index 0000000..21cd0f3
---- /dev/null
-+++ b/src/thread/pthread_setattr_default_np.c
-@@ -0,0 +1,31 @@
-+#include "pthread_impl.h"
-+
-+extern size_t __default_stacksize;
-+extern size_t __default_guardsize;
-+
-+int pthread_setattr_default_np(const pthread_attr_t *attrp)
-+{
-+ if (attrp->_a_stackaddr || attrp->_a_detach ||
-+ attrp->_a_sched || attrp->_a_policy || attrp->_a_prio)
-+ return EINVAL;
-+
-+ __inhibit_ptc();
-+ if (DEFAULT_STACK_SIZE+attrp->_a_stacksize >= DEFAULT_STACK_SIZE+__default_stacksize)
-+ __default_stacksize = attrp->_a_stacksize;
-+ if (DEFAULT_GUARD_SIZE+attrp->_a_guardsize >= DEFAULT_GUARD_SIZE+__default_guardsize)
-+ __default_guardsize = attrp->_a_guardsize;
-+ __release_ptc();
-+
-+ return 0;
-+}
-+
-+int pthread_getattr_default_np(pthread_attr_t *attrp)
-+{
-+ __acquire_ptc();
-+ *attrp = (pthread_attr_t) {
-+ ._a_stacksize = __default_stacksize,
-+ ._a_guardsize = __default_guardsize,
-+ };
-+ __release_ptc();
-+ return 0;
-+}
---
-2.10.1
-