Commit 27cc2594 authored by Alex Elder's avatar Alex Elder

rbd: simplify error handling in rbd_add()

If a couple pointers are initialized to NULL then a single
"out_nomem" label can be used for all of the memory allocation
failure cases in rbd_add().

Also, get rid of the "irc" local variable there.  There is no
real need for "rc" to be type ssize_t, and it can be used in
the spot "irc" was.
Signed-off-by: default avatarAlex Elder <elder@dreamhost.com>
Signed-off-by: default avatarSage Weil <sage@newdream.net>
parent 60571c7d
...@@ -2224,28 +2224,24 @@ static ssize_t rbd_add(struct bus_type *bus, ...@@ -2224,28 +2224,24 @@ static ssize_t rbd_add(struct bus_type *bus,
const char *buf, const char *buf,
size_t count) size_t count)
{ {
struct ceph_osd_client *osdc;
struct rbd_device *rbd_dev; struct rbd_device *rbd_dev;
ssize_t rc = -ENOMEM; char *mon_dev_name = NULL;
int irc; char *options = NULL;
char *mon_dev_name; struct ceph_osd_client *osdc;
char *options; int rc = -ENOMEM;
if (!try_module_get(THIS_MODULE)) if (!try_module_get(THIS_MODULE))
return -ENODEV; return -ENODEV;
rbd_dev = kzalloc(sizeof(*rbd_dev), GFP_KERNEL);
if (!rbd_dev)
goto err_nomem;
mon_dev_name = kmalloc(count, GFP_KERNEL); mon_dev_name = kmalloc(count, GFP_KERNEL);
if (!mon_dev_name) if (!mon_dev_name)
goto err_out_mod; goto err_nomem;
options = kmalloc(count, GFP_KERNEL); options = kmalloc(count, GFP_KERNEL);
if (!options) if (!options)
goto err_mon_dev; goto err_nomem;
/* new rbd_device object */
rbd_dev = kzalloc(sizeof(*rbd_dev), GFP_KERNEL);
if (!rbd_dev)
goto err_out_opt;
/* static rbd_device initialization */ /* static rbd_device initialization */
spin_lock_init(&rbd_dev->lock); spin_lock_init(&rbd_dev->lock);
...@@ -2294,12 +2290,10 @@ static ssize_t rbd_add(struct bus_type *bus, ...@@ -2294,12 +2290,10 @@ static ssize_t rbd_add(struct bus_type *bus,
rbd_dev->poolid = rc; rbd_dev->poolid = rc;
/* register our block device */ /* register our block device */
irc = register_blkdev(0, rbd_dev->name); rc = register_blkdev(0, rbd_dev->name);
if (irc < 0) { if (rc < 0)
rc = irc;
goto err_out_client; goto err_out_client;
} rbd_dev->major = rc;
rbd_dev->major = irc;
rc = rbd_bus_add_dev(rbd_dev); rc = rbd_bus_add_dev(rbd_dev);
if (rc) if (rc)
...@@ -2332,15 +2326,15 @@ static ssize_t rbd_add(struct bus_type *bus, ...@@ -2332,15 +2326,15 @@ static ssize_t rbd_add(struct bus_type *bus,
rbd_put_client(rbd_dev); rbd_put_client(rbd_dev);
err_put_id: err_put_id:
rbd_id_put(rbd_dev); rbd_id_put(rbd_dev);
kfree(rbd_dev); err_nomem:
err_out_opt:
kfree(options); kfree(options);
err_mon_dev:
kfree(mon_dev_name); kfree(mon_dev_name);
err_out_mod: kfree(rbd_dev);
dout("Error adding device %s\n", buf); dout("Error adding device %s\n", buf);
module_put(THIS_MODULE); module_put(THIS_MODULE);
return rc;
return (ssize_t) rc;
} }
static struct rbd_device *__rbd_get_dev(unsigned long id) static struct rbd_device *__rbd_get_dev(unsigned long id)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment