PERFORCE change 110523 for review
    Alexander Leidinger 
    netchild at FreeBSD.org
       
    Sat Nov 25 10:06:55 PST 2006
    
    
  
http://perforce.freebsd.org/chv.cgi?CH=110523
Change 110523 by netchild at netchild_magellan on 2006/11/25 18:06:38
	semi-automatic style(9)
Affected files ...
.. //depot/projects/linuxolator/src/sys/compat/linux/linux_futex.c#7 edit
.. //depot/projects/linuxolator/src/sys/compat/linux/linux_futex.h#2 edit
Differences ...
==== //depot/projects/linuxolator/src/sys/compat/linux/linux_futex.c#7 (text+ko) ====
@@ -14,14 +14,14 @@
  * 3. All advertising materials mentioning features or use of this software
  *    must display the following acknowledgement:
  *	This product includes software developed by Emmanuel Dreyfus
- * 4. The name of the author may not be used to endorse or promote 
- *    products derived from this software without specific prior written 
+ * 4. The name of the author may not be used to endorse or promote
+ *    products derived from this software without specific prior written
  *    permission.
  *
- * THIS SOFTWARE IS PROVIDED BY THE THE AUTHOR AND CONTRIBUTORS ``AS IS'' 
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 
+ * THIS SOFTWARE IS PROVIDED BY THE THE AUTHOR AND CONTRIBUTORS ``AS IS''
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS 
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS
  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
@@ -34,7 +34,7 @@
 #include <sys/cdefs.h>
 __FBSDID("$FreeBSD: src/sys/compat/linux/linux_futex.c,v 1.6 2006/09/09 16:25:25 netchild Exp $");
 #if 0
- __KERNEL_RCSID(1, "$NetBSD: linux_futex.c,v 1.5 2005/11/23 16:14:57 manu Exp $");
+__KERNEL_RCSID(1, "$NetBSD: linux_futex.c,v 1.5 2005/11/23 16:14:57 manu Exp $");
 #endif
 
 #include "opt_compat.h"
@@ -67,8 +67,8 @@
 	TAILQ_ENTRY(waiting_proc) wp_list;
 };
 struct futex {
-	void *f_uaddr;
-	int f_refcount;
+	void   *f_uaddr;
+	int	f_refcount;
 	LIST_ENTRY(futex) f_list;
 	TAILQ_HEAD(lf_waiting_proc, waiting_proc) f_waiting_proc;
 };
@@ -85,7 +85,7 @@
 #define FUTEX_SYSTEM_LOCK mtx_lock(&Giant)
 #define FUTEX_SYSTEM_UNLOCK mtx_unlock(&Giant)
 
-static struct futex *futex_get(void *, int);
+static struct futex	*futex_get(void *, int);
 static void futex_put(struct futex *);
 static int futex_sleep(struct futex *, struct thread *, unsigned long);
 static int futex_wake(struct futex *, int, struct futex *);
