summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTrond Myklebust <Trond.Myklebust@netapp.com>2006-03-20 19:44:09 +0100
committerTrond Myklebust <Trond.Myklebust@netapp.com>2006-03-20 19:44:09 +0100
commit967b9281361481aecf323563886ef972ee88c681 (patch)
treede7ced8972fdff5011d43a6fe24c2c7ac7cc0cb6
parentSUNRPC: Ensure that rpc_mkpipe returns a refcounted dentry (diff)
downloadlinux-967b9281361481aecf323563886ef972ee88c681.tar.xz
linux-967b9281361481aecf323563886ef972ee88c681.zip
NFSv4: Do not call rpciod_down() before call to destroy_nfsv4_state()
The reason is that the idmapper cleanup may call flush_workqueue() on rpciod_workqueue. Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
-rw-r--r--fs/nfs/inode.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/fs/nfs/inode.c b/fs/nfs/inode.c
index 24988f430e4b..b81149eb26e5 100644
--- a/fs/nfs/inode.c
+++ b/fs/nfs/inode.c
@@ -2025,10 +2025,11 @@ static void nfs4_kill_super(struct super_block *sb)
if (server->client != NULL && !IS_ERR(server->client))
rpc_shutdown_client(server->client);
- rpciod_down(); /* release rpciod */
destroy_nfsv4_state(server);
+ rpciod_down();
+
kfree(server->hostname);
kfree(server);
}