nfsd: pass network context to export caches init/shutdown routines
authorStanislav Kinsbursky <skinsbursky@parallels.com>
Wed, 11 Apr 2012 11:13:14 +0000 (15:13 +0400)
committerJ. Bruce Fields <bfields@redhat.com>
Wed, 11 Apr 2012 22:01:33 +0000 (18:01 -0400)
These functions will be called from per-net operations.

Signed-off-by: Stanislav Kinsbursky <skinsbursky@parallels.com>
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
fs/nfsd/export.c
fs/nfsd/nfsctl.c
include/linux/nfsd/export.h

index 84723bc37c59f213342d1256e42f4434917f5271..6453669dcef73d736a9a60874a86e547f490f728 100644 (file)
@@ -1228,17 +1228,17 @@ const struct seq_operations nfs_exports_op = {
  * Initialize the exports module.
  */
 int
-nfsd_export_init(void)
+nfsd_export_init(struct net *net)
 {
        int rv;
-       dprintk("nfsd: initializing export module.\n");
+       dprintk("nfsd: initializing export module (net: %p).\n", net);
 
-       rv = cache_register_net(&svc_export_cache, &init_net);
+       rv = cache_register_net(&svc_export_cache, net);
        if (rv)
                return rv;
-       rv = cache_register_net(&svc_expkey_cache, &init_net);
+       rv = cache_register_net(&svc_expkey_cache, net);
        if (rv)
-               cache_unregister_net(&svc_export_cache, &init_net);
+               cache_unregister_net(&svc_export_cache, net);
        return rv;
 
 }
@@ -1257,14 +1257,14 @@ nfsd_export_flush(void)
  * Shutdown the exports module.
  */
 void
-nfsd_export_shutdown(void)
+nfsd_export_shutdown(struct net *net)
 {
 
-       dprintk("nfsd: shutting down export module.\n");
+       dprintk("nfsd: shutting down export module (net: %p).\n", net);
 
-       cache_unregister_net(&svc_expkey_cache, &init_net);
-       cache_unregister_net(&svc_export_cache, &init_net);
+       cache_unregister_net(&svc_expkey_cache, net);
+       cache_unregister_net(&svc_export_cache, net);
        svcauth_unix_purge();
 
-       dprintk("nfsd: export shutdown complete.\n");
+       dprintk("nfsd: export shutdown complete (net: %p).\n", net);
 }
index ae19293e68df2081c65fe931541c34744076fe79..bc76f8ebbe5ee4ba7e3fb99b985e4a2c04a17a27 100644 (file)
@@ -1163,7 +1163,7 @@ static int __init init_nfsd(void)
        retval = nfsd_reply_cache_init();
        if (retval)
                goto out_free_stat;
-       retval = nfsd_export_init();
+       retval = nfsd_export_init(&init_net);
        if (retval)
                goto out_free_cache;
        nfsd_lockd_init();      /* lockd->nfsd callbacks */
@@ -1184,7 +1184,7 @@ out_free_idmap:
        nfsd_idmap_shutdown();
 out_free_lockd:
        nfsd_lockd_shutdown();
-       nfsd_export_shutdown();
+       nfsd_export_shutdown(&init_net);
 out_free_cache:
        nfsd_reply_cache_shutdown();
 out_free_stat:
@@ -1201,7 +1201,7 @@ out_unregister_notifier:
 
 static void __exit exit_nfsd(void)
 {
-       nfsd_export_shutdown();
+       nfsd_export_shutdown(&init_net);
        nfsd_reply_cache_shutdown();
        remove_proc_entry("fs/nfs/exports", NULL);
        remove_proc_entry("fs/nfs", NULL);
index 485c2afa96f715a8ebc1f25d6a1831a1d68fc3cb..375096c083d3b479eccc0f7731e1028616a59a9a 100644 (file)
@@ -130,8 +130,8 @@ __be32 check_nfsd_access(struct svc_export *exp, struct svc_rqst *rqstp);
 /*
  * Function declarations
  */
-int                    nfsd_export_init(void);
-void                   nfsd_export_shutdown(void);
+int                    nfsd_export_init(struct net *);
+void                   nfsd_export_shutdown(struct net *);
 void                   nfsd_export_flush(void);
 struct svc_export *    rqst_exp_get_by_name(struct svc_rqst *,
                                             struct path *);