Commit 081f79a9 authored by Chuck Lever's avatar Chuck Lever Committed by Trond Myklebust

SUNRPC: Teach the RPC portmapper to use the new rpc_peeraddr() API.

Hide the details of how the RPC client stores remote peer addresses from
the RPC portmapper.

Test plan:
Destructive testing (unplugging the network temporarily).  Connectathon
with UDP and TCP.  NFSv2/3 and NFSv4 mounting should be carefully checked.
Signed-off-by: default avatarChuck Lever <chuck.lever@oracle.com>
Signed-off-by: default avatarTrond Myklebust <Trond.Myklebust@netapp.com>
parent 44c31be2
...@@ -89,7 +89,7 @@ void rpc_getport(struct rpc_task *task) ...@@ -89,7 +89,7 @@ void rpc_getport(struct rpc_task *task)
{ {
struct rpc_clnt *clnt = task->tk_client; struct rpc_clnt *clnt = task->tk_client;
struct rpc_xprt *xprt = task->tk_xprt; struct rpc_xprt *xprt = task->tk_xprt;
struct sockaddr_in *sap = &xprt->addr; struct sockaddr_in addr;
struct portmap_args *map; struct portmap_args *map;
struct rpc_clnt *pmap_clnt; struct rpc_clnt *pmap_clnt;
struct rpc_task *child; struct rpc_task *child;
...@@ -124,7 +124,8 @@ void rpc_getport(struct rpc_task *task) ...@@ -124,7 +124,8 @@ void rpc_getport(struct rpc_task *task)
map->pm_port = 0; map->pm_port = 0;
map->pm_task = task; map->pm_task = task;
pmap_clnt = pmap_create(clnt->cl_server, sap, map->pm_prot, 0); rpc_peeraddr(clnt, (struct sockaddr *) &addr, sizeof(addr));
pmap_clnt = pmap_create(clnt->cl_server, &addr, map->pm_prot, 0);
if (IS_ERR(pmap_clnt)) { if (IS_ERR(pmap_clnt)) {
task->tk_status = PTR_ERR(pmap_clnt); task->tk_status = PTR_ERR(pmap_clnt);
goto bailout; goto bailout;
......
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