diff options
| author | Pavel Begunkov <[email protected]> | 2019-11-21 11:54:28 +0300 | 
|---|---|---|
| committer | Jens Axboe <[email protected]> | 2019-11-25 19:56:10 -0700 | 
| commit | 1b4a51b6d03d21f55effbcf609ba5526d87d9e9d (patch) | |
| tree | bb06df2306988aa5d80dfa4985fa449ee5bdbf64 /drivers/usb/cdns3/cdns3-pci-wrap.c | |
| parent | b76da70fc3759df13e0991706451f1a2e06ba19e (diff) | |
io_uring: drain next sqe instead of shadowing
There's an issue with the shadow drain logic in that we drop the
completion lock after deciding to defer a request, then re-grab it later
and assume that the state is still the same. In the mean time, someone
else completing a request could have found and issued it. This can cause
a stall in the queue, by having a shadow request inserted that nobody is
going to drain.
Additionally, if we fail allocating the shadow request, we simply ignore
the drain.
Instead of using a shadow request, defer the next request/link instead.
This also has the following advantages:
- removes semi-duplicated code
- doesn't allocate memory for shadows
- works better if only the head marked for drain
- doesn't need complex synchronisation
On the flip side, it removes the shadow->seq ==
last_drain_in_in_link->seq optimization. That shouldn't be a common
case, and can always be added back, if needed.
Fixes: 4fe2c963154c ("io_uring: add support for link with drain")
Cc: Jackie Liu <[email protected]>
Reported-by: Jens Axboe <[email protected]>
Signed-off-by: Pavel Begunkov <[email protected]>
Signed-off-by: Jens Axboe <[email protected]>
Diffstat (limited to 'drivers/usb/cdns3/cdns3-pci-wrap.c')
0 files changed, 0 insertions, 0 deletions