This is a note to let you know that I've just added the patch titled erofs: ensure that the post-EOF tails are all zeroed to the 6.4-stable tree which can be found at: http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary The filename of the patch is: erofs-ensure-that-the-post-eof-tails-are-all-zeroed.patch and it can be found in the queue-6.4 subdirectory. If you, or anyone else, feels it should not be added to the stable tree, please let <stable@xxxxxxxxxxxxxxx> know about it. >From hsiangkao@xxxxxxxxxxxxxxxxx Sat Sep 2 09:30:52 2023 From: Gao Xiang <hsiangkao@xxxxxxxxxxxxxxxxx> Date: Thu, 31 Aug 2023 19:29:58 +0800 Subject: erofs: ensure that the post-EOF tails are all zeroed To: stable@xxxxxxxxxxxxxxx, Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx> Cc: linux-erofs@xxxxxxxxxxxxxxxx, Gao Xiang <hsiangkao@xxxxxxxxxxxxxxxxx>, keltargw <keltar.gw@xxxxxxxxx> Message-ID: <20230831112959.99884-6-hsiangkao@xxxxxxxxxxxxxxxxx> From: Gao Xiang <hsiangkao@xxxxxxxxxxxxxxxxx> commit e4c1cf523d820730a86cae2c6d55924833b6f7ac upstream. This was accidentally fixed up in commit e4c1cf523d82 but we can't take the full change due to other dependancy issues, so here is just the actual bugfix that is needed. [Background] keltargw reported an issue [1] that with mmaped I/Os, sometimes the tail of the last page (after file ends) is not filled with zeroes. The root cause is that such tail page could be wrongly selected for inplace I/Os so the zeroed part will then be filled with compressed data instead of zeroes. A simple fix is to avoid doing inplace I/Os for such tail parts, actually that was already fixed upstream in commit e4c1cf523d82 ("erofs: tidy up z_erofs_do_read_page()") by accident. [1] https://lore.kernel.org/r/3ad8b469-25db-a297-21f9-75db2d6ad224@xxxxxxxxxxxxxxxxx Reported-by: keltargw <keltar.gw@xxxxxxxxx> Fixes: 3883a79abd02 ("staging: erofs: introduce VLE decompression support") Signed-off-by: Gao Xiang <hsiangkao@xxxxxxxxxxxxxxxxx> Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx> --- fs/erofs/zdata.c | 2 ++ 1 file changed, 2 insertions(+) --- a/fs/erofs/zdata.c +++ b/fs/erofs/zdata.c @@ -993,6 +993,8 @@ hitted: cur = end - min_t(erofs_off_t, offset + end - map->m_la, end); if (!(map->m_flags & EROFS_MAP_MAPPED)) { zero_user_segment(page, cur, end); + ++spiltted; + tight = false; goto next_part; } if (map->m_flags & EROFS_MAP_FRAGMENT) { Patches currently in stable-queue which might be from hsiangkao@xxxxxxxxxxxxxxxxx are queue-6.4/erofs-ensure-that-the-post-eof-tails-are-all-zeroed.patch