@@ -103,7 +103,7 @@
 {
 	int val;
 	int ret;
-	struct l_timespec timeout = { 0, 0 };
+	struct l_timespec timeout = {0, 0};
 	int error = 0;
 	struct futex *f;
 	struct futex *newf;
@@ -114,56 +114,57 @@
 
 #ifdef	DEBUG
 	if (ldebug(sys_futex))
-	   	printf(ARGS(futex,"%p, %i, %i"), args->uaddr, args->op, args->val);
+		printf(ARGS(futex, "%p, %i, %i"), args->uaddr, args->op,
+		    args->val);
 #endif
 
 	switch (args->op) {
 	case LINUX_FUTEX_WAIT:
-	   	FUTEX_SYSTEM_LOCK;
+		FUTEX_SYSTEM_LOCK;
 
-		if ((error = copyin(args->uaddr, 
+		if ((error = copyin(args->uaddr,
 		    &val, sizeof(val))) != 0) {
-		   	FUTEX_SYSTEM_UNLOCK;
+			FUTEX_SYSTEM_UNLOCK;
 			return error;
 		}
 
 		if (val != args->val) {
-		   	FUTEX_SYSTEM_UNLOCK;
+			FUTEX_SYSTEM_UNLOCK;
 			return EWOULDBLOCK;
 		}
 
 		if (args->timeout != NULL) {
-			if ((error = copyin(args->timeout, 
+			if ((error = copyin(args->timeout,
 			    &timeout, sizeof(timeout))) != 0) {
-			  	FUTEX_SYSTEM_UNLOCK;
+				FUTEX_SYSTEM_UNLOCK;
 				return error;
 			}
 		}
 
 #ifdef DEBUG
 		if (ldebug(sys_futex))
-   			printf("FUTEX_WAIT %d: val = %d, uaddr = %p, "
-		    		"*uaddr = %d, timeout = %d.%09lu\n", 
-		    		td->td_proc->p_pid, args->val, 
-		    		args->uaddr, val, timeout.tv_sec,
-				(unsigned long)timeout.tv_nsec); 
+			printf("FUTEX_WAIT %d: val = %d, uaddr = %p, "
+			    "*uaddr = %d, timeout = %d.%09lu\n",
+			    td->td_proc->p_pid, args->val,
+			    args->uaddr, val, timeout.tv_sec,
+			    (unsigned long)timeout.tv_nsec);
 #endif
 		tv.tv_usec = timeout.tv_sec * 1000000 + timeout.tv_nsec / 1000;
 		timeout_hz = tvtohz(&tv);
 
 		if (timeout.tv_sec == 0 && timeout.tv_nsec == 0)
-		   	timeout_hz = 0;
-      		/*
-                 * If the user process requests a non null timeout,
-                 * make sure we do not turn it into an infinite
-                 * timeout because timeout_hz gets null.
-                 *
-                 * We use a minimal timeout of 1/hz. Maybe it would
-                 * make sense to just return ETIMEDOUT without sleeping.
-                 */
-                if (((timeout.tv_sec != 0) || (timeout.tv_nsec != 0)) &&
-                    (timeout_hz == 0))
-                        timeout_hz = 1;
+			timeout_hz = 0;
+		/*
+		 * If the user process requests a non null timeout,
+		 * make sure we do not turn it into an infinite
+		 * timeout because timeout_hz gets null.
+		 *
+		 * We use a minimal timeout of 1/hz. Maybe it would
+		 * make sense to just return ETIMEDOUT without sleeping.
+		 */
+		if (((timeout.tv_sec != 0) || (timeout.tv_nsec != 0)) &&
+		    (timeout_hz == 0))
+			timeout_hz = 1;
 
 
 		f = futex_get(args->uaddr, FUTEX_UNLOCKED);
@@ -172,8 +173,8 @@
 
 #ifdef DEBUG
 		if (ldebug(sys_futex))
-   			printf("FUTEX_WAIT %d: uaddr = %p, "
-		    		"ret = %d\n", td->td_proc->p_pid, args->uaddr, ret); 
+			printf("FUTEX_WAIT %d: uaddr = %p, "
+			    "ret = %d\n", td->td_proc->p_pid, args->uaddr, ret);
 #endif
 
 		FUTEX_SYSTEM_UNLOCK;
@@ -184,37 +185,37 @@
 		case EINTR:		/* signal */
 			return EINTR;
 			break;
-		case 0:			/* FUTEX_WAKE received */
+		case 0:		/* FUTEX_WAKE received */
 #ifdef DEBUG
 			if (ldebug(sys_futex))
 				printf("FUTEX_WAIT %d: uaddr = %p, got FUTEX_WAKE\n",
-			    		td->td_proc->p_pid, args->uaddr); 
+				    td->td_proc->p_pid, args->uaddr);
 #endif
 			return 0;
 			break;
 		default:
 #ifdef DEBUG
 			if (ldebug(sys_futex))
-   				printf("FUTEX_WAIT: unexpected ret = %d\n", ret);
+				printf("FUTEX_WAIT: unexpected ret = %d\n", ret);
 #endif
 			break;
 		}
 
 		/* NOTREACHED */
 		break;
-		
+
 	case LINUX_FUTEX_WAKE:
 		FUTEX_SYSTEM_LOCK;
 
-		/* 
-		 * XXX: Linux is able cope with different addresses 
-		 * corresponding to the same mapped memory in the sleeping 
+		/*
+		 * XXX: Linux is able cope with different addresses
+		 * corresponding to the same mapped memory in the sleeping
 		 * and the waker process.
 		 */
 #ifdef DEBUG
 		if (ldebug(sys_futex))
-   			printf("FUTEX_WAKE %d: uaddr = %p, val = %d\n", 
-		   		 td->td_proc->p_pid, args->uaddr, args->val); 
+			printf("FUTEX_WAKE %d: uaddr = %p, val = %d\n",
+			    td->td_proc->p_pid, args->uaddr, args->val);
 #endif
 		f = futex_get(args->uaddr, FUTEX_UNLOCKED);
 		td->td_retval[0] = futex_wake(f, args->val, NULL);
@@ -226,14 +227,14 @@
 	case LINUX_FUTEX_CMP_REQUEUE:
 		FUTEX_SYSTEM_LOCK;
 
-		if ((error = copyin(args->uaddr, 
+		if ((error = copyin(args->uaddr,
 		    &val, sizeof(val))) != 0) {
-		   	FUTEX_SYSTEM_UNLOCK;
+			FUTEX_SYSTEM_UNLOCK;
 			return error;
 		}
 
 		if (val != args->val3) {
-		   	FUTEX_SYSTEM_UNLOCK;
+			FUTEX_SYSTEM_UNLOCK;
 			return EAGAIN;
 		}
 
@@ -248,19 +249,19 @@
 
 	case LINUX_FUTEX_REQUEUE:
 		FUTEX_SYSTEM_LOCK;
-		
+
 		f = futex_get(args->uaddr, FUTEX_UNLOCKED);
 		newf = futex_get(args->uaddr2, FUTEX_UNLOCKED);
 		td->td_retval[0] = futex_wake(f, args->val, newf);
 		futex_put(f);
 		futex_put(newf);
-		
+
 		FUTEX_SYSTEM_UNLOCK;
 		break;
 
 	case LINUX_FUTEX_FD:
 		/* XXX: linux plans to remove this operation */
-		printf("linux_sys_futex: unimplemented op %d\n", 
+		printf("linux_sys_futex: unimplemented op %d\n",
 		    args->op);
 		break;
 
@@ -268,30 +269,32 @@
 		FUTEX_SYSTEM_LOCK;
 #ifdef DEBUG
 		if (ldebug(sys_futex))
-   		   	printf("FUTEX_WAKE_OP: %d: uaddr = %p, op = %d, val = %d, uaddr2 = %p, val3 = %d\n",
-		      		td->td_proc->p_pid, args->uaddr, args->op, args->val, args->uaddr2, args->val3);
+			printf("FUTEX_WAKE_OP: %d: uaddr = %p, op = %d, val = %d, uaddr2 = %p, val3 = %d\n",
+			    td->td_proc->p_pid, args->uaddr, args->op, args->val,
+			    args->uaddr2, args->val3);
 #endif
 		f = futex_get(args->uaddr, FUTEX_UNLOCKED);
 		f2 = futex_get(args->uaddr2, FUTEX_UNLOCKED);
 
-		/* This function returns positive number as results
-		 * and negative as errors
+		/*
+		 * This function returns positive number as results and
+		 * negative as errors
 		 */
 		op_ret = futex_atomic_op(td, args->val3, args->uaddr2);
 		if (op_ret < 0) {
 
-		   	/* XXX: we dont handle the EFAULT yet */
-		   	if (op_ret != -EFAULT) {
-			   	futex_put(f);
-			   	futex_put(f2);
+			/* XXX: we dont handle the EFAULT yet */
+			if (op_ret != -EFAULT) {
+				futex_put(f);
+				futex_put(f2);
 				FUTEX_SYSTEM_UNLOCK;
-			   	return (-op_ret);
+				return (-op_ret);
 			}
 
 			futex_put(f);
 			futex_put(f2);
 
-		   	FUTEX_SYSTEM_UNLOCK;
+			FUTEX_SYSTEM_UNLOCK;
 			return (EFAULT);
 
 		}
@@ -299,23 +302,23 @@
 		ret = futex_wake(f, args->val, NULL);
 		futex_put(f);
 		if (op_ret > 0) {
-		   	op_ret = 0;
-		   	/*
+			op_ret = 0;
+			/*
 			 * Linux uses the address of the timespec parameter
 			 * as the number of retries, so any large number will
 			 * be ok.
 			 */
-   		   	op_ret += futex_wake(f2, 0x7fffffff, NULL);
+			op_ret += futex_wake(f2, 0x7fffffff, NULL);
 			ret += op_ret;
 		}
 		futex_put(f2);
 		td->td_retval[0] = ret;
 
 		FUTEX_SYSTEM_UNLOCK;
-	   	break;
+		break;
 
 	default:
-		printf("linux_sys_futex: unknown op %d\n", 
+		printf("linux_sys_futex: unknown op %d\n",
 		    args->op);
 		break;
 	}
@@ -328,12 +331,12 @@
 	struct futex *f;
 
 	if (locked == FUTEX_UNLOCKED)
-   	   	FUTEX_LOCK;
+		FUTEX_LOCK;
 	LIST_FOREACH(f, &futex_list, f_list) {
 		if (f->f_uaddr == uaddr) {
 			f->f_refcount++;
 			if (locked == FUTEX_UNLOCKED)
-   			   	FUTEX_UNLOCK;
+				FUTEX_UNLOCK;
 			return f;
 		}
 	}
@@ -344,17 +347,17 @@
 	TAILQ_INIT(&f->f_waiting_proc);
 	LIST_INSERT_HEAD(&futex_list, f, f_list);
 	if (locked == FUTEX_UNLOCKED)
-   	   	FUTEX_UNLOCK;
+		FUTEX_UNLOCK;
 
 	return f;
 }
 
-static void 
+static void
 futex_put(f)
 	struct futex *f;
 {
-   	FUTEX_LOCK;
-   	f->f_refcount--;
+	FUTEX_LOCK;
+	f->f_refcount--;
 	if (f->f_refcount == 0) {
 		LIST_REMOVE(f, f_list);
 		free(f, M_LINUX);
@@ -364,7 +367,7 @@
 	return;
 }
 
-static int 
+static int
 futex_sleep(struct futex *f, struct thread *td, unsigned long timeout)
 {
 	struct waiting_proc *wp;
@@ -379,10 +382,10 @@
 
 #ifdef DEBUG
 	if (ldebug(sys_futex))
-   		printf("FUTEX --> %d tlseep timeout = %ld\n", td->td_proc->p_pid,
-	  	      timeout);
+		printf("FUTEX --> %d tlseep timeout = %ld\n", td->td_proc->p_pid,
+		    timeout);
 #endif
-	ret = tsleep(wp, PCATCH|PZERO, "linuxfutex", timeout);
+	ret = tsleep(wp, PCATCH | PZERO, "linuxfutex", timeout);
 
 	FUTEX_LOCK;
 	TAILQ_REMOVE(&f->f_waiting_proc, wp, wp_list);
@@ -390,7 +393,7 @@
 
 	if ((ret == 0) && (wp->wp_new_futex != NULL)) {
 		ret = futex_sleep(wp->wp_new_futex, td, timeout);
-		futex_put(wp->wp_new_futex); /* futex_get called in wakeup */
+		futex_put(wp->wp_new_futex);	/* futex_get called in wakeup */
 	}
 
 	free(wp, M_LINUX);
@@ -402,7 +405,7 @@
 futex_wake(struct futex *f, int n, struct futex *newf)
 {
 	struct waiting_proc *wp;
-	int count = 0; 
+	int count = 0;
 
 	FUTEX_LOCK;
 	TAILQ_FOREACH(wp, &f->f_waiting_proc, wp_list) {
@@ -425,62 +428,63 @@
 static int
 futex_atomic_op(struct thread *td, int encoded_op, caddr_t uaddr)
 {
-   	int op = (encoded_op >> 28) & 7;
-        int cmp = (encoded_op >> 24) & 15;
-        int oparg = (encoded_op << 8) >> 20;
-        int cmparg = (encoded_op << 20) >> 20;
-        int oldval = 0, ret;
+	int op = (encoded_op >> 28) & 7;
+	int cmp = (encoded_op >> 24) & 15;
+	int oparg = (encoded_op << 8) >> 20;
+	int cmparg = (encoded_op << 20) >> 20;
+	int oldval = 0, ret;
 
 	if (encoded_op & (FUTEX_OP_OPARG_SHIFT << 28))
-	   	oparg = 1 << oparg;
+		oparg = 1 << oparg;
 
-#ifdef DEBUG	
+#ifdef DEBUG
 	printf("futex_atomic_op: op = %d, cmp = %d, oparg = %d, cmparg = %d, uaddr = %p\n",
-	      op, cmp, oparg, cmparg, uaddr);
+	    op, cmp, oparg, cmparg, uaddr);
 #endif
 	/* XXX: linux verifies access here and returns EFAULT */
 
 	switch (op) {
-	   	case FUTEX_OP_SET:
-		   	ret = futex_xchgl(oparg, uaddr, &oldval);
+	case FUTEX_OP_SET:
+		ret = futex_xchgl(oparg, uaddr, &oldval);
+		break;
+	case FUTEX_OP_ADD:
+		ret = futex_addl(oparg, uaddr, &oldval);
+		break;
+	case FUTEX_OP_OR:
+		ret = futex_orl(oparg, uaddr, &oldval);
+		break;
+	case FUTEX_OP_ANDN:
+		ret = futex_andl(~oparg, uaddr, &oldval);
+		break;
+	case FUTEX_OP_XOR:
+		ret = futex_xorl(oparg, uaddr, &oldval);
+		break;
+	default:
+		ret = -ENOSYS;
+	}
+
+	if (!ret)
+		switch (cmp) {
+		case FUTEX_OP_CMP_EQ:
+			ret = (oldval == cmparg);
+			break;
+		case FUTEX_OP_CMP_NE:
+			ret = (oldval != cmparg);
 			break;
-		case FUTEX_OP_ADD:
-			ret = futex_addl(oparg, uaddr, &oldval);
+		case FUTEX_OP_CMP_LT:
+			ret = (oldval < cmparg);
 			break;
-		case FUTEX_OP_OR:
-			ret = futex_orl(oparg, uaddr, &oldval);
+		case FUTEX_OP_CMP_GE:
+			ret = (oldval >= cmparg);
 			break;
-		case FUTEX_OP_ANDN:
-			ret = futex_andl(~oparg, uaddr, &oldval);
+		case FUTEX_OP_CMP_LE:
+			ret = (oldval <= cmparg);
 			break;
-		case FUTEX_OP_XOR:
-			ret = futex_xorl(oparg, uaddr, &oldval);
+		case FUTEX_OP_CMP_GT:
+			ret = (oldval > cmparg);
 			break;
 		default:
 			ret = -ENOSYS;
-	}
-
-	if (!ret)
-	   	switch (cmp) {
-		      case FUTEX_OP_CMP_EQ: 
-			 	ret = (oldval == cmparg); 
-				break;
-		      case FUTEX_OP_CMP_NE: 
-				ret = (oldval != cmparg); 
-				break;
-		      case FUTEX_OP_CMP_LT: 
-				ret = (oldval < cmparg); 
-				break;
-		      case FUTEX_OP_CMP_GE: 
-				ret = (oldval >= cmparg); 
-				break;
-		      case FUTEX_OP_CMP_LE: 
-				ret = (oldval <= cmparg); 
-				break;
-		      case FUTEX_OP_CMP_GT: 
-				ret = (oldval > cmparg); 
-				break;
-		      default: ret = -ENOSYS;
 		}
 
 	return (ret);
==== //depot/projects/linuxolator/src/sys/compat/linux/linux_futex.h#2 (text+ko) ====
@@ -14,14 +14,14 @@
  * 3. All advertising materials mentioning features or use of this software
  *    must display the following acknowledgement:
  *	This product includes software developed by Emmanuel Dreyfus
- * 4. The name of the author may not be used to endorse or promote 
- *    products derived from this software without specific prior written 
+ * 4. The name of the author may not be used to endorse or promote
+ *    products derived from this software without specific prior written
  *    permission.
  *
- * THIS SOFTWARE IS PROVIDED BY THE THE AUTHOR AND CONTRIBUTORS ``AS IS'' 
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 
+ * THIS SOFTWARE IS PROVIDED BY THE THE AUTHOR AND CONTRIBUTORS ``AS IS''
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS 
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS
  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
@@ -36,26 +36,26 @@
 #ifndef _LINUX_FUTEX_H
 #define _LINUX_FUTEX_H
 
-#define LINUX_FUTEX_WAIT	0 
+#define LINUX_FUTEX_WAIT	0
 #define LINUX_FUTEX_WAKE	1
 #define LINUX_FUTEX_FD		2
 #define LINUX_FUTEX_REQUEUE	3
 #define LINUX_FUTEX_CMP_REQUEUE	4
 #define LINUX_FUTEX_WAKE_OP	5
 
-#define FUTEX_OP_SET            0       /* *(int *)UADDR2 = OPARG; */
-#define FUTEX_OP_ADD            1       /* *(int *)UADDR2 += OPARG; */
-#define FUTEX_OP_OR             2       /* *(int *)UADDR2 |= OPARG; */
-#define FUTEX_OP_ANDN           3       /* *(int *)UADDR2 &= ~OPARG; */
-#define FUTEX_OP_XOR            4       /* *(int *)UADDR2 ^= OPARG; */
+#define FUTEX_OP_SET            0	/* *(int *)UADDR2 = OPARG; */
+#define FUTEX_OP_ADD            1	/* *(int *)UADDR2 += OPARG; */
+#define FUTEX_OP_OR             2	/* *(int *)UADDR2 |= OPARG; */
+#define FUTEX_OP_ANDN           3	/* *(int *)UADDR2 &= ~OPARG; */
+#define FUTEX_OP_XOR            4	/* *(int *)UADDR2 ^= OPARG; */
 
-#define FUTEX_OP_OPARG_SHIFT    8       /* Use (1 << OPARG) instead of OPARG.  */
+#define FUTEX_OP_OPARG_SHIFT    8	/* Use (1 << OPARG) instead of OPARG.  */
 
-#define FUTEX_OP_CMP_EQ         0       /* if (oldval == CMPARG) wake */
-#define FUTEX_OP_CMP_NE         1       /* if (oldval != CMPARG) wake */
-#define FUTEX_OP_CMP_LT         2       /* if (oldval < CMPARG) wake */
-#define FUTEX_OP_CMP_LE         3       /* if (oldval <= CMPARG) wake */
-#define FUTEX_OP_CMP_GT         4       /* if (oldval > CMPARG) wake */
-#define FUTEX_OP_CMP_GE         5       /* if (oldval >= CMPARG) wake */
+#define FUTEX_OP_CMP_EQ         0	/* if (oldval == CMPARG) wake */
+#define FUTEX_OP_CMP_NE         1	/* if (oldval != CMPARG) wake */
+#define FUTEX_OP_CMP_LT         2	/* if (oldval < CMPARG) wake */
+#define FUTEX_OP_CMP_LE         3	/* if (oldval <= CMPARG) wake */
+#define FUTEX_OP_CMP_GT         4	/* if (oldval > CMPARG) wake */
+#define FUTEX_OP_CMP_GE         5	/* if (oldval >= CMPARG) wake */
 
-#endif /* !_LINUX_FUTEX_H */
+#endif	/* !_LINUX_FUTEX_H */
    
    
More information about the p4-projects
mailing list