Commit bf93dda2 authored by Robbie Ko's avatar Robbie Ko Committed by Greg Kroah-Hartman

btrfs: fix page leaks after failure to lock page for delalloc

commit 5909ca11 upstream.

When locking pages for delalloc, we check if it's dirty and mapping still
matches. If it does not match, we need to return -EAGAIN and release all
pages. Only the current page was put though, iterate over all the
remaining pages too.

CC: stable@vger.kernel.org # 4.14+
Reviewed-by: default avatarFilipe Manana <fdmanana@suse.com>
Reviewed-by: default avatarNikolay Borisov <nborisov@suse.com>
Signed-off-by: default avatarRobbie Ko <robbieko@synology.com>
Reviewed-by: default avatarDavid Sterba <dsterba@suse.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 2fae5cc5
...@@ -1707,7 +1707,8 @@ static int __process_pages_contig(struct address_space *mapping, ...@@ -1707,7 +1707,8 @@ static int __process_pages_contig(struct address_space *mapping,
if (!PageDirty(pages[i]) || if (!PageDirty(pages[i]) ||
pages[i]->mapping != mapping) { pages[i]->mapping != mapping) {
unlock_page(pages[i]); unlock_page(pages[i]);
put_page(pages[i]); for (; i < ret; i++)
put_page(pages[i]);
err = -EAGAIN; err = -EAGAIN;
goto out; goto out;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment