fs: convert core infrastructure to new timestamp accessors
Convert the core vfs code to use the new timestamp accessor functions. Signed-off-by: Jeff Layton <jlayton@kernel.org> Link: https://lore.kernel.org/r/20231004185239.80830-2-jlayton@kernel.org Signed-off-by: Christian Brauner <brauner@kernel.org>
This commit is contained in:
committed by
Christian Brauner
parent
077c212f03
commit
16a9496523
35
fs/inode.c
35
fs/inode.c
@ -1837,27 +1837,29 @@ EXPORT_SYMBOL(bmap);
|
||||
static int relatime_need_update(struct vfsmount *mnt, struct inode *inode,
|
||||
struct timespec64 now)
|
||||
{
|
||||
struct timespec64 ctime;
|
||||
struct timespec64 atime, mtime, ctime;
|
||||
|
||||
if (!(mnt->mnt_flags & MNT_RELATIME))
|
||||
return 1;
|
||||
/*
|
||||
* Is mtime younger than or equal to atime? If yes, update atime:
|
||||
*/
|
||||
if (timespec64_compare(&inode->i_mtime, &inode->i_atime) >= 0)
|
||||
atime = inode_get_atime(inode);
|
||||
mtime = inode_get_mtime(inode);
|
||||
if (timespec64_compare(&mtime, &atime) >= 0)
|
||||
return 1;
|
||||
/*
|
||||
* Is ctime younger than or equal to atime? If yes, update atime:
|
||||
*/
|
||||
ctime = inode_get_ctime(inode);
|
||||
if (timespec64_compare(&ctime, &inode->i_atime) >= 0)
|
||||
if (timespec64_compare(&ctime, &atime) >= 0)
|
||||
return 1;
|
||||
|
||||
/*
|
||||
* Is the previous atime value older than a day? If yes,
|
||||
* update atime:
|
||||
*/
|
||||
if ((long)(now.tv_sec - inode->i_atime.tv_sec) >= 24*60*60)
|
||||
if ((long)(now.tv_sec - atime.tv_sec) >= 24*60*60)
|
||||
return 1;
|
||||
/*
|
||||
* Good, we can skip the atime update:
|
||||
@ -1888,12 +1890,13 @@ int inode_update_timestamps(struct inode *inode, int flags)
|
||||
|
||||
if (flags & (S_MTIME|S_CTIME|S_VERSION)) {
|
||||
struct timespec64 ctime = inode_get_ctime(inode);
|
||||
struct timespec64 mtime = inode_get_mtime(inode);
|
||||
|
||||
now = inode_set_ctime_current(inode);
|
||||
if (!timespec64_equal(&now, &ctime))
|
||||
updated |= S_CTIME;
|
||||
if (!timespec64_equal(&now, &inode->i_mtime)) {
|
||||
inode->i_mtime = now;
|
||||
if (!timespec64_equal(&now, &mtime)) {
|
||||
inode_set_mtime_to_ts(inode, now);
|
||||
updated |= S_MTIME;
|
||||
}
|
||||
if (IS_I_VERSION(inode) && inode_maybe_inc_iversion(inode, updated))
|
||||
@ -1903,8 +1906,10 @@ int inode_update_timestamps(struct inode *inode, int flags)
|
||||
}
|
||||
|
||||
if (flags & S_ATIME) {
|
||||
if (!timespec64_equal(&now, &inode->i_atime)) {
|
||||
inode->i_atime = now;
|
||||
struct timespec64 atime = inode_get_atime(inode);
|
||||
|
||||
if (!timespec64_equal(&now, &atime)) {
|
||||
inode_set_atime_to_ts(inode, now);
|
||||
updated |= S_ATIME;
|
||||
}
|
||||
}
|
||||
@ -1963,7 +1968,7 @@ EXPORT_SYMBOL(inode_update_time);
|
||||
bool atime_needs_update(const struct path *path, struct inode *inode)
|
||||
{
|
||||
struct vfsmount *mnt = path->mnt;
|
||||
struct timespec64 now;
|
||||
struct timespec64 now, atime;
|
||||
|
||||
if (inode->i_flags & S_NOATIME)
|
||||
return false;
|
||||
@ -1989,7 +1994,8 @@ bool atime_needs_update(const struct path *path, struct inode *inode)
|
||||
if (!relatime_need_update(mnt, inode, now))
|
||||
return false;
|
||||
|
||||
if (timespec64_equal(&inode->i_atime, &now))
|
||||
atime = inode_get_atime(inode);
|
||||
if (timespec64_equal(&atime, &now))
|
||||
return false;
|
||||
|
||||
return true;
|
||||
@ -2106,17 +2112,18 @@ static int inode_needs_update_time(struct inode *inode)
|
||||
{
|
||||
int sync_it = 0;
|
||||
struct timespec64 now = current_time(inode);
|
||||
struct timespec64 ctime;
|
||||
struct timespec64 ts;
|
||||
|
||||
/* First try to exhaust all avenues to not sync */
|
||||
if (IS_NOCMTIME(inode))
|
||||
return 0;
|
||||
|
||||
if (!timespec64_equal(&inode->i_mtime, &now))
|
||||
ts = inode_get_mtime(inode);
|
||||
if (!timespec64_equal(&ts, &now))
|
||||
sync_it = S_MTIME;
|
||||
|
||||
ctime = inode_get_ctime(inode);
|
||||
if (!timespec64_equal(&ctime, &now))
|
||||
ts = inode_get_ctime(inode);
|
||||
if (!timespec64_equal(&ts, &now))
|
||||
sync_it |= S_CTIME;
|
||||
|
||||
if (IS_I_VERSION(inode) && inode_iversion_need_inc(inode))
|
||||
|
Reference in New Issue
Block a user