summaryrefslogtreecommitdiff
path: root/sysdeps
diff options
context:
space:
mode:
authorNeal H. Walfield <neal@gnu.org>2007-11-20 18:38:00 +0000
committerThomas Schwinge <tschwinge@gnu.org>2009-04-07 23:10:27 +0200
commit96d719679962ea3f765b3e3f23672af130de9c1d (patch)
treeaf75c45cb9241f281c87cad84993ee6eacbd2cb3 /sysdeps
parent961d71afd49f55395e6dbfe203d6b968e4105ee0 (diff)
2007-11-20 Neal H. Walfield <neal@gnu.org>
* sysdeps/l4/pt-thread-dealloc.c: New file. * Makefile.am (libpthread_a_SOURCES): Add pt-thread-dealloc.c. * sysdeps/l4/hurd/pt-sysdep.h (PTHREAD_STACK_DEFAULT): Change to 2MB. * sysdeps/l4/hurd/pt-sysdep.c (sched_yield): New function. (sigprocmask): Likewise. (init_routine): Only call __pthread_initialize once. Update comments.
Diffstat (limited to 'sysdeps')
-rw-r--r--sysdeps/l4/hurd/pt-sysdep.c28
-rw-r--r--sysdeps/l4/hurd/pt-sysdep.h4
-rw-r--r--sysdeps/l4/pt-thread-dealloc.c32
-rw-r--r--sysdeps/l4/pt-thread-start.c2
4 files changed, 52 insertions, 14 deletions
diff --git a/sysdeps/l4/hurd/pt-sysdep.c b/sysdeps/l4/hurd/pt-sysdep.c
index 265592ca..a05eb0a5 100644
--- a/sysdeps/l4/hurd/pt-sysdep.c
+++ b/sysdeps/l4/hurd/pt-sysdep.c
@@ -23,6 +23,20 @@
#include <pt-internal.h>
+int
+sched_yield (void)
+{
+ l4_yield ();
+ return 0;
+}
+
+int
+sigprocmask (int HOW, const sigset_t *restrict SET, sigset_t *restrict OLDSET)
+{
+ /* Just ignore for now. */
+ return 0;
+}
+
/* Forward. */
static void *init_routine (void);
@@ -36,23 +50,15 @@ void *(*_pthread_init_routine)(void) = &init_routine;
static void *
init_routine (void)
{
- struct __pthread *thread;
- int err;
-
/* Initialize the library. */
__pthread_initialize ();
+ struct __pthread *thread;
+ int err;
+
/* Create the pthread structure for the main thread (i.e. us). */
err = __pthread_create_internal (&thread, 0, 0, 0);
assert_perror (err);
- __pthread_initialize ();
-
- /* Decrease the number of threads, to take into account that the
- signal thread (which will be created by the startup code when we
- return from here) shouldn't be seen as a user thread. */
-#warning Need to implement the signal thread.
- // __pthread_total--;
-
return (void *) thread->mcontext.sp;
}
diff --git a/sysdeps/l4/hurd/pt-sysdep.h b/sysdeps/l4/hurd/pt-sysdep.h
index 0b5abb74..ca2c9015 100644
--- a/sysdeps/l4/hurd/pt-sysdep.h
+++ b/sysdeps/l4/hurd/pt-sysdep.h
@@ -25,8 +25,8 @@
/* XXX */
#define _POSIX_THREAD_THREADS_MAX 64
-/* The default stack size. */
-#define PTHREAD_STACK_DEFAULT 4096
+/* The default stack size: 2MB. */
+#define PTHREAD_STACK_DEFAULT (2 * 1024 * 1024)
#define PTHREAD_SYSDEP_MEMBERS \
l4_thread_id_t threadid; \
diff --git a/sysdeps/l4/pt-thread-dealloc.c b/sysdeps/l4/pt-thread-dealloc.c
new file mode 100644
index 00000000..c09e4860
--- /dev/null
+++ b/sysdeps/l4/pt-thread-dealloc.c
@@ -0,0 +1,32 @@
+/* Deallocate the kernel thread resources. L4 version.
+ Copyright (C) 2005 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Library General Public License as
+ published by the Free Software Foundation; either version 2 of the
+ License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Library General Public License for more details.
+
+ You should have received a copy of the GNU Library General Public
+ License along with the GNU C Library; see the file COPYING.LIB. If not,
+ write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ Boston, MA 02111-1307, USA. */
+
+#include <assert.h>
+#include <errno.h>
+#include <l4.h>
+
+#include <pt-internal.h>
+
+/* Deallocate any kernel resources associated with THREAD except don't
+ halt the thread itself. On return, the thread will be marked as
+ dead and __pthread_halt will be called. */
+void
+__pthread_thread_dealloc (struct __pthread *thread)
+{
+}
diff --git a/sysdeps/l4/pt-thread-start.c b/sysdeps/l4/pt-thread-start.c
index 538d0444..144c58bb 100644
--- a/sysdeps/l4/pt-thread-start.c
+++ b/sysdeps/l4/pt-thread-start.c
@@ -27,8 +27,8 @@
int
__pthread_thread_start (struct __pthread *thread)
{
- /* The main thread is already running of course. */
if (__pthread_num_threads == 1)
+ /* The main thread is already running of course. */
{
assert (__pthread_total == 1);
assert (l4_is_thread_equal (l4_myself (), thread->threadid));