Commit 8367224b authored by Jeff Layton's avatar Jeff Layton Committed by Steve French

cifs: fix double-free of "string" in cifs_parse_mount_options

Dan reported the following regression in commit d387a5c5:

    + fs/cifs/connect.c:1903 cifs_parse_mount_options() error: double free of 'string'

That patch has some of the new option parsing code free "string" without
setting the variable to NULL afterward. Since "string" is automatically
freed in an error condition, fix the code to just rely on that instead
of freeing it explicitly.
Reported-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
Signed-off-by: default avatarSteve French <smfrench@gmail.com>
parent 18000985
...@@ -1624,14 +1624,11 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1624,14 +1624,11 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
case Opt_unc: case Opt_unc:
string = vol->UNC; string = vol->UNC;
vol->UNC = match_strdup(args); vol->UNC = match_strdup(args);
if (vol->UNC == NULL) { if (vol->UNC == NULL)
kfree(string);
goto out_nomem; goto out_nomem;
}
convert_delimiter(vol->UNC, '\\'); convert_delimiter(vol->UNC, '\\');
if (vol->UNC[0] != '\\' || vol->UNC[1] != '\\') { if (vol->UNC[0] != '\\' || vol->UNC[1] != '\\') {
kfree(string);
printk(KERN_ERR "CIFS: UNC Path does not " printk(KERN_ERR "CIFS: UNC Path does not "
"begin with // or \\\\\n"); "begin with // or \\\\\n");
goto cifs_parse_mount_err; goto cifs_parse_mount_err;
...@@ -1687,10 +1684,8 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1687,10 +1684,8 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
string = vol->prepath; string = vol->prepath;
vol->prepath = match_strdup(args); vol->prepath = match_strdup(args);
if (vol->prepath == NULL) { if (vol->prepath == NULL)
kfree(string);
goto out_nomem; goto out_nomem;
}
/* Compare old prefixpath= option to new one */ /* Compare old prefixpath= option to new one */
if (!string || strcmp(string, vol->prepath)) if (!string || strcmp(string, vol->prepath))
printk(KERN_WARNING "CIFS: the value of the " printk(KERN_WARNING "CIFS: the value of the "
......
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