Commit 70fe25b6 authored by Stanislav Kinsbursky's avatar Stanislav Kinsbursky Committed by Trond Myklebust

SUNRPC: remove RPC pipefs mount point manipulations from RPC clients code

v2:
1) Updated due to changes in the first patch of the series.

Now, with RPC pipefs mount notifications handling in RPC clients, we can remove
mount point creation and destruction. RPC clients dentries will be created on
PipeFS mount event and removed on umount event.
Signed-off-by: default avatarStanislav Kinsbursky <skinsbursky@parallels.com>
Signed-off-by: default avatarTrond Myklebust <Trond.Myklebust@netapp.com>
parent f5131257
...@@ -109,17 +109,12 @@ static void __rpc_clnt_remove_pipedir(struct rpc_clnt *clnt) ...@@ -109,17 +109,12 @@ static void __rpc_clnt_remove_pipedir(struct rpc_clnt *clnt)
static void rpc_clnt_remove_pipedir(struct rpc_clnt *clnt) static void rpc_clnt_remove_pipedir(struct rpc_clnt *clnt)
{ {
struct super_block *pipefs_sb; struct super_block *pipefs_sb;
int put_mnt = 0;
pipefs_sb = rpc_get_sb_net(clnt->cl_xprt->xprt_net); pipefs_sb = rpc_get_sb_net(clnt->cl_xprt->xprt_net);
if (pipefs_sb) { if (pipefs_sb) {
if (clnt->cl_path.dentry)
put_mnt = 1;
__rpc_clnt_remove_pipedir(clnt); __rpc_clnt_remove_pipedir(clnt);
rpc_put_sb_net(clnt->cl_xprt->xprt_net); rpc_put_sb_net(clnt->cl_xprt->xprt_net);
} }
if (put_mnt)
rpc_put_mount();
} }
static struct dentry *rpc_setup_pipedir_sb(struct super_block *sb, static struct dentry *rpc_setup_pipedir_sb(struct super_block *sb,
...@@ -165,21 +160,13 @@ rpc_setup_pipedir(struct rpc_clnt *clnt, char *dir_name) ...@@ -165,21 +160,13 @@ rpc_setup_pipedir(struct rpc_clnt *clnt, char *dir_name)
clnt->cl_path.dentry = NULL; clnt->cl_path.dentry = NULL;
if (dir_name == NULL) if (dir_name == NULL)
return 0; return 0;
path.mnt = rpc_get_mount();
if (IS_ERR(path.mnt))
return PTR_ERR(path.mnt);
pipefs_sb = rpc_get_sb_net(clnt->cl_xprt->xprt_net); pipefs_sb = rpc_get_sb_net(clnt->cl_xprt->xprt_net);
if (!pipefs_sb) { if (!pipefs_sb)
rpc_put_mount(); return 0;
return -ENOENT;
}
path.dentry = rpc_setup_pipedir_sb(pipefs_sb, clnt, dir_name); path.dentry = rpc_setup_pipedir_sb(pipefs_sb, clnt, dir_name);
rpc_put_sb_net(clnt->cl_xprt->xprt_net); rpc_put_sb_net(clnt->cl_xprt->xprt_net);
if (IS_ERR(path.dentry)) { if (IS_ERR(path.dentry))
rpc_put_mount();
return PTR_ERR(path.dentry); return PTR_ERR(path.dentry);
}
clnt->cl_path = path; clnt->cl_path = path;
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment