mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-04-04 05:24:03 +00:00
NFS: Remove the NFS v4 xdev mount function
I can now share this code with the v2 and v3 code by using the NFS subversion structure. Signed-off-by: Bryan Schumaker <bjschuma@netapp.com> Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
This commit is contained in:
parent
ab7017a3a0
commit
e8f25e6d6d
3 changed files with 10 additions and 58 deletions
|
@ -195,20 +195,7 @@ static struct vfsmount *nfs_do_clone_mount(struct nfs_server *server,
|
||||||
const char *devname,
|
const char *devname,
|
||||||
struct nfs_clone_mount *mountdata)
|
struct nfs_clone_mount *mountdata)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_NFS_V4
|
|
||||||
struct vfsmount *mnt = ERR_PTR(-EINVAL);
|
|
||||||
switch (server->nfs_client->rpc_ops->version) {
|
|
||||||
case 2:
|
|
||||||
case 3:
|
|
||||||
mnt = vfs_kern_mount(&nfs_xdev_fs_type, 0, devname, mountdata);
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
mnt = vfs_kern_mount(&nfs4_xdev_fs_type, 0, devname, mountdata);
|
|
||||||
}
|
|
||||||
return mnt;
|
|
||||||
#else
|
|
||||||
return vfs_kern_mount(&nfs_xdev_fs_type, 0, devname, mountdata);
|
return vfs_kern_mount(&nfs_xdev_fs_type, 0, devname, mountdata);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -14,8 +14,6 @@
|
||||||
|
|
||||||
static struct dentry *nfs4_remote_mount(struct file_system_type *fs_type,
|
static struct dentry *nfs4_remote_mount(struct file_system_type *fs_type,
|
||||||
int flags, const char *dev_name, void *raw_data);
|
int flags, const char *dev_name, void *raw_data);
|
||||||
static struct dentry *nfs4_xdev_mount(struct file_system_type *fs_type,
|
|
||||||
int flags, const char *dev_name, void *raw_data);
|
|
||||||
static struct dentry *nfs4_referral_mount(struct file_system_type *fs_type,
|
static struct dentry *nfs4_referral_mount(struct file_system_type *fs_type,
|
||||||
int flags, const char *dev_name, void *raw_data);
|
int flags, const char *dev_name, void *raw_data);
|
||||||
static struct dentry *nfs4_remote_referral_mount(struct file_system_type *fs_type,
|
static struct dentry *nfs4_remote_referral_mount(struct file_system_type *fs_type,
|
||||||
|
@ -37,14 +35,6 @@ static struct file_system_type nfs4_remote_fs_type = {
|
||||||
.fs_flags = FS_RENAME_DOES_D_MOVE|FS_REVAL_DOT|FS_BINARY_MOUNTDATA,
|
.fs_flags = FS_RENAME_DOES_D_MOVE|FS_REVAL_DOT|FS_BINARY_MOUNTDATA,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct file_system_type nfs4_xdev_fs_type = {
|
|
||||||
.owner = THIS_MODULE,
|
|
||||||
.name = "nfs4",
|
|
||||||
.mount = nfs4_xdev_mount,
|
|
||||||
.kill_sb = nfs_kill_super,
|
|
||||||
.fs_flags = FS_RENAME_DOES_D_MOVE|FS_REVAL_DOT|FS_BINARY_MOUNTDATA,
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct file_system_type nfs4_remote_referral_fs_type = {
|
static struct file_system_type nfs4_remote_referral_fs_type = {
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
.name = "nfs4",
|
.name = "nfs4",
|
||||||
|
@ -261,21 +251,6 @@ struct dentry *nfs4_try_mount(int flags, const char *dev_name,
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Clone an NFS4 server record on xdev traversal (FSID-change)
|
|
||||||
*/
|
|
||||||
static struct dentry *
|
|
||||||
nfs4_xdev_mount(struct file_system_type *fs_type, int flags,
|
|
||||||
const char *dev_name, void *raw_data)
|
|
||||||
{
|
|
||||||
struct nfs_mount_info mount_info = {
|
|
||||||
.fill_super = nfs_clone_super,
|
|
||||||
.set_security = nfs_clone_sb_security,
|
|
||||||
.cloned = raw_data,
|
|
||||||
};
|
|
||||||
return nfs_xdev_mount_common(&nfs4_fs_type, flags, dev_name, &mount_info);
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct dentry *
|
static struct dentry *
|
||||||
nfs4_remote_referral_mount(struct file_system_type *fs_type, int flags,
|
nfs4_remote_referral_mount(struct file_system_type *fs_type, int flags,
|
||||||
const char *dev_name, void *raw_data)
|
const char *dev_name, void *raw_data)
|
||||||
|
|
|
@ -2445,10 +2445,15 @@ void nfs_kill_super(struct super_block *s)
|
||||||
* Clone an NFS2/3/4 server record on xdev traversal (FSID-change)
|
* Clone an NFS2/3/4 server record on xdev traversal (FSID-change)
|
||||||
*/
|
*/
|
||||||
struct dentry *
|
struct dentry *
|
||||||
nfs_xdev_mount_common(struct file_system_type *fs_type, int flags,
|
nfs_xdev_mount(struct file_system_type *fs_type, int flags,
|
||||||
const char *dev_name, struct nfs_mount_info *mount_info)
|
const char *dev_name, void *raw_data)
|
||||||
{
|
{
|
||||||
struct nfs_clone_mount *data = mount_info->cloned;
|
struct nfs_clone_mount *data = raw_data;
|
||||||
|
struct nfs_mount_info mount_info = {
|
||||||
|
.fill_super = nfs_clone_super,
|
||||||
|
.set_security = nfs_clone_sb_security,
|
||||||
|
.cloned = data,
|
||||||
|
};
|
||||||
struct nfs_server *server;
|
struct nfs_server *server;
|
||||||
struct dentry *mntroot = ERR_PTR(-ENOMEM);
|
struct dentry *mntroot = ERR_PTR(-ENOMEM);
|
||||||
struct nfs_subversion *nfs_mod = NFS_SB(data->sb)->nfs_client->cl_nfs_mod;
|
struct nfs_subversion *nfs_mod = NFS_SB(data->sb)->nfs_client->cl_nfs_mod;
|
||||||
|
@ -2456,7 +2461,7 @@ nfs_xdev_mount_common(struct file_system_type *fs_type, int flags,
|
||||||
|
|
||||||
dprintk("--> nfs_xdev_mount_common()\n");
|
dprintk("--> nfs_xdev_mount_common()\n");
|
||||||
|
|
||||||
mount_info->mntfh = data->fh;
|
mount_info.mntfh = mount_info.cloned->fh;
|
||||||
|
|
||||||
/* create a new volume representation */
|
/* create a new volume representation */
|
||||||
server = nfs_clone_server(NFS_SB(data->sb), data->fh, data->fattr, data->authflavor);
|
server = nfs_clone_server(NFS_SB(data->sb), data->fh, data->fattr, data->authflavor);
|
||||||
|
@ -2465,7 +2470,7 @@ nfs_xdev_mount_common(struct file_system_type *fs_type, int flags,
|
||||||
goto out_err;
|
goto out_err;
|
||||||
}
|
}
|
||||||
|
|
||||||
mntroot = nfs_fs_mount_common(server, flags, dev_name, mount_info, nfs_mod);
|
mntroot = nfs_fs_mount_common(server, flags, dev_name, &mount_info, nfs_mod);
|
||||||
dprintk("<-- nfs_xdev_mount_common() = 0\n");
|
dprintk("<-- nfs_xdev_mount_common() = 0\n");
|
||||||
out:
|
out:
|
||||||
return mntroot;
|
return mntroot;
|
||||||
|
@ -2475,21 +2480,6 @@ out_err:
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Clone an NFS2/3 server record on xdev traversal (FSID-change)
|
|
||||||
*/
|
|
||||||
static struct dentry *
|
|
||||||
nfs_xdev_mount(struct file_system_type *fs_type, int flags,
|
|
||||||
const char *dev_name, void *raw_data)
|
|
||||||
{
|
|
||||||
struct nfs_mount_info mount_info = {
|
|
||||||
.fill_super = nfs_clone_super,
|
|
||||||
.set_security = nfs_clone_sb_security,
|
|
||||||
.cloned = raw_data,
|
|
||||||
};
|
|
||||||
return nfs_xdev_mount_common(&nfs_fs_type, flags, dev_name, &mount_info);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef CONFIG_NFS_V4
|
#ifdef CONFIG_NFS_V4
|
||||||
|
|
||||||
static void nfs4_validate_mount_flags(struct nfs_parsed_mount_data *args)
|
static void nfs4_validate_mount_flags(struct nfs_parsed_mount_data *args)
|
||||||
|
|
Loading…
Add table
Reference in a new issue