diff options
author | Kozlov Dmitry <dima@server> | 2011-05-30 09:58:14 +0400 |
---|---|---|
committer | Kozlov Dmitry <dima@server> | 2011-05-30 09:58:14 +0400 |
commit | 01afc34e830f2adf94c191a3c4f2761888dae53b (patch) | |
tree | e5a9685aa74daed6346ee2a65931d06262d88666 /accel-pppd | |
parent | a06c41c335789d7c3154422d3f60481e26feb1b0 (diff) | |
download | accel-ppp-xebd-01afc34e830f2adf94c191a3c4f2761888dae53b.tar.gz accel-ppp-xebd-01afc34e830f2adf94c191a3c4f2761888dae53b.zip |
set PTHREAD_STACK_MIN stack size for threads
Diffstat (limited to 'accel-pppd')
-rw-r--r-- | accel-pppd/triton/triton.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/accel-pppd/triton/triton.c b/accel-pppd/triton/triton.c index d2ed595..df3d5c1 100644 --- a/accel-pppd/triton/triton.c +++ b/accel-pppd/triton/triton.c @@ -4,6 +4,7 @@ #include <stdio.h> #include <string.h> #include <unistd.h> +#include <limits.h> #include <sys/resource.h> #include "triton_p.h" @@ -231,17 +232,21 @@ static void ctx_thread(struct _triton_context_t *ctx) struct _triton_thread_t *create_thread() { + pthread_attr_t attr; struct _triton_thread_t *thread = _malloc(sizeof(*thread)); if (!thread) { triton_log_error("out of memory"); return NULL; } + pthread_attr_init(&attr); + pthread_attr_setstacksize(&attr, PTHREAD_STACK_MIN); + memset(thread, 0, sizeof(*thread)); pthread_mutex_init(&thread->sleep_lock, NULL); pthread_cond_init(&thread->sleep_cond, NULL); pthread_mutex_lock(&thread->sleep_lock); - if (pthread_create(&thread->thread, NULL, (void*(*)(void*))triton_thread, thread)) { + if (pthread_create(&thread->thread, &attr, (void*(*)(void*))triton_thread, thread)) { triton_log_error("pthread_create: %s", strerror(errno)); return NULL; } |