SUNRPC: Teach the RPC portmapper to use the new rpc_peeraddr() API.
authorChuck Lever <chuck.lever@oracle.com>
Wed, 23 Aug 2006 00:06:17 +0000 (20:06 -0400)
committerTrond Myklebust <Trond.Myklebust@netapp.com>
Sat, 23 Sep 2006 03:24:46 +0000 (23:24 -0400)
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: Chuck Lever <chuck.lever@oracle.com>
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
net/sunrpc/pmap_clnt.c

index f7b279a63baa8328d565cf67f877461c5156b0da..3eee8e907275c7269ef69c3d35d02c636b25590e 100644 (file)
@@ -89,7 +89,7 @@ void rpc_getport(struct rpc_task *task)
 {
        struct rpc_clnt *clnt = task->tk_client;
        struct rpc_xprt *xprt = task->tk_xprt;
-       struct sockaddr_in *sap = &xprt->addr;
+       struct sockaddr_in addr;
        struct portmap_args *map;
        struct rpc_clnt *pmap_clnt;
        struct rpc_task *child;
@@ -124,7 +124,8 @@ void rpc_getport(struct rpc_task *task)
        map->pm_port = 0;
        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)) {
                task->tk_status = PTR_ERR(pmap_clnt);
                goto bailout;