mirror of
https://github.com/rd-stuffs/msm-4.14.git
synced 2025-02-20 11:45:48 +08:00
[PATCH] dm kcopyd: error accumulation fix
kcopyd should accumulate errors - otherwise I/O failures may be ignored unintentionally. And invert 'success' (used in a future patch), using a more intuitive !(read_err || write_err). Signed-off-by: Jonathan Brassow <jbrassow@redhat.com> Signed-off-by: Alasdair G Kergon <agk@redhat.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
8a835f11bc
commit
ce503f59ae
@ -602,7 +602,7 @@ static void recovery_complete(int read_err, unsigned int write_err,
|
|||||||
struct region *reg = (struct region *) context;
|
struct region *reg = (struct region *) context;
|
||||||
|
|
||||||
/* FIXME: better error handling */
|
/* FIXME: better error handling */
|
||||||
rh_recovery_end(reg, read_err || write_err);
|
rh_recovery_end(reg, !(read_err || write_err));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int recover(struct mirror_set *ms, struct region *reg)
|
static int recover(struct mirror_set *ms, struct region *reg)
|
||||||
|
@ -314,7 +314,7 @@ static void complete_io(unsigned long error, void *context)
|
|||||||
|
|
||||||
if (error) {
|
if (error) {
|
||||||
if (job->rw == WRITE)
|
if (job->rw == WRITE)
|
||||||
job->write_err &= error;
|
job->write_err |= error;
|
||||||
else
|
else
|
||||||
job->read_err = 1;
|
job->read_err = 1;
|
||||||
|
|
||||||
@ -460,7 +460,7 @@ static void segment_complete(int read_err,
|
|||||||
job->read_err = 1;
|
job->read_err = 1;
|
||||||
|
|
||||||
if (write_err)
|
if (write_err)
|
||||||
job->write_err &= write_err;
|
job->write_err |= write_err;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Only dispatch more work if there hasn't been an error.
|
* Only dispatch more work if there hasn't been an error.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user