From: Alasdair G Kergon Change dm_get_mdptr() to take a struct mapped_device instead of dev_t. Signed-off-by: Alasdair G Kergon Signed-off-by: Andrew Morton --- drivers/md/dm-ioctl.c | 16 +++++++++++++--- drivers/md/dm.c | 10 ++-------- drivers/md/dm.h | 2 +- 3 files changed, 16 insertions(+), 12 deletions(-) diff -puN drivers/md/dm.c~dm-tidy-mdptr drivers/md/dm.c --- devel/drivers/md/dm.c~dm-tidy-mdptr 2006-03-12 16:53:42.000000000 -0800 +++ devel-akpm/drivers/md/dm.c 2006-03-12 16:53:42.000000000 -0800 @@ -985,15 +985,9 @@ struct mapped_device *dm_get_md(dev_t de return md; } -void *dm_get_mdptr(dev_t dev) +void *dm_get_mdptr(struct mapped_device *md) { - struct mapped_device *md; - void *mdptr = NULL; - - md = dm_find_md(dev); - if (md) - mdptr = md->interface_ptr; - return mdptr; + return md->interface_ptr; } void dm_set_mdptr(struct mapped_device *md, void *ptr) diff -puN drivers/md/dm.h~dm-tidy-mdptr drivers/md/dm.h --- devel/drivers/md/dm.h~dm-tidy-mdptr 2006-03-12 16:53:42.000000000 -0800 +++ devel-akpm/drivers/md/dm.h 2006-03-12 16:53:42.000000000 -0800 @@ -47,7 +47,7 @@ struct mapped_device; int dm_create(struct mapped_device **md); int dm_create_with_minor(unsigned int minor, struct mapped_device **md); void dm_set_mdptr(struct mapped_device *md, void *ptr); -void *dm_get_mdptr(dev_t dev); +void *dm_get_mdptr(struct mapped_device *md); struct mapped_device *dm_get_md(dev_t dev); /* diff -puN drivers/md/dm-ioctl.c~dm-tidy-mdptr drivers/md/dm-ioctl.c --- devel/drivers/md/dm-ioctl.c~dm-tidy-mdptr 2006-03-12 16:53:42.000000000 -0800 +++ devel-akpm/drivers/md/dm-ioctl.c 2006-03-12 16:53:42.000000000 -0800 @@ -600,12 +600,22 @@ static int dev_create(struct dm_ioctl *p */ static struct hash_cell *__find_device_hash_cell(struct dm_ioctl *param) { + struct mapped_device *md; + void *mdptr = NULL; + if (*param->uuid) return __get_uuid_cell(param->uuid); - else if (*param->name) + + if (*param->name) return __get_name_cell(param->name); - else - return dm_get_mdptr(huge_decode_dev(param->dev)); + + md = dm_get_md(huge_decode_dev(param->dev)); + if (md) { + mdptr = dm_get_mdptr(md); + dm_put(md); + } + + return mdptr; } static struct mapped_device *find_device(struct dm_ioctl *param) _