aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md/raid0.c
diff options
context:
space:
mode:
authorMaciej Trela <maciej.trela@intel.com>2010-06-16 06:56:12 -0400
committerNeilBrown <neilb@suse.de>2010-06-23 23:34:57 -0400
commit049d6c1ef983c9ac43aa423dfd752071a5b0002d (patch)
tree909db6119d7b96991fa724b633c2ee185474836d /drivers/md/raid0.c
parent001048a318d48e93cb6a1246f3b20335b2a7c855 (diff)
md: enable raid4->raid0 takeover
Only level 5 with layout=PARITY_N can be taken over to raid0 now. Lets allow level 4 either. Signed-off-by: Maciej Trela <maciej.trela@intel.com> Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'drivers/md/raid0.c')
-rw-r--r--drivers/md/raid0.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/md/raid0.c b/drivers/md/raid0.c
index ac09b7d38553..563abed5a2cb 100644
--- a/drivers/md/raid0.c
+++ b/drivers/md/raid0.c
@@ -569,7 +569,7 @@ static void raid0_status(struct seq_file *seq, mddev_t *mddev)
569 return; 569 return;
570} 570}
571 571
572static void *raid0_takeover_raid5(mddev_t *mddev) 572static void *raid0_takeover_raid45(mddev_t *mddev)
573{ 573{
574 mdk_rdev_t *rdev; 574 mdk_rdev_t *rdev;
575 raid0_conf_t *priv_conf; 575 raid0_conf_t *priv_conf;
@@ -647,12 +647,16 @@ static void *raid0_takeover_raid10(mddev_t *mddev)
647static void *raid0_takeover(mddev_t *mddev) 647static void *raid0_takeover(mddev_t *mddev)
648{ 648{
649 /* raid0 can take over: 649 /* raid0 can take over:
650 * raid4 - if all data disks are active.
650 * raid5 - providing it is Raid4 layout and one disk is faulty 651 * raid5 - providing it is Raid4 layout and one disk is faulty
651 * raid10 - assuming we have all necessary active disks 652 * raid10 - assuming we have all necessary active disks
652 */ 653 */
654 if (mddev->level == 4)
655 return raid0_takeover_raid45(mddev);
656
653 if (mddev->level == 5) { 657 if (mddev->level == 5) {
654 if (mddev->layout == ALGORITHM_PARITY_N) 658 if (mddev->layout == ALGORITHM_PARITY_N)
655 return raid0_takeover_raid5(mddev); 659 return raid0_takeover_raid45(mddev);
656 660
657 printk(KERN_ERR "md/raid0:%s: Raid can only takeover Raid5 with layout: %d\n", 661 printk(KERN_ERR "md/raid0:%s: Raid can only takeover Raid5 with layout: %d\n",
658 mdname(mddev), ALGORITHM_PARITY_N); 662 mdname(mddev), ALGORITHM_PARITY_N);