summary refs log tree commit diff
path: root/block
diff options
context:
space:
mode:
authorWenbo Wang <wenbo.wang@memblaze.com>2015-03-20 01:04:54 -0400
committerJens Axboe <axboe@fb.com>2015-03-20 08:50:41 -0600
commit7ee8e4f3983c4ff700958a6099c8fd212ea67b94 (patch)
tree26208113a37530a9918c72f20490c34f076b5983 /block
parentbc188d818edf325ae38cfa43254a0b10a4defd65 (diff)
downloadlinux-7ee8e4f3983c4ff700958a6099c8fd212ea67b94.tar.gz
Fix bug in blk_rq_merge_ok
Use the right array index to reference the last
element of rq->biotail->bi_io_vec[]

Signed-off-by: Wenbo Wang <wenbo.wang@memblaze.com>
Reviewed-by: Chong Yuan <chong.yuan@memblaze.com>
Fixes: 66cb45aa41315 ("block: add support for limiting gaps in SG lists")
Cc: stable@kernel.org
Signed-off-by: Jens Axboe <axboe@fb.com>
Diffstat (limited to 'block')
-rw-r--r--block/blk-merge.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/block/blk-merge.c b/block/blk-merge.c
index fc1ff3b1ea1f..fd3fee81c23c 100644
--- a/block/blk-merge.c
+++ b/block/blk-merge.c
@@ -592,7 +592,7 @@ bool blk_rq_merge_ok(struct request *rq, struct bio *bio)
 	if (q->queue_flags & (1 << QUEUE_FLAG_SG_GAPS)) {
 		struct bio_vec *bprev;
 
-		bprev = &rq->biotail->bi_io_vec[bio->bi_vcnt - 1];
+		bprev = &rq->biotail->bi_io_vec[rq->biotail->bi_vcnt - 1];
 		if (bvec_gap_to_prev(bprev, bio->bi_io_vec[0].bv_offset))
 			return false;
 	}