summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/libpthread/uthread/pthread_private.h4
-rw-r--r--lib/libpthread/uthread/uthread_cancel.c8
-rw-r--r--lib/libpthread/uthread/uthread_cond.c6
-rw-r--r--lib/libpthread/uthread/uthread_mutex.c4
-rw-r--r--lib/libpthread/uthread/uthread_suspend_np.c8
5 files changed, 13 insertions, 17 deletions
diff --git a/lib/libpthread/uthread/pthread_private.h b/lib/libpthread/uthread/pthread_private.h
index 15dedb454ca..21e2431b330 100644
--- a/lib/libpthread/uthread/pthread_private.h
+++ b/lib/libpthread/uthread/pthread_private.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: pthread_private.h,v 1.62 2007/04/27 18:04:08 kurt Exp $ */
+/* $OpenBSD: pthread_private.h,v 1.63 2007/04/27 19:40:08 kurt Exp $ */
/*
* Copyright (c) 1995-1998 John Birrell <jb@cimlogic.com.au>.
* All rights reserved.
@@ -581,7 +581,7 @@ struct stack {
* Define a continuation routine that can be used to perform a
* transfer of control:
*/
-typedef void (*thread_continuation_t) (void *);
+typedef void (*thread_continuation_t) (struct pthread *);
typedef V_TAILQ_ENTRY(pthread) pthread_entry_t;
diff --git a/lib/libpthread/uthread/uthread_cancel.c b/lib/libpthread/uthread/uthread_cancel.c
index c5eb358aff9..560e034527b 100644
--- a/lib/libpthread/uthread/uthread_cancel.c
+++ b/lib/libpthread/uthread/uthread_cancel.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uthread_cancel.c,v 1.14 2005/12/21 01:40:23 millert Exp $ */
+/* $OpenBSD: uthread_cancel.c,v 1.15 2007/04/27 19:40:08 kurt Exp $ */
/*
* David Leonard <d@openbsd.org>, 1999. Public domain.
*/
@@ -6,7 +6,7 @@
#include <pthread.h>
#include "pthread_private.h"
-static void finish_cancellation(void *arg);
+static void finish_cancellation(struct pthread *arg);
int
pthread_cancel(pthread_t pthread)
@@ -228,10 +228,8 @@ _thread_leave_cancellation_point(void)
}
static void
-finish_cancellation(void *arg)
+finish_cancellation(struct pthread *curthread)
{
- struct pthread *curthread = _get_curthread();
-
curthread->continuation = NULL;
curthread->interrupted = 0;
diff --git a/lib/libpthread/uthread/uthread_cond.c b/lib/libpthread/uthread/uthread_cond.c
index a8cc4923c36..8e21247d5fc 100644
--- a/lib/libpthread/uthread/uthread_cond.c
+++ b/lib/libpthread/uthread/uthread_cond.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uthread_cond.c,v 1.14 2003/12/23 19:31:05 brad Exp $ */
+/* $OpenBSD: uthread_cond.c,v 1.15 2007/04/27 19:40:08 kurt Exp $ */
/*
* Copyright (c) 1995 John Birrell <jb@cimlogic.com.au>.
* All rights reserved.
@@ -314,7 +314,7 @@ pthread_cond_wait(pthread_cond_t * cond, pthread_mutex_t * mutex)
}
if ((interrupted != 0) && (curthread->continuation != NULL))
- curthread->continuation((void *) curthread);
+ curthread->continuation(curthread);
} while ((done == 0) && (rval == 0));
/* No longer in a cancellation point: */
@@ -494,7 +494,7 @@ pthread_cond_timedwait(pthread_cond_t * cond, pthread_mutex_t * mutex,
}
if ((interrupted != 0) && (curthread->continuation != NULL))
- curthread->continuation((void *) curthread);
+ curthread->continuation(curthread);
} while ((done == 0) && (rval == 0));
/* No longer in a cancellation point: */
diff --git a/lib/libpthread/uthread/uthread_mutex.c b/lib/libpthread/uthread/uthread_mutex.c
index 748c6ffd2eb..362ba9cc13d 100644
--- a/lib/libpthread/uthread/uthread_mutex.c
+++ b/lib/libpthread/uthread/uthread_mutex.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uthread_mutex.c,v 1.18 2005/10/31 20:48:31 brad Exp $ */
+/* $OpenBSD: uthread_mutex.c,v 1.19 2007/04/27 19:40:08 kurt Exp $ */
/*
* Copyright (c) 1995 John Birrell <jb@cimlogic.com.au>.
* All rights reserved.
@@ -648,7 +648,7 @@ mutex_lock_common(pthread_mutex_t * mutex)
if (curthread->interrupted != 0 &&
curthread->continuation != NULL)
- curthread->continuation((void *) curthread);
+ curthread->continuation(curthread);
/* Return the completion status: */
return (ret);
diff --git a/lib/libpthread/uthread/uthread_suspend_np.c b/lib/libpthread/uthread/uthread_suspend_np.c
index 2caca0030df..8f3fa261232 100644
--- a/lib/libpthread/uthread/uthread_suspend_np.c
+++ b/lib/libpthread/uthread/uthread_suspend_np.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uthread_suspend_np.c,v 1.9 2004/09/18 19:57:35 marc Exp $ */
+/* $OpenBSD: uthread_suspend_np.c,v 1.10 2007/04/27 19:40:08 kurt Exp $ */
/*
* Copyright (c) 1995-1998 John Birrell <jb@cimlogic.com.au>.
* All rights reserved.
@@ -38,7 +38,7 @@
#include "pthread_private.h"
static void suspend_common(struct pthread *thread);
-static void finish_suspension(void *arg);
+static void finish_suspension(struct pthread *);
/* Suspend a thread: */
int
@@ -195,10 +195,8 @@ suspend_common(struct pthread *thread)
}
static void
-finish_suspension(void *arg)
+finish_suspension(struct pthread *curthread)
{
- struct pthread *curthread = _get_curthread();
-
if (curthread->suspended != SUSP_NO)
_thread_kern_sched_state(PS_SUSPENDED, __FILE__, __LINE__);
}