aboutsummaryrefslogtreecommitdiffstats
path: root/block
diff options
context:
space:
mode:
authorJens Axboe <jens.axboe@oracle.com>2008-08-26 04:25:02 -0400
committerJens Axboe <jens.axboe@oracle.com>2008-10-09 02:56:09 -0400
commitab780f1ece0dc8d5e8e8e85435acc5e4747ccda3 (patch)
tree4085b6c929a44de229eb5ef13fa2079211ea5512 /block
parentc7c22e4d5c1fdebfac4dba76de7d0338c2b0d832 (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.c4
-rw-r--r--block/blk-merge.c2
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;