Commit 7ab3fe4e authored by NeilBrown's avatar NeilBrown Committed by Greg Kroah-Hartman

md/raid1: fix counting of write targets.

commit 964147d5 upstream.

There is a very small race window when writing to a
RAID1 such that if a device is marked faulty at exactly the wrong
time, the write-in-progress will not be sent to the device,
but the bitmap (if present) will be updated to say that
the write was sent.

Then if the device turned out to still be usable as was re-added
to the array, the bitmap-based-resync would skip resyncing that
block, possibly leading to corruption.  This would only be a problem
if no further writes were issued to that area of the device (i.e.
that bitmap chunk).

Suitable for any pending -stable kernel.
Signed-off-by: default avatarNeilBrown <neilb@suse.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent ff021ea1
...@@ -912,9 +912,10 @@ static int make_request(struct request_queue *q, struct bio * bio) ...@@ -912,9 +912,10 @@ static int make_request(struct request_queue *q, struct bio * bio)
if (test_bit(Faulty, &rdev->flags)) { if (test_bit(Faulty, &rdev->flags)) {
rdev_dec_pending(rdev, mddev); rdev_dec_pending(rdev, mddev);
r1_bio->bios[i] = NULL; r1_bio->bios[i] = NULL;
} else } else {
r1_bio->bios[i] = bio; r1_bio->bios[i] = bio;
targets++; targets++;
}
} else } else
r1_bio->bios[i] = NULL; r1_bio->bios[i] = NULL;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment