diff options
author | Martin K. Petersen <martin.petersen@oracle.com> | 2012-09-18 12:19:26 -0400 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2012-09-20 08:31:41 -0400 |
commit | f31dc1cd490539e2b62a126bc4dc2495b165d772 (patch) | |
tree | e8a917161111266f72a7aea539c9562dc2f2653d /block/blk-merge.c | |
parent | e2a60da74fc8215c68509a89e9a69c66363153db (diff) |
block: Consolidate command flag and queue limit checks for merges
- blk_check_merge_flags() verifies that cmd_flags / bi_rw are
compatible. This function is called for both req-req and req-bio
merging.
- blk_rq_get_max_sectors() and blk_queue_get_max_sectors() can be used
to query the maximum sector count for a given request or queue. The
calls will return the right value from the queue limits given the
type of command (RW, discard, write same, etc.)
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Acked-by: Mike Snitzer <snitzer@redhat.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'block/blk-merge.c')
-rw-r--r-- | block/blk-merge.c | 30 |
1 files changed, 12 insertions, 18 deletions
diff --git a/block/blk-merge.c b/block/blk-merge.c index 86710ca408b8..642b862608a1 100644 --- a/block/blk-merge.c +++ b/block/blk-merge.c | |||
@@ -275,14 +275,8 @@ no_merge: | |||
275 | int ll_back_merge_fn(struct request_queue *q, struct request *req, | 275 | int ll_back_merge_fn(struct request_queue *q, struct request *req, |
276 | struct bio *bio) | 276 | struct bio *bio) |
277 | { | 277 | { |
278 | unsigned short max_sectors; | 278 | if (blk_rq_sectors(req) + bio_sectors(bio) > |
279 | 279 | blk_rq_get_max_sectors(req)) { | |
280 | if (unlikely(req->cmd_type == REQ_TYPE_BLOCK_PC)) | ||
281 | max_sectors = queue_max_hw_sectors(q); | ||
282 | else | ||
283 | max_sectors = queue_max_sectors(q); | ||
284 | |||
285 | if (blk_rq_sectors(req) + bio_sectors(bio) > max_sectors) { | ||
286 | req->cmd_flags |= REQ_NOMERGE; | 280 | req->cmd_flags |= REQ_NOMERGE; |
287 | if (req == q->last_merge) | 281 | if (req == q->last_merge) |
288 | q->last_merge = NULL; | 282 | q->last_merge = NULL; |
@@ -299,15 +293,8 @@ int ll_back_merge_fn(struct request_queue *q, struct request *req, | |||
299 | int ll_front_merge_fn(struct request_queue *q, struct request *req, | 293 | int ll_front_merge_fn(struct request_queue *q, struct request *req, |
300 | struct bio *bio) | 294 | struct bio *bio) |
301 | { | 295 | { |
302 | unsigned short max_sectors; | 296 | if (blk_rq_sectors(req) + bio_sectors(bio) > |
303 | 297 | blk_rq_get_max_sectors(req)) { | |
304 | if (unlikely(req->cmd_type == REQ_TYPE_BLOCK_PC)) | ||
305 | max_sectors = queue_max_hw_sectors(q); | ||
306 | else | ||
307 | max_sectors = queue_max_sectors(q); | ||
308 | |||
309 | |||
310 | if (blk_rq_sectors(req) + bio_sectors(bio) > max_sectors) { | ||
311 | req->cmd_flags |= REQ_NOMERGE; | 298 | req->cmd_flags |= REQ_NOMERGE; |
312 | if (req == q->last_merge) | 299 | if (req == q->last_merge) |
313 | q->last_merge = NULL; | 300 | q->last_merge = NULL; |
@@ -338,7 +325,8 @@ static int ll_merge_requests_fn(struct request_queue *q, struct request *req, | |||
338 | /* | 325 | /* |
339 | * Will it become too large? | 326 | * Will it become too large? |
340 | */ | 327 | */ |
341 | if ((blk_rq_sectors(req) + blk_rq_sectors(next)) > queue_max_sectors(q)) | 328 | if ((blk_rq_sectors(req) + blk_rq_sectors(next)) > |
329 | blk_rq_get_max_sectors(req)) | ||
342 | return 0; | 330 | return 0; |
343 | 331 | ||
344 | total_phys_segments = req->nr_phys_segments + next->nr_phys_segments; | 332 | total_phys_segments = req->nr_phys_segments + next->nr_phys_segments; |
@@ -417,6 +405,9 @@ static int attempt_merge(struct request_queue *q, struct request *req, | |||
417 | if (!rq_mergeable(req) || !rq_mergeable(next)) | 405 | if (!rq_mergeable(req) || !rq_mergeable(next)) |
418 | return 0; | 406 | return 0; |
419 | 407 | ||
408 | if (!blk_check_merge_flags(req->cmd_flags, next->cmd_flags)) | ||
409 | return 0; | ||
410 | |||
420 | /* | 411 | /* |
421 | * not contiguous | 412 | * not contiguous |
422 | */ | 413 | */ |
@@ -512,6 +503,9 @@ bool blk_rq_merge_ok(struct request *rq, struct bio *bio) | |||
512 | if (!rq_mergeable(rq) || !bio_mergeable(bio)) | 503 | if (!rq_mergeable(rq) || !bio_mergeable(bio)) |
513 | return false; | 504 | return false; |
514 | 505 | ||
506 | if (!blk_check_merge_flags(rq->cmd_flags, bio->bi_rw)) | ||
507 | return false; | ||
508 | |||
515 | /* different data direction or already started, don't merge */ | 509 | /* different data direction or already started, don't merge */ |
516 | if (bio_data_dir(bio) != rq_data_dir(rq)) | 510 | if (bio_data_dir(bio) != rq_data_dir(rq)) |
517 | return false; | 511 | return false; |