Commit 4e357761 authored by Al Viro's avatar Al Viro Committed by Anna Schumaker

nfs4: fold nfs_do_root_mount/nfs_follow_remote_path

Reviewed-by: default avatarDavid Howells <dhowells@redhat.com>
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
Signed-off-by: default avatarAnna Schumaker <Anna.Schumaker@Netapp.com>
parent 6654f8e2
...@@ -101,37 +101,6 @@ nfs4_remote_mount(struct file_system_type *fs_type, int flags, ...@@ -101,37 +101,6 @@ nfs4_remote_mount(struct file_system_type *fs_type, int flags,
return nfs_fs_mount_common(flags, dev_name, info, &nfs_v4); return nfs_fs_mount_common(flags, dev_name, info, &nfs_v4);
} }
static struct vfsmount *nfs_do_root_mount(struct nfs_server *server, int flags,
struct nfs_mount_info *info,
const char *hostname)
{
struct vfsmount *root_mnt;
char *root_devname;
size_t len;
if (IS_ERR(server))
return ERR_CAST(server);
len = strlen(hostname) + 5;
root_devname = kmalloc(len, GFP_KERNEL);
if (root_devname == NULL) {
nfs_free_server(server);
return ERR_PTR(-ENOMEM);
}
/* Does hostname needs to be enclosed in brackets? */
if (strchr(hostname, ':'))
snprintf(root_devname, len, "[%s]:/", hostname);
else
snprintf(root_devname, len, "%s:/", hostname);
info->server = server;
root_mnt = vfs_kern_mount(&nfs4_remote_fs_type, flags, root_devname, info);
if (info->server)
nfs_free_server(info->server);
info->server = NULL;
kfree(root_devname);
return root_mnt;
}
struct nfs_referral_count { struct nfs_referral_count {
struct list_head list; struct list_head list;
const struct task_struct *task; const struct task_struct *task;
...@@ -198,11 +167,38 @@ static void nfs_referral_loop_unprotect(void) ...@@ -198,11 +167,38 @@ static void nfs_referral_loop_unprotect(void)
kfree(p); kfree(p);
} }
static struct dentry *nfs_follow_remote_path(struct vfsmount *root_mnt, static struct dentry *do_nfs4_mount(struct nfs_server *server, int flags,
const char *export_path) struct nfs_mount_info *info,
const char *hostname,
const char *export_path)
{ {
struct vfsmount *root_mnt;
struct dentry *dentry; struct dentry *dentry;
char *root_devname;
int err; int err;
size_t len;
if (IS_ERR(server))
return ERR_CAST(server);
len = strlen(hostname) + 5;
root_devname = kmalloc(len, GFP_KERNEL);
if (root_devname == NULL) {
nfs_free_server(server);
return ERR_PTR(-ENOMEM);
}
/* Does hostname needs to be enclosed in brackets? */
if (strchr(hostname, ':'))
snprintf(root_devname, len, "[%s]:/", hostname);
else
snprintf(root_devname, len, "%s:/", hostname);
info->server = server;
root_mnt = vfs_kern_mount(&nfs4_remote_fs_type, flags, root_devname, info);
if (info->server)
nfs_free_server(info->server);
info->server = NULL;
kfree(root_devname);
if (IS_ERR(root_mnt)) if (IS_ERR(root_mnt))
return ERR_CAST(root_mnt); return ERR_CAST(root_mnt);
...@@ -223,22 +219,17 @@ struct dentry *nfs4_try_mount(int flags, const char *dev_name, ...@@ -223,22 +219,17 @@ struct dentry *nfs4_try_mount(int flags, const char *dev_name,
struct nfs_mount_info *mount_info, struct nfs_mount_info *mount_info,
struct nfs_subversion *nfs_mod) struct nfs_subversion *nfs_mod)
{ {
char *export_path;
struct vfsmount *root_mnt;
struct dentry *res;
struct nfs_parsed_mount_data *data = mount_info->parsed; struct nfs_parsed_mount_data *data = mount_info->parsed;
struct dentry *res;
mount_info->set_security = nfs_set_sb_security; mount_info->set_security = nfs_set_sb_security;
dfprintk(MOUNT, "--> nfs4_try_mount()\n"); dfprintk(MOUNT, "--> nfs4_try_mount()\n");
export_path = data->nfs_server.export_path; res = do_nfs4_mount(nfs4_create_server(mount_info, &nfs_v4),
root_mnt = nfs_do_root_mount( flags, mount_info,
nfs4_create_server(mount_info, &nfs_v4), data->nfs_server.hostname,
flags, mount_info, data->nfs_server.export_path);
data->nfs_server.hostname);
res = nfs_follow_remote_path(root_mnt, export_path);
dfprintk(MOUNT, "<-- nfs4_try_mount() = %d%s\n", dfprintk(MOUNT, "<-- nfs4_try_mount() = %d%s\n",
PTR_ERR_OR_ZERO(res), PTR_ERR_OR_ZERO(res),
...@@ -258,8 +249,6 @@ static struct dentry *nfs4_referral_mount(struct file_system_type *fs_type, ...@@ -258,8 +249,6 @@ static struct dentry *nfs4_referral_mount(struct file_system_type *fs_type,
.set_security = nfs_clone_sb_security, .set_security = nfs_clone_sb_security,
.cloned = data, .cloned = data,
}; };
char *export_path;
struct vfsmount *root_mnt;
struct dentry *res; struct dentry *res;
dprintk("--> nfs4_referral_mount()\n"); dprintk("--> nfs4_referral_mount()\n");
...@@ -268,13 +257,10 @@ static struct dentry *nfs4_referral_mount(struct file_system_type *fs_type, ...@@ -268,13 +257,10 @@ static struct dentry *nfs4_referral_mount(struct file_system_type *fs_type,
if (!mount_info.mntfh) if (!mount_info.mntfh)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
export_path = data->mnt_path; res = do_nfs4_mount(nfs4_create_referral_server(mount_info.cloned,
root_mnt = nfs_do_root_mount( mount_info.mntfh),
nfs4_create_referral_server(mount_info.cloned, flags, &mount_info, data->hostname, data->mnt_path);
mount_info.mntfh),
flags, &mount_info, data->hostname);
res = nfs_follow_remote_path(root_mnt, export_path);
dprintk("<-- nfs4_referral_mount() = %d%s\n", dprintk("<-- nfs4_referral_mount() = %d%s\n",
PTR_ERR_OR_ZERO(res), PTR_ERR_OR_ZERO(res),
IS_ERR(res) ? " [error]" : ""); IS_ERR(res) ? " [error]" : "");
......
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