aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLiu Bo <bo.li.liu@oracle.com>2016-12-01 16:43:31 -0500
committerDavid Sterba <dsterba@suse.com>2017-01-19 12:02:22 -0500
commit91298eec05cd8d4e828cf7ee5d4a6334f70cf69a (patch)
tree20aa96d1fbc65c4149890a3db9b7071e20803cba
parent97dcdea076ecef41ea4aaa23d4397c2f622e4265 (diff)
Btrfs: fix truncate down when no_holes feature is enabled
For such a file mapping, [0-4k][hole][8k-12k] In NO_HOLES mode, we don't have the [hole] extent any more. Commit c1aa45759e90 ("Btrfs: fix shrinking truncate when the no_holes feature is enabled") fixed disk isize not being updated in NO_HOLES mode when data is not flushed. However, even if data has been flushed, we can still have trouble in updating disk isize since we updated disk isize to 'start' of the last evicted extent. Reviewed-by: Chris Mason <clm@fb.com> Signed-off-by: Liu Bo <bo.li.liu@oracle.com> Signed-off-by: David Sterba <dsterba@suse.com>
-rw-r--r--fs/btrfs/inode.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c
index bed6cf5f67a4..177e7284909c 100644
--- a/fs/btrfs/inode.c
+++ b/fs/btrfs/inode.c
@@ -4505,8 +4505,19 @@ search_again:
4505 if (found_type > min_type) { 4505 if (found_type > min_type) {
4506 del_item = 1; 4506 del_item = 1;
4507 } else { 4507 } else {
4508 if (item_end < new_size) 4508 if (item_end < new_size) {
4509 /*
4510 * With NO_HOLES mode, for the following mapping
4511 *
4512 * [0-4k][hole][8k-12k]
4513 *
4514 * if truncating isize down to 6k, it ends up
4515 * isize being 8k.
4516 */
4517 if (btrfs_fs_incompat(root->fs_info, NO_HOLES))
4518 last_size = new_size;
4509 break; 4519 break;
4520 }
4510 if (found_key.offset >= new_size) 4521 if (found_key.offset >= new_size)
4511 del_item = 1; 4522 del_item = 1;
4512 else 4523 else