diff options
author | Jens Axboe <jens.axboe@oracle.com> | 2008-08-26 04:25:02 -0400 |
---|---|---|
committer | Jens Axboe <jens.axboe@oracle.com> | 2008-10-09 02:56:09 -0400 |
commit | ab780f1ece0dc8d5e8e8e85435acc5e4747ccda3 (patch) | |
tree | 4085b6c929a44de229eb5ef13fa2079211ea5512 /block | |
parent | c7c22e4d5c1fdebfac4dba76de7d0338c2b0d832 (diff) |
block: inherit CPU completion on bio->rq and rq->rq merges
Somewhat incomplete, as we do allow merges of requests and bios
that have different completion CPUs given. This is done on the
assumption that a larger IO is still more beneficial than CPU
locality.
Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
Diffstat (limited to 'block')
-rw-r--r-- | block/blk-core.c | 4 | ||||
-rw-r--r-- | block/blk-merge.c | 2 |
2 files changed, 6 insertions, 0 deletions
diff --git a/block/blk-core.c b/block/blk-core.c index 5484838f46e7..b9a252cae4df 100644 --- a/block/blk-core.c +++ b/block/blk-core.c | |||
@@ -1134,6 +1134,8 @@ static int __make_request(struct request_queue *q, struct bio *bio) | |||
1134 | req->biotail = bio; | 1134 | req->biotail = bio; |
1135 | req->nr_sectors = req->hard_nr_sectors += nr_sectors; | 1135 | req->nr_sectors = req->hard_nr_sectors += nr_sectors; |
1136 | req->ioprio = ioprio_best(req->ioprio, prio); | 1136 | req->ioprio = ioprio_best(req->ioprio, prio); |
1137 | if (!blk_rq_cpu_valid(req)) | ||
1138 | req->cpu = bio->bi_comp_cpu; | ||
1137 | drive_stat_acct(req, 0); | 1139 | drive_stat_acct(req, 0); |
1138 | if (!attempt_back_merge(q, req)) | 1140 | if (!attempt_back_merge(q, req)) |
1139 | elv_merged_request(q, req, el_ret); | 1141 | elv_merged_request(q, req, el_ret); |
@@ -1161,6 +1163,8 @@ static int __make_request(struct request_queue *q, struct bio *bio) | |||
1161 | req->sector = req->hard_sector = bio->bi_sector; | 1163 | req->sector = req->hard_sector = bio->bi_sector; |
1162 | req->nr_sectors = req->hard_nr_sectors += nr_sectors; | 1164 | req->nr_sectors = req->hard_nr_sectors += nr_sectors; |
1163 | req->ioprio = ioprio_best(req->ioprio, prio); | 1165 | req->ioprio = ioprio_best(req->ioprio, prio); |
1166 | if (!blk_rq_cpu_valid(req)) | ||
1167 | req->cpu = bio->bi_comp_cpu; | ||
1164 | drive_stat_acct(req, 0); | 1168 | drive_stat_acct(req, 0); |
1165 | if (!attempt_front_merge(q, req)) | 1169 | if (!attempt_front_merge(q, req)) |
1166 | elv_merged_request(q, req, el_ret); | 1170 | elv_merged_request(q, req, el_ret); |
diff --git a/block/blk-merge.c b/block/blk-merge.c index c77196d55899..908d3e11ac52 100644 --- a/block/blk-merge.c +++ b/block/blk-merge.c | |||
@@ -400,6 +400,8 @@ static int attempt_merge(struct request_queue *q, struct request *req, | |||
400 | } | 400 | } |
401 | 401 | ||
402 | req->ioprio = ioprio_best(req->ioprio, next->ioprio); | 402 | req->ioprio = ioprio_best(req->ioprio, next->ioprio); |
403 | if (blk_rq_cpu_valid(next)) | ||
404 | req->cpu = next->cpu; | ||
403 | 405 | ||
404 | __blk_put_request(q, next); | 406 | __blk_put_request(q, next); |
405 | return 1; | 407 | return 1; |