sunrpc: set cl_max_connect when cloning an rpc_clnt
authorScott Mayhew <smayhew@redhat.com>
Wed, 1 Jun 2022 17:34:49 +0000 (13:34 -0400)
committerAnna Schumaker <Anna.Schumaker@Netapp.com>
Tue, 7 Jun 2022 14:36:33 +0000 (10:36 -0400)
commit304791255a2dc1c9be7e7c8a6cbdb31b6847b0e5
treeb3a4945b24a1fcd350fb951284e0860b80cd0000
parent880265c77ac415090090d1fe72a188fee71cb458
sunrpc: set cl_max_connect when cloning an rpc_clnt

If the initial attempt at trunking detection using the krb5i auth flavor
fails with -EACCES, -NFS4ERR_CLID_INUSE, or -NFS4ERR_WRONGSEC, then the
NFS client tries again using auth_sys, cloning the rpc_clnt in the
process.  If this second attempt at trunking detection succeeds, then
the resulting nfs_client->cl_rpcclient winds up having cl_max_connect=0
and subsequent attempts to add additional transport connections to the
rpc_clnt will fail with a message similar to the following being logged:

[502044.312640] SUNRPC: reached max allowed number (0) did not add
transport to server: 192.168.122.3

Signed-off-by: Scott Mayhew <smayhew@redhat.com>
Fixes: dc48e0abee24 ("SUNRPC enforce creation of no more than max_connect xprts")
Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com>
net/sunrpc/clnt.c