You've already forked linux-apfs
mirror of
https://github.com/linux-apfs/linux-apfs.git
synced 2026-05-01 15:00:59 -07:00
[PATCH] ufs2: more correct work with time
This patch corrects work with time in UFS2 case. 1) According to UFS2 disk layout modification/access and so on "time" should be hold in two variables one 64bit for seconds and another 32bit for nanoseconds, at now for some unknown reason we suppose that "inode time" holds in three variables 32bit for seconds, 32bit for milliseconds and 32bit for nanoseconds. 2) We set amount of nanoseconds in "VFS inode" to 0 during read, instead of getting values from "on disk inode"(this should close http://bugzilla.kernel.org/show_bug.cgi?id=7991). Signed-off-by: Evgeniy Dushistov <dushistov@mail.ru> Cc: Bjoern Jacke <bjoern@j3e.de> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
committed by
Linus Torvalds
parent
94985134b7
commit
2189850f42
+2
-3
@@ -343,9 +343,8 @@ cg_found:
|
||||
lock_buffer(bh);
|
||||
ufs2_inode = (struct ufs2_inode *)bh->b_data;
|
||||
ufs2_inode += ufs_inotofsbo(inode->i_ino);
|
||||
ufs2_inode->ui_birthtime.tv_sec =
|
||||
cpu_to_fs32(sb, CURRENT_TIME_SEC.tv_sec);
|
||||
ufs2_inode->ui_birthtime.tv_usec = 0;
|
||||
ufs2_inode->ui_birthtime = cpu_to_fs64(sb, CURRENT_TIME.tv_sec);
|
||||
ufs2_inode->ui_birthnsec = cpu_to_fs32(sb, CURRENT_TIME.tv_nsec);
|
||||
mark_buffer_dirty(bh);
|
||||
unlock_buffer(bh);
|
||||
if (sb->s_flags & MS_SYNCHRONOUS)
|
||||
|
||||
+12
-12
@@ -668,12 +668,12 @@ static void ufs2_read_inode(struct inode *inode, struct ufs2_inode *ufs2_inode)
|
||||
inode->i_gid = fs32_to_cpu(sb, ufs2_inode->ui_gid);
|
||||
|
||||
inode->i_size = fs64_to_cpu(sb, ufs2_inode->ui_size);
|
||||
inode->i_atime.tv_sec = fs32_to_cpu(sb, ufs2_inode->ui_atime.tv_sec);
|
||||
inode->i_ctime.tv_sec = fs32_to_cpu(sb, ufs2_inode->ui_ctime.tv_sec);
|
||||
inode->i_mtime.tv_sec = fs32_to_cpu(sb, ufs2_inode->ui_mtime.tv_sec);
|
||||
inode->i_mtime.tv_nsec = 0;
|
||||
inode->i_atime.tv_nsec = 0;
|
||||
inode->i_ctime.tv_nsec = 0;
|
||||
inode->i_atime.tv_sec = fs64_to_cpu(sb, ufs2_inode->ui_atime);
|
||||
inode->i_ctime.tv_sec = fs64_to_cpu(sb, ufs2_inode->ui_ctime);
|
||||
inode->i_mtime.tv_sec = fs64_to_cpu(sb, ufs2_inode->ui_mtime);
|
||||
inode->i_atime.tv_nsec = fs32_to_cpu(sb, ufs2_inode->ui_atimensec);
|
||||
inode->i_ctime.tv_nsec = fs32_to_cpu(sb, ufs2_inode->ui_ctimensec);
|
||||
inode->i_mtime.tv_nsec = fs32_to_cpu(sb, ufs2_inode->ui_mtimensec);
|
||||
inode->i_blocks = fs64_to_cpu(sb, ufs2_inode->ui_blocks);
|
||||
inode->i_generation = fs32_to_cpu(sb, ufs2_inode->ui_gen);
|
||||
ufsi->i_flags = fs32_to_cpu(sb, ufs2_inode->ui_flags);
|
||||
@@ -803,12 +803,12 @@ static void ufs2_update_inode(struct inode *inode, struct ufs2_inode *ufs_inode)
|
||||
ufs_inode->ui_gid = cpu_to_fs32(sb, inode->i_gid);
|
||||
|
||||
ufs_inode->ui_size = cpu_to_fs64(sb, inode->i_size);
|
||||
ufs_inode->ui_atime.tv_sec = cpu_to_fs32(sb, inode->i_atime.tv_sec);
|
||||
ufs_inode->ui_atime.tv_usec = 0;
|
||||
ufs_inode->ui_ctime.tv_sec = cpu_to_fs32(sb, inode->i_ctime.tv_sec);
|
||||
ufs_inode->ui_ctime.tv_usec = 0;
|
||||
ufs_inode->ui_mtime.tv_sec = cpu_to_fs32(sb, inode->i_mtime.tv_sec);
|
||||
ufs_inode->ui_mtime.tv_usec = 0;
|
||||
ufs_inode->ui_atime = cpu_to_fs64(sb, inode->i_atime.tv_sec);
|
||||
ufs_inode->ui_atimensec = cpu_to_fs32(sb, inode->i_atime.tv_nsec);
|
||||
ufs_inode->ui_ctime = cpu_to_fs64(sb, inode->i_ctime.tv_sec);
|
||||
ufs_inode->ui_ctimensec = cpu_to_fs32(sb, inode->i_ctime.tv_nsec);
|
||||
ufs_inode->ui_mtime = cpu_to_fs64(sb, inode->i_mtime.tv_sec);
|
||||
ufs_inode->ui_mtimensec = cpu_to_fs32(sb, inode->i_mtime.tv_nsec);
|
||||
|
||||
ufs_inode->ui_blocks = cpu_to_fs64(sb, inode->i_blocks);
|
||||
ufs_inode->ui_flags = cpu_to_fs32(sb, ufsi->i_flags);
|
||||
|
||||
Reference in New Issue
Block a user