Commit 16d99dce authored by Jeff Layton's avatar Jeff Layton Committed by Trond Myklebust
Browse files

nfs: fix utimensat() for atime with delegated timestamps



xfstest generic/221 is failing with delegated timestamps enabled.  When
the client holds a WRITE_ATTRS_DELEG delegation, and a userland process
does a utimensat() for only the atime, the ctime is not properly
updated. The problem is that the client tries to cache the atime update,
but there is no mtime update, so the delegated attribute update never
updates the ctime.

Delegated timestamps don't have a mechanism to update the ctime in
accordance with atime-only changes due to utimensat() and the like.
Change the client to issue an RPC in this case, so that the ctime gets
properly updated alongside the atime.

Fixes: 40f45ab3 ("NFS: Further fixes to attribute delegation a/mtime changes")
Reported-by: default avatarOlga Kornievskaia <aglo@umich.edu>
Signed-off-by: default avatarJeff Layton <jlayton@kernel.org>
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@hammerspace.com>
parent 3a06bac5
Loading
Loading
Loading
Loading
+1 −8
Original line number Diff line number Diff line
@@ -757,14 +757,7 @@ nfs_setattr(struct mnt_idmap *idmap, struct dentry *dentry,
	} else if (nfs_have_delegated_atime(inode) &&
		   attr->ia_valid & ATTR_ATIME &&
		   !(attr->ia_valid & ATTR_MTIME)) {
		if (attr->ia_valid & ATTR_ATIME_SET) {
			if (uid_eq(task_uid, owner_uid)) {
				spin_lock(&inode->i_lock);
				nfs_set_timestamps_to_ts(inode, attr);
				spin_unlock(&inode->i_lock);
				attr->ia_valid &= ~(ATTR_ATIME|ATTR_ATIME_SET);
			}
		} else {
		if (!(attr->ia_valid & ATTR_ATIME_SET)) {
			nfs_update_delegated_atime(inode);
			attr->ia_valid &= ~ATTR_ATIME;
		}