Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Davide Libenzi | e1ad746 | 2007-05-10 22:23:19 -0700 | [diff] [blame] | 2 | /* |
| 3 | * include/linux/eventfd.h |
| 4 | * |
| 5 | * Copyright (C) 2007 Davide Libenzi <davidel@xmailserver.org> |
| 6 | * |
| 7 | */ |
| 8 | |
| 9 | #ifndef _LINUX_EVENTFD_H |
| 10 | #define _LINUX_EVENTFD_H |
| 11 | |
Ulrich Drepper | b087498e | 2008-07-23 21:29:25 -0700 | [diff] [blame] | 12 | #include <linux/fcntl.h> |
Davide Libenzi | cb289d6 | 2010-01-13 09:34:36 -0800 | [diff] [blame] | 13 | #include <linux/wait.h> |
Arnd Bergmann | fa3fc2a | 2018-07-26 16:37:38 -0700 | [diff] [blame] | 14 | #include <linux/err.h> |
Jens Axboe | b5e683d | 2020-02-02 08:23:03 -0700 | [diff] [blame^] | 15 | #include <linux/percpu-defs.h> |
| 16 | #include <linux/percpu.h> |
Ulrich Drepper | b087498e | 2008-07-23 21:29:25 -0700 | [diff] [blame] | 17 | |
Davide Libenzi | bcd0b23 | 2009-03-31 15:24:18 -0700 | [diff] [blame] | 18 | /* |
Martin Sustrik | 1d730c4 | 2013-02-27 17:05:42 -0800 | [diff] [blame] | 19 | * CAREFUL: Check include/uapi/asm-generic/fcntl.h when defining |
Davide Libenzi | bcd0b23 | 2009-03-31 15:24:18 -0700 | [diff] [blame] | 20 | * new flags, since they might collide with O_* ones. We want |
| 21 | * to re-use O_* flags that couldn't possibly have a meaning |
| 22 | * from eventfd, in order to leave a free define-space for |
| 23 | * shared O_* flags. |
| 24 | */ |
| 25 | #define EFD_SEMAPHORE (1 << 0) |
Ulrich Drepper | b087498e | 2008-07-23 21:29:25 -0700 | [diff] [blame] | 26 | #define EFD_CLOEXEC O_CLOEXEC |
Ulrich Drepper | e7d476d | 2008-07-23 21:29:38 -0700 | [diff] [blame] | 27 | #define EFD_NONBLOCK O_NONBLOCK |
Ulrich Drepper | b087498e | 2008-07-23 21:29:25 -0700 | [diff] [blame] | 28 | |
Davide Libenzi | bcd0b23 | 2009-03-31 15:24:18 -0700 | [diff] [blame] | 29 | #define EFD_SHARED_FCNTL_FLAGS (O_CLOEXEC | O_NONBLOCK) |
| 30 | #define EFD_FLAGS_SET (EFD_SHARED_FCNTL_FLAGS | EFD_SEMAPHORE) |
| 31 | |
Eric Biggers | 105f2b7 | 2018-01-06 09:45:44 -0800 | [diff] [blame] | 32 | struct eventfd_ctx; |
Al Viro | 4e10f3c | 2013-08-30 12:29:49 -0400 | [diff] [blame] | 33 | struct file; |
| 34 | |
Davide Libenzi | 1338901 | 2009-06-30 11:41:11 -0700 | [diff] [blame] | 35 | #ifdef CONFIG_EVENTFD |
| 36 | |
Davide Libenzi | 1338901 | 2009-06-30 11:41:11 -0700 | [diff] [blame] | 37 | void eventfd_ctx_put(struct eventfd_ctx *ctx); |
Davide Libenzi | e1ad746 | 2007-05-10 22:23:19 -0700 | [diff] [blame] | 38 | struct file *eventfd_fget(int fd); |
Davide Libenzi | 1338901 | 2009-06-30 11:41:11 -0700 | [diff] [blame] | 39 | struct eventfd_ctx *eventfd_ctx_fdget(int fd); |
| 40 | struct eventfd_ctx *eventfd_ctx_fileget(struct file *file); |
Sha Zhengju | ee62c6b | 2012-05-31 16:26:41 -0700 | [diff] [blame] | 41 | __u64 eventfd_signal(struct eventfd_ctx *ctx, __u64 n); |
Ingo Molnar | ac6424b | 2017-06-20 12:06:13 +0200 | [diff] [blame] | 42 | int eventfd_ctx_remove_wait_queue(struct eventfd_ctx *ctx, wait_queue_entry_t *wait, |
Davide Libenzi | cb289d6 | 2010-01-13 09:34:36 -0800 | [diff] [blame] | 43 | __u64 *cnt); |
Davide Libenzi | e1ad746 | 2007-05-10 22:23:19 -0700 | [diff] [blame] | 44 | |
Jens Axboe | b5e683d | 2020-02-02 08:23:03 -0700 | [diff] [blame^] | 45 | DECLARE_PER_CPU(int, eventfd_wake_count); |
| 46 | |
| 47 | static inline bool eventfd_signal_count(void) |
| 48 | { |
| 49 | return this_cpu_read(eventfd_wake_count); |
| 50 | } |
| 51 | |
Davide Libenzi | e1ad746 | 2007-05-10 22:23:19 -0700 | [diff] [blame] | 52 | #else /* CONFIG_EVENTFD */ |
| 53 | |
Davide Libenzi | 1338901 | 2009-06-30 11:41:11 -0700 | [diff] [blame] | 54 | /* |
| 55 | * Ugly ugly ugly error layer to support modules that uses eventfd but |
| 56 | * pretend to work in !CONFIG_EVENTFD configurations. Namely, AIO. |
| 57 | */ |
Davide Libenzi | 562787a | 2009-09-22 16:43:57 -0700 | [diff] [blame] | 58 | |
Davide Libenzi | 1338901 | 2009-06-30 11:41:11 -0700 | [diff] [blame] | 59 | static inline struct eventfd_ctx *eventfd_ctx_fdget(int fd) |
| 60 | { |
| 61 | return ERR_PTR(-ENOSYS); |
| 62 | } |
Davide Libenzi | e1ad746 | 2007-05-10 22:23:19 -0700 | [diff] [blame] | 63 | |
Davide Libenzi | 1338901 | 2009-06-30 11:41:11 -0700 | [diff] [blame] | 64 | static inline int eventfd_signal(struct eventfd_ctx *ctx, int n) |
| 65 | { |
| 66 | return -ENOSYS; |
| 67 | } |
| 68 | |
| 69 | static inline void eventfd_ctx_put(struct eventfd_ctx *ctx) |
| 70 | { |
| 71 | |
| 72 | } |
| 73 | |
Davide Libenzi | cb289d6 | 2010-01-13 09:34:36 -0800 | [diff] [blame] | 74 | static inline int eventfd_ctx_remove_wait_queue(struct eventfd_ctx *ctx, |
Ingo Molnar | ac6424b | 2017-06-20 12:06:13 +0200 | [diff] [blame] | 75 | wait_queue_entry_t *wait, __u64 *cnt) |
Davide Libenzi | cb289d6 | 2010-01-13 09:34:36 -0800 | [diff] [blame] | 76 | { |
| 77 | return -ENOSYS; |
| 78 | } |
| 79 | |
Jens Axboe | b5e683d | 2020-02-02 08:23:03 -0700 | [diff] [blame^] | 80 | static inline bool eventfd_signal_count(void) |
| 81 | { |
| 82 | return false; |
| 83 | } |
| 84 | |
Davide Libenzi | 1338901 | 2009-06-30 11:41:11 -0700 | [diff] [blame] | 85 | #endif |
Davide Libenzi | e1ad746 | 2007-05-10 22:23:19 -0700 | [diff] [blame] | 86 | |
Davide Libenzi | e1ad746 | 2007-05-10 22:23:19 -0700 | [diff] [blame] | 87 | #endif /* _LINUX_EVENTFD_H */ |
| 88 | |