svn commit: r219254 - in stable/8/sys: kern sys
John Baldwin
jhb at FreeBSD.org
Thu Mar 3 22:08:51 UTC 2011
Author: jhb
Date: Thu Mar 3 22:08:51 2011
New Revision: 219254
URL: http://svn.freebsd.org/changeset/base/219254
Log:
MFC 218969:
Expose the umtx_key structure and API to the rest of the kernel.
Modified:
stable/8/sys/kern/kern_umtx.c
stable/8/sys/sys/umtx.h
Directory Properties:
stable/8/sys/ (props changed)
stable/8/sys/amd64/include/xen/ (props changed)
stable/8/sys/cddl/contrib/opensolaris/ (props changed)
stable/8/sys/contrib/dev/acpica/ (props changed)
stable/8/sys/contrib/pf/ (props changed)
Modified: stable/8/sys/kern/kern_umtx.c
==============================================================================
--- stable/8/sys/kern/kern_umtx.c Thu Mar 3 21:56:08 2011 (r219253)
+++ stable/8/sys/kern/kern_umtx.c Thu Mar 3 22:08:51 2011 (r219254)
@@ -58,38 +58,9 @@ __FBSDID("$FreeBSD$");
#include <compat/freebsd32/freebsd32_proto.h>
#endif
-#define TYPE_SIMPLE_WAIT 0
-#define TYPE_CV 1
-#define TYPE_SIMPLE_LOCK 2
-#define TYPE_NORMAL_UMUTEX 3
-#define TYPE_PI_UMUTEX 4
-#define TYPE_PP_UMUTEX 5
-#define TYPE_RWLOCK 6
-
#define _UMUTEX_TRY 1
#define _UMUTEX_WAIT 2
-/* Key to represent a unique userland synchronous object */
-struct umtx_key {
- int hash;
- int type;
- int shared;
- union {
- struct {
- vm_object_t object;
- uintptr_t offset;
- } shared;
- struct {
- struct vmspace *vs;
- uintptr_t addr;
- } private;
- struct {
- void *a;
- uintptr_t b;
- } both;
- } info;
-};
-
/* Priority inheritance mutex info. */
struct umtx_pi {
/* Owner thread */
@@ -185,10 +156,6 @@ struct umtxq_chain {
#define UMTX_CHAINS 128
#define UMTX_SHIFTS (__WORD_BIT - 7)
-#define THREAD_SHARE 0
-#define PROCESS_SHARE 1
-#define AUTO_SHARE 2
-
#define GET_SHARE(flags) \
(((flags) & USYNC_PROCESS_SHARED) == 0 ? THREAD_SHARE : PROCESS_SHARE)
@@ -214,10 +181,6 @@ static void umtxq_insert_queue(struct um
static void umtxq_remove_queue(struct umtx_q *uq, int q);
static int umtxq_sleep(struct umtx_q *uq, const char *wmesg, int timo);
static int umtxq_count(struct umtx_key *key);
-static int umtx_key_match(const struct umtx_key *k1, const struct umtx_key *k2);
-static int umtx_key_get(void *addr, int type, int share,
- struct umtx_key *key);
-static void umtx_key_release(struct umtx_key *key);
static struct umtx_pi *umtx_pi_alloc(int);
static void umtx_pi_free(struct umtx_pi *pi);
static void umtx_pi_adjust_locked(struct thread *td, u_char oldpri);
@@ -280,14 +243,6 @@ umtxq_hash(struct umtx_key *key)
key->hash = ((n * GOLDEN_RATIO_PRIME) >> UMTX_SHIFTS) % UMTX_CHAINS;
}
-static inline int
-umtx_key_match(const struct umtx_key *k1, const struct umtx_key *k2)
-{
- return (k1->type == k2->type &&
- k1->info.both.a == k2->info.both.a &&
- k1->info.both.b == k2->info.both.b);
-}
-
static inline struct umtxq_chain *
umtxq_getchain(struct umtx_key *key)
{
@@ -500,7 +455,7 @@ umtxq_sleep(struct umtx_q *uq, const cha
/*
* Convert userspace address into unique logical address.
*/
-static int
+int
umtx_key_get(void *addr, int type, int share, struct umtx_key *key)
{
struct thread *td = curthread;
@@ -546,7 +501,7 @@ umtx_key_get(void *addr, int type, int s
/*
* Release key.
*/
-static inline void
+void
umtx_key_release(struct umtx_key *key)
{
if (key->shared)
Modified: stable/8/sys/sys/umtx.h
==============================================================================
--- stable/8/sys/sys/umtx.h Thu Mar 3 21:56:08 2011 (r219253)
+++ stable/8/sys/sys/umtx.h Thu Mar 3 22:08:51 2011 (r219254)
@@ -190,8 +190,58 @@ umtx_wake(u_long *p, int nr_wakeup)
#else
+/*
+ * The umtx_key structure is used by both the Linux futex code and the
+ * umtx implementation to map userland addresses to unique keys.
+ */
+
+enum {
+ TYPE_SIMPLE_WAIT,
+ TYPE_CV,
+ TYPE_SIMPLE_LOCK,
+ TYPE_NORMAL_UMUTEX,
+ TYPE_PI_UMUTEX,
+ TYPE_PP_UMUTEX,
+ TYPE_RWLOCK,
+};
+
+/* Key to represent a unique userland synchronous object */
+struct umtx_key {
+ int hash;
+ int type;
+ int shared;
+ union {
+ struct {
+ struct vm_object *object;
+ uintptr_t offset;
+ } shared;
+ struct {
+ struct vmspace *vs;
+ uintptr_t addr;
+ } private;
+ struct {
+ void *a;
+ uintptr_t b;
+ } both;
+ } info;
+};
+
+#define THREAD_SHARE 0
+#define PROCESS_SHARE 1
+#define AUTO_SHARE 2
+
struct thread;
+static inline int
+umtx_key_match(const struct umtx_key *k1, const struct umtx_key *k2)
+{
+ return (k1->type == k2->type &&
+ k1->info.both.a == k2->info.both.a &&
+ k1->info.both.b == k2->info.both.b);
+}
+
+int umtx_key_get(void *, int, int, struct umtx_key *);
+void umtx_key_release(struct umtx_key *);
struct umtx_q *umtxq_alloc(void);
void umtxq_free(struct umtx_q *);
int kern_umtx_wake(struct thread *, void *, int, int);
More information about the svn-src-stable-8
mailing list