mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-01 02:36:02 +00:00
block: Fix a memory leak in bdev_open_by_dev()
If we early exit here, 'handle' needs to be freed, or some memory leaks.
Fixes: ed5cc702d3
("block: Add config option to not allow writing to mounted devices")
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Link: https://lore.kernel.org/r/8eaec334781e695810aaa383b55de00ca4ab1352.1703439383.git.christophe.jaillet@wanadoo.fr
Reviewed-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Jens Axboe <axboe@kernel.dk>
Signed-off-by: Christian Brauner <brauner@kernel.org>
This commit is contained in:
parent
63513f8574
commit
8ff363ade3
@ -828,8 +828,10 @@ struct bdev_handle *bdev_open_by_dev(dev_t dev, blk_mode_t mode, void *holder,
|
|||||||
goto free_handle;
|
goto free_handle;
|
||||||
|
|
||||||
/* Blocking writes requires exclusive opener */
|
/* Blocking writes requires exclusive opener */
|
||||||
if (mode & BLK_OPEN_RESTRICT_WRITES && !holder)
|
if (mode & BLK_OPEN_RESTRICT_WRITES && !holder) {
|
||||||
return ERR_PTR(-EINVAL);
|
ret = -EINVAL;
|
||||||
|
goto free_handle;
|
||||||
|
}
|
||||||
|
|
||||||
bdev = blkdev_get_no_open(dev);
|
bdev = blkdev_get_no_open(dev);
|
||||||
if (!bdev) {
|
if (!bdev) {
|
||||||
|
Loading…
Reference in New Issue
Block a user