-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[PATCH] uml: adapt asm/futex.h to our arch
Follow up to 4732efb - uml must just reuse as-is the backing architecture support. There is a micro-fixup is needed for the included file, which won't affect i386 behaviour at all. I've not tested compilation on x86_64, only on x86, but the code is almost the same except the culprit test, so everything should be ok on x86_64 too. Cc: Jakub Jelinek <jakub@redhat.com> Signed-off-by: Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
- Loading branch information
Paolo 'Blaisorblade' Giarrusso
authored and
Linus Torvalds
committed
Sep 21, 2005
1 parent
f62378f
commit c51179f
Showing
2 changed files
with
6 additions
and
47 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,53 +1,12 @@ | ||
#ifndef _ASM_FUTEX_H | ||
#define _ASM_FUTEX_H | ||
|
||
#ifdef __KERNEL__ | ||
#ifndef __UM_FUTEX_H | ||
#define __UM_FUTEX_H | ||
|
||
#include <linux/futex.h> | ||
#include <asm/errno.h> | ||
#include <asm/system.h> | ||
#include <asm/processor.h> | ||
#include <asm/uaccess.h> | ||
|
||
static inline int | ||
futex_atomic_op_inuser (int encoded_op, int __user *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, tem; | ||
if (encoded_op & (FUTEX_OP_OPARG_SHIFT << 28)) | ||
oparg = 1 << oparg; | ||
|
||
if (! access_ok (VERIFY_WRITE, uaddr, sizeof(int))) | ||
return -EFAULT; | ||
|
||
inc_preempt_count(); | ||
|
||
switch (op) { | ||
case FUTEX_OP_SET: | ||
case FUTEX_OP_ADD: | ||
case FUTEX_OP_OR: | ||
case FUTEX_OP_ANDN: | ||
case FUTEX_OP_XOR: | ||
default: | ||
ret = -ENOSYS; | ||
} | ||
#include "asm/arch/futex.h" | ||
|
||
dec_preempt_count(); | ||
|
||
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; | ||
} | ||
|
||
#endif | ||
#endif |