Re: [PATCH 03/11] sunrpc: remove the rpc_clients_block notifier

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sun, 01 Dec 2013 05:14:44 -0800
Christoph Hellwig <hch@xxxxxxxxxxxxx> wrote:

> Now that a rpc_pipefs mount is always availble there is no need for it.
> 
> Signed-off-by: Christoph Hellwig <hch@xxxxxx>
> ---
>  fs/nfs/blocklayout/blocklayout.c   |   56 ++-----------------
>  fs/nfs/cache_lib.c                 |    6 ++-
>  fs/nfs/cache_lib.h                 |    4 --
>  fs/nfs/dns_resolve.c               |   49 +----------------
>  fs/nfsd/nfs4recover.c              |   55 -------------------
>  fs/nfsd/nfsctl.c                   |    9 +---
>  fs/nfsd/nfsd.h                     |    6 ---
>  include/linux/sunrpc/rpc_pipe_fs.h |   13 -----
>  net/sunrpc/clnt.c                  |  104 ------------------------------------
>  net/sunrpc/rpc_pipe.c              |   48 +----------------
>  net/sunrpc/sunrpc.h                |    2 -
>  11 files changed, 11 insertions(+), 341 deletions(-)
> 
> diff --git a/fs/nfs/blocklayout/blocklayout.c b/fs/nfs/blocklayout/blocklayout.c
> index e242bbf..17088b9 100644
> --- a/fs/nfs/blocklayout/blocklayout.c
> +++ b/fs/nfs/blocklayout/blocklayout.c
> @@ -1315,48 +1315,6 @@ static void nfs4blocklayout_unregister_sb(struct super_block *sb,
>  		rpc_unlink(pipe->dentry);
>  }
>  
> -static int rpc_pipefs_event(struct notifier_block *nb, unsigned long event,
> -			   void *ptr)
> -{
> -	struct super_block *sb = ptr;
> -	struct net *net = sb->s_fs_info;
> -	struct nfs_net *nn = net_generic(net, nfs_net_id);
> -	struct dentry *dentry;
> -	int ret = 0;
> -
> -	if (!try_module_get(THIS_MODULE))
> -		return 0;
> -
> -	if (nn->bl_device_pipe == NULL) {
> -		module_put(THIS_MODULE);
> -		return 0;
> -	}
> -
> -	switch (event) {
> -	case RPC_PIPEFS_MOUNT:
> -		dentry = nfs4blocklayout_register_sb(sb, nn->bl_device_pipe);
> -		if (IS_ERR(dentry)) {
> -			ret = PTR_ERR(dentry);
> -			break;
> -		}
> -		nn->bl_device_pipe->dentry = dentry;
> -		break;
> -	case RPC_PIPEFS_UMOUNT:
> -		if (nn->bl_device_pipe->dentry)
> -			nfs4blocklayout_unregister_sb(sb, nn->bl_device_pipe);
> -		break;
> -	default:
> -		ret = -ENOTSUPP;
> -		break;
> -	}
> -	module_put(THIS_MODULE);
> -	return ret;
> -}
> -
> -static struct notifier_block nfs4blocklayout_block = {
> -	.notifier_call = rpc_pipefs_event,
> -};
> -
>  static struct dentry *nfs4blocklayout_register_net(struct net *net,
>  						   struct rpc_pipe *pipe)
>  {
> @@ -1424,20 +1382,13 @@ static int __init nfs4blocklayout_init(void)
>  	ret = pnfs_register_layoutdriver(&blocklayout_type);
>  	if (ret)
>  		goto out;
> -
> -	ret = rpc_pipefs_notifier_register(&nfs4blocklayout_block);
> -	if (ret)
> -		goto out_remove;
>  	ret = register_pernet_subsys(&nfs4blocklayout_net_ops);
>  	if (ret)
> -		goto out_notifier;
> -out:
> -	return ret;
> -
> -out_notifier:
> -	rpc_pipefs_notifier_unregister(&nfs4blocklayout_block);
> +		goto out_remove;
> +	return 0;
>  out_remove:
>  	pnfs_unregister_layoutdriver(&blocklayout_type);
> +out:
>  	return ret;
>  }
>  
> @@ -1446,7 +1397,6 @@ static void __exit nfs4blocklayout_exit(void)
>  	dprintk("%s: NFSv4 Block Layout Driver Unregistering...\n",
>  	       __func__);
>  
> -	rpc_pipefs_notifier_unregister(&nfs4blocklayout_block);
>  	unregister_pernet_subsys(&nfs4blocklayout_net_ops);
>  	pnfs_unregister_layoutdriver(&blocklayout_type);
>  }
> diff --git a/fs/nfs/cache_lib.c b/fs/nfs/cache_lib.c
> index 5f7b053..4e9226f 100644
> --- a/fs/nfs/cache_lib.c
> +++ b/fs/nfs/cache_lib.c
> @@ -112,7 +112,8 @@ int nfs_cache_wait_for_upcall(struct nfs_cache_defer_req *dreq)
>  	return 0;
>  }
>  
> -int nfs_cache_register_sb(struct super_block *sb, struct cache_detail *cd)
> +static int nfs_cache_register_sb(struct super_block *sb,
> +		struct cache_detail *cd)
>  {
>  	int ret;
>  	struct dentry *dir;
> @@ -139,7 +140,8 @@ int nfs_cache_register_net(struct net *net, struct cache_detail *cd)
>  	return ret;
>  }
>  
> -void nfs_cache_unregister_sb(struct super_block *sb, struct cache_detail *cd)
> +static void nfs_cache_unregister_sb(struct super_block *sb,
> +		struct cache_detail *cd)
>  {
>  	if (cd->u.pipefs.dir)
>  		sunrpc_cache_unregister_pipefs(cd);
> diff --git a/fs/nfs/cache_lib.h b/fs/nfs/cache_lib.h
> index 4116d2c..27280b8 100644
> --- a/fs/nfs/cache_lib.h
> +++ b/fs/nfs/cache_lib.h
> @@ -25,7 +25,3 @@ extern int nfs_cache_wait_for_upcall(struct nfs_cache_defer_req *dreq);
>  
>  extern int nfs_cache_register_net(struct net *net, struct cache_detail *cd);
>  extern void nfs_cache_unregister_net(struct net *net, struct cache_detail *cd);
> -extern int nfs_cache_register_sb(struct super_block *sb,
> -				 struct cache_detail *cd);
> -extern void nfs_cache_unregister_sb(struct super_block *sb,
> -				    struct cache_detail *cd);
> diff --git a/fs/nfs/dns_resolve.c b/fs/nfs/dns_resolve.c
> index fc0f95e..d9e641a 100644
> --- a/fs/nfs/dns_resolve.c
> +++ b/fs/nfs/dns_resolve.c
> @@ -409,60 +409,13 @@ static struct pernet_operations nfs4_dns_resolver_ops = {
>  	.exit = nfs4_dns_net_exit,
>  };
>  
> -static int rpc_pipefs_event(struct notifier_block *nb, unsigned long event,
> -			   void *ptr)
> -{
> -	struct super_block *sb = ptr;
> -	struct net *net = sb->s_fs_info;
> -	struct nfs_net *nn = net_generic(net, nfs_net_id);
> -	struct cache_detail *cd = nn->nfs_dns_resolve;
> -	int ret = 0;
> -
> -	if (cd == NULL)
> -		return 0;
> -
> -	if (!try_module_get(THIS_MODULE))
> -		return 0;
> -
> -	switch (event) {
> -	case RPC_PIPEFS_MOUNT:
> -		ret = nfs_cache_register_sb(sb, cd);
> -		break;
> -	case RPC_PIPEFS_UMOUNT:
> -		nfs_cache_unregister_sb(sb, cd);
> -		break;
> -	default:
> -		ret = -ENOTSUPP;
> -		break;
> -	}
> -	module_put(THIS_MODULE);
> -	return ret;
> -}
> -
> -static struct notifier_block nfs_dns_resolver_block = {
> -	.notifier_call	= rpc_pipefs_event,
> -};
> -
>  int nfs_dns_resolver_init(void)
>  {
> -	int err;
> -
> -	err = register_pernet_subsys(&nfs4_dns_resolver_ops);
> -	if (err < 0)
> -		goto out;
> -	err = rpc_pipefs_notifier_register(&nfs_dns_resolver_block);
> -	if (err < 0)
> -		goto out1;
> -	return 0;
> -out1:
> -	unregister_pernet_subsys(&nfs4_dns_resolver_ops);
> -out:
> -	return err;
> +	return register_pernet_subsys(&nfs4_dns_resolver_ops);
>  }
>  
>  void nfs_dns_resolver_destroy(void)
>  {
> -	rpc_pipefs_notifier_unregister(&nfs_dns_resolver_block);
>  	unregister_pernet_subsys(&nfs4_dns_resolver_ops);
>  }
>  #endif
> diff --git a/fs/nfsd/nfs4recover.c b/fs/nfsd/nfs4recover.c
> index 9c271f4..d9a03e4 100644
> --- a/fs/nfsd/nfs4recover.c
> +++ b/fs/nfsd/nfs4recover.c
> @@ -1361,58 +1361,3 @@ nfsd4_record_grace_done(struct nfsd_net *nn, time_t boot_time)
>  	if (nn->client_tracking_ops)
>  		nn->client_tracking_ops->grace_done(nn, boot_time);
>  }
> -
> -static int
> -rpc_pipefs_event(struct notifier_block *nb, unsigned long event, void *ptr)
> -{
> -	struct super_block *sb = ptr;
> -	struct net *net = sb->s_fs_info;
> -	struct nfsd_net *nn = net_generic(net, nfsd_net_id);
> -	struct cld_net *cn = nn->cld_net;
> -	struct dentry *dentry;
> -	int ret = 0;
> -
> -	if (!try_module_get(THIS_MODULE))
> -		return 0;
> -
> -	if (!cn) {
> -		module_put(THIS_MODULE);
> -		return 0;
> -	}
> -
> -	switch (event) {
> -	case RPC_PIPEFS_MOUNT:
> -		dentry = nfsd4_cld_register_sb(sb, cn->cn_pipe);
> -		if (IS_ERR(dentry)) {
> -			ret = PTR_ERR(dentry);
> -			break;
> -		}
> -		cn->cn_pipe->dentry = dentry;
> -		break;
> -	case RPC_PIPEFS_UMOUNT:
> -		if (cn->cn_pipe->dentry)
> -			nfsd4_cld_unregister_sb(cn->cn_pipe);
> -		break;
> -	default:
> -		ret = -ENOTSUPP;
> -		break;
> -	}
> -	module_put(THIS_MODULE);
> -	return ret;
> -}
> -
> -static struct notifier_block nfsd4_cld_block = {
> -	.notifier_call = rpc_pipefs_event,
> -};
> -
> -int
> -register_cld_notifier(void)
> -{
> -	return rpc_pipefs_notifier_register(&nfsd4_cld_block);
> -}
> -
> -void
> -unregister_cld_notifier(void)
> -{
> -	rpc_pipefs_notifier_unregister(&nfsd4_cld_block);
> -}
> diff --git a/fs/nfsd/nfsctl.c b/fs/nfsd/nfsctl.c
> index 7f55517..14da88f 100644
> --- a/fs/nfsd/nfsctl.c
> +++ b/fs/nfsd/nfsctl.c
> @@ -1165,12 +1165,9 @@ static int __init init_nfsd(void)
>  	int retval;
>  	printk(KERN_INFO "Installing knfsd (copyright (C) 1996 okir@xxxxxxxxxxxx).\n");
>  
> -	retval = register_cld_notifier();
> -	if (retval)
> -		return retval;
>  	retval = register_pernet_subsys(&nfsd_net_ops);
>  	if (retval < 0)
> -		goto out_unregister_notifier;
> +		goto out;
>  	retval = nfsd4_init_slabs();
>  	if (retval)
>  		goto out_unregister_pernet;
> @@ -1203,8 +1200,7 @@ out_free_slabs:
>  	nfsd4_free_slabs();
>  out_unregister_pernet:
>  	unregister_pernet_subsys(&nfsd_net_ops);
> -out_unregister_notifier:
> -	unregister_cld_notifier();
> +out:
>  	return retval;
>  }
>  
> @@ -1219,7 +1215,6 @@ static void __exit exit_nfsd(void)
>  	nfsd_fault_inject_cleanup();
>  	unregister_filesystem(&nfsd_fs_type);
>  	unregister_pernet_subsys(&nfsd_net_ops);
> -	unregister_cld_notifier();
>  }
>  
>  MODULE_AUTHOR("Olaf Kirch <okir@xxxxxxxxxxxx>");
> diff --git a/fs/nfsd/nfsd.h b/fs/nfsd/nfsd.h
> index 30f34ab..10d35f1 100644
> --- a/fs/nfsd/nfsd.h
> +++ b/fs/nfsd/nfsd.h
> @@ -384,17 +384,11 @@ static inline u32 nfsd_suppattrs2(u32 minorversion)
>  	NFSD_WRITEABLE_ATTRS_WORD2
>  
>  extern int nfsd4_is_junction(struct dentry *dentry);
> -extern int register_cld_notifier(void);
> -extern void unregister_cld_notifier(void);
>  #else /* CONFIG_NFSD_V4 */
>  static inline int nfsd4_is_junction(struct dentry *dentry)
>  {
>  	return 0;
>  }
> -
> -#define register_cld_notifier() 0
> -#define unregister_cld_notifier() do { } while(0)
> -
>  #endif /* CONFIG_NFSD_V4 */
>  
>  #endif /* LINUX_NFSD_NFSD_H */
> diff --git a/include/linux/sunrpc/rpc_pipe_fs.h b/include/linux/sunrpc/rpc_pipe_fs.h
> index d5807e7..b9f3805 100644
> --- a/include/linux/sunrpc/rpc_pipe_fs.h
> +++ b/include/linux/sunrpc/rpc_pipe_fs.h
> @@ -69,19 +69,6 @@ RPC_I(struct inode *inode)
>  	return container_of(inode, struct rpc_inode, vfs_inode);
>  }
>  
> -enum {
> -	SUNRPC_PIPEFS_NFS_PRIO,
> -	SUNRPC_PIPEFS_RPC_PRIO,
> -};
> -
> -extern int rpc_pipefs_notifier_register(struct notifier_block *);
> -extern void rpc_pipefs_notifier_unregister(struct notifier_block *);
> -
> -enum {
> -	RPC_PIPEFS_MOUNT,
> -	RPC_PIPEFS_UMOUNT,
> -};
> -
>  extern struct dentry *rpc_d_lookup_sb(const struct super_block *sb,
>  				      const unsigned char *dir_name);
>  extern struct super_block *rpc_get_sb_net(const struct net *net);
> diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
> index f09b7db..ec059c2 100644
> --- a/net/sunrpc/clnt.c
> +++ b/net/sunrpc/clnt.c
> @@ -160,110 +160,6 @@ rpc_setup_pipedir(struct super_block *pipefs_sb, struct rpc_clnt *clnt)
>  	return 0;
>  }
>  
> -static int rpc_clnt_skip_event(struct rpc_clnt *clnt, unsigned long event)
> -{
> -	if (clnt->cl_program->pipe_dir_name == NULL)
> -		return 1;
> -
> -	switch (event) {
> -	case RPC_PIPEFS_MOUNT:
> -		if (clnt->cl_pipedir_objects.pdh_dentry != NULL)
> -			return 1;
> -		if (atomic_read(&clnt->cl_count) == 0)
> -			return 1;
> -		break;
> -	case RPC_PIPEFS_UMOUNT:
> -		if (clnt->cl_pipedir_objects.pdh_dentry == NULL)
> -			return 1;
> -		break;
> -	}
> -	return 0;
> -}
> -
> -static int __rpc_clnt_handle_event(struct rpc_clnt *clnt, unsigned long event,
> -				   struct super_block *sb)
> -{
> -	struct dentry *dentry;
> -	int err = 0;
> -
> -	switch (event) {
> -	case RPC_PIPEFS_MOUNT:
> -		dentry = rpc_setup_pipedir_sb(sb, clnt);
> -		if (!dentry)
> -			return -ENOENT;
> -		if (IS_ERR(dentry))
> -			return PTR_ERR(dentry);
> -		break;
> -	case RPC_PIPEFS_UMOUNT:
> -		__rpc_clnt_remove_pipedir(clnt);
> -		break;
> -	default:
> -		printk(KERN_ERR "%s: unknown event: %ld\n", __func__, event);
> -		return -ENOTSUPP;
> -	}
> -	return err;
> -}
> -
> -static int __rpc_pipefs_event(struct rpc_clnt *clnt, unsigned long event,
> -				struct super_block *sb)
> -{
> -	int error = 0;
> -
> -	for (;; clnt = clnt->cl_parent) {
> -		if (!rpc_clnt_skip_event(clnt, event))
> -			error = __rpc_clnt_handle_event(clnt, event, sb);
> -		if (error || clnt == clnt->cl_parent)
> -			break;
> -	}
> -	return error;
> -}
> -
> -static struct rpc_clnt *rpc_get_client_for_event(struct net *net, int event)
> -{
> -	struct sunrpc_net *sn = net_generic(net, sunrpc_net_id);
> -	struct rpc_clnt *clnt;
> -
> -	spin_lock(&sn->rpc_client_lock);
> -	list_for_each_entry(clnt, &sn->all_clients, cl_clients) {
> -		if (rpc_clnt_skip_event(clnt, event))
> -			continue;
> -		spin_unlock(&sn->rpc_client_lock);
> -		return clnt;
> -	}
> -	spin_unlock(&sn->rpc_client_lock);
> -	return NULL;
> -}
> -
> -static int rpc_pipefs_event(struct notifier_block *nb, unsigned long event,
> -			    void *ptr)
> -{
> -	struct super_block *sb = ptr;
> -	struct rpc_clnt *clnt;
> -	int error = 0;
> -
> -	while ((clnt = rpc_get_client_for_event(sb->s_fs_info, event))) {
> -		error = __rpc_pipefs_event(clnt, event, sb);
> -		if (error)
> -			break;
> -	}
> -	return error;
> -}
> -
> -static struct notifier_block rpc_clients_block = {
> -	.notifier_call	= rpc_pipefs_event,
> -	.priority	= SUNRPC_PIPEFS_RPC_PRIO,
> -};
> -
> -int rpc_clients_notifier_register(void)
> -{
> -	return rpc_pipefs_notifier_register(&rpc_clients_block);
> -}
> -
> -void rpc_clients_notifier_unregister(void)
> -{
> -	return rpc_pipefs_notifier_unregister(&rpc_clients_block);
> -}
> -
>  static struct rpc_xprt *rpc_clnt_set_transport(struct rpc_clnt *clnt,
>  		struct rpc_xprt *xprt,
>  		const struct rpc_timeout *timeout)
> diff --git a/net/sunrpc/rpc_pipe.c b/net/sunrpc/rpc_pipe.c
> index e654b65..73e7963 100644
> --- a/net/sunrpc/rpc_pipe.c
> +++ b/net/sunrpc/rpc_pipe.c
> @@ -42,20 +42,6 @@ static struct file_system_type rpc_pipe_fs_type;
>  
>  #define RPC_UPCALL_TIMEOUT (30*HZ)
>  
> -static BLOCKING_NOTIFIER_HEAD(rpc_pipefs_notifier_list);
> -
> -int rpc_pipefs_notifier_register(struct notifier_block *nb)
> -{
> -	return blocking_notifier_chain_cond_register(&rpc_pipefs_notifier_list, nb);
> -}
> -EXPORT_SYMBOL_GPL(rpc_pipefs_notifier_register);
> -
> -void rpc_pipefs_notifier_unregister(struct notifier_block *nb)
> -{
> -	blocking_notifier_chain_unregister(&rpc_pipefs_notifier_list, nb);
> -}
> -EXPORT_SYMBOL_GPL(rpc_pipefs_notifier_unregister);
> -
>  static void rpc_purge_list(wait_queue_head_t *waitq, struct list_head *head,
>  		void (*destroy_msg)(struct rpc_pipe_msg *), int err)
>  {
> @@ -1258,7 +1244,6 @@ rpc_fill_super(struct super_block *sb, void *data, int silent)
>  	struct dentry *root;
>  	struct net *net = data;
>  	struct sunrpc_net *sn = net_generic(net, sunrpc_net_id);
> -	int err;
>  
>  	sb->s_blocksize = PAGE_CACHE_SIZE;
>  	sb->s_blocksize_bits = PAGE_CACHE_SHIFT;
> @@ -1277,23 +1262,9 @@ rpc_fill_super(struct super_block *sb, void *data, int silent)
>  		net, NET_NAME(net));
>  	mutex_lock(&sn->pipefs_sb_lock);
>  	sn->pipefs_sb = sb;
> -	err = blocking_notifier_call_chain(&rpc_pipefs_notifier_list,
> -					   RPC_PIPEFS_MOUNT,
> -					   sb);
> -	if (err)
> -		goto err_depopulate;
>  	sb->s_fs_info = get_net(net);
>  	mutex_unlock(&sn->pipefs_sb_lock);
>  	return 0;
> -
> -err_depopulate:
> -	blocking_notifier_call_chain(&rpc_pipefs_notifier_list,
> -					   RPC_PIPEFS_UMOUNT,
> -					   sb);
> -	sn->pipefs_sb = NULL;
> -	__rpc_depopulate(root, files, RPCAUTH_lockd, RPCAUTH_RootEOF);
> -	mutex_unlock(&sn->pipefs_sb_lock);
> -	return err;
>  }
>  
>  static struct dentry *
> @@ -1316,9 +1287,6 @@ static void rpc_kill_sb(struct super_block *sb)
>  	sn->pipefs_sb = NULL;
>  	dprintk("RPC:       sending pipefs UMOUNT notification for net %p%s\n",
>  		net, NET_NAME(net));
> -	blocking_notifier_call_chain(&rpc_pipefs_notifier_list,
> -					   RPC_PIPEFS_UMOUNT,
> -					   sb);
>  	mutex_unlock(&sn->pipefs_sb_lock);
>  	put_net(net);
>  out:
> @@ -1336,24 +1304,10 @@ MODULE_ALIAS("rpc_pipefs");
>  
>  int register_rpc_pipefs(void)
>  {
> -	int err;
> -
> -	err = rpc_clients_notifier_register();
> -	if (err)
> -		goto err_notifier;
> -	err = register_filesystem(&rpc_pipe_fs_type);
> -	if (err)
> -		goto err_register;
> -	return 0;
> -
> -err_register:
> -	rpc_clients_notifier_unregister();
> -err_notifier:
> -	return err;
> +	return register_filesystem(&rpc_pipe_fs_type);
>  }
>  
>  void unregister_rpc_pipefs(void)
>  {
> -	rpc_clients_notifier_unregister();
>  	unregister_filesystem(&rpc_pipe_fs_type);
>  }
> diff --git a/net/sunrpc/sunrpc.h b/net/sunrpc/sunrpc.h
> index 14c9f6d..90c292e 100644
> --- a/net/sunrpc/sunrpc.h
> +++ b/net/sunrpc/sunrpc.h
> @@ -47,7 +47,5 @@ int svc_send_common(struct socket *sock, struct xdr_buf *xdr,
>  		    struct page *headpage, unsigned long headoffset,
>  		    struct page *tailpage, unsigned long tailoffset);
>  
> -int rpc_clients_notifier_register(void);
> -void rpc_clients_notifier_unregister(void);
>  #endif /* _NET_SUNRPC_SUNRPC_H */
>  

Good riddance... ;)

Reviewed-by: Jeff Layton <jlayton@xxxxxxxxxx>
--
To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Filesystem Development]     [Linux USB Development]     [Linux Media Development]     [Video for Linux]     [Linux NILFS]     [Linux Audio Users]     [Yosemite Info]     [Linux SCSI]

  Powered by Linux