fs/exofs: fix potential memory leak in mount option parsing
[ Upstream commit 515f1867ad
]
There are some cases can cause memory leak when parsing
option 'osdname'.
Signed-off-by: Chengguang Xu <cgxu519@gmx.com>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
bff410ea7e
commit
a088fde602
@ -100,6 +100,7 @@ static int parse_options(char *options, struct exofs_mountopt *opts)
|
|||||||
token = match_token(p, tokens, args);
|
token = match_token(p, tokens, args);
|
||||||
switch (token) {
|
switch (token) {
|
||||||
case Opt_name:
|
case Opt_name:
|
||||||
|
kfree(opts->dev_name);
|
||||||
opts->dev_name = match_strdup(&args[0]);
|
opts->dev_name = match_strdup(&args[0]);
|
||||||
if (unlikely(!opts->dev_name)) {
|
if (unlikely(!opts->dev_name)) {
|
||||||
EXOFS_ERR("Error allocating dev_name");
|
EXOFS_ERR("Error allocating dev_name");
|
||||||
@ -863,8 +864,10 @@ static struct dentry *exofs_mount(struct file_system_type *type,
|
|||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ret = parse_options(data, &opts);
|
ret = parse_options(data, &opts);
|
||||||
if (ret)
|
if (ret) {
|
||||||
|
kfree(opts.dev_name);
|
||||||
return ERR_PTR(ret);
|
return ERR_PTR(ret);
|
||||||
|
}
|
||||||
|
|
||||||
if (!opts.dev_name)
|
if (!opts.dev_name)
|
||||||
opts.dev_name = dev_name;
|
opts.dev_name = dev_name;
|
||||||
|
Reference in New Issue
Block a user