diff options
author | Josef Bacik <josef@redhat.com> | 2012-03-26 09:59:21 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2012-06-01 12:07:25 -0400 |
commit | c3b2da314834499f34cba94f7053e55f6d6f92d8 (patch) | |
tree | 7012b569ee9e0781761a8eb388190979441583c7 /include/linux | |
parent | 033369d1af1264abc23bea2e174aa47cdd212f6f (diff) |
fs: introduce inode operation ->update_time
Btrfs has to make sure we have space to allocate new blocks in order to modify
the inode, so updating time can fail. We've gotten around this by having our
own file_update_time but this is kind of a pain, and Christoph has indicated he
would like to make xfs do something different with atime updates. So introduce
->update_time, where we will deal with i_version an a/m/c time updates and
indicate which changes need to be made. The normal version just does what it
has always done, updates the time and marks the inode dirty, and then
filesystems can choose to do something different.
I've gone through all of the users of file_update_time and made them check for
errors with the exception of the fault code since it's complicated and I wasn't
quite sure what to do there, also Jan is going to be pushing the file time
updates into page_mkwrite for those who have it so that should satisfy btrfs and
make it not a big deal to check the file_update_time() return code in the
generic fault path. Thanks,
Signed-off-by: Josef Bacik <josef@redhat.com>
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/fs.h | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/include/linux/fs.h b/include/linux/fs.h index cdc1a9630948..57fc70574d20 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h | |||
@@ -1684,6 +1684,7 @@ struct inode_operations { | |||
1684 | void (*truncate_range)(struct inode *, loff_t, loff_t); | 1684 | void (*truncate_range)(struct inode *, loff_t, loff_t); |
1685 | int (*fiemap)(struct inode *, struct fiemap_extent_info *, u64 start, | 1685 | int (*fiemap)(struct inode *, struct fiemap_extent_info *, u64 start, |
1686 | u64 len); | 1686 | u64 len); |
1687 | int (*update_time)(struct inode *, struct timespec *, int); | ||
1687 | } ____cacheline_aligned; | 1688 | } ____cacheline_aligned; |
1688 | 1689 | ||
1689 | struct seq_file; | 1690 | struct seq_file; |
@@ -1843,6 +1844,13 @@ static inline void inode_inc_iversion(struct inode *inode) | |||
1843 | spin_unlock(&inode->i_lock); | 1844 | spin_unlock(&inode->i_lock); |
1844 | } | 1845 | } |
1845 | 1846 | ||
1847 | enum file_time_flags { | ||
1848 | S_ATIME = 1, | ||
1849 | S_MTIME = 2, | ||
1850 | S_CTIME = 4, | ||
1851 | S_VERSION = 8, | ||
1852 | }; | ||
1853 | |||
1846 | extern void touch_atime(struct path *); | 1854 | extern void touch_atime(struct path *); |
1847 | static inline void file_accessed(struct file *file) | 1855 | static inline void file_accessed(struct file *file) |
1848 | { | 1856 | { |
@@ -2579,7 +2587,7 @@ extern int inode_change_ok(const struct inode *, struct iattr *); | |||
2579 | extern int inode_newsize_ok(const struct inode *, loff_t offset); | 2587 | extern int inode_newsize_ok(const struct inode *, loff_t offset); |
2580 | extern void setattr_copy(struct inode *inode, const struct iattr *attr); | 2588 | extern void setattr_copy(struct inode *inode, const struct iattr *attr); |
2581 | 2589 | ||
2582 | extern void file_update_time(struct file *file); | 2590 | extern int file_update_time(struct file *file); |
2583 | 2591 | ||
2584 | extern int generic_show_options(struct seq_file *m, struct dentry *root); | 2592 | extern int generic_show_options(struct seq_file *m, struct dentry *root); |
2585 | extern void save_mount_options(struct super_block *sb, char *options); | 2593 | extern void save_mount_options(struct super_block *sb, char *options); |