[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <176169811764.1426244.5194845806307778812.stgit@frogsfrogsfrogs>
Date: Tue, 28 Oct 2025 17:55:55 -0700
From: "Darrick J. Wong" <djwong@...nel.org>
To: djwong@...nel.org, miklos@...redi.hu
Cc: joannelkoong@...il.com, bernd@...ernd.com, neal@...pa.dev,
linux-ext4@...r.kernel.org, linux-fsdevel@...r.kernel.org
Subject: [PATCH 8/9] fuse: update ctime when updating acls on an iomap inode
From: Darrick J. Wong <djwong@...nel.org>
In iomap mode, the fuse kernel driver is in charge of updating file
attributes, so we need to update ctime after an ACL change.
Signed-off-by: "Darrick J. Wong" <djwong@...nel.org>
---
fs/fuse/acl.c | 17 ++++++++++++++++-
1 file changed, 16 insertions(+), 1 deletion(-)
diff --git a/fs/fuse/acl.c b/fs/fuse/acl.c
index 4ba65ded008649..bdd209b9908c2d 100644
--- a/fs/fuse/acl.c
+++ b/fs/fuse/acl.c
@@ -111,6 +111,7 @@ int fuse_set_acl(struct mnt_idmap *idmap, struct dentry *dentry,
struct fuse_conn *fc = get_fuse_conn(inode);
const char *name;
umode_t mode = inode->i_mode;
+ const bool is_iomap = fuse_inode_has_iomap(inode);
int ret;
if (fuse_is_bad(inode))
@@ -182,10 +183,24 @@ int fuse_set_acl(struct mnt_idmap *idmap, struct dentry *dentry,
ret = 0;
}
- /* If we scheduled a mode update above, push that to userspace now. */
if (!ret) {
struct iattr attr = { };
+ /*
+ * When we're running in iomap mode, we need to update mode and
+ * ctime ourselves instead of letting the fuse server figure
+ * that out.
+ */
+ if (is_iomap) {
+ attr.ia_valid |= ATTR_CTIME;
+ inode_set_ctime_current(inode);
+ attr.ia_ctime = inode_get_ctime(inode);
+ }
+
+ /*
+ * If we scheduled a mode update above, push that to userspace
+ * now.
+ */
if (mode != inode->i_mode) {
attr.ia_valid |= ATTR_MODE;
attr.ia_mode = mode;
Powered by blists - more mailing lists