]> git.ipfire.org Git - thirdparty/kernel/stable.git/commit
mm: never attempt async page lock if we've transferred data already
authorJens Axboe <axboe@kernel.dk>
Mon, 16 Nov 2020 20:36:24 +0000 (13:36 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 24 Nov 2020 12:39:14 +0000 (13:39 +0100)
commit38d3e20ff427d5b3dc47e3312728bb05dac8b8f4
treec71ff1af3975333d868b16780ea3e54e85365392
parent3261603426ec2c7e147abad6db95aac5261728d6
mm: never attempt async page lock if we've transferred data already

commit 0abed7c69b956d135cb6d320c350b2adb213e7d8 upstream.

We catch the case where we enter generic_file_buffered_read() with data
already transferred, but we also need to be careful not to allow an async
page lock if we're looping transferring data. If not, we could be
returning -EIOCBQUEUED instead of the transferred amount, and it could
result in double waitqueue additions as well.

Cc: stable@vger.kernel.org # v5.9
Fixes: 1a0a7853b901 ("mm: support async buffered reads in generic_file_buffered_read()")
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
mm/filemap.c