Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit ab780f1e authored by Jens Axboe's avatar Jens Axboe
Browse files

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: default avatarJens Axboe <jens.axboe@oracle.com>
parent c7c22e4d
Loading
Loading
Loading
Loading
+4 −0
Original line number Diff line number Diff line
@@ -1134,6 +1134,8 @@ static int __make_request(struct request_queue *q, struct bio *bio)
		req->biotail = bio;
		req->nr_sectors = req->hard_nr_sectors += nr_sectors;
		req->ioprio = ioprio_best(req->ioprio, prio);
		if (!blk_rq_cpu_valid(req))
			req->cpu = bio->bi_comp_cpu;
		drive_stat_acct(req, 0);
		if (!attempt_back_merge(q, req))
			elv_merged_request(q, req, el_ret);
@@ -1161,6 +1163,8 @@ static int __make_request(struct request_queue *q, struct bio *bio)
		req->sector = req->hard_sector = bio->bi_sector;
		req->nr_sectors = req->hard_nr_sectors += nr_sectors;
		req->ioprio = ioprio_best(req->ioprio, prio);
		if (!blk_rq_cpu_valid(req))
			req->cpu = bio->bi_comp_cpu;
		drive_stat_acct(req, 0);
		if (!attempt_front_merge(q, req))
			elv_merged_request(q, req, el_ret);
+2 −0
Original line number Diff line number Diff line
@@ -400,6 +400,8 @@ static int attempt_merge(struct request_queue *q, struct request *req,
	}

	req->ioprio = ioprio_best(req->ioprio, next->ioprio);
	if (blk_rq_cpu_valid(next))
		req->cpu = next->cpu;

	__blk_put_request(q, next);
	return 1;
+1 −0
Original line number Diff line number Diff line
@@ -545,6 +545,7 @@ enum {
#define blk_pm_request(rq)	\
	(blk_pm_suspend_request(rq) || blk_pm_resume_request(rq))

#define blk_rq_cpu_valid(rq)	((rq)->cpu != -1)
#define blk_sorted_rq(rq)	((rq)->cmd_flags & REQ_SORTED)
#define blk_barrier_rq(rq)	((rq)->cmd_flags & REQ_HARDBARRIER)
#define blk_fua_rq(rq)		((rq)->cmd_flags & REQ_FUA)