From ba7d5151de8f30ce991582b610d1ac5e8ee4ca34 Mon Sep 17 00:00:00 2001 From: NeilBrown Date: Tue, 1 Jun 2010 19:37:25 +1000 Subject: [PATCH] --- yaml --- r: 208366 b: refs/heads/master c: f4be6b43f1ac60dff00ef0923ee43b0e08872947 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/md/raid5.c | 12 ++++++++---- trunk/drivers/md/raid5.h | 2 +- 3 files changed, 10 insertions(+), 6 deletions(-) diff --git a/[refs] b/[refs] index 4759ded05860..31c9afb01a61 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: c41d4ac40df0d01bf9c383ff28f194d1df2d4fd9 +refs/heads/master: f4be6b43f1ac60dff00ef0923ee43b0e08872947 diff --git a/trunk/drivers/md/raid5.c b/trunk/drivers/md/raid5.c index bd4067a70834..6fa60e416a09 100644 --- a/trunk/drivers/md/raid5.c +++ b/trunk/drivers/md/raid5.c @@ -1337,10 +1337,14 @@ static int grow_stripes(raid5_conf_t *conf, int num) struct kmem_cache *sc; int devs = max(conf->raid_disks, conf->previous_raid_disks); - sprintf(conf->cache_name[0], - "raid%d-%s", conf->level, mdname(conf->mddev)); - sprintf(conf->cache_name[1], - "raid%d-%s-alt", conf->level, mdname(conf->mddev)); + if (conf->mddev->gendisk) + sprintf(conf->cache_name[0], + "raid%d-%s", conf->level, mdname(conf->mddev)); + else + sprintf(conf->cache_name[0], + "raid%d-%p", conf->level, conf->mddev); + sprintf(conf->cache_name[1], "%s-alt", conf->cache_name[0]); + conf->active_name = 0; sc = kmem_cache_create(conf->cache_name[conf->active_name], sizeof(struct stripe_head)+(devs-1)*sizeof(struct r5dev), diff --git a/trunk/drivers/md/raid5.h b/trunk/drivers/md/raid5.h index cbdbc77695b3..61b6b25dc5e7 100644 --- a/trunk/drivers/md/raid5.h +++ b/trunk/drivers/md/raid5.h @@ -388,7 +388,7 @@ struct raid5_private_data { * two caches. */ int active_name; - char cache_name[2][20]; + char cache_name[2][32]; struct kmem_cache *slab_cache; /* for allocating stripes */ int seq_flush, seq_write;