diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2017-11-29 19:00:41 -0500 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2017-11-29 19:00:41 -0500 |
commit | c71d227fc4133f949dae620ed5e3a250b43f2415 (patch) | |
tree | ce12b907996c2acd37e9d86f4ba492b09a0ab0f8 /arch/m68k/include/uapi | |
parent | 69112736e2f025ff3ba280cf81c36e25cf7cc59f (diff) |
make kernel-side POLL... arch-independent
mangle/demangle on the way to/from userland
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'arch/m68k/include/uapi')
-rw-r--r-- | arch/m68k/include/uapi/asm/poll.h | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/arch/m68k/include/uapi/asm/poll.h b/arch/m68k/include/uapi/asm/poll.h index 99314937fe5c..d8be239e8141 100644 --- a/arch/m68k/include/uapi/asm/poll.h +++ b/arch/m68k/include/uapi/asm/poll.h | |||
@@ -2,8 +2,25 @@ | |||
2 | #ifndef __m68k_POLL_H | 2 | #ifndef __m68k_POLL_H |
3 | #define __m68k_POLL_H | 3 | #define __m68k_POLL_H |
4 | 4 | ||
5 | #ifndef __KERNEL__ | ||
5 | #define POLLWRNORM POLLOUT | 6 | #define POLLWRNORM POLLOUT |
6 | #define POLLWRBAND (__force __poll_t)256 | 7 | #define POLLWRBAND (__force __poll_t)256 |
8 | #else | ||
9 | #define __ARCH_HAS_MANGLED_POLL | ||
10 | static inline __u16 mangle_poll(__poll_t val) | ||
11 | { | ||
12 | __u16 v = (__force __u16)val; | ||
13 | /* bit 9 -> bit 8, bit 8 -> bit 2 */ | ||
14 | return (v & ~0x300) | ((v & 0x200) >> 1) | ((v & 0x100) >> 6); | ||
15 | } | ||
16 | |||
17 | static inline __poll_t demangle_poll(__u16 v) | ||
18 | { | ||
19 | /* bit 8 -> bit 9, bit 2 -> bits 2 and 8 */ | ||
20 | return (__force __poll_t)((v & ~0x100) | ((v & 0x100) << 1) | | ||
21 | ((v & 4) << 6)); | ||
22 | } | ||
23 | #endif | ||
7 | 24 | ||
8 | #include <asm-generic/poll.h> | 25 | #include <asm-generic/poll.h> |
9 | 26 | ||