1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- /* SPDX-License-Identifier: GPL-2.0 */
- #ifndef _LINUX_FUTEX_H
- #define _LINUX_FUTEX_H
- #include <linux/ktime.h>
- #include <uapi/linux/futex.h>
- struct inode;
- struct mm_struct;
- struct task_struct;
- /*
- * Futexes are matched on equal values of this key.
- * The key type depends on whether it's a shared or private mapping.
- * Don't rearrange members without looking at hash_futex().
- *
- * offset is aligned to a multiple of sizeof(u32) (== 4) by definition.
- * We use the two low order bits of offset to tell what is the kind of key :
- * 00 : Private process futex (PTHREAD_PROCESS_PRIVATE)
- * (no reference on an inode or mm)
- * 01 : Shared futex (PTHREAD_PROCESS_SHARED)
- * mapped on a file (reference on the underlying inode)
- * 10 : Shared futex (PTHREAD_PROCESS_SHARED)
- * (but private mapping on an mm, and reference taken on it)
- */
- #define FUT_OFF_INODE 1 /* We set bit 0 if key has a reference on inode */
- #define FUT_OFF_MMSHARED 2 /* We set bit 1 if key has a reference on mm */
- union futex_key {
- struct {
- u64 i_seq;
- unsigned long pgoff;
- unsigned int offset;
- } shared;
- struct {
- union {
- struct mm_struct *mm;
- u64 __tmp;
- };
- unsigned long address;
- unsigned int offset;
- } private;
- struct {
- u64 ptr;
- unsigned long word;
- unsigned int offset;
- } both;
- };
- #define FUTEX_KEY_INIT (union futex_key) { .both = { .ptr = 0ULL } }
- #ifdef CONFIG_FUTEX
- extern void exit_robust_list(struct task_struct *curr);
- long do_futex(u32 __user *uaddr, int op, u32 val, ktime_t *timeout,
- u32 __user *uaddr2, u32 val2, u32 val3);
- #else
- static inline void exit_robust_list(struct task_struct *curr)
- {
- }
- static inline long do_futex(u32 __user *uaddr, int op, u32 val,
- ktime_t *timeout, u32 __user *uaddr2,
- u32 val2, u32 val3)
- {
- return -EINVAL;
- }
- #endif
- #ifdef CONFIG_FUTEX_PI
- extern void exit_pi_state_list(struct task_struct *curr);
- #else
- static inline void exit_pi_state_list(struct task_struct *curr)
- {
- }
- #endif
- #endif
|