rnbd: 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. Acked-by: Jack Wang <jinpu.wang@ionos.com> Signed-off-by: Luis Chamberlain <mcgrof@kernel.org> Link: https://lore.kernel.org/r/20211015233028.2167651-9-mcgrof@kernel.org Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
66638f163a
commit
2e9e31bea0
@ -1384,8 +1384,10 @@ static void setup_request_queue(struct rnbd_clt_dev *dev)
|
||||
blk_queue_write_cache(dev->queue, dev->wc, dev->fua);
|
||||
}
|
||||
|
||||
static void rnbd_clt_setup_gen_disk(struct rnbd_clt_dev *dev, int idx)
|
||||
static int rnbd_clt_setup_gen_disk(struct rnbd_clt_dev *dev, int idx)
|
||||
{
|
||||
int err;
|
||||
|
||||
dev->gd->major = rnbd_client_major;
|
||||
dev->gd->first_minor = idx << RNBD_PART_BITS;
|
||||
dev->gd->minors = 1 << RNBD_PART_BITS;
|
||||
@ -1410,7 +1412,11 @@ static void rnbd_clt_setup_gen_disk(struct rnbd_clt_dev *dev, int idx)
|
||||
|
||||
if (!dev->rotational)
|
||||
blk_queue_flag_set(QUEUE_FLAG_NONROT, dev->queue);
|
||||
add_disk(dev->gd);
|
||||
err = add_disk(dev->gd);
|
||||
if (err)
|
||||
blk_cleanup_disk(dev->gd);
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
static int rnbd_client_setup_device(struct rnbd_clt_dev *dev)
|
||||
@ -1426,8 +1432,7 @@ static int rnbd_client_setup_device(struct rnbd_clt_dev *dev)
|
||||
rnbd_init_mq_hw_queues(dev);
|
||||
|
||||
setup_request_queue(dev);
|
||||
rnbd_clt_setup_gen_disk(dev, idx);
|
||||
return 0;
|
||||
return rnbd_clt_setup_gen_disk(dev, idx);
|
||||
}
|
||||
|
||||
static struct rnbd_clt_dev *init_dev(struct rnbd_clt_session *sess,
|
||||
|
Loading…
Reference in New Issue
Block a user