From: Andy Adamson <andros@xxxxxxxxxx> Signed-off-by: Andy Adamson <andros@xxxxxxxxxx> --- fs/nfs/nfs4client.c | 16 +++++++++++++++- net/sunrpc/xprtmultipath.c | 2 ++ 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/fs/nfs/nfs4client.c b/fs/nfs/nfs4client.c index 5f20acf..6736805 100644 --- a/fs/nfs/nfs4client.c +++ b/fs/nfs/nfs4client.c @@ -412,8 +412,22 @@ struct nfs_client *nfs4_init_client(struct nfs_client *clp, if (error < 0) goto error; - if (clp != old) + if (clp != old) { + if (clp->cl_minorversion != 0) { + struct rpc_xprt *add = clp->cl_rpcclient->cl_xprt; + struct xprt_create xprt_args = { + .ident = XPRT_TRANSPORT_TCP, + .net = old->cl_net, /* clp->cl_net ??*/ + .dstaddr = (struct sockaddr *)&add->addr, + .addrlen = add->addrlen, + .servername = clp->cl_hostname, + }; + /* Add this address as an alias */ + rpc_clnt_add_xprt(old->cl_rpcclient, &xprt_args, + rpc_clnt_test_and_add_xprt, NULL); + } clp->cl_preserve_clid = true; + } nfs_put_client(clp); return old; diff --git a/net/sunrpc/xprtmultipath.c b/net/sunrpc/xprtmultipath.c index 7be5bd2..f13419e 100644 --- a/net/sunrpc/xprtmultipath.c +++ b/net/sunrpc/xprtmultipath.c @@ -35,6 +35,8 @@ static void xprt_switch_add_xprt_locked(struct rpc_xprt_switch *xps, if (xps->xps_nxprts == 0) xps->xps_net = xprt->xprt_net; xps->xps_nxprts++; + pr_info("RPC: ADDED %s to xps %p xps_nxprts %d\n", + xprt->servername, xps, xps->xps_nxprts); } /** -- 1.8.3.1 -- To unsubscribe from this list: send the line "unsubscribe linux-nfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html