Commit 8a388c1
committed
NFSD: Skip sending CB_RECALL_ANY when the backchannel isn't up
NFSD sends CB_RECALL_ANY to clients when the server is low on
memory or that client has a large number of delegations outstanding.
We've seen cases where NFSD attempts to send CB_RECALL_ANY requests
to disconnected clients, and gets confused. These calls never go
anywhere if a backchannel transport to the target client isn't
available. Before the server can send any backchannel operation, the
client has to connect first and then do a BIND_CONN_TO_SESSION.
This patch doesn't address the root cause of the confusion, but
there's no need to queue up these optional operations if they can't
go anywhere.
Fixes: 44df6f4 ("NFSD: add delegation reaper to react to low memory condition")
Reviewed-by: Jeff Layton <[email protected]>
Cc: [email protected]
Signed-off-by: Chuck Lever <[email protected]>1 parent 45de52d commit 8a388c1
1 file changed
+12
-7
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6861 | 6861 | | |
6862 | 6862 | | |
6863 | 6863 | | |
6864 | | - | |
6865 | | - | |
6866 | | - | |
6867 | | - | |
6868 | | - | |
6869 | | - | |
| 6864 | + | |
| 6865 | + | |
| 6866 | + | |
| 6867 | + | |
| 6868 | + | |
| 6869 | + | |
| 6870 | + | |
| 6871 | + | |
| 6872 | + | |
| 6873 | + | |
| 6874 | + | |
| 6875 | + | |
6870 | 6876 | | |
6871 | | - | |
6872 | 6877 | | |
6873 | 6878 | | |
6874 | 6879 | | |
| |||
0 commit comments