aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@lst.de>2017-01-13 17:18:16 -0500
committerJens Axboe <axboe@fb.com>2017-01-13 17:18:16 -0500
commitbef13315e990fd3d3fb4c39013aefd53f06c3657 (patch)
tree25101dd0c76363c670fd08f947ef46df48285e28
parentf80de881d8df967488b7343381619efa15019493 (diff)
block: don't try to discard from __blkdev_issue_zeroout
Discard can return -EIO asynchronously if the alignment for the request isn't suitable for the driver, which makes a proper fallback to other methods in __blkdev_issue_zeroout impossible. Thus only issue a sync discard from blkdev_issue_zeroout an don't try discard at all from __blkdev_issue_zeroout as a non-invasive workaround. One more reason why abusing discard for zeroing must die.. Signed-off-by: Christoph Hellwig <hch@lst.de> Reported-by: Eryu Guan <eguan@redhat.com> Fixes: e73c23ff ("block: add async variant of blkdev_issue_zeroout") Signed-off-by: Jens Axboe <axboe@fb.com>
-rw-r--r--block/blk-lib.c13
1 files changed, 6 insertions, 7 deletions
diff --git a/block/blk-lib.c b/block/blk-lib.c
index ed89c8f4b2a0..f8c82a9b4012 100644
--- a/block/blk-lib.c
+++ b/block/blk-lib.c
@@ -301,13 +301,6 @@ int __blkdev_issue_zeroout(struct block_device *bdev, sector_t sector,
301 if ((sector | nr_sects) & bs_mask) 301 if ((sector | nr_sects) & bs_mask)
302 return -EINVAL; 302 return -EINVAL;
303 303
304 if (discard) {
305 ret = __blkdev_issue_discard(bdev, sector, nr_sects, gfp_mask,
306 BLKDEV_DISCARD_ZERO, biop);
307 if (ret == 0 || (ret && ret != -EOPNOTSUPP))
308 goto out;
309 }
310
311 ret = __blkdev_issue_write_zeroes(bdev, sector, nr_sects, gfp_mask, 304 ret = __blkdev_issue_write_zeroes(bdev, sector, nr_sects, gfp_mask,
312 biop); 305 biop);
313 if (ret == 0 || (ret && ret != -EOPNOTSUPP)) 306 if (ret == 0 || (ret && ret != -EOPNOTSUPP))
@@ -370,6 +363,12 @@ int blkdev_issue_zeroout(struct block_device *bdev, sector_t sector,
370 struct bio *bio = NULL; 363 struct bio *bio = NULL;
371 struct blk_plug plug; 364 struct blk_plug plug;
372 365
366 if (discard) {
367 if (!blkdev_issue_discard(bdev, sector, nr_sects, gfp_mask,
368 BLKDEV_DISCARD_ZERO))
369 return 0;
370 }
371
373 blk_start_plug(&plug); 372 blk_start_plug(&plug);
374 ret = __blkdev_issue_zeroout(bdev, sector, nr_sects, gfp_mask, 373 ret = __blkdev_issue_zeroout(bdev, sector, nr_sects, gfp_mask,
375 &bio, discard); 374 &bio, discard);