From: Phillip Lougher Date: Sun, 24 Nov 2013 00:40:49 +0000 (+0000) Subject: Squashfs: fix failure to unlock pages on decompress error X-Git-Tag: firefly_0821_release~176^2~4835^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=6d565409503f4e1f74ac30de14e8c91a2b826cd8;p=firefly-linux-kernel-4.4.55.git Squashfs: fix failure to unlock pages on decompress error Direct decompression into the page cache. If we fall back to using an intermediate buffer (because we cannot grab all the page cache pages) and we get a decompress fail, we forgot to release the pages. Reported-by: Roman Peniaev Signed-off-by: Phillip Lougher --- diff --git a/fs/squashfs/file_direct.c b/fs/squashfs/file_direct.c index 2943b2bfae48..62a0de6632e1 100644 --- a/fs/squashfs/file_direct.c +++ b/fs/squashfs/file_direct.c @@ -84,6 +84,9 @@ int squashfs_readpage_block(struct page *target_page, u64 block, int bsize) */ res = squashfs_read_cache(target_page, block, bsize, pages, page); + if (res < 0) + goto mark_errored; + goto out; } @@ -119,7 +122,7 @@ mark_errored: * dealt with by the caller */ for (i = 0; i < pages; i++) { - if (page[i] == target_page) + if (page[i] == NULL || page[i] == target_page) continue; flush_dcache_page(page[i]); SetPageError(page[i]);