diff options
author | Theodore Ts'o <tytso@mit.edu> | 2011-11-07 10:47:42 -0500 |
---|---|---|
committer | Theodore Ts'o <tytso@mit.edu> | 2011-11-07 10:47:42 -0500 |
commit | eb513689c97e3e73bb9b4459d490a8e894b4a546 (patch) | |
tree | 767931920c50055b4416b4554fa2dfac4c579b2a /fs/ext4 | |
parent | 5c8a0fbba543d9428a486f0d1282bbcf3cf1d95a (diff) | |
download | op-kernel-dev-eb513689c97e3e73bb9b4459d490a8e894b4a546.zip op-kernel-dev-eb513689c97e3e73bb9b4459d490a8e894b4a546.tar.gz |
ext4: ignore journalled data options on remount if fs has no journal
This avoids a confusing failure in the init scripts when the
/etc/fstab has data=writeback or data=journal but the file system does
not have a journal. So check for this case explicitly, and warn the
user that we are ignoring the (pointless, since they have no journal)
data=* mount option.
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Diffstat (limited to 'fs/ext4')
-rw-r--r-- | fs/ext4/super.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/fs/ext4/super.c b/fs/ext4/super.c index 9953d80..0435013 100644 --- a/fs/ext4/super.c +++ b/fs/ext4/super.c @@ -1683,7 +1683,9 @@ static int parse_options(char *options, struct super_block *sb, data_opt = EXT4_MOUNT_WRITEBACK_DATA; datacheck: if (is_remount) { - if (test_opt(sb, DATA_FLAGS) != data_opt) { + if (!sbi->s_journal) + ext4_msg(sb, KERN_WARNING, "Remounting file system with no journal so ignoring journalled data option"); + else if (test_opt(sb, DATA_FLAGS) != data_opt) { ext4_msg(sb, KERN_ERR, "Cannot change data mode on remount"); return 0; |