summaryrefslogtreecommitdiffstats
path: root/Documentation/devicetree/bindings
diff options
context:
space:
mode:
authorJens Axboe <axboe@kernel.dk>2019-09-24 21:47:15 +0200
committerJens Axboe <axboe@kernel.dk>2019-09-26 11:55:40 +0200
commitbda521624e75c665c407b3d9cece6e7a28178cd8 (patch)
treef6b34adf621ac71e5c5257d92e9c6d5ab9b58c1f /Documentation/devicetree/bindings
parentio_uring: compare cached_cq_tail with cq.head in_io_uring_poll (diff)
downloadlinux-bda521624e75c665c407b3d9cece6e7a28178cd8.tar.xz
linux-bda521624e75c665c407b3d9cece6e7a28178cd8.zip
io_uring: make CQ ring wakeups be more efficient
For batched IO, it's not uncommon for waiters to ask for more than 1 IO to complete before being woken up. This is a problem with wait_event() since tasks will get woken for every IO that completes, re-check condition, then go back to sleep. For batch counts on the order of what you do for high IOPS, that can result in 10s of extra wakeups for the waiting task. Add a private wake function that checks for the wake up count criteria being met before calling autoremove_wake_function(). Pavel reports that one test case he has runs 40% faster with proper batching of wakeups. Reported-by: Pavel Begunkov <asml.silence@gmail.com> Tested-by: Pavel Begunkov <asml.silence@gmail.com> Reviewed-by: Pavel Begunkov <asml.silence@gmail.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'Documentation/devicetree/bindings')
0 files changed, 0 insertions, 0 deletions