summaryrefslogtreecommitdiff
path: root/.cocciconfig
diff options
context:
space:
mode:
authorJens Axboe <axboe@kernel.dk>2019-08-19 12:15:59 -0600
committerJens Axboe <axboe@kernel.dk>2019-08-20 11:01:58 -0600
commit500f9fbadef86466a435726192f4ca4df7d94236 (patch)
treef73f93d0f7d5a76b4f71dfc70fa30008a93d204c /.cocciconfig
parentd1abaeb3be7b5fa6d7a1fbbd2e14e3310005c4c1 (diff)
io_uring: fix potential hang with polled IO
If a request issue ends up being punted to async context to avoid blocking, we can get into a situation where the original application enters the poll loop for that very request before it has been issued. This should not be an issue, except that the polling will hold the io_uring uring_ctx mutex for the duration of the poll. When the async worker has actually issued the request, it needs to acquire this mutex to add the request to the poll issued list. Since the application polling is already holding this mutex, the workqueue sleeps on the mutex forever, and the application thus never gets a chance to poll for the very request it was interested in. Fix this by ensuring that the polling drops the uring_ctx occasionally if it's not making any progress. Reported-by: Jeffrey M. Birnbaum <jmbnyc@gmail.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to '.cocciconfig')
0 files changed, 0 insertions, 0 deletions