From 1b16a6998aced8da72f5aeb77564c2c0e16a8cd0 Mon Sep 17 00:00:00 2001 From: NeilBrown Date: Sat, 16 Apr 2005 15:26:42 -0700 Subject: [PATCH] --- yaml --- r: 199 b: refs/heads/master c: a757e64cfa400391041ed7953f0290c34a820c93 h: refs/heads/master i: 197: 6b9fa9e980d34b82ff09816da27f75939f721eb8 195: ef0516ef9175025469a1e7bea10caabe882567ad 191: 07f108b8f75355868206554ee391488401946f11 v: v3 --- [refs] | 2 +- trunk/drivers/md/md.c | 30 ++++++++---------------------- 2 files changed, 9 insertions(+), 23 deletions(-) diff --git a/[refs] b/[refs] index 2c90e8bb858c..6a7acb432ad4 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: d28446fe2d87ea344c14741c39962dcc7aee5c78 +refs/heads/master: a757e64cfa400391041ed7953f0290c34a820c93 diff --git a/trunk/drivers/md/md.c b/trunk/drivers/md/md.c index 44a164965546..97af857d8a88 100644 --- a/trunk/drivers/md/md.c +++ b/trunk/drivers/md/md.c @@ -1387,7 +1387,7 @@ static mdk_rdev_t *md_import_device(dev_t newdev, int super_format, int super_mi */ -static int analyze_sbs(mddev_t * mddev) +static void analyze_sbs(mddev_t * mddev) { int i; struct list_head *tmp; @@ -1441,7 +1441,6 @@ static int analyze_sbs(mddev_t * mddev) " -- starting background reconstruction\n", mdname(mddev)); - return 0; } int mdp_major = 0; @@ -1508,10 +1507,9 @@ static int do_md_run(mddev_t * mddev) struct gendisk *disk; char b[BDEVNAME_SIZE]; - if (list_empty(&mddev->disks)) { - MD_BUG(); + if (list_empty(&mddev->disks)) + /* cannot run an array with no devices.. */ return -EINVAL; - } if (mddev->pers) return -EBUSY; @@ -1519,10 +1517,8 @@ static int do_md_run(mddev_t * mddev) /* * Analyze all RAID superblock(s) */ - if (!mddev->raid_disks && analyze_sbs(mddev)) { - MD_BUG(); - return -EINVAL; - } + if (!mddev->raid_disks) + analyze_sbs(mddev); chunk_size = mddev->chunk_size; pnum = level_to_pers(mddev->level); @@ -1548,7 +1544,7 @@ static int do_md_run(mddev_t * mddev) * chunk-size has to be a power of 2 and multiples of PAGE_SIZE */ if ( (1 << ffz(~chunk_size)) != chunk_size) { - MD_BUG(); + printk(KERN_ERR "chunk_size of %d not valid\n", chunk_size); return -EINVAL; } if (chunk_size < PAGE_SIZE) { @@ -1573,11 +1569,6 @@ static int do_md_run(mddev_t * mddev) } } - if (pnum >= MAX_PERSONALITY) { - MD_BUG(); - return -EINVAL; - } - #ifdef CONFIG_KMOD if (!pers[pnum]) { @@ -1762,10 +1753,8 @@ static void autorun_array(mddev_t *mddev) struct list_head *tmp; int err; - if (list_empty(&mddev->disks)) { - MD_BUG(); + if (list_empty(&mddev->disks)) return; - } printk(KERN_INFO "md: running: "); @@ -3128,7 +3117,6 @@ int register_md_personality(int pnum, mdk_personality_t *p) spin_lock(&pers_lock); if (pers[pnum]) { spin_unlock(&pers_lock); - MD_BUG(); return -EBUSY; } @@ -3140,10 +3128,8 @@ int register_md_personality(int pnum, mdk_personality_t *p) int unregister_md_personality(int pnum) { - if (pnum >= MAX_PERSONALITY) { - MD_BUG(); + if (pnum >= MAX_PERSONALITY) return -EINVAL; - } printk(KERN_INFO "md: %s personality unregistered\n", pers[pnum]->name); spin_lock(&pers_lock);