diff options
| author | Jens Axboe <axboe@kernel.dk> | 2022-11-20 10:13:44 -0700 |
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2023-01-04 11:28:48 +0100 |
| commit | 3b2728881dcd4ec3549d479c4b3aa38cf15fc73d (patch) | |
| tree | cd402e2bbfcb16a52d026d45174d59eb258e2af8 /io_uring | |
| parent | 717ed90a661494b895609fc536382dec40f71de6 (diff) | |
| download | linux-3b2728881dcd4ec3549d479c4b3aa38cf15fc73d.tar.gz linux-3b2728881dcd4ec3549d479c4b3aa38cf15fc73d.tar.bz2 linux-3b2728881dcd4ec3549d479c4b3aa38cf15fc73d.zip | |
eventfd: provide a eventfd_signal_mask() helper
[ Upstream commit 03e02acda8e267a8183e1e0ed289ff1ef9cd7ed8 ]
This is identical to eventfd_signal(), but it allows the caller to pass
in a mask to be used for the poll wakeup key. The use case is avoiding
repeated multishot triggers if we have a dependency between eventfd and
io_uring.
If we setup an eventfd context and register that as the io_uring eventfd,
and at the same time queue a multishot poll request for the eventfd
context, then any CQE posted will repeatedly trigger the multishot request
until it terminates when the CQ ring overflows.
In preparation for io_uring detecting this circular dependency, add the
mentioned helper so that io_uring can pass in EPOLL_URING as part of the
poll wakeup key.
Cc: stable@vger.kernel.org # 6.0
[axboe: fold in !CONFIG_EVENTFD fix from Zhang Qilong]
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Stable-dep-of: 4464853277d0 ("io_uring: pass in EPOLL_URING_WAKE for eventfd signaling and wakeups")
Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'io_uring')
0 files changed, 0 insertions, 0 deletions
