|
@@ -1314,8 +1314,6 @@ static int f2fs_zero_range(struct inode *inode, loff_t offset, loff_t len,
|
|
|
if (ret)
|
|
|
goto out_sem;
|
|
|
|
|
|
- truncate_pagecache_range(inode, offset, offset + len - 1);
|
|
|
-
|
|
|
pg_start = ((unsigned long long) offset) >> PAGE_SHIFT;
|
|
|
pg_end = ((unsigned long long) offset + len) >> PAGE_SHIFT;
|
|
|
|
|
@@ -1345,12 +1343,19 @@ static int f2fs_zero_range(struct inode *inode, loff_t offset, loff_t len,
|
|
|
unsigned int end_offset;
|
|
|
pgoff_t end;
|
|
|
|
|
|
+ down_write(&F2FS_I(inode)->i_gc_rwsem[WRITE]);
|
|
|
+
|
|
|
+ truncate_pagecache_range(inode,
|
|
|
+ (loff_t)index << PAGE_SHIFT,
|
|
|
+ ((loff_t)pg_end << PAGE_SHIFT) - 1);
|
|
|
+
|
|
|
f2fs_lock_op(sbi);
|
|
|
|
|
|
set_new_dnode(&dn, inode, NULL, NULL, 0);
|
|
|
ret = f2fs_get_dnode_of_data(&dn, index, ALLOC_NODE);
|
|
|
if (ret) {
|
|
|
f2fs_unlock_op(sbi);
|
|
|
+ up_write(&F2FS_I(inode)->i_gc_rwsem[WRITE]);
|
|
|
goto out;
|
|
|
}
|
|
|
|
|
@@ -1359,7 +1364,9 @@ static int f2fs_zero_range(struct inode *inode, loff_t offset, loff_t len,
|
|
|
|
|
|
ret = f2fs_do_zero_range(&dn, index, end);
|
|
|
f2fs_put_dnode(&dn);
|
|
|
+
|
|
|
f2fs_unlock_op(sbi);
|
|
|
+ up_write(&F2FS_I(inode)->i_gc_rwsem[WRITE]);
|
|
|
|
|
|
f2fs_balance_fs(sbi, dn.node_changed);
|
|
|
|