This patch set corrects several bugs that occur when blocksize = 1k. The first bug appears in xfstests 75, 112, 127 and occurs because the partial pages appearing at the head and tail of a hole are not properly zeroed and unmapped A second bug in test 127 occurs when i_size and the end of the hole appear in the same page. Because punch hole needs to flush the pages in the hole, it will need to properly unmap the partial page appearing after i_size. A similar bug occurred during extra fsx testing for the first two patches. This bug happens because truncate also does not zero and unmap the partial page at the end of the file. Similar bugs also occurred when a write operation begins or ends in a hole or extends EOF. The partial page of the write operation needs to be zeroed and unmapped. These bugs are corrected using a new ext4_discard_partial_page_buffers routine that zeros a specified region of a page, and unmaps buffer heads for any block aligned region of the page that was completely zeroed. This set also contains a fix for a bug reported by Lukas while working on a new patch to add discard support to loop devices using punch hole. This bug occurs when calculating the byte block offset for very large holes. Since the code now needs the byte offset of the pages instead of the blocks, the problem code is simply removed. Lastly the set contains a patch to lock i_mutex for punch hole. Yongquiang noticed that the vfs locks i_mutex for truncate, but not for fallocate, so fallocate will need to take i_mutex before calling punch hole. This patch set has passed the following tests (for both 1k and 4k blocksizes): xfstests 75, 112, 127, 130, 252 and 256 fsx stress test (12 hours) v1 -> v2 Added EXT4_BLOCK_ZERO_DISCARD_BUFFER flag v2 -> v3 Moved code out of ext4_zero_block_page_range and in to new ext4_unmap_page_range function v3 -> v4 Renamed ext4_unmap_page_range to ext4_unmap_partial_page_buffers Moved ext4_unmap_partial_page_buffers from inode.c to extents.c Corrected comments for non block/page aligned handling Added checks to avoid unnecessary page unmaps Removed unneeded journaling and mapping from new routine v4 -> v5 Renamed ext4_unmap_partial_page_buffers to ext4_discard_partial_page_buffers_no_lock and added new ext4_discard_partial_page_buffers wrapper function Modified ext4_discard_partial_page_buffers_no_lock to zero the page as well as unmap buffers Moved ext4_discard_partial_page_buffers functions back to inode.c, and also put in a separate patch. Added extra patches for write bugs and truncate bugs Added extra patch for large hole calculation v5 -> v6 Merged patch 4 into patch 2 since block offsets are no longer needed Removed uneeded ClearPageUptodate when unmapping buffer heads Patch set now passes test 130. The ext4_discard_partial_page_buffers_no_lock routine was modified to map buffer heads for unblock aligned regions of the page (if needed) so that they can be updated with the contents of the block before being partially zeroed v6 -> v7 Added feedback to simplify ext4_discard_partial_page_buffers_no_lock Remove journaling for buffer heads that are block aligned Do not mark unmapped buffers dirty (causes a warning) Added patch to lock i_mutex for punch hole Allison Henderson (6): ext4: Add new ext4_discard_partial_page_buffers routines ext4: fix xfstests 75, 112, 127 punch hole failure ext4: fix 2nd xfstests 127 punch hole failure ext4: Lock i_mutex for punch hole ext4: fix fsx truncate failure ext4: fix partial page writes fs/ext4/ext4.h | 11 +++ fs/ext4/extents.c | 126 ++++++++++++++++++++------- fs/ext4/indirect.c | 16 +++- fs/ext4/inode.c | 243 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 363 insertions(+), 33 deletions(-) -- To unsubscribe from this list: send the line "unsubscribe linux-ext4" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html