diff options
author | Jeff Layton <jlayton@samba.org> | 2010-05-02 06:32:34 -0400 |
---|---|---|
committer | Jeff Layton <jlayton@samba.org> | 2010-05-02 06:32:34 -0400 |
commit | e5d3ceb9958437ef50510a578b0274615a37bcf7 (patch) | |
tree | 0a3cfa0c08a80218e0932b78f9d09336f99d5e1c | |
parent | 373146ceda319fb7585439d74f216b8a94b9525b (diff) | |
download | cifs-utils-e5d3ceb9958437ef50510a578b0274615a37bcf7.tar.gz cifs-utils-e5d3ceb9958437ef50510a578b0274615a37bcf7.tar.bz2 cifs-utils-e5d3ceb9958437ef50510a578b0274615a37bcf7.zip |
mount.cifs: strip leading delimiter off of prefixpath option
...the kernel doesn't expect to see it and it causes a regression
when mounting some UNCs.
Reported-by: Ales Zelinka <azelinka@redhat.com>
Signed-off-by: Jeff Layton <jlayton@samba.org>
-rw-r--r-- | mount.cifs.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/mount.cifs.c b/mount.cifs.c index 1040e8b..c4eb59a 100644 --- a/mount.cifs.c +++ b/mount.cifs.c @@ -1169,6 +1169,9 @@ static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info } prepath = share + sharelen; + if (*prepath != '\0') + prepath++; + prepathlen = strlen(prepath); if (prepathlen + 1 > sizeof(parsed_info->prefix)) { @@ -1669,6 +1672,7 @@ int main(int argc, char **argv) goto mount_exit; } + /* lengths of different strings + slashes + trailing \0 */ dev_len = strnlen(parsed_info->host, sizeof(parsed_info->host)) + strnlen(parsed_info->share, sizeof(parsed_info->share)) + strnlen(parsed_info->prefix, sizeof(parsed_info->prefix)) + @@ -1684,6 +1688,7 @@ int main(int argc, char **argv) strlcat(dev_name, parsed_info->host, dev_len); strlcat(dev_name, "/", dev_len); strlcat(dev_name, parsed_info->share, dev_len); + strlcat(dev_name, "/", dev_len); strlcat(dev_name, parsed_info->prefix, dev_len); currentaddress = parsed_info->addrlist; |