]> git.baikalelectronics.ru Git - kernel.git/commit
svcrdma: Ignore source port when computing DRC hash
authorChuck Lever <chuck.lever@oracle.com>
Tue, 11 Jun 2019 15:01:16 +0000 (11:01 -0400)
committerJ. Bruce Fields <bfields@redhat.com>
Wed, 19 Jun 2019 20:40:40 +0000 (16:40 -0400)
commit6259c11422d598a0966c13e699f3d5a2509a9620
tree3a5a50ac864afc4b4cfeafb8738b8f6e5bb3341c
parenta625c11366e50a3384d4004c5c5e549d155ccb68
svcrdma: Ignore source port when computing DRC hash

The DRC appears to be effectively empty after an RPC/RDMA transport
reconnect. The problem is that each connection uses a different
source port, which defeats the DRC hash.

Clients always have to disconnect before they send retransmissions
to reset the connection's credit accounting, thus every retransmit
on NFS/RDMA will miss the DRC.

An NFS/RDMA client's IP source port is meaningless for RDMA
transports. The transport layer typically sets the source port value
on the connection to a random ephemeral port. The server already
ignores it for the "secure port" check. See commit 448622600549
("NFSD: Ignore client's source port on RDMA transports").

The Linux NFS server's DRC resolves XID collisions from the same
source IP address by using the checksum of the first 200 bytes of
the RPC call header.

Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
Cc: stable@vger.kernel.org # v4.14+
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
net/sunrpc/xprtrdma/svc_rdma_transport.c