Commit 3b01d7ea authored by Dinghao Liu's avatar Dinghao Liu Committed by Martin K. Petersen

scsi: scsi_debug: Fix memleak in scsi_debug_init()

When sdeb_zbc_model does not match BLK_ZONED_NONE, BLK_ZONED_HA or
BLK_ZONED_HM, we should free sdebug_q_arr to prevent memleak. Also there is
no need to execute sdebug_erase_store() on failure of sdeb_zbc_model_str().

Link: https://lore.kernel.org/r/20201226061503.20050-1-dinghao.liu@zju.edu.cnAcked-by: default avatarDouglas Gilbert <dgilbert@interlog.com>
Signed-off-by: default avatarDinghao Liu <dinghao.liu@zju.edu.cn>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 39718fe7
...@@ -6740,7 +6740,7 @@ static int __init scsi_debug_init(void) ...@@ -6740,7 +6740,7 @@ static int __init scsi_debug_init(void)
k = sdeb_zbc_model_str(sdeb_zbc_model_s); k = sdeb_zbc_model_str(sdeb_zbc_model_s);
if (k < 0) { if (k < 0) {
ret = k; ret = k;
goto free_vm; goto free_q_arr;
} }
sdeb_zbc_model = k; sdeb_zbc_model = k;
switch (sdeb_zbc_model) { switch (sdeb_zbc_model) {
...@@ -6753,7 +6753,8 @@ static int __init scsi_debug_init(void) ...@@ -6753,7 +6753,8 @@ static int __init scsi_debug_init(void)
break; break;
default: default:
pr_err("Invalid ZBC model\n"); pr_err("Invalid ZBC model\n");
return -EINVAL; ret = -EINVAL;
goto free_q_arr;
} }
} }
if (sdeb_zbc_model != BLK_ZONED_NONE) { if (sdeb_zbc_model != BLK_ZONED_NONE) {
......
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