summaryrefslogtreecommitdiffstats
path: root/fs/f2fs/file.c
diff options
context:
space:
mode:
authorJaegeuk Kim <jaegeuk@kernel.org>2014-11-11 17:10:01 -0500
committerJaegeuk Kim <jaegeuk@kernel.org>2014-11-11 17:16:12 -0500
commit92dffd01790a5219d234fc83c3ba854f4490b7f4 (patch)
tree226fac18c0ac172e2bb6f9c966e03e9a8a8c81d9 /fs/f2fs/file.c
parent764d2c80401fcc7ee15933d604c6a783d5addc40 (diff)
f2fs: convert inline_data when i_size becomes large
If i_size becomes large outside of MAX_INLINE_DATA, we shoud convert the inode. Otherwise, we can make some dirty pages during the truncation, and those pages will be written through f2fs_write_data_page. At that moment, the inode has still inline_data, so that it tries to write non- zero pages into inline_data area. Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
Diffstat (limited to 'fs/f2fs/file.c')
-rw-r--r--fs/f2fs/file.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c
index edc3ce867e9c..7c2ec3ebebe0 100644
--- a/fs/f2fs/file.c
+++ b/fs/f2fs/file.c
@@ -522,6 +522,12 @@ void f2fs_truncate(struct inode *inode)
522 522
523 trace_f2fs_truncate(inode); 523 trace_f2fs_truncate(inode);
524 524
525 /* we should check inline_data size */
526 if (f2fs_has_inline_data(inode) && !f2fs_may_inline(inode)) {
527 if (f2fs_convert_inline_inode(inode))
528 return;
529 }
530
525 if (!truncate_blocks(inode, i_size_read(inode), true)) { 531 if (!truncate_blocks(inode, i_size_read(inode), true)) {
526 inode->i_mtime = inode->i_ctime = CURRENT_TIME; 532 inode->i_mtime = inode->i_ctime = CURRENT_TIME;
527 mark_inode_dirty(inode); 533 mark_inode_dirty(inode);