summaryrefslogtreecommitdiffstats
path: root/block
diff options
context:
space:
mode:
authorMichael Lyle <mlyle@lyle.org>2017-11-17 08:47:25 +0100
committerJens Axboe <axboe@kernel.dk>2017-11-17 16:29:34 +0100
commit62530ed8b1d07a45dec94d46e521c0c6c2d476e6 (patch)
treec4f89ec9c2886890a4e6d266a049620a96fc379f /block
parentnvmet_fc: fix better length checking (diff)
downloadlinux-62530ed8b1d07a45dec94d46e521c0c6c2d476e6.tar.xz
linux-62530ed8b1d07a45dec94d46e521c0c6c2d476e6.zip
bio: ensure __bio_clone_fast copies bi_partno
A new field was introduced in 74d46992e0d9, bi_partno, instead of using bdev->bd_contains and encoding the partition information in the bi_bdev field. __bio_clone_fast was changed to copy the disk information, but not the partition information. At minimum, this regressed bcache and caused data corruption. Signed-off-by: Michael Lyle <mlyle@lyle.org> Fixes: 74d46992e0d9 ("block: replace bi_bdev with a gendisk pointer and partitions index") Reported-by: Pavel Goran <via-bcache@pvgoran.name> Reported-by: Campbell Steven <casteven@gmail.com> Reviewed-by: Coly Li <colyli@suse.de> Reviewed-by: Ming Lei <ming.lei@redhat.com> Cc: <stable@vger.kernel.org> # 4.14 Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'block')
-rw-r--r--block/bio.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/block/bio.c b/block/bio.c
index b94a802f8ba3..459cc857f3d9 100644
--- a/block/bio.c
+++ b/block/bio.c
@@ -597,6 +597,7 @@ void __bio_clone_fast(struct bio *bio, struct bio *bio_src)
* so we don't set nor calculate new physical/hw segment counts here
*/
bio->bi_disk = bio_src->bi_disk;
+ bio->bi_partno = bio_src->bi_partno;
bio_set_flag(bio, BIO_CLONED);
bio->bi_opf = bio_src->bi_opf;
bio->bi_write_hint = bio_src->bi_write_hint;