]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
NFSv4.2: fix CLONE/COPY attrs in presence of delegated attributes
authorOlga Kornievskaia <okorniev@redhat.com>
Fri, 17 Apr 2026 20:35:43 +0000 (16:35 -0400)
committerTrond Myklebust <trond.myklebust@hammerspace.com>
Wed, 22 Apr 2026 12:53:23 +0000 (08:53 -0400)
xfstest generic/407 is failing in 2 ways. It detects that after
doing a clone the client does not update it's mtime and it's ctime.
CLONE always sends a GETATTR operation and then calls
nfs_post_op_update_inode() based on the returned attributes.
Because of the delegated attributes the client ignores updating
the mtime. Then also, when delegated attributes are present, for
the change_attr the server replies with the same values as what
the client cached before and thus the generic/407 would flag that.
Instead, make sure we invalidate the blocks attr.

By adding updating delegated attributes in nfs42_copy_dest_done()
both COPY and CLONE would update mtime appropriately.

Fixes: e12912d94137 ("NFSv4: Add support for delegated atime and mtime attributes")
Signed-off-by: Olga Kornievskaia <okorniev@redhat.com>
Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
fs/nfs/nfs42proc.c

index 7e5c1172fc11c9d5a55b3621977ac83bb98f7c20..7602ede6f75f7c7afbe39076ce3521eef9a5d768 100644 (file)
@@ -401,6 +401,7 @@ static void nfs42_copy_dest_done(struct file *file, loff_t pos, loff_t len,
                                             NFS_INO_INVALID_MTIME |
                                             NFS_INO_INVALID_BLOCKS);
        spin_unlock(&inode->i_lock);
+       nfs_update_delegated_mtime(inode);
 }
 
 static ssize_t _nfs42_proc_copy(struct file *src,