Blame view
include/asm-s390/futex.h
1.32 KB
3363fbdd6
|
1 2 |
#ifndef _ASM_S390_FUTEX_H #define _ASM_S390_FUTEX_H |
4732efbeb
|
3 |
|
3363fbdd6
|
4 |
#ifdef __KERNEL__ |
4732efbeb
|
5 |
|
3363fbdd6
|
6 |
#include <linux/futex.h> |
d8ad075ef
|
7 |
#include <linux/uaccess.h> |
3363fbdd6
|
8 |
#include <asm/errno.h> |
3363fbdd6
|
9 |
|
3363fbdd6
|
10 11 12 13 14 15 |
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; |
d02765d1a
|
16 |
int oldval, ret; |
3363fbdd6
|
17 18 19 20 21 |
if (encoded_op & (FUTEX_OP_OPARG_SHIFT << 28)) oparg = 1 << oparg; if (! access_ok (VERIFY_WRITE, uaddr, sizeof(int))) return -EFAULT; |
d8ad075ef
|
22 |
pagefault_disable(); |
d02765d1a
|
23 |
ret = uaccess.futex_atomic_op(op, uaddr, oparg, &oldval); |
d8ad075ef
|
24 |
pagefault_enable(); |
3363fbdd6
|
25 26 27 28 29 30 31 32 33 34 35 36 37 38 |
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; } |
d02765d1a
|
39 40 |
static inline int futex_atomic_cmpxchg_inatomic(int __user *uaddr, int oldval, int newval) |
3363fbdd6
|
41 |
{ |
3363fbdd6
|
42 43 |
if (! access_ok (VERIFY_WRITE, uaddr, sizeof(int))) return -EFAULT; |
d02765d1a
|
44 45 |
return uaccess.futex_atomic_cmpxchg(uaddr, oldval, newval); |
3363fbdd6
|
46 47 48 49 |
} #endif /* __KERNEL__ */ #endif /* _ASM_S390_FUTEX_H */ |