提交 92e59b6b 编写于 作者: R raz ben yehuda 提交者: NeilBrown

md: raid0: chunk size check in raid0_run

have raid0 check chunk size in run method instead of in md.
This is part of a series moving the checks from common code to
the personalities where they belong.

hardsect is short and chunksize is an int, so it is safe to use %.

Signed-off-by: raziebe@gmail.com
Signed-off-by: NNeilBrown <neilb@suse.de>
上级 46994191
...@@ -234,6 +234,16 @@ static int create_strip_zones(mddev_t *mddev) ...@@ -234,6 +234,16 @@ static int create_strip_zones(mddev_t *mddev)
mddev->queue->backing_dev_info.congested_fn = raid0_congested; mddev->queue->backing_dev_info.congested_fn = raid0_congested;
mddev->queue->backing_dev_info.congested_data = mddev; mddev->queue->backing_dev_info.congested_data = mddev;
/*
* now since we have the hard sector sizes, we can make sure
* chunk size is a multiple of that sector size
*/
if (mddev->chunk_size % queue_logical_block_size(mddev->queue)) {
printk(KERN_ERR "%s chunk_size of %d not valid\n",
mdname(mddev),
mddev->chunk_size);
goto abort;
}
printk(KERN_INFO "raid0: done.\n"); printk(KERN_INFO "raid0: done.\n");
mddev->private = conf; mddev->private = conf;
return 0; return 0;
...@@ -289,8 +299,9 @@ static int raid0_run(mddev_t *mddev) ...@@ -289,8 +299,9 @@ static int raid0_run(mddev_t *mddev)
{ {
int ret; int ret;
if (mddev->chunk_size == 0) { if (mddev->chunk_size == 0 ||
printk(KERN_ERR "md/raid0: non-zero chunk size required.\n"); !is_power_of_2(mddev->chunk_size)) {
printk(KERN_ERR "md/raid0: chunk size must be a power of 2.\n");
return -EINVAL; return -EINVAL;
} }
blk_queue_max_sectors(mddev->queue, mddev->chunk_size >> 9); blk_queue_max_sectors(mddev->queue, mddev->chunk_size >> 9);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册