dm thin: fix issue_discard to pass GFP_NOIO to __blkdev_issue_discard
commit 722d90822321497e2837cfc9000202e256e6b32f upstream. issue_discard() passes GFP_NOWAIT to __blkdev_issue_discard() despite its code assuming bio_alloc() always succeeds. Commit3dba53a958("dm thin: use __blkdev_issue_discard for async discard support") clearly shows where things went bad: Before commit3dba53a958, dm-thin.c's open-coded __blkdev_issue_discard_async() properly handled using GFP_NOWAIT. Unfortunately __blkdev_issue_discard() doesn't and it was missed during review. Cc: stable@vger.kernel.org Signed-off-by: Mike Snitzer <snitzer@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
088ad777ee
commit
bfaf388d35
1 changed files with 1 additions and 2 deletions
|
|
@ -398,8 +398,7 @@ static int issue_discard(struct discard_op *op, dm_block_t data_b, dm_block_t da
|
||||||
sector_t s = block_to_sectors(tc->pool, data_b);
|
sector_t s = block_to_sectors(tc->pool, data_b);
|
||||||
sector_t len = block_to_sectors(tc->pool, data_e - data_b);
|
sector_t len = block_to_sectors(tc->pool, data_e - data_b);
|
||||||
|
|
||||||
return __blkdev_issue_discard(tc->pool_dev->bdev, s, len, GFP_NOWAIT,
|
return __blkdev_issue_discard(tc->pool_dev->bdev, s, len, GFP_NOIO, &op->bio);
|
||||||
&op->bio);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void end_discard(struct discard_op *op, int r)
|
static void end_discard(struct discard_op *op, int r)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue