summaryrefslogtreecommitdiff
path: root/accel-pppd/triton
diff options
context:
space:
mode:
authorKozlov Dmitry <dima@server>2011-05-30 09:58:14 +0400
committerKozlov Dmitry <dima@server>2011-05-30 09:58:14 +0400
commit01afc34e830f2adf94c191a3c4f2761888dae53b (patch)
treee5a9685aa74daed6346ee2a65931d06262d88666 /accel-pppd/triton
parenta06c41c335789d7c3154422d3f60481e26feb1b0 (diff)
downloadaccel-ppp-xebd-01afc34e830f2adf94c191a3c4f2761888dae53b.tar.gz
accel-ppp-xebd-01afc34e830f2adf94c191a3c4f2761888dae53b.zip
set PTHREAD_STACK_MIN stack size for threads
Diffstat (limited to 'accel-pppd/triton')
-rw-r--r--accel-pppd/triton/triton.c7
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;
}