aboutsummaryrefslogtreecommitdiffstats
path: root/net/sunrpc/clnt.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/sunrpc/clnt.c')
-rw-r--r--net/sunrpc/clnt.c53
1 files changed, 17 insertions, 36 deletions
diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
index 63bf591310e0..5a8f01d726e9 100644
--- a/net/sunrpc/clnt.c
+++ b/net/sunrpc/clnt.c
@@ -67,42 +67,26 @@ static u32 * call_verify(struct rpc_task *task);
67static int 67static int
68rpc_setup_pipedir(struct rpc_clnt *clnt, char *dir_name) 68rpc_setup_pipedir(struct rpc_clnt *clnt, char *dir_name)
69{ 69{
70 static unsigned int clntid; 70 static uint32_t clntid;
71 char name[128];
72 int error; 71 int error;
73 72
74 if (dir_name == NULL) 73 if (dir_name == NULL)
75 return 0; 74 return 0;
76 75 for (;;) {
77 retry_parent: 76 snprintf(clnt->cl_pathname, sizeof(clnt->cl_pathname),
78 clnt->__cl_parent_dentry = rpc_mkdir(NULL, dir_name, NULL); 77 "%s/clnt%x", dir_name,
79 if (IS_ERR(clnt->__cl_parent_dentry)) { 78 (unsigned int)clntid++);
80 error = PTR_ERR(clnt->__cl_parent_dentry); 79 clnt->cl_pathname[sizeof(clnt->cl_pathname) - 1] = '\0';
81 if (error == -EEXIST) 80 clnt->cl_dentry = rpc_mkdir(clnt->cl_pathname, clnt);
82 goto retry_parent; /* XXX(hch): WTF? */ 81 if (!IS_ERR(clnt->cl_dentry))
83 82 return 0;
84 printk(KERN_INFO "RPC: Couldn't create pipefs entry %s, error %d\n",
85 dir_name, error);
86 return error;
87 }
88
89
90 retry_child:
91 snprintf(name, sizeof(name), "clnt%x", clntid++);
92 name[sizeof(name) - 1] = '\0';
93
94 clnt->cl_dentry = rpc_mkdir(clnt->__cl_parent_dentry, name, clnt);
95 if (IS_ERR(clnt->cl_dentry)) {
96 error = PTR_ERR(clnt->cl_dentry); 83 error = PTR_ERR(clnt->cl_dentry);
97 if (error == -EEXIST) 84 if (error != -EEXIST) {
98 goto retry_child; 85 printk(KERN_INFO "RPC: Couldn't create pipefs entry %s, error %d\n",
99 printk(KERN_INFO "RPC: Couldn't create pipefs entry %s, error %d\n", 86 clnt->cl_pathname, error);
100 name, error); 87 return error;
101 rpc_rmdir(clnt->__cl_parent_dentry); 88 }
102 return error;
103 } 89 }
104
105 return 0;
106} 90}
107 91
108/* 92/*
@@ -190,8 +174,7 @@ rpc_new_client(struct rpc_xprt *xprt, char *servname,
190 return clnt; 174 return clnt;
191 175
192out_no_auth: 176out_no_auth:
193 rpc_rmdir(clnt->cl_dentry); 177 rpc_rmdir(clnt->cl_pathname);
194 rpc_rmdir(clnt->__cl_parent_dentry);
195out_no_path: 178out_no_path:
196 if (clnt->cl_server != clnt->cl_inline_name) 179 if (clnt->cl_server != clnt->cl_inline_name)
197 kfree(clnt->cl_server); 180 kfree(clnt->cl_server);
@@ -319,10 +302,8 @@ rpc_destroy_client(struct rpc_clnt *clnt)
319 rpc_destroy_client(clnt->cl_parent); 302 rpc_destroy_client(clnt->cl_parent);
320 goto out_free; 303 goto out_free;
321 } 304 }
322 if (clnt->cl_dentry) 305 if (clnt->cl_pathname[0])
323 rpc_rmdir(clnt->cl_dentry); 306 rpc_rmdir(clnt->cl_pathname);
324 if (clnt->__cl_parent_dentry)
325 rpc_rmdir(clnt->__cl_parent_dentry);
326 if (clnt->cl_xprt) { 307 if (clnt->cl_xprt) {
327 xprt_destroy(clnt->cl_xprt); 308 xprt_destroy(clnt->cl_xprt);
328 clnt->cl_xprt = NULL; 309 clnt->cl_xprt = NULL;