Thread (62 messages) 62 messages, 8 authors, 2017-01-16

Re: [PATCH 08/10] blk-mq-sched: add framework for MQ capable IO schedulers

From: Bart Van Assche <hidden>
Date: 2017-01-13 16:39:35
Also in: lkml

On Fri, 2017-01-13 at 12:15 +0100, Hannes Reinecke wrote:
On 01/11/2017 10:40 PM, Jens Axboe wrote:
quoted
This adds a set of hooks that intercepts the blk-mq path of
allocating/inserting/issuing/completing requests, allowing
us to develop a scheduler within that framework.
=20
We reuse the existing elevator scheduler API on the registration
side, but augment that with the scheduler flagging support for
the blk-mq interfce, and with a separate set of ops hooks for MQ
devices.
=20
We split driver and scheduler tags, so we can run the scheduling
independent of device queue depth.
=20
Signed-off-by: Jens Axboe <axboe@fb.com>
=20
[ .. ]
quoted
@@ -823,6 +847,35 @@ static inline unsigned int queued_to_index(unsigne=
d int queued)
quoted
 	return min(BLK_MQ_MAX_DISPATCH_ORDER - 1, ilog2(queued) + 1);
 }
=20
+static bool blk_mq_get_driver_tag(struct request *rq,
+				  struct blk_mq_hw_ctx **hctx, bool wait)
+{
+	struct blk_mq_alloc_data data =3D {
+		.q =3D rq->q,
+		.ctx =3D rq->mq_ctx,
+		.hctx =3D blk_mq_map_queue(rq->q, rq->mq_ctx->cpu),
+		.flags =3D wait ? 0 : BLK_MQ_REQ_NOWAIT,
+	};
+
+	if (blk_mq_hctx_stopped(data.hctx))
+		return false;
+
+	if (rq->tag !=3D -1) {
+done:
+		if (hctx)
+			*hctx =3D data.hctx;
+		return true;
+	}
+
+	rq->tag =3D blk_mq_get_tag(&data);
+	if (rq->tag >=3D 0) {
+		data.hctx->tags->rqs[rq->tag] =3D rq;
+		goto done;
+	}
+
+	return false;
+}
+
=20
What happens with the existing request at 'rqs[rq->tag]' ?
Surely there is one already, right?
Things like '->init_request' assume a fully populated array, so moving
one entry to another location is ... interesting.
=20
I would have thought we need to do a request cloning here,
otherwise this would introduce a memory leak, right?
(Not to mention a potential double completion, as the request is now at
two positions in the array)
Hello Hannes,

Have you noticed that there are two .rqs[] arrays - tags->rqs and
sched_tags->rqs[]? .init_request() loops over sched_tags->rqs[]. The
above assignment applies to tags->rqs[].

Bart.=
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help