summaryrefslogtreecommitdiffstats
path: root/crypto/rmd160.c
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2010-06-16 09:17:53 +0200
committerNeilBrown <neilb@suse.de>2010-06-24 05:35:27 +0200
commit674806d62fb02a22eea948c9f1b5e58e0947b728 (patch)
tree3367850a95d62713aa96acd2aecc493b66779398 /crypto/rmd160.c
parentmd: Don't update ->recovery_offset when reshaping an array to fewer devices. (diff)
downloadlinux-674806d62fb02a22eea948c9f1b5e58e0947b728.tar.xz
linux-674806d62fb02a22eea948c9f1b5e58e0947b728.zip
md/raid5: More careful check for "has array failed".
When we are reshaping an array, the device failure combinations that cause us to decide that the array as failed are more subtle. In particular, any 'spare' will be fully in-sync in the section of the array that has already been reshaped, thus failures that affect only that section are less critical. So encode this subtlety in a new function and call it as appropriate. The case that showed this problem was a 4 drive RAID5 to 8 drive RAID6 conversion where the last two devices failed. This resulted in: good good good good incomplete good good failed failed while converting a 5-drive RAID6 to 8 drive RAID5 The incomplete device causes the whole array to look bad, bad as it was actually good for the section that had been converted to 8-drives, all the data was actually safe. Reported-by: Terry Morris <tbmorris@tbmorris.com> Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'crypto/rmd160.c')
0 files changed, 0 insertions, 0 deletions