diff options
author | Miklos Szeredi <miklos@szeredi.hu> | 2007-11-29 01:22:03 +0100 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-11-29 18:24:54 +0100 |
commit | 08b633070ad5fa17a837428a601c32cf3db6aafd (patch) | |
tree | 3aa400a5f3f70bfa99f871f9aa3b80610ebb0053 /fs/fuse/dir.c | |
parent | fuse: fix uninitialized field in fuse_inode (diff) | |
download | linux-08b633070ad5fa17a837428a601c32cf3db6aafd.tar.xz linux-08b633070ad5fa17a837428a601c32cf3db6aafd.zip |
fuse: fix attribute caching after rename
Invalidate attributes on rename, since some filesystems may update
st_ctime. Reported by Szabolcs Szakacsits
Signed-off-by: Miklos Szeredi <mszeredi@suse.cz>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs/fuse/dir.c')
-rw-r--r-- | fs/fuse/dir.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c index dfc32dc97f7f..80d2f5292cf9 100644 --- a/fs/fuse/dir.c +++ b/fs/fuse/dir.c @@ -657,6 +657,9 @@ static int fuse_rename(struct inode *olddir, struct dentry *oldent, err = req->out.h.error; fuse_put_request(fc, req); if (!err) { + /* ctime changes */ + fuse_invalidate_attr(oldent->d_inode); + fuse_invalidate_attr(olddir); if (olddir != newdir) fuse_invalidate_attr(newdir); |