diff options
Diffstat (limited to 'fs/btrfs/inode.c')
-rw-r--r-- | fs/btrfs/inode.c | 45 |
1 files changed, 30 insertions, 15 deletions
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c index 3a6f953337b5..a7058fca3aab 100644 --- a/fs/btrfs/inode.c +++ b/fs/btrfs/inode.c | |||
@@ -424,9 +424,10 @@ again: | |||
424 | * and free up our temp pages. | 424 | * and free up our temp pages. |
425 | */ | 425 | */ |
426 | extent_clear_unlock_delalloc(inode, | 426 | extent_clear_unlock_delalloc(inode, |
427 | &BTRFS_I(inode)->io_tree, | 427 | &BTRFS_I(inode)->io_tree, |
428 | start, end, NULL, 1, 0, | 428 | start, end, NULL, |
429 | 0, 1, 1, 1, 0); | 429 | EXTENT_CLEAR_UNLOCK_PAGE | EXTENT_CLEAR_DIRTY | |
430 | EXTENT_SET_WRITEBACK | EXTENT_END_WRITEBACK); | ||
430 | ret = 0; | 431 | ret = 0; |
431 | goto free_pages_out; | 432 | goto free_pages_out; |
432 | } | 433 | } |
@@ -637,11 +638,13 @@ static noinline int submit_compressed_extents(struct inode *inode, | |||
637 | * clear dirty, set writeback and unlock the pages. | 638 | * clear dirty, set writeback and unlock the pages. |
638 | */ | 639 | */ |
639 | extent_clear_unlock_delalloc(inode, | 640 | extent_clear_unlock_delalloc(inode, |
640 | &BTRFS_I(inode)->io_tree, | 641 | &BTRFS_I(inode)->io_tree, |
641 | async_extent->start, | 642 | async_extent->start, |
642 | async_extent->start + | 643 | async_extent->start + |
643 | async_extent->ram_size - 1, | 644 | async_extent->ram_size - 1, |
644 | NULL, 1, 1, 0, 1, 1, 0, 0); | 645 | NULL, EXTENT_CLEAR_UNLOCK_PAGE | |
646 | EXTENT_CLEAR_UNLOCK | | ||
647 | EXTENT_CLEAR_DIRTY | EXTENT_SET_WRITEBACK); | ||
645 | 648 | ||
646 | ret = btrfs_submit_compressed_write(inode, | 649 | ret = btrfs_submit_compressed_write(inode, |
647 | async_extent->start, | 650 | async_extent->start, |
@@ -712,9 +715,14 @@ static noinline int cow_file_range(struct inode *inode, | |||
712 | start, end, 0, NULL); | 715 | start, end, 0, NULL); |
713 | if (ret == 0) { | 716 | if (ret == 0) { |
714 | extent_clear_unlock_delalloc(inode, | 717 | extent_clear_unlock_delalloc(inode, |
715 | &BTRFS_I(inode)->io_tree, | 718 | &BTRFS_I(inode)->io_tree, |
716 | start, end, NULL, 1, 1, | 719 | start, end, NULL, |
717 | 1, 1, 1, 1, 0); | 720 | EXTENT_CLEAR_UNLOCK_PAGE | |
721 | EXTENT_CLEAR_UNLOCK | | ||
722 | EXTENT_CLEAR_DELALLOC | | ||
723 | EXTENT_CLEAR_DIRTY | | ||
724 | EXTENT_SET_WRITEBACK | | ||
725 | EXTENT_END_WRITEBACK); | ||
718 | *nr_written = *nr_written + | 726 | *nr_written = *nr_written + |
719 | (end - start + PAGE_CACHE_SIZE) / PAGE_CACHE_SIZE; | 727 | (end - start + PAGE_CACHE_SIZE) / PAGE_CACHE_SIZE; |
720 | *page_started = 1; | 728 | *page_started = 1; |
@@ -738,6 +746,8 @@ static noinline int cow_file_range(struct inode *inode, | |||
738 | btrfs_drop_extent_cache(inode, start, start + num_bytes - 1, 0); | 746 | btrfs_drop_extent_cache(inode, start, start + num_bytes - 1, 0); |
739 | 747 | ||
740 | while (disk_num_bytes > 0) { | 748 | while (disk_num_bytes > 0) { |
749 | unsigned long op; | ||
750 | |||
741 | cur_alloc_size = min(disk_num_bytes, root->fs_info->max_extent); | 751 | cur_alloc_size = min(disk_num_bytes, root->fs_info->max_extent); |
742 | ret = btrfs_reserve_extent(trans, root, cur_alloc_size, | 752 | ret = btrfs_reserve_extent(trans, root, cur_alloc_size, |
743 | root->sectorsize, 0, alloc_hint, | 753 | root->sectorsize, 0, alloc_hint, |
@@ -789,10 +799,13 @@ static noinline int cow_file_range(struct inode *inode, | |||
789 | * Do set the Private2 bit so we know this page was properly | 799 | * Do set the Private2 bit so we know this page was properly |
790 | * setup for writepage | 800 | * setup for writepage |
791 | */ | 801 | */ |
802 | op = unlock ? EXTENT_CLEAR_UNLOCK_PAGE : 0; | ||
803 | op |= EXTENT_CLEAR_UNLOCK | EXTENT_CLEAR_DELALLOC | | ||
804 | EXTENT_SET_PRIVATE2; | ||
805 | |||
792 | extent_clear_unlock_delalloc(inode, &BTRFS_I(inode)->io_tree, | 806 | extent_clear_unlock_delalloc(inode, &BTRFS_I(inode)->io_tree, |
793 | start, start + ram_size - 1, | 807 | start, start + ram_size - 1, |
794 | locked_page, unlock, 1, | 808 | locked_page, op); |
795 | 1, 0, 0, 0, 1); | ||
796 | disk_num_bytes -= cur_alloc_size; | 809 | disk_num_bytes -= cur_alloc_size; |
797 | num_bytes -= cur_alloc_size; | 810 | num_bytes -= cur_alloc_size; |
798 | alloc_hint = ins.objectid + ins.offset; | 811 | alloc_hint = ins.objectid + ins.offset; |
@@ -1112,8 +1125,10 @@ out_check: | |||
1112 | BUG_ON(ret); | 1125 | BUG_ON(ret); |
1113 | 1126 | ||
1114 | extent_clear_unlock_delalloc(inode, &BTRFS_I(inode)->io_tree, | 1127 | extent_clear_unlock_delalloc(inode, &BTRFS_I(inode)->io_tree, |
1115 | cur_offset, cur_offset + num_bytes - 1, | 1128 | cur_offset, cur_offset + num_bytes - 1, |
1116 | locked_page, 1, 1, 1, 0, 0, 0, 1); | 1129 | locked_page, EXTENT_CLEAR_UNLOCK_PAGE | |
1130 | EXTENT_CLEAR_UNLOCK | EXTENT_CLEAR_DELALLOC | | ||
1131 | EXTENT_SET_PRIVATE2); | ||
1117 | cur_offset = extent_end; | 1132 | cur_offset = extent_end; |
1118 | if (cur_offset > end) | 1133 | if (cur_offset > end) |
1119 | break; | 1134 | break; |