diff options
author | Jaegeuk Kim <jaegeuk@kernel.org> | 2014-10-17 17:14:16 -0400 |
---|---|---|
committer | Jaegeuk Kim <jaegeuk@kernel.org> | 2014-11-03 19:07:31 -0500 |
commit | af41d3ee00bf97bfc3bd64bce6d7a92e85955e98 (patch) | |
tree | 317fa5d31729a361bf39727701de5705fcbda239 /fs/f2fs | |
parent | 4a257ed677cb68a2096358e58b61efacf85d5f16 (diff) |
f2fs: avoid infinite loop at cp_error
This patch avoids an infinite loop in sync_dirty_inode_page when -EIO was
detected.
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
Diffstat (limited to 'fs/f2fs')
-rw-r--r-- | fs/f2fs/checkpoint.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/fs/f2fs/checkpoint.c b/fs/f2fs/checkpoint.c index dd10a031c052..ca514d599b79 100644 --- a/fs/f2fs/checkpoint.c +++ b/fs/f2fs/checkpoint.c | |||
@@ -731,6 +731,9 @@ void sync_dirty_dir_inodes(struct f2fs_sb_info *sbi) | |||
731 | struct dir_inode_entry *entry; | 731 | struct dir_inode_entry *entry; |
732 | struct inode *inode; | 732 | struct inode *inode; |
733 | retry: | 733 | retry: |
734 | if (unlikely(f2fs_cp_error(sbi))) | ||
735 | return; | ||
736 | |||
734 | spin_lock(&sbi->dir_inode_lock); | 737 | spin_lock(&sbi->dir_inode_lock); |
735 | 738 | ||
736 | head = &sbi->dir_inode_list; | 739 | head = &sbi->dir_inode_list; |