diff options
Diffstat (limited to 'block/blk-merge.c')
-rw-r--r-- | block/blk-merge.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/block/blk-merge.c b/block/blk-merge.c index b3bf0df0f4c2..54535831f1e1 100644 --- a/block/blk-merge.c +++ b/block/blk-merge.c | |||
@@ -568,6 +568,8 @@ int blk_attempt_req_merge(struct request_queue *q, struct request *rq, | |||
568 | 568 | ||
569 | bool blk_rq_merge_ok(struct request *rq, struct bio *bio) | 569 | bool blk_rq_merge_ok(struct request *rq, struct bio *bio) |
570 | { | 570 | { |
571 | struct request_queue *q = rq->q; | ||
572 | |||
571 | if (!rq_mergeable(rq) || !bio_mergeable(bio)) | 573 | if (!rq_mergeable(rq) || !bio_mergeable(bio)) |
572 | return false; | 574 | return false; |
573 | 575 | ||
@@ -591,6 +593,14 @@ bool blk_rq_merge_ok(struct request *rq, struct bio *bio) | |||
591 | !blk_write_same_mergeable(rq->bio, bio)) | 593 | !blk_write_same_mergeable(rq->bio, bio)) |
592 | return false; | 594 | return false; |
593 | 595 | ||
596 | if (q->queue_flags & (1 << QUEUE_FLAG_SG_GAPS)) { | ||
597 | struct bio_vec *bprev; | ||
598 | |||
599 | bprev = &rq->biotail->bi_io_vec[bio->bi_vcnt - 1]; | ||
600 | if (bvec_gap_to_prev(bprev, bio->bi_io_vec[0].bv_offset)) | ||
601 | return false; | ||
602 | } | ||
603 | |||
594 | return true; | 604 | return true; |
595 | } | 605 | } |
596 | 606 | ||