mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-02 01:18:26 +03:00
bcache: support interrupts when waiting on IO
Since lvm2 normally block signals during protected phase where it does not want to be interrupted. Support interruptible processing when allowed in section between sigint_allow() ... sigint_restore()) and let the 'io_getenvents()' finish with EINTR.
This commit is contained in:
parent
0fe58fc54f
commit
b3c7a2b3f0
@ -1,5 +1,6 @@
|
|||||||
Version 2.03.11 -
|
Version 2.03.11 -
|
||||||
==================================
|
==================================
|
||||||
|
Support interruption for bcache waiting.
|
||||||
Fix bcache when device has too many failing writes.
|
Fix bcache when device has too many failing writes.
|
||||||
Fix bcache waiting for IO completion with failing disks.
|
Fix bcache waiting for IO completion with failing disks.
|
||||||
Configure use own python path name order to prefer using python3.
|
Configure use own python path name order to prefer using python3.
|
||||||
|
@ -325,9 +325,7 @@ static bool _async_wait(struct io_engine *ioe, io_complete_fn fn)
|
|||||||
struct async_engine *e = _to_async(ioe);
|
struct async_engine *e = _to_async(ioe);
|
||||||
|
|
||||||
memset(&event, 0, sizeof(event));
|
memset(&event, 0, sizeof(event));
|
||||||
do {
|
|
||||||
r = io_getevents(e->aio_context, 1, MAX_EVENT, event, NULL);
|
r = io_getevents(e->aio_context, 1, MAX_EVENT, event, NULL);
|
||||||
} while (r == -EINTR);
|
|
||||||
|
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
log_sys_warn("io_getevents");
|
log_sys_warn("io_getevents");
|
||||||
|
Loading…
Reference in New Issue
Block a user