NFSv4.2: fix client's attribute cache management for copy_file_range
authorOlga Kornievskaia <kolga@netapp.com>
Wed, 16 Sep 2020 13:07:54 +0000 (09:07 -0400)
committerTrond Myklebust <trond.myklebust@hammerspace.com>
Wed, 16 Sep 2020 16:25:14 +0000 (12:25 -0400)
commit16abd2a0c124a6c3543c88ca4c53c997c9fb4114
tree32365b41de84b35ef68d77894bbe1e4355991517
parentd33030e2ee3508d65db5644551435310df86010e
NFSv4.2: fix client's attribute cache management for copy_file_range

After client is done with the COPY operation, it needs to invalidate
its pagecache (as it did no reading or writing of the data locally)
and it needs to invalidate it's attributes just like it would have
for a read on the source file and write on the destination file.

Once the linux server started giving out read delegations to
read+write opens, the destination file of the copy_file range
started having delegations and not doing syncup on close of the
file leading to xfstest failures for generic/430,431,432,433,565.

v2: changing cache_validity needs to be protected by the i_lock.

Reported-by: Murphy Zhou <jencce.kernel@gmail.com>
Fixes: 2e72448b07dc ("NFS: Add COPY nfs operation")
Signed-off-by: Olga Kornievskaia <kolga@netapp.com>
Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
fs/nfs/nfs42proc.c