diff options
| -rw-r--r-- | fs/ext2/super.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/fs/ext2/super.c b/fs/ext2/super.c index 0faf770fb776..1388802b7803 100644 --- a/fs/ext2/super.c +++ b/fs/ext2/super.c | |||
| @@ -1137,8 +1137,24 @@ static void ext2_sync_super(struct super_block *sb, struct ext2_super_block *es) | |||
| 1137 | static int ext2_sync_fs(struct super_block *sb, int wait) | 1137 | static int ext2_sync_fs(struct super_block *sb, int wait) |
| 1138 | { | 1138 | { |
| 1139 | struct ext2_super_block *es = EXT2_SB(sb)->s_es; | 1139 | struct ext2_super_block *es = EXT2_SB(sb)->s_es; |
| 1140 | struct buffer_head *sbh = EXT2_SB(sb)->s_sbh; | ||
| 1140 | 1141 | ||
| 1141 | lock_kernel(); | 1142 | lock_kernel(); |
| 1143 | if (buffer_write_io_error(sbh)) { | ||
| 1144 | /* | ||
| 1145 | * Oh, dear. A previous attempt to write the | ||
| 1146 | * superblock failed. This could happen because the | ||
| 1147 | * USB device was yanked out. Or it could happen to | ||
| 1148 | * be a transient write error and maybe the block will | ||
| 1149 | * be remapped. Nothing we can do but to retry the | ||
| 1150 | * write and hope for the best. | ||
| 1151 | */ | ||
| 1152 | ext2_msg(sb, KERN_ERR, | ||
| 1153 | "previous I/O error to superblock detected\n"); | ||
| 1154 | clear_buffer_write_io_error(sbh); | ||
| 1155 | set_buffer_uptodate(sbh); | ||
| 1156 | } | ||
| 1157 | |||
| 1142 | if (es->s_state & cpu_to_le16(EXT2_VALID_FS)) { | 1158 | if (es->s_state & cpu_to_le16(EXT2_VALID_FS)) { |
| 1143 | ext2_debug("setting valid to 0\n"); | 1159 | ext2_debug("setting valid to 0\n"); |
| 1144 | es->s_state &= cpu_to_le16(~EXT2_VALID_FS); | 1160 | es->s_state &= cpu_to_le16(~EXT2_VALID_FS); |
