Skip to content

Commit 17637cb

Browse files
Miklos SzerediLinus Torvalds
authored andcommitted
fuse: improve utimes support
Add two new flags for setattr: FATTR_ATIME_NOW and FATTR_MTIME_NOW. These mean, that atime or mtime should be changed to the current time. Also it is now possible to update atime or mtime individually, not just together. Signed-off-by: Miklos Szeredi <[email protected]> Signed-off-by: Andrew Morton <[email protected]> Signed-off-by: Linus Torvalds <[email protected]>
1 parent d139d7f commit 17637cb

File tree

2 files changed

+27
-3
lines changed

2 files changed

+27
-3
lines changed

fs/fuse/dir.c

Lines changed: 25 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1014,6 +1014,20 @@ static int fuse_dir_fsync(struct file *file, struct dentry *de, int datasync)
10141014
return file ? fuse_fsync_common(file, de, datasync, 1) : 0;
10151015
}
10161016

1017+
static bool update_mtime(unsigned ivalid)
1018+
{
1019+
/* Always update if mtime is explicitly set */
1020+
if (ivalid & ATTR_MTIME_SET)
1021+
return true;
1022+
1023+
/* If it's an open(O_TRUNC) or an ftruncate(), don't update */
1024+
if ((ivalid & ATTR_SIZE) && (ivalid & (ATTR_OPEN | ATTR_FILE)))
1025+
return false;
1026+
1027+
/* In all other cases update */
1028+
return true;
1029+
}
1030+
10171031
static void iattr_to_fattr(struct iattr *iattr, struct fuse_setattr_in *arg)
10181032
{
10191033
unsigned ivalid = iattr->ia_valid;
@@ -1026,11 +1040,19 @@ static void iattr_to_fattr(struct iattr *iattr, struct fuse_setattr_in *arg)
10261040
arg->valid |= FATTR_GID, arg->gid = iattr->ia_gid;
10271041
if (ivalid & ATTR_SIZE)
10281042
arg->valid |= FATTR_SIZE, arg->size = iattr->ia_size;
1029-
/* You can only _set_ these together (they may change by themselves) */
1030-
if ((ivalid & (ATTR_ATIME | ATTR_MTIME)) == (ATTR_ATIME | ATTR_MTIME)) {
1031-
arg->valid |= FATTR_ATIME | FATTR_MTIME;
1043+
if (ivalid & ATTR_ATIME) {
1044+
arg->valid |= FATTR_ATIME;
10321045
arg->atime = iattr->ia_atime.tv_sec;
1046+
arg->atimensec = iattr->ia_atime.tv_nsec;
1047+
if (!(ivalid & ATTR_ATIME_SET))
1048+
arg->valid |= FATTR_ATIME_NOW;
1049+
}
1050+
if ((ivalid & ATTR_MTIME) && update_mtime(ivalid)) {
1051+
arg->valid |= FATTR_MTIME;
10331052
arg->mtime = iattr->ia_mtime.tv_sec;
1053+
arg->mtimensec = iattr->ia_mtime.tv_nsec;
1054+
if (!(ivalid & ATTR_MTIME_SET))
1055+
arg->valid |= FATTR_MTIME_NOW;
10341056
}
10351057
}
10361058

include/linux/fuse.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -83,6 +83,8 @@ struct fuse_file_lock {
8383
#define FATTR_ATIME (1 << 4)
8484
#define FATTR_MTIME (1 << 5)
8585
#define FATTR_FH (1 << 6)
86+
#define FATTR_ATIME_NOW (1 << 7)
87+
#define FATTR_MTIME_NOW (1 << 8)
8688

8789
/**
8890
* Flags returned by the OPEN request

0 commit comments

Comments
 (0)