提交 4fe9e963 编写于 作者: S Sachin Prabhu 提交者: Steve French

Cleanup handling of NULL value passed for a mount option

Allow blank user= and ip= mount option. Also clean up redundant
checks for NULL values since the token parser will not actually
match mount options with NULL values unless explicitly specified.
Signed-off-by: NSachin Prabhu <sprabhu@redhat.com>
Reported-by: NChris Clayton <chris2553@googlemail.com>
Acked-by: NJeff Layton <jlayton@samba.org>
Tested-by: NChris Clayton <chris2553@googlemail.com>
Signed-off-by: NSteve French <sfrench@us.ibm.com>
上级 f68e556e
...@@ -109,6 +109,8 @@ enum { ...@@ -109,6 +109,8 @@ enum {
/* Options which could be blank */ /* Options which could be blank */
Opt_blank_pass, Opt_blank_pass,
Opt_blank_user,
Opt_blank_ip,
Opt_err Opt_err
}; };
...@@ -183,11 +185,15 @@ static const match_table_t cifs_mount_option_tokens = { ...@@ -183,11 +185,15 @@ static const match_table_t cifs_mount_option_tokens = {
{ Opt_wsize, "wsize=%s" }, { Opt_wsize, "wsize=%s" },
{ Opt_actimeo, "actimeo=%s" }, { Opt_actimeo, "actimeo=%s" },
{ Opt_blank_user, "user=" },
{ Opt_blank_user, "username=" },
{ Opt_user, "user=%s" }, { Opt_user, "user=%s" },
{ Opt_user, "username=%s" }, { Opt_user, "username=%s" },
{ Opt_blank_pass, "pass=" }, { Opt_blank_pass, "pass=" },
{ Opt_pass, "pass=%s" }, { Opt_pass, "pass=%s" },
{ Opt_pass, "password=%s" }, { Opt_pass, "password=%s" },
{ Opt_blank_ip, "ip=" },
{ Opt_blank_ip, "addr=" },
{ Opt_ip, "ip=%s" }, { Opt_ip, "ip=%s" },
{ Opt_ip, "addr=%s" }, { Opt_ip, "addr=%s" },
{ Opt_unc, "unc=%s" }, { Opt_unc, "unc=%s" },
...@@ -1534,15 +1540,17 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1534,15 +1540,17 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
/* String Arguments */ /* String Arguments */
case Opt_blank_user:
/* null user, ie. anonymous authentication */
vol->nullauth = 1;
vol->username = NULL;
break;
case Opt_user: case Opt_user:
string = match_strdup(args); string = match_strdup(args);
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) { if (strnlen(string, MAX_USERNAME_SIZE) >
/* null user, ie. anonymous authentication */
vol->nullauth = 1;
} else if (strnlen(string, MAX_USERNAME_SIZE) >
MAX_USERNAME_SIZE) { MAX_USERNAME_SIZE) {
printk(KERN_WARNING "CIFS: username too long\n"); printk(KERN_WARNING "CIFS: username too long\n");
goto cifs_parse_mount_err; goto cifs_parse_mount_err;
...@@ -1611,14 +1619,15 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1611,14 +1619,15 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
} }
vol->password[j] = '\0'; vol->password[j] = '\0';
break; break;
case Opt_blank_ip:
vol->UNCip = NULL;
break;
case Opt_ip: case Opt_ip:
string = match_strdup(args); string = match_strdup(args);
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) { if (strnlen(string, INET6_ADDRSTRLEN) >
vol->UNCip = NULL;
} else if (strnlen(string, INET6_ADDRSTRLEN) >
INET6_ADDRSTRLEN) { INET6_ADDRSTRLEN) {
printk(KERN_WARNING "CIFS: ip address " printk(KERN_WARNING "CIFS: ip address "
"too long\n"); "too long\n");
...@@ -1636,12 +1645,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1636,12 +1645,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) {
printk(KERN_WARNING "CIFS: invalid path to "
"network resource\n");
goto cifs_parse_mount_err;
}
temp_len = strnlen(string, 300); temp_len = strnlen(string, 300);
if (temp_len == 300) { if (temp_len == 300) {
printk(KERN_WARNING "CIFS: UNC name too long\n"); printk(KERN_WARNING "CIFS: UNC name too long\n");
...@@ -1670,11 +1673,7 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1670,11 +1673,7 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) { if (strnlen(string, 256) == 256) {
printk(KERN_WARNING "CIFS: invalid domain"
" name\n");
goto cifs_parse_mount_err;
} else if (strnlen(string, 256) == 256) {
printk(KERN_WARNING "CIFS: domain name too" printk(KERN_WARNING "CIFS: domain name too"
" long\n"); " long\n");
goto cifs_parse_mount_err; goto cifs_parse_mount_err;
...@@ -1693,11 +1692,7 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1693,11 +1692,7 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) { if (!cifs_convert_address(
printk(KERN_WARNING "CIFS: srcaddr value not"
" specified\n");
goto cifs_parse_mount_err;
} else if (!cifs_convert_address(
(struct sockaddr *)&vol->srcaddr, (struct sockaddr *)&vol->srcaddr,
string, strlen(string))) { string, strlen(string))) {
printk(KERN_WARNING "CIFS: Could not parse" printk(KERN_WARNING "CIFS: Could not parse"
...@@ -1710,11 +1705,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1710,11 +1705,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) {
printk(KERN_WARNING "CIFS: Invalid path"
" prefix\n");
goto cifs_parse_mount_err;
}
temp_len = strnlen(string, 1024); temp_len = strnlen(string, 1024);
if (string[0] != '/') if (string[0] != '/')
temp_len++; /* missing leading slash */ temp_len++; /* missing leading slash */
...@@ -1742,11 +1732,7 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1742,11 +1732,7 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) { if (strnlen(string, 1024) >= 65) {
printk(KERN_WARNING "CIFS: Invalid iocharset"
" specified\n");
goto cifs_parse_mount_err;
} else if (strnlen(string, 1024) >= 65) {
printk(KERN_WARNING "CIFS: iocharset name " printk(KERN_WARNING "CIFS: iocharset name "
"too long.\n"); "too long.\n");
goto cifs_parse_mount_err; goto cifs_parse_mount_err;
...@@ -1771,11 +1757,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1771,11 +1757,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) {
printk(KERN_WARNING "CIFS: No socket option"
" specified\n");
goto cifs_parse_mount_err;
}
if (strnicmp(string, "TCP_NODELAY", 11) == 0) if (strnicmp(string, "TCP_NODELAY", 11) == 0)
vol->sockopt_tcp_nodelay = 1; vol->sockopt_tcp_nodelay = 1;
break; break;
...@@ -1784,12 +1765,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1784,12 +1765,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) {
printk(KERN_WARNING "CIFS: Invalid (empty)"
" netbiosname\n");
break;
}
memset(vol->source_rfc1001_name, 0x20, memset(vol->source_rfc1001_name, 0x20,
RFC1001_NAME_LEN); RFC1001_NAME_LEN);
/* /*
...@@ -1817,11 +1792,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1817,11 +1792,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) {
printk(KERN_WARNING "CIFS: Empty server"
" netbiosname specified\n");
break;
}
/* last byte, type, is 0x20 for servr type */ /* last byte, type, is 0x20 for servr type */
memset(vol->target_rfc1001_name, 0x20, memset(vol->target_rfc1001_name, 0x20,
RFC1001_NAME_LEN_WITH_NULL); RFC1001_NAME_LEN_WITH_NULL);
...@@ -1848,12 +1818,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1848,12 +1818,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) {
cERROR(1, "no protocol version specified"
" after vers= mount option");
goto cifs_parse_mount_err;
}
if (strnicmp(string, "cifs", 4) == 0 || if (strnicmp(string, "cifs", 4) == 0 ||
strnicmp(string, "1", 1) == 0) { strnicmp(string, "1", 1) == 0) {
/* This is the default */ /* This is the default */
...@@ -1868,12 +1832,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, ...@@ -1868,12 +1832,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,
if (string == NULL) if (string == NULL)
goto out_nomem; goto out_nomem;
if (!*string) {
printk(KERN_WARNING "CIFS: no security flavor"
" specified\n");
break;
}
if (cifs_parse_security_flavors(string, vol) != 0) if (cifs_parse_security_flavors(string, vol) != 0)
goto cifs_parse_mount_err; goto cifs_parse_mount_err;
break; break;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册