block: apply blk_partition_remap to REQ_OP_ZONE_RESET
authorShaun Tancheff <shaun@tancheff.com>
Mon, 21 Nov 2016 21:52:23 +0000 (15:52 -0600)
committerJens Axboe <axboe@fb.com>
Mon, 21 Nov 2016 22:08:24 +0000 (15:08 -0700)
If a ZBC device is partitioned and operations are performed on the partition
the zone information is rebased to the partition, however the zone reset
is not mapped from the partition to device as are other operations.

This causes the API (report zones / reset zone) to be unbalanced in this
regard. Checking for the zone reset op code explicitly will balance the
API.

Signed-off-by: Shaun Tancheff <shaun.tancheff@seagate.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
block/blk-core.c

index 473dd698effdb8c414ac52f1cb442db58d148238..6c4a425690fc7fe0d4b74ae81c652ba96d28bfb8 100644 (file)
@@ -1787,7 +1787,12 @@ static inline void blk_partition_remap(struct bio *bio)
 {
        struct block_device *bdev = bio->bi_bdev;
 
-       if (bio_sectors(bio) && bdev != bdev->bd_contains) {
+       /*
+        * Zone reset does not include bi_size so bio_sectors() is always 0.
+        * Include a test for the reset op code and perform the remap if needed.
+        */
+       if (bdev != bdev->bd_contains &&
+           (bio_sectors(bio) || bio_op(bio) == REQ_OP_ZONE_RESET)) {
                struct hd_struct *p = bdev->bd_part;
 
                bio->bi_iter.bi_sector += p->start_sect;