]> git.baikalelectronics.ru Git - kernel.git/commit
btrfs: fix the memory leak caused in lzo_compress_pages()
authorQu Wenruo <wqu@suse.com>
Sat, 20 Nov 2021 08:34:11 +0000 (16:34 +0800)
committerDavid Sterba <dsterba@suse.com>
Fri, 26 Nov 2021 15:10:05 +0000 (16:10 +0100)
commit8789150124b67d6784a488c0106801e53fdcdf73
tree28e8dbee575ea177897e2b62e6b834fab5d11616
parent4ef5c28709470c983c3a4dc8307a05eda92004cf
btrfs: fix the memory leak caused in lzo_compress_pages()

[BUG]
Fstests generic/027 is pretty easy to trigger a slow but steady memory
leak if run with "-o compress=lzo" mount option.

Normally one single run of generic/027 is enough to eat up at least 4G ram.

[CAUSE]
In commit ec8247416bbe ("btrfs: subpage: make lzo_compress_pages()
compatible") we changed how @page_in is released.

But that refactoring makes @page_in only released after all pages being
compressed.

This leaves error path not releasing @page_in. And by "error path"
things like incompressible data will also be treated as an error
(-E2BIG).

Thus it can cause a memory leak if even nothing wrong happened.

[FIX]
Add check under @out label to release @page_in when needed, so when we
hit any error, the input page is properly released.

Reported-by: Josef Bacik <josef@toxicpanda.com>
Fixes: ec8247416bbe ("btrfs: subpage: make lzo_compress_pages() compatible")
Reviewed-and-tested-by: Josef Bacik <josef@toxicpanda.com>
Signed-off-by: Qu Wenruo <wqu@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
fs/btrfs/lzo.c