Re: [PATCH] erofs: fix unsigned underflow in z_erofs_lz4_handle_overlap()
From: Gao Xiang
Date: Thu Apr 09 2026 - 06:57:01 EST
On 2026/4/9 18:38, Junrui Luo wrote:
Hi Gao Xiang,Can you share your initial crafted image binary
Thank you for the review.
On Thu, Apr 09, 2026 at 03:28:21PM +0800, Gao Xiang wrote:
For this kind of stuff, do you have a reproducer?
I constructed a crafted EROFS image declaring plen=8192 and i_size=4096, giving
inpages=2 and outpages=1. Tested under QEMU with kernel (v7.0-rc6) plus a temporary
pr_warn trace in z_erofs_lz4_handle_overlap():
[ 12.889652] erofs: BOUNDARY CHECK: outpages=1 < inpages=2
The image mounts and the decompressor is reached with
partial_decoding=false and outpages < inpages.
I'm not sure what you're saying, but I don't think
you really understand the entire logic.
`m_la + m_llen` should not be page-aligned for typical
erofs images, you can just mkfs.erofs -zlz4hc with some
file and check it yourself.
BTW, I just check upstream, and the inplace branch
works prefectly.
During testing I observed that the inplace branch was not entered with
my crafted image and incorrectly concluded it was structurally unreachable.
I apologize for the incorrect analysis.
with `gzip -9 | base64` encoding here?
I think the proper place to fix this is in
z_erofs_map_sanity_check().
But we only accept patches with proper reproducible
ways (e.g. base64-encoded zipped images or syzbot
link).
Thanks,
Gao Xiang