提交 0f308a31 编写于 作者: A Alex Elder

rbd: call rbd_init_disk() sooner

Call rbd_init_disk() from rbd_add() as soon as we have the major
device number for the mapping.
Signed-off-by: NAlex Elder <elder@inktank.com>
Reviewed-by: NJosh Durgin <josh.durgin@inktank.com>
上级 85ae8926
...@@ -2623,10 +2623,16 @@ static ssize_t rbd_add(struct bus_type *bus, ...@@ -2623,10 +2623,16 @@ static ssize_t rbd_add(struct bus_type *bus,
goto err_out_id; goto err_out_id;
rbd_dev->major = rc; rbd_dev->major = rc;
rc = rbd_bus_add_dev(rbd_dev); /* Set up the blkdev mapping. */
rc = rbd_init_disk(rbd_dev);
if (rc) if (rc)
goto err_out_blkdev; goto err_out_blkdev;
rc = rbd_bus_add_dev(rbd_dev);
if (rc)
goto err_out_disk;
/* /*
* At this point cleanup in the event of an error is the job * At this point cleanup in the event of an error is the job
* of the sysfs code (initiated by rbd_bus_del_dev()). * of the sysfs code (initiated by rbd_bus_del_dev()).
...@@ -2638,12 +2644,6 @@ static ssize_t rbd_add(struct bus_type *bus, ...@@ -2638,12 +2644,6 @@ static ssize_t rbd_add(struct bus_type *bus,
if (rc) if (rc)
goto err_out_bus; goto err_out_bus;
/* Set up the blkdev mapping. */
rc = rbd_init_disk(rbd_dev);
if (rc)
goto err_out_bus;
/* Everything's ready. Announce the disk to the world. */ /* Everything's ready. Announce the disk to the world. */
set_capacity(rbd_dev->disk, rbd_dev->mapping.size / SECTOR_SIZE); set_capacity(rbd_dev->disk, rbd_dev->mapping.size / SECTOR_SIZE);
...@@ -2664,6 +2664,8 @@ static ssize_t rbd_add(struct bus_type *bus, ...@@ -2664,6 +2664,8 @@ static ssize_t rbd_add(struct bus_type *bus,
kfree(options); kfree(options);
return rc; return rc;
err_out_disk:
rbd_free_disk(rbd_dev);
err_out_blkdev: err_out_blkdev:
unregister_blkdev(rbd_dev->major, rbd_dev->name); unregister_blkdev(rbd_dev->major, rbd_dev->name);
err_out_id: err_out_id:
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册