Commit 59a2f3f0 authored by Chengguang Xu's avatar Chengguang Xu Committed by Jens Axboe

nvme: fix potential memory leak in option parsing

When specifying same string type option several times,
current option parsing may cause memory leak. Hence,
call kfree for previous one in this case.
Signed-off-by: default avatarChengguang Xu <cgxu519@gmx.com>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarSagi Grimberg <sagi@grimberg.me>
Signed-off-by: default avatarKeith Busch <keith.busch@intel.com>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent f53823c1
...@@ -668,6 +668,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts, ...@@ -668,6 +668,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts,
ret = -ENOMEM; ret = -ENOMEM;
goto out; goto out;
} }
kfree(opts->transport);
opts->transport = p; opts->transport = p;
break; break;
case NVMF_OPT_NQN: case NVMF_OPT_NQN:
...@@ -676,6 +677,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts, ...@@ -676,6 +677,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts,
ret = -ENOMEM; ret = -ENOMEM;
goto out; goto out;
} }
kfree(opts->subsysnqn);
opts->subsysnqn = p; opts->subsysnqn = p;
nqnlen = strlen(opts->subsysnqn); nqnlen = strlen(opts->subsysnqn);
if (nqnlen >= NVMF_NQN_SIZE) { if (nqnlen >= NVMF_NQN_SIZE) {
...@@ -698,6 +700,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts, ...@@ -698,6 +700,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts,
ret = -ENOMEM; ret = -ENOMEM;
goto out; goto out;
} }
kfree(opts->traddr);
opts->traddr = p; opts->traddr = p;
break; break;
case NVMF_OPT_TRSVCID: case NVMF_OPT_TRSVCID:
...@@ -706,6 +709,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts, ...@@ -706,6 +709,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts,
ret = -ENOMEM; ret = -ENOMEM;
goto out; goto out;
} }
kfree(opts->trsvcid);
opts->trsvcid = p; opts->trsvcid = p;
break; break;
case NVMF_OPT_QUEUE_SIZE: case NVMF_OPT_QUEUE_SIZE:
...@@ -792,6 +796,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts, ...@@ -792,6 +796,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts,
ret = -EINVAL; ret = -EINVAL;
goto out; goto out;
} }
nvmf_host_put(opts->host);
opts->host = nvmf_host_add(p); opts->host = nvmf_host_add(p);
kfree(p); kfree(p);
if (!opts->host) { if (!opts->host) {
...@@ -817,6 +822,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts, ...@@ -817,6 +822,7 @@ static int nvmf_parse_options(struct nvmf_ctrl_options *opts,
ret = -ENOMEM; ret = -ENOMEM;
goto out; goto out;
} }
kfree(opts->host_traddr);
opts->host_traddr = p; opts->host_traddr = p;
break; break;
case NVMF_OPT_HOST_ID: case NVMF_OPT_HOST_ID:
......
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