forked from luck/tmp_suning_uos_patched
md: add ->takeover method for raid5 to be able to take over raid1
The RAID1 must have two drives and be a suitable size to be a multiple of a chunksize that isn't too small. Signed-off-by: NeilBrown <neilb@suse.de>
This commit is contained in:
parent
245f46c2c2
commit
d562b0c431
|
@ -4884,6 +4884,53 @@ static void raid5_quiesce(mddev_t *mddev, int state)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void *raid5_takeover_raid1(mddev_t *mddev)
|
||||||
|
{
|
||||||
|
int chunksect;
|
||||||
|
|
||||||
|
if (mddev->raid_disks != 2 ||
|
||||||
|
mddev->degraded > 1)
|
||||||
|
return ERR_PTR(-EINVAL);
|
||||||
|
|
||||||
|
/* Should check if there are write-behind devices? */
|
||||||
|
|
||||||
|
chunksect = 64*2; /* 64K by default */
|
||||||
|
|
||||||
|
/* The array must be an exact multiple of chunksize */
|
||||||
|
while (chunksect && (mddev->array_sectors & (chunksect-1)))
|
||||||
|
chunksect >>= 1;
|
||||||
|
|
||||||
|
if ((chunksect<<9) < STRIPE_SIZE)
|
||||||
|
/* array size does not allow a suitable chunk size */
|
||||||
|
return ERR_PTR(-EINVAL);
|
||||||
|
|
||||||
|
mddev->new_level = 5;
|
||||||
|
mddev->new_layout = ALGORITHM_LEFT_SYMMETRIC;
|
||||||
|
mddev->new_chunk = chunksect << 9;
|
||||||
|
|
||||||
|
return setup_conf(mddev);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void *raid5_takeover(mddev_t *mddev)
|
||||||
|
{
|
||||||
|
/* raid5 can take over:
|
||||||
|
* raid0 - if all devices are the same - make it a raid4 layout
|
||||||
|
* raid1 - if there are two drives. We need to know the chunk size
|
||||||
|
* raid4 - trivial - just use a raid4 layout.
|
||||||
|
* raid6 - Providing it is a *_6 layout
|
||||||
|
*
|
||||||
|
* For now, just do raid1
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (mddev->level == 1)
|
||||||
|
return raid5_takeover_raid1(mddev);
|
||||||
|
|
||||||
|
return ERR_PTR(-EINVAL);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static struct mdk_personality raid5_personality;
|
static struct mdk_personality raid5_personality;
|
||||||
|
|
||||||
static void *raid6_takeover(mddev_t *mddev)
|
static void *raid6_takeover(mddev_t *mddev)
|
||||||
|
@ -4975,6 +5022,7 @@ static struct mdk_personality raid5_personality =
|
||||||
.start_reshape = raid5_start_reshape,
|
.start_reshape = raid5_start_reshape,
|
||||||
#endif
|
#endif
|
||||||
.quiesce = raid5_quiesce,
|
.quiesce = raid5_quiesce,
|
||||||
|
.takeover = raid5_takeover,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct mdk_personality raid4_personality =
|
static struct mdk_personality raid4_personality =
|
||||||
|
|
Loading…
Reference in New Issue
Block a user