nfsd: fix BindConnectionToSession so that it clears "cb path down"
Commit 01ae8969a9ee stopped the NFSv4.1/4.2 server from implicitly binding the back channel to a new TCP connection so that it conforms to RFC5661, for NFSv4.1/4.2. An effect of this for the Linux NFS client is that it will do a BindConnectionToSession when it sees NFSV4SEQ_CBPATHDOWN set in a sequence reply. It will do this for every RPC reply until it no longer sees the flag. Without that patch, this will happen until the client does an Open, which will clear LCL_CBDOWN. This patch clears LCL_CBDOWN right away, so that NFSV4SEQ_CBPATHDOWN will no longer be sent to the client in Sequence replies and the Linux client will not repeat the BindConnectionToSession RPCs. This is not critical for correct behaviour, but reduces RPC overheads for cases where the Open will not be done for a while. MFC after: 2 weeks
This commit is contained in:
parent
d218c6f6af
commit
6f2addd838
@ -6440,6 +6440,7 @@ nfsrv_bindconnsess(struct nfsrv_descript *nd, uint8_t *sessionid, int *foreaftp)
|
||||
sep->sess_crflags |= NFSV4CRSESS_CONNBACKCHAN;
|
||||
clp->lc_flags |= LCL_DONEBINDCONN |
|
||||
LCL_NEEDSCBNULL;
|
||||
clp->lc_flags &= ~LCL_CBDOWN;
|
||||
if (*foreaftp == NFSCDFS4_BACK)
|
||||
*foreaftp = NFSCDFS4_BACK;
|
||||
else
|
||||
|
Loading…
x
Reference in New Issue
Block a user