aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
Diffstat (limited to 'fs')
-rw-r--r--fs/f2fs/file.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c
index 5cde363cf7a8..77426c7eb0f1 100644
--- a/fs/f2fs/file.c
+++ b/fs/f2fs/file.c
@@ -139,6 +139,7 @@ int f2fs_sync_file(struct file *file, loff_t start, loff_t end, int datasync)
139 struct inode *inode = file->f_mapping->host; 139 struct inode *inode = file->f_mapping->host;
140 struct f2fs_inode_info *fi = F2FS_I(inode); 140 struct f2fs_inode_info *fi = F2FS_I(inode);
141 struct f2fs_sb_info *sbi = F2FS_I_SB(inode); 141 struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
142 nid_t ino = inode->i_ino;
142 int ret = 0; 143 int ret = 0;
143 bool need_cp = false; 144 bool need_cp = false;
144 struct writeback_control wbc = { 145 struct writeback_control wbc = {
@@ -168,9 +169,9 @@ int f2fs_sync_file(struct file *file, loff_t start, loff_t end, int datasync)
168 * if there is no written data, don't waste time to write recovery info. 169 * if there is no written data, don't waste time to write recovery info.
169 */ 170 */
170 if (!is_inode_flag_set(fi, FI_APPEND_WRITE) && 171 if (!is_inode_flag_set(fi, FI_APPEND_WRITE) &&
171 !exist_written_data(sbi, inode->i_ino, APPEND_INO)) { 172 !exist_written_data(sbi, ino, APPEND_INO)) {
172 if (is_inode_flag_set(fi, FI_UPDATE_WRITE) || 173 if (is_inode_flag_set(fi, FI_UPDATE_WRITE) ||
173 exist_written_data(sbi, inode->i_ino, UPDATE_INO)) 174 exist_written_data(sbi, ino, UPDATE_INO))
174 goto flush_out; 175 goto flush_out;
175 goto out; 176 goto out;
176 } 177 }
@@ -208,23 +209,23 @@ int f2fs_sync_file(struct file *file, loff_t start, loff_t end, int datasync)
208 } 209 }
209 } else { 210 } else {
210 /* if there is no written node page, write its inode page */ 211 /* if there is no written node page, write its inode page */
211 while (!sync_node_pages(sbi, inode->i_ino, &wbc)) { 212 while (!sync_node_pages(sbi, ino, &wbc)) {
212 if (fsync_mark_done(sbi, inode->i_ino)) 213 if (fsync_mark_done(sbi, ino))
213 goto out; 214 goto out;
214 mark_inode_dirty_sync(inode); 215 mark_inode_dirty_sync(inode);
215 ret = f2fs_write_inode(inode, NULL); 216 ret = f2fs_write_inode(inode, NULL);
216 if (ret) 217 if (ret)
217 goto out; 218 goto out;
218 } 219 }
219 ret = wait_on_node_pages_writeback(sbi, inode->i_ino); 220 ret = wait_on_node_pages_writeback(sbi, ino);
220 if (ret) 221 if (ret)
221 goto out; 222 goto out;
222 223
223 /* once recovery info is written, don't need to tack this */ 224 /* once recovery info is written, don't need to tack this */
224 remove_dirty_inode(sbi, inode->i_ino, APPEND_INO); 225 remove_dirty_inode(sbi, ino, APPEND_INO);
225 clear_inode_flag(fi, FI_APPEND_WRITE); 226 clear_inode_flag(fi, FI_APPEND_WRITE);
226flush_out: 227flush_out:
227 remove_dirty_inode(sbi, inode->i_ino, UPDATE_INO); 228 remove_dirty_inode(sbi, ino, UPDATE_INO);
228 clear_inode_flag(fi, FI_UPDATE_WRITE); 229 clear_inode_flag(fi, FI_UPDATE_WRITE);
229 ret = f2fs_issue_flush(F2FS_I_SB(inode)); 230 ret = f2fs_issue_flush(F2FS_I_SB(inode));
230 } 231 }