aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Sandeen <sandeen@redhat.com>2012-09-26 23:30:12 -0400
committerTheodore Ts'o <tytso@mit.edu>2012-09-26 23:30:12 -0400
commitc25f9bc6143f4cb4dc31d2ad7a6fe4e4005fc414 (patch)
tree35b45f146ece8fdd2deb6a62739f685e74bf18ab
parentb794e7a6ebfbddb819b0e75ab59ada6b08a285f2 (diff)
ext4: don't clear orphan list on ro mount with errors
If the file system contains errors and it is being mounted read-only, don't clear the orphan list. We should minimize changes to the file system if it is mounted read-only. Signed-off-by: Eric Sandeen <sandeen@redhat.com> Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
-rw-r--r--fs/ext4/super.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/fs/ext4/super.c b/fs/ext4/super.c
index 7bef0a4bc518..a53a23aef5e3 100644
--- a/fs/ext4/super.c
+++ b/fs/ext4/super.c
@@ -2177,10 +2177,12 @@ static void ext4_orphan_cleanup(struct super_block *sb,
2177 } 2177 }
2178 2178
2179 if (EXT4_SB(sb)->s_mount_state & EXT4_ERROR_FS) { 2179 if (EXT4_SB(sb)->s_mount_state & EXT4_ERROR_FS) {
2180 if (es->s_last_orphan) 2180 /* don't clear list on RO mount w/ errors */
2181 if (es->s_last_orphan && !(s_flags & MS_RDONLY)) {
2181 jbd_debug(1, "Errors on filesystem, " 2182 jbd_debug(1, "Errors on filesystem, "
2182 "clearing orphan list.\n"); 2183 "clearing orphan list.\n");
2183 es->s_last_orphan = 0; 2184 es->s_last_orphan = 0;
2185 }
2184 jbd_debug(1, "Skipping orphan recovery on fs with errors.\n"); 2186 jbd_debug(1, "Skipping orphan recovery on fs with errors.\n");
2185 return; 2187 return;
2186 } 2188 }