aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2011-12-22 18:17:54 -0500
committerNeilBrown <neilb@suse.de>2011-12-22 18:17:54 -0500
commit3a6de2924af602f9c1b5a5154438c37f2d712dfa (patch)
tree895462dfefd70827c5b6d860503d1244d003a56e /drivers/md
parent7bfec5f35c68121e7b1849f3f4166dd96c8da5b3 (diff)
md/raid5: Mark device want_replacement when we see a write error.
Now that WantReplacement drives are replaced cleanly, mark a drive as WantReplacement when we see a write error. It might get failed soon so the WantReplacement flag is irrelevant, but if the write error is recorded in the bad block log, we still want to activate any spare that might be available. Reviewed-by: Dan Williams <dan.j.williams@intel.com> Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'drivers/md')
-rw-r--r--drivers/md/raid5.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/md/raid5.c b/drivers/md/raid5.c
index b2c83859f75b..360f2b98f62b 100644
--- a/drivers/md/raid5.c
+++ b/drivers/md/raid5.c
@@ -1796,6 +1796,9 @@ static void raid5_end_write_request(struct bio *bi, int error)
1796 if (!uptodate) { 1796 if (!uptodate) {
1797 set_bit(WriteErrorSeen, &rdev->flags); 1797 set_bit(WriteErrorSeen, &rdev->flags);
1798 set_bit(R5_WriteError, &sh->dev[i].flags); 1798 set_bit(R5_WriteError, &sh->dev[i].flags);
1799 if (!test_and_set_bit(WantReplacement, &rdev->flags))
1800 set_bit(MD_RECOVERY_NEEDED,
1801 &rdev->mddev->recovery);
1799 } else if (is_badblock(rdev, sh->sector, 1802 } else if (is_badblock(rdev, sh->sector,
1800 STRIPE_SECTORS, 1803 STRIPE_SECTORS,
1801 &first_bad, &bad_sectors)) 1804 &first_bad, &bad_sectors))