aboutsummaryrefslogtreecommitdiffstats
path: root/net/sunrpc/rpcb_clnt.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/sunrpc/rpcb_clnt.c')
-rw-r--r--net/sunrpc/rpcb_clnt.c35
1 files changed, 19 insertions, 16 deletions
diff --git a/net/sunrpc/rpcb_clnt.c b/net/sunrpc/rpcb_clnt.c
index 7d32f19ba868..3df276a74d1b 100644
--- a/net/sunrpc/rpcb_clnt.c
+++ b/net/sunrpc/rpcb_clnt.c
@@ -161,10 +161,10 @@ static void rpcb_map_release(void *data)
161 kfree(map); 161 kfree(map);
162} 162}
163 163
164static int rpcb_get_local(void) 164static int rpcb_get_local(struct net *net)
165{ 165{
166 int cnt; 166 int cnt;
167 struct sunrpc_net *sn = net_generic(&init_net, sunrpc_net_id); 167 struct sunrpc_net *sn = net_generic(net, sunrpc_net_id);
168 168
169 spin_lock(&sn->rpcb_clnt_lock); 169 spin_lock(&sn->rpcb_clnt_lock);
170 if (sn->rpcb_users) 170 if (sn->rpcb_users)
@@ -201,9 +201,10 @@ void rpcb_put_local(void)
201 } 201 }
202} 202}
203 203
204static void rpcb_set_local(struct rpc_clnt *clnt, struct rpc_clnt *clnt4) 204static void rpcb_set_local(struct net *net, struct rpc_clnt *clnt,
205 struct rpc_clnt *clnt4)
205{ 206{
206 struct sunrpc_net *sn = net_generic(&init_net, sunrpc_net_id); 207 struct sunrpc_net *sn = net_generic(net, sunrpc_net_id);
207 208
208 /* Protected by rpcb_create_local_mutex */ 209 /* Protected by rpcb_create_local_mutex */
209 sn->rpcb_local_clnt = clnt; 210 sn->rpcb_local_clnt = clnt;
@@ -211,22 +212,23 @@ static void rpcb_set_local(struct rpc_clnt *clnt, struct rpc_clnt *clnt4)
211 smp_wmb(); 212 smp_wmb();
212 sn->rpcb_users = 1; 213 sn->rpcb_users = 1;
213 dprintk("RPC: created new rpcb local clients (rpcb_local_clnt: " 214 dprintk("RPC: created new rpcb local clients (rpcb_local_clnt: "
214 "%p, rpcb_local_clnt4: %p)\n", sn->rpcb_local_clnt, 215 "%p, rpcb_local_clnt4: %p) for net %p%s\n",
215 sn->rpcb_local_clnt4); 216 sn->rpcb_local_clnt, sn->rpcb_local_clnt4,
217 net, (net == &init_net) ? " (init_net)" : "");
216} 218}
217 219
218/* 220/*
219 * Returns zero on success, otherwise a negative errno value 221 * Returns zero on success, otherwise a negative errno value
220 * is returned. 222 * is returned.
221 */ 223 */
222static int rpcb_create_local_unix(void) 224static int rpcb_create_local_unix(struct net *net)
223{ 225{
224 static const struct sockaddr_un rpcb_localaddr_rpcbind = { 226 static const struct sockaddr_un rpcb_localaddr_rpcbind = {
225 .sun_family = AF_LOCAL, 227 .sun_family = AF_LOCAL,
226 .sun_path = RPCBIND_SOCK_PATHNAME, 228 .sun_path = RPCBIND_SOCK_PATHNAME,
227 }; 229 };
228 struct rpc_create_args args = { 230 struct rpc_create_args args = {
229 .net = &init_net, 231 .net = net,
230 .protocol = XPRT_TRANSPORT_LOCAL, 232 .protocol = XPRT_TRANSPORT_LOCAL,
231 .address = (struct sockaddr *)&rpcb_localaddr_rpcbind, 233 .address = (struct sockaddr *)&rpcb_localaddr_rpcbind,
232 .addrsize = sizeof(rpcb_localaddr_rpcbind), 234 .addrsize = sizeof(rpcb_localaddr_rpcbind),
@@ -259,7 +261,7 @@ static int rpcb_create_local_unix(void)
259 clnt4 = NULL; 261 clnt4 = NULL;
260 } 262 }
261 263
262 rpcb_set_local(clnt, clnt4); 264 rpcb_set_local(net, clnt, clnt4);
263 265
264out: 266out:
265 return result; 267 return result;
@@ -269,7 +271,7 @@ out:
269 * Returns zero on success, otherwise a negative errno value 271 * Returns zero on success, otherwise a negative errno value
270 * is returned. 272 * is returned.
271 */ 273 */
272static int rpcb_create_local_net(void) 274static int rpcb_create_local_net(struct net *net)
273{ 275{
274 static const struct sockaddr_in rpcb_inaddr_loopback = { 276 static const struct sockaddr_in rpcb_inaddr_loopback = {
275 .sin_family = AF_INET, 277 .sin_family = AF_INET,
@@ -277,7 +279,7 @@ static int rpcb_create_local_net(void)
277 .sin_port = htons(RPCBIND_PORT), 279 .sin_port = htons(RPCBIND_PORT),
278 }; 280 };
279 struct rpc_create_args args = { 281 struct rpc_create_args args = {
280 .net = &init_net, 282 .net = net,
281 .protocol = XPRT_TRANSPORT_TCP, 283 .protocol = XPRT_TRANSPORT_TCP,
282 .address = (struct sockaddr *)&rpcb_inaddr_loopback, 284 .address = (struct sockaddr *)&rpcb_inaddr_loopback,
283 .addrsize = sizeof(rpcb_inaddr_loopback), 285 .addrsize = sizeof(rpcb_inaddr_loopback),
@@ -311,7 +313,7 @@ static int rpcb_create_local_net(void)
311 clnt4 = NULL; 313 clnt4 = NULL;
312 } 314 }
313 315
314 rpcb_set_local(clnt, clnt4); 316 rpcb_set_local(net, clnt, clnt4);
315 317
316out: 318out:
317 return result; 319 return result;
@@ -325,16 +327,17 @@ int rpcb_create_local(void)
325{ 327{
326 static DEFINE_MUTEX(rpcb_create_local_mutex); 328 static DEFINE_MUTEX(rpcb_create_local_mutex);
327 int result = 0; 329 int result = 0;
330 struct net *net = &init_net;
328 331
329 if (rpcb_get_local()) 332 if (rpcb_get_local(net))
330 return result; 333 return result;
331 334
332 mutex_lock(&rpcb_create_local_mutex); 335 mutex_lock(&rpcb_create_local_mutex);
333 if (rpcb_get_local()) 336 if (rpcb_get_local(net))
334 goto out; 337 goto out;
335 338
336 if (rpcb_create_local_unix() != 0) 339 if (rpcb_create_local_unix(net) != 0)
337 result = rpcb_create_local_net(); 340 result = rpcb_create_local_net(net);
338 341
339out: 342out:
340 mutex_unlock(&rpcb_create_local_mutex); 343 mutex_unlock(&rpcb_create_local_mutex);