Commit 11fc2ee5 authored by Jiang Liu's avatar Jiang Liu Committed by Greg Kroah-Hartman

zram: destroy all devices on error recovery path in zram_init()

commit 39a9b8ac upstream.

On error recovery path of zram_init(), it leaks the zram device object
causing the failure. So change create_device() to free allocated
resources on error path.
Signed-off-by: default avatarJiang Liu <jiang.liu@huawei.com>
Acked-by: default avatarMinchan Kim <minchan@kernel.org>
Acked-by: default avatarJerome Marchand <jmarchan@redhat.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
[bwh: Backported to 3.2: adjust context]
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
Cc: Jianguo Wu <wujianguo@huawei.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 5e84bf6d
...@@ -703,7 +703,7 @@ static const struct block_device_operations zram_devops = { ...@@ -703,7 +703,7 @@ static const struct block_device_operations zram_devops = {
static int create_device(struct zram *zram, int device_id) static int create_device(struct zram *zram, int device_id)
{ {
int ret = 0; int ret = -ENOMEM;
init_rwsem(&zram->lock); init_rwsem(&zram->lock);
init_rwsem(&zram->init_lock); init_rwsem(&zram->init_lock);
...@@ -713,7 +713,6 @@ static int create_device(struct zram *zram, int device_id) ...@@ -713,7 +713,6 @@ static int create_device(struct zram *zram, int device_id)
if (!zram->queue) { if (!zram->queue) {
pr_err("Error allocating disk queue for device %d\n", pr_err("Error allocating disk queue for device %d\n",
device_id); device_id);
ret = -ENOMEM;
goto out; goto out;
} }
...@@ -723,11 +722,9 @@ static int create_device(struct zram *zram, int device_id) ...@@ -723,11 +722,9 @@ static int create_device(struct zram *zram, int device_id)
/* gendisk structure */ /* gendisk structure */
zram->disk = alloc_disk(1); zram->disk = alloc_disk(1);
if (!zram->disk) { if (!zram->disk) {
blk_cleanup_queue(zram->queue);
pr_warning("Error allocating disk structure for device %d\n", pr_warning("Error allocating disk structure for device %d\n",
device_id); device_id);
ret = -ENOMEM; goto out_free_queue;
goto out;
} }
zram->disk->major = zram_major; zram->disk->major = zram_major;
...@@ -756,11 +753,17 @@ static int create_device(struct zram *zram, int device_id) ...@@ -756,11 +753,17 @@ static int create_device(struct zram *zram, int device_id)
&zram_disk_attr_group); &zram_disk_attr_group);
if (ret < 0) { if (ret < 0) {
pr_warning("Error creating sysfs group"); pr_warning("Error creating sysfs group");
goto out; goto out_free_disk;
} }
zram->init_done = 0; zram->init_done = 0;
return 0;
out_free_disk:
del_gendisk(zram->disk);
put_disk(zram->disk);
out_free_queue:
blk_cleanup_queue(zram->queue);
out: out:
return ret; return ret;
} }
......
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