fs/ext4/super.c | 7 +++++++ 1 file changed, 7 insertions(+)
While the order of writing to the shutdown and read-only flags has been
enforced by a write memory barrier, the read side in remount does not
have a pairing read barrier.
In the event of a fs forced shutdown remounting as read-only,
remounting it again as read-write can succeed when the flag reads are
reordered such that sb_rdonly() returns true and
ext4_forced_shutdown() returns false.
Commit 4418e14112e3 ("ext4: Fix fsync error handling after filesystem
abort") has added the other barriers related to these two flags but
seems to have missed this one.
Signed-off-by: Fanqi Yu <fanqi.yu@columbia.edu>
---
fs/ext4/super.c | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/fs/ext4/super.c b/fs/ext4/super.c
index 044135796f2b..c5d3f8969dec 100644
--- a/fs/ext4/super.c
+++ b/fs/ext4/super.c
@@ -6542,6 +6542,13 @@ static int __ext4_remount(struct fs_context *fc, struct super_block *sb)
flush_work(&sbi->s_sb_upd_work);
if ((bool)(fc->sb_flags & SB_RDONLY) != sb_rdonly(sb)) {
+
+ /*
+ * Make sure we read the updated s_ext4_flags.
+ * Pairs with smp_wmb() in ext4_handle_error().
+ */
+ smp_rmb();
+
if (ext4_forced_shutdown(sb)) {
err = -EROFS;
goto restore_opts;
--
2.34.1
On Sun 15-09-24 17:08:04, Fanqi Yu wrote: > While the order of writing to the shutdown and read-only flags has been > enforced by a write memory barrier, the read side in remount does not > have a pairing read barrier. > > In the event of a fs forced shutdown remounting as read-only, > remounting it again as read-write can succeed when the flag reads are > reordered such that sb_rdonly() returns true and > ext4_forced_shutdown() returns false. > > Commit 4418e14112e3 ("ext4: Fix fsync error handling after filesystem > abort") has added the other barriers related to these two flags but > seems to have missed this one. > > Signed-off-by: Fanqi Yu <fanqi.yu@columbia.edu> Thanks for the patch but there's a changed queued in ext4 tree [1] which removes setting of SB_RDONLY flag in emergency remount because it has other problems as well. And after this change the memory ordering problem you speak about is not an issue anymore. Honza [1] https://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4.git/commit/?h=dev&id=d3476f3dad4ad68ae5f6b008ea6591d1520da5d8 > --- > fs/ext4/super.c | 7 +++++++ > 1 file changed, 7 insertions(+) > > diff --git a/fs/ext4/super.c b/fs/ext4/super.c > index 044135796f2b..c5d3f8969dec 100644 > --- a/fs/ext4/super.c > +++ b/fs/ext4/super.c > @@ -6542,6 +6542,13 @@ static int __ext4_remount(struct fs_context *fc, struct super_block *sb) > flush_work(&sbi->s_sb_upd_work); > > if ((bool)(fc->sb_flags & SB_RDONLY) != sb_rdonly(sb)) { > + > + /* > + * Make sure we read the updated s_ext4_flags. > + * Pairs with smp_wmb() in ext4_handle_error(). > + */ > + smp_rmb(); > + > if (ext4_forced_shutdown(sb)) { > err = -EROFS; > goto restore_opts; > -- > 2.34.1 > > -- Jan Kara <jack@suse.com> SUSE Labs, CR
© 2016 - 2024 Red Hat, Inc.