From: Stanislav Kinsbursky Date: Thu, 6 Dec 2012 15:34:42 +0000 (+0300) Subject: nfsd: pass proper net to nfsd_destroy() from NFSd kthreads X-Git-Tag: v3.4.93~19 X-Git-Url: https://git.fsl.cs.sunysb.edu/?a=commitdiff_plain;h=fa16ac16fc1dfe1ddca4b4c9ce71aea73a878402;p=unionfs-2.6.32.y.git nfsd: pass proper net to nfsd_destroy() from NFSd kthreads commit 88c47666171989ed4c5b1a5687df09511e8c5e35 upstream. Since NFSd service is per-net now, we have to pass proper network context in nfsd_shutdown() from NFSd kthreads. The simplest way I found is to get proper net from one of transports with permanent sockets. Signed-off-by: Stanislav Kinsbursky Signed-off-by: J. Bruce Fields [wengmeiling: backport to 3.4: adjust context] Signed-off-by: Weng Meiling Signed-off-by: Greg Kroah-Hartman --- diff --git a/fs/nfsd/nfssvc.c b/fs/nfsd/nfssvc.c index 097481832ae..5bc93803da3 100644 --- a/fs/nfsd/nfssvc.c +++ b/fs/nfsd/nfssvc.c @@ -483,6 +483,8 @@ static int nfsd(void *vrqstp) { struct svc_rqst *rqstp = (struct svc_rqst *) vrqstp; + struct svc_xprt *perm_sock = list_entry(rqstp->rq_server->sv_permsocks.next, typeof(struct svc_xprt), xpt_list); + struct net *net = perm_sock->xpt_net; int err, preverr = 0; /* Lock module and set up kernel thread */ @@ -557,7 +559,7 @@ out: /* Release the thread */ svc_exit_thread(rqstp); - nfsd_destroy(&init_net); + nfsd_destroy(net); /* Release module */ mutex_unlock(&nfsd_mutex);