summaryrefslogtreecommitdiffstats
path: root/devel/glib20/files/extra-patch-gthread_gthread-posix.c
blob: bde2862f605e33529654efe72e76148478a8e687 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
--- gthread/gthread-posix.c.orig    Thu Jun  9 11:25:01 2005
+++ gthread/gthread-posix.c Fri Jun 10 20:23:17 2005
@@ -115,7 +115,11 @@ static gint priority_normal_value;
 # define PRIORITY_NORMAL_VALUE    priority_normal_value
 #endif /* POSIX_MIN_PRIORITY && POSIX_MAX_PRIORITY */
 
+#define G_THREAD_STACK_SIZE32  (1*1024*1024)
+#define G_THREAD_STACK_SIZE64  (2*1024*1024)
+
 static gulong g_thread_min_stack_size = 0;
+static gulong g_thread_default_stack_size = 0;
 
 #define G_MUTEX_SIZE (sizeof (pthread_mutex_t))
 
@@ -309,8 +313,16 @@ g_thread_create_posix_impl (GThreadFunc 
       stack_size = MAX (g_thread_min_stack_size, stack_size);
       /* No error check here, because some systems can't do it and
        * we simply don't want threads to fail because of that. */
-      pthread_attr_setstacksize (&attr, stack_size);
     }
+  else
+    {
+      if (sizeof(void *) == 8)
+        g_thread_default_stack_size = G_THREAD_STACK_SIZE64;
+      else
+        g_thread_default_stack_size = G_THREAD_STACK_SIZE32;
+      stack_size = MAX (g_thread_min_stack_size, g_thread_default_stack_size);
+    }
+  pthread_attr_setstacksize (&attr, stack_size);
 #endif /* HAVE_PTHREAD_ATTR_SETSTACKSIZE */
 
 #ifdef PTHREAD_SCOPE_SYSTEM