aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md/raid0.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/md/raid0.c')
-rw-r--r--drivers/md/raid0.c22
1 files changed, 10 insertions, 12 deletions
diff --git a/drivers/md/raid0.c b/drivers/md/raid0.c
index bb245a6d16c8..1afdfd120bba 100644
--- a/drivers/md/raid0.c
+++ b/drivers/md/raid0.c
@@ -55,7 +55,7 @@ static int raid0_congested(void *data, int bits)
55static int create_strip_zones (mddev_t *mddev) 55static int create_strip_zones (mddev_t *mddev)
56{ 56{
57 int i, c, j; 57 int i, c, j;
58 sector_t current_start, curr_zone_start; 58 sector_t curr_zone_end;
59 sector_t min_spacing; 59 sector_t min_spacing;
60 raid0_conf_t *conf = mddev_to_conf(mddev); 60 raid0_conf_t *conf = mddev_to_conf(mddev);
61 mdk_rdev_t *smallest, *rdev1, *rdev2, *rdev; 61 mdk_rdev_t *smallest, *rdev1, *rdev2, *rdev;
@@ -159,8 +159,7 @@ static int create_strip_zones (mddev_t *mddev)
159 zone->sectors = smallest->sectors * cnt; 159 zone->sectors = smallest->sectors * cnt;
160 zone->zone_end = zone->sectors; 160 zone->zone_end = zone->sectors;
161 161
162 current_start = smallest->sectors; 162 curr_zone_end = zone->sectors;
163 curr_zone_start = zone->sectors;
164 163
165 /* now do the other zones */ 164 /* now do the other zones */
166 for (i = 1; i < conf->nr_strip_zones; i++) 165 for (i = 1; i < conf->nr_strip_zones; i++)
@@ -169,7 +168,7 @@ static int create_strip_zones (mddev_t *mddev)
169 zone->dev = conf->strip_zone[i-1].dev + mddev->raid_disks; 168 zone->dev = conf->strip_zone[i-1].dev + mddev->raid_disks;
170 169
171 printk(KERN_INFO "raid0: zone %d\n", i); 170 printk(KERN_INFO "raid0: zone %d\n", i);
172 zone->dev_start = current_start; 171 zone->dev_start = smallest->sectors;
173 smallest = NULL; 172 smallest = NULL;
174 c = 0; 173 c = 0;
175 174
@@ -178,7 +177,7 @@ static int create_strip_zones (mddev_t *mddev)
178 rdev = conf->strip_zone[0].dev[j]; 177 rdev = conf->strip_zone[0].dev[j];
179 printk(KERN_INFO "raid0: checking %s ...", 178 printk(KERN_INFO "raid0: checking %s ...",
180 bdevname(rdev->bdev, b)); 179 bdevname(rdev->bdev, b));
181 if (rdev->sectors <= current_start) { 180 if (rdev->sectors <= zone->dev_start) {
182 printk(KERN_INFO " nope.\n"); 181 printk(KERN_INFO " nope.\n");
183 continue; 182 continue;
184 } 183 }
@@ -193,16 +192,15 @@ static int create_strip_zones (mddev_t *mddev)
193 } 192 }
194 193
195 zone->nb_dev = c; 194 zone->nb_dev = c;
196 zone->sectors = (smallest->sectors - current_start) * c; 195 zone->sectors = (smallest->sectors - zone->dev_start) * c;
197 printk(KERN_INFO "raid0: zone->nb_dev: %d, sectors: %llu\n", 196 printk(KERN_INFO "raid0: zone->nb_dev: %d, sectors: %llu\n",
198 zone->nb_dev, (unsigned long long)zone->sectors); 197 zone->nb_dev, (unsigned long long)zone->sectors);
199 198
200 zone->zone_end = curr_zone_start + zone->sectors; 199 curr_zone_end += zone->sectors;
201 curr_zone_start += zone->sectors; 200 zone->zone_end = curr_zone_end;
202 201
203 current_start = smallest->sectors;
204 printk(KERN_INFO "raid0: current zone start: %llu\n", 202 printk(KERN_INFO "raid0: current zone start: %llu\n",
205 (unsigned long long)current_start); 203 (unsigned long long)smallest->sectors);
206 } 204 }
207 /* Now find appropriate hash spacing. 205 /* Now find appropriate hash spacing.
208 * We want a number which causes most hash entries to cover 206 * We want a number which causes most hash entries to cover
@@ -212,8 +210,8 @@ static int create_strip_zones (mddev_t *mddev)
212 * strip though as it's size has no bearing on the efficacy of the hash 210 * strip though as it's size has no bearing on the efficacy of the hash
213 * table. 211 * table.
214 */ 212 */
215 conf->spacing = curr_zone_start; 213 conf->spacing = curr_zone_end;
216 min_spacing = curr_zone_start; 214 min_spacing = curr_zone_end;
217 sector_div(min_spacing, PAGE_SIZE/sizeof(struct strip_zone*)); 215 sector_div(min_spacing, PAGE_SIZE/sizeof(struct strip_zone*));
218 for (i=0; i < conf->nr_strip_zones-1; i++) { 216 for (i=0; i < conf->nr_strip_zones-1; i++) {
219 sector_t s = 0; 217 sector_t s = 0;