diff options
Diffstat (limited to 'fs/nfsd/nfsctl.c')
| -rw-r--r-- | fs/nfsd/nfsctl.c | 23 | 
1 files changed, 13 insertions, 10 deletions
| diff --git a/fs/nfsd/nfsctl.c b/fs/nfsd/nfsctl.c index b68e96681522..cd05732f8eaa 100644 --- a/fs/nfsd/nfsctl.c +++ b/fs/nfsd/nfsctl.c @@ -1335,6 +1335,7 @@ void nfsd_client_rmdir(struct dentry *dentry)  	WARN_ON_ONCE(ret);  	fsnotify_rmdir(dir, dentry);  	d_delete(dentry); +	dput(dentry);  	inode_unlock(dir);  } @@ -1424,6 +1425,18 @@ static struct file_system_type nfsd_fs_type = {  };  MODULE_ALIAS_FS("nfsd"); +int get_nfsdfs(struct net *net) +{ +	struct nfsd_net *nn = net_generic(net, nfsd_net_id); +	struct vfsmount *mnt; + +	mnt =  vfs_kern_mount(&nfsd_fs_type, SB_KERNMOUNT, "nfsd", NULL); +	if (IS_ERR(mnt)) +		return PTR_ERR(mnt); +	nn->nfsd_mnt = mnt; +	return 0; +} +  #ifdef CONFIG_PROC_FS  static int create_proc_exports_entry(void)  { @@ -1451,7 +1464,6 @@ unsigned int nfsd_net_id;  static __net_init int nfsd_init_net(struct net *net)  {  	int retval; -	struct vfsmount *mnt;  	struct nfsd_net *nn = net_generic(net, nfsd_net_id);  	retval = nfsd_export_init(net); @@ -1478,16 +1490,8 @@ static __net_init int nfsd_init_net(struct net *net)  	init_waitqueue_head(&nn->ntf_wq);  	seqlock_init(&nn->boot_lock); -	mnt =  vfs_kern_mount(&nfsd_fs_type, SB_KERNMOUNT, "nfsd", NULL); -	if (IS_ERR(mnt)) { -		retval = PTR_ERR(mnt); -		goto out_mount_err; -	} -	nn->nfsd_mnt = mnt;  	return 0; -out_mount_err: -	nfsd_reply_cache_shutdown(nn);  out_drc_error:  	nfsd_idmap_shutdown(net);  out_idmap_error: @@ -1500,7 +1504,6 @@ static __net_exit void nfsd_exit_net(struct net *net)  {  	struct nfsd_net *nn = net_generic(net, nfsd_net_id); -	mntput(nn->nfsd_mnt);  	nfsd_reply_cache_shutdown(nn);  	nfsd_idmap_shutdown(net);  	nfsd_export_shutdown(net); | 
