Commit e1654f41 authored by Luis Chamberlain's avatar Luis Chamberlain Committed by Jens Axboe

nbd: add error handling support for add_disk()

We never checked for errors on add_disk() as this function
returned void. Now that this is fixed, use the shiny new
error handling.
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarHannes Reinecke <hare@suse.de>
Signed-off-by: default avatarLuis Chamberlain <mcgrof@kernel.org>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 905705f0
...@@ -1762,7 +1762,9 @@ static struct nbd_device *nbd_dev_add(int index, unsigned int refs) ...@@ -1762,7 +1762,9 @@ static struct nbd_device *nbd_dev_add(int index, unsigned int refs)
disk->fops = &nbd_fops; disk->fops = &nbd_fops;
disk->private_data = nbd; disk->private_data = nbd;
sprintf(disk->disk_name, "nbd%d", index); sprintf(disk->disk_name, "nbd%d", index);
add_disk(disk); err = add_disk(disk);
if (err)
goto out_err_disk;
/* /*
* Now publish the device. * Now publish the device.
...@@ -1771,6 +1773,8 @@ static struct nbd_device *nbd_dev_add(int index, unsigned int refs) ...@@ -1771,6 +1773,8 @@ static struct nbd_device *nbd_dev_add(int index, unsigned int refs)
nbd_total_devices++; nbd_total_devices++;
return nbd; return nbd;
out_err_disk:
blk_cleanup_disk(disk);
out_free_idr: out_free_idr:
mutex_lock(&nbd_index_mutex); mutex_lock(&nbd_index_mutex);
idr_remove(&nbd_index_idr, index); idr_remove(&nbd_index_idr, index);
......
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