Blame view
include/linux/eventfd.h
1.97 KB
b24413180 License cleanup: ... |
1 |
/* SPDX-License-Identifier: GPL-2.0 */ |
e1ad7468c signal/timer/even... |
2 3 4 5 6 7 8 9 10 |
/* * include/linux/eventfd.h * * Copyright (C) 2007 Davide Libenzi <davidel@xmailserver.org> * */ #ifndef _LINUX_EVENTFD_H #define _LINUX_EVENTFD_H |
b087498eb flag parameters: ... |
11 |
#include <linux/fcntl.h> |
cb289d624 eventfd - allow a... |
12 |
#include <linux/wait.h> |
fa3fc2ad9 include/linux/eve... |
13 |
#include <linux/err.h> |
844d2025b eventfd: track ev... |
14 15 |
#include <linux/percpu-defs.h> #include <linux/percpu.h> |
b087498eb flag parameters: ... |
16 |
|
bcd0b235b eventfd: improve ... |
17 |
/* |
1d730c49a include/linux/eve... |
18 |
* CAREFUL: Check include/uapi/asm-generic/fcntl.h when defining |
bcd0b235b eventfd: improve ... |
19 20 21 22 23 24 |
* new flags, since they might collide with O_* ones. We want * to re-use O_* flags that couldn't possibly have a meaning * from eventfd, in order to leave a free define-space for * shared O_* flags. */ #define EFD_SEMAPHORE (1 << 0) |
b087498eb flag parameters: ... |
25 |
#define EFD_CLOEXEC O_CLOEXEC |
e7d476dfd flag parameters: ... |
26 |
#define EFD_NONBLOCK O_NONBLOCK |
b087498eb flag parameters: ... |
27 |
|
bcd0b235b eventfd: improve ... |
28 29 |
#define EFD_SHARED_FCNTL_FLAGS (O_CLOEXEC | O_NONBLOCK) #define EFD_FLAGS_SET (EFD_SHARED_FCNTL_FLAGS | EFD_SEMAPHORE) |
105f2b709 eventfd: fold eve... |
30 |
struct eventfd_ctx; |
4e10f3c98 Kill indirect inc... |
31 |
struct file; |
133890103 eventfd: revised ... |
32 |
#ifdef CONFIG_EVENTFD |
133890103 eventfd: revised ... |
33 |
void eventfd_ctx_put(struct eventfd_ctx *ctx); |
e1ad7468c signal/timer/even... |
34 |
struct file *eventfd_fget(int fd); |
133890103 eventfd: revised ... |
35 36 |
struct eventfd_ctx *eventfd_ctx_fdget(int fd); struct eventfd_ctx *eventfd_ctx_fileget(struct file *file); |
ee62c6b2d eventfd: change i... |
37 |
__u64 eventfd_signal(struct eventfd_ctx *ctx, __u64 n); |
ac6424b98 sched/wait: Renam... |
38 |
int eventfd_ctx_remove_wait_queue(struct eventfd_ctx *ctx, wait_queue_entry_t *wait, |
cb289d624 eventfd - allow a... |
39 |
__u64 *cnt); |
e1ad7468c signal/timer/even... |
40 |
|
844d2025b eventfd: track ev... |
41 42 43 44 45 46 |
DECLARE_PER_CPU(int, eventfd_wake_count); static inline bool eventfd_signal_count(void) { return this_cpu_read(eventfd_wake_count); } |
e1ad7468c signal/timer/even... |
47 |
#else /* CONFIG_EVENTFD */ |
133890103 eventfd: revised ... |
48 49 50 51 |
/* * Ugly ugly ugly error layer to support modules that uses eventfd but * pretend to work in !CONFIG_EVENTFD configurations. Namely, AIO. */ |
562787a5c anonfd: split int... |
52 |
|
133890103 eventfd: revised ... |
53 54 55 56 57 58 59 60 61 62 63 64 65 66 |
static inline struct eventfd_ctx *eventfd_ctx_fdget(int fd) { return ERR_PTR(-ENOSYS); } static inline int eventfd_signal(struct eventfd_ctx *ctx, int n) { return -ENOSYS; } static inline void eventfd_ctx_put(struct eventfd_ctx *ctx) { } |
e1ad7468c signal/timer/even... |
67 |
|
cb289d624 eventfd - allow a... |
68 |
static inline int eventfd_ctx_remove_wait_queue(struct eventfd_ctx *ctx, |
ac6424b98 sched/wait: Renam... |
69 |
wait_queue_entry_t *wait, __u64 *cnt) |
cb289d624 eventfd - allow a... |
70 71 72 |
{ return -ENOSYS; } |
844d2025b eventfd: track ev... |
73 74 75 76 |
static inline bool eventfd_signal_count(void) { return false; } |
133890103 eventfd: revised ... |
77 |
#endif |
e1ad7468c signal/timer/even... |
78 |
|
e1ad7468c signal/timer/even... |
79 |
#endif /* _LINUX_EVENTFD_H */ |