blk-mq-tag.c 17.0 KB
Newer Older
1
// SPDX-License-Identifier: GPL-2.0
2
/*
3 4 5
 * Tag allocation using scalable bitmaps. Uses active queue tracking to support
 * fairer distribution of tags between multiple submitters when a shared tag map
 * is used.
6 7 8
 *
 * Copyright (C) 2013-2014 Jens Axboe
 */
9 10 11 12
#include <linux/kernel.h>
#include <linux/module.h>

#include <linux/blk-mq.h>
13
#include <linux/delay.h>
14 15 16 17
#include "blk.h"
#include "blk-mq.h"
#include "blk-mq-tag.h"

18 19
/*
 * If a previously inactive queue goes active, bump the active user count.
20 21 22
 * We need to do this before try to allocate driver tag, then even if fail
 * to get tag when first time, the other shared-tag users could reserve
 * budget for it.
23 24 25
 */
bool __blk_mq_tag_busy(struct blk_mq_hw_ctx *hctx)
{
26 27 28 29 30 31 32 33 34 35 36 37
	if (blk_mq_is_sbitmap_shared(hctx->flags)) {
		struct request_queue *q = hctx->queue;
		struct blk_mq_tag_set *set = q->tag_set;

		if (!test_bit(QUEUE_FLAG_HCTX_ACTIVE, &q->queue_flags) &&
		    !test_and_set_bit(QUEUE_FLAG_HCTX_ACTIVE, &q->queue_flags))
			atomic_inc(&set->active_queues_shared_sbitmap);
	} else {
		if (!test_bit(BLK_MQ_S_TAG_ACTIVE, &hctx->state) &&
		    !test_and_set_bit(BLK_MQ_S_TAG_ACTIVE, &hctx->state))
			atomic_inc(&hctx->tags->active_queues);
	}
38 39 40 41 42

	return true;
}

/*
43
 * Wakeup all potentially sleeping on tags
44
 */
45
void blk_mq_tag_wakeup_all(struct blk_mq_tags *tags, bool include_reserve)
46
{
47
	sbitmap_queue_wake_all(tags->bitmap_tags);
48
	if (include_reserve)
49
		sbitmap_queue_wake_all(tags->breserved_tags);
50 51
}

52 53 54 55 56 57 58
/*
 * If a previously busy queue goes inactive, potential waiters could now
 * be allowed to queue. Wake them up and check.
 */
void __blk_mq_tag_idle(struct blk_mq_hw_ctx *hctx)
{
	struct blk_mq_tags *tags = hctx->tags;
59 60
	struct request_queue *q = hctx->queue;
	struct blk_mq_tag_set *set = q->tag_set;
61

62 63 64 65 66 67 68 69 70 71
	if (blk_mq_is_sbitmap_shared(hctx->flags)) {
		if (!test_and_clear_bit(QUEUE_FLAG_HCTX_ACTIVE,
					&q->queue_flags))
			return;
		atomic_dec(&set->active_queues_shared_sbitmap);
	} else {
		if (!test_and_clear_bit(BLK_MQ_S_TAG_ACTIVE, &hctx->state))
			return;
		atomic_dec(&tags->active_queues);
	}
72

73
	blk_mq_tag_wakeup_all(tags, false);
74 75
}

76 77
static int __blk_mq_get_tag(struct blk_mq_alloc_data *data,
			    struct sbitmap_queue *bt)
78
{
79 80
	if (!data->q->elevator && !(data->flags & BLK_MQ_REQ_RESERVED) &&
			!hctx_may_queue(data->hctx, bt))
81
		return BLK_MQ_NO_TAG;
82

83 84 85 86
	if (data->shallow_depth)
		return __sbitmap_queue_get_shallow(bt, data->shallow_depth);
	else
		return __sbitmap_queue_get(bt);
87 88
}

89
unsigned int blk_mq_get_tag(struct blk_mq_alloc_data *data)
90
{
91 92
	struct blk_mq_tags *tags = blk_mq_tags_from_data(data);
	struct sbitmap_queue *bt;
93
	struct sbq_wait_state *ws;
J
Jens Axboe 已提交
94
	DEFINE_SBQ_WAIT(wait);
95
	unsigned int tag_offset;
96 97
	int tag;

98 99 100
	if (data->flags & BLK_MQ_REQ_RESERVED) {
		if (unlikely(!tags->nr_reserved_tags)) {
			WARN_ON_ONCE(1);
101
			return BLK_MQ_NO_TAG;
102
		}
103
		bt = tags->breserved_tags;
104 105
		tag_offset = 0;
	} else {
106
		bt = tags->bitmap_tags;
107 108 109
		tag_offset = tags->nr_reserved_tags;
	}

110
	tag = __blk_mq_get_tag(data, bt);
111
	if (tag != BLK_MQ_NO_TAG)
112
		goto found_tag;
113

114
	if (data->flags & BLK_MQ_REQ_NOWAIT)
115
		return BLK_MQ_NO_TAG;
116

117
	ws = bt_wait_ptr(bt, data->hctx);
118
	do {
119 120
		struct sbitmap_queue *bt_prev;

B
Bart Van Assche 已提交
121 122 123
		/*
		 * We're out of tags on this hardware queue, kick any
		 * pending IO submits before going to sleep waiting for
124
		 * some to complete.
B
Bart Van Assche 已提交
125
		 */
126
		blk_mq_run_hw_queue(data->hctx, false);
B
Bart Van Assche 已提交
127

128 129 130 131
		/*
		 * Retry tag allocation after running the hardware queue,
		 * as running the queue may also have found completions.
		 */
132
		tag = __blk_mq_get_tag(data, bt);
133
		if (tag != BLK_MQ_NO_TAG)
134 135
			break;

J
Jens Axboe 已提交
136
		sbitmap_prepare_to_wait(bt, ws, &wait, TASK_UNINTERRUPTIBLE);
137 138

		tag = __blk_mq_get_tag(data, bt);
139
		if (tag != BLK_MQ_NO_TAG)
140 141
			break;

142
		bt_prev = bt;
143
		io_schedule();
144

J
Jens Axboe 已提交
145 146
		sbitmap_finish_wait(bt, ws, &wait);

147
		data->ctx = blk_mq_get_ctx(data->q);
148
		data->hctx = blk_mq_map_queue(data->q, data->cmd_flags,
149
						data->ctx);
150 151
		tags = blk_mq_tags_from_data(data);
		if (data->flags & BLK_MQ_REQ_RESERVED)
152
			bt = tags->breserved_tags;
153
		else
154
			bt = tags->bitmap_tags;
155

156 157 158 159 160 161 162 163
		/*
		 * If destination hw queue is changed, fake wake up on
		 * previous queue for compensating the wake up miss, so
		 * other allocations on previous queue won't be starved.
		 */
		if (bt != bt_prev)
			sbitmap_queue_wake_up(bt_prev);

164
		ws = bt_wait_ptr(bt, data->hctx);
165 166
	} while (1);

J
Jens Axboe 已提交
167
	sbitmap_finish_wait(bt, ws, &wait);
168

169
found_tag:
170 171 172 173 174 175 176 177
	/*
	 * Give up this allocation if the hctx is inactive.  The caller will
	 * retry on an active hctx.
	 */
	if (unlikely(test_bit(BLK_MQ_S_INACTIVE, &data->hctx->state))) {
		blk_mq_put_tag(tags, data->ctx, tag + tag_offset);
		return BLK_MQ_NO_TAG;
	}
178
	return tag + tag_offset;
179 180
}

181 182
void blk_mq_put_tag(struct blk_mq_tags *tags, struct blk_mq_ctx *ctx,
		    unsigned int tag)
183
{
184
	if (!blk_mq_tag_is_reserved(tags, tag)) {
185 186
		const int real_tag = tag - tags->nr_reserved_tags;

J
Jens Axboe 已提交
187
		BUG_ON(real_tag >= tags->nr_tags);
188
		sbitmap_queue_clear(tags->bitmap_tags, real_tag, ctx->cpu);
J
Jens Axboe 已提交
189 190
	} else {
		BUG_ON(tag >= tags->nr_reserved_tags);
191
		sbitmap_queue_clear(tags->breserved_tags, tag, ctx->cpu);
J
Jens Axboe 已提交
192
	}
193 194
}

195 196 197 198 199 200 201 202
struct bt_iter_data {
	struct blk_mq_hw_ctx *hctx;
	busy_iter_fn *fn;
	void *data;
	bool reserved;
};

static bool bt_iter(struct sbitmap *bitmap, unsigned int bitnr, void *data)
203
{
204 205 206 207
	struct bt_iter_data *iter_data = data;
	struct blk_mq_hw_ctx *hctx = iter_data->hctx;
	struct blk_mq_tags *tags = hctx->tags;
	bool reserved = iter_data->reserved;
208
	struct request *rq;
209

210 211 212
	if (!reserved)
		bitnr += tags->nr_reserved_tags;
	rq = tags->rqs[bitnr];
213

214 215
	/*
	 * We can hit rq == NULL here, because the tagging functions
216
	 * test and set the bit before assigning ->rqs[].
217
	 */
218
	if (rq && rq->q == hctx->queue && rq->mq_hctx == hctx)
219
		return iter_data->fn(hctx, rq, iter_data->data, reserved);
220 221
	return true;
}
222

223 224 225 226 227 228 229 230
/**
 * bt_for_each - iterate over the requests associated with a hardware queue
 * @hctx:	Hardware queue to examine.
 * @bt:		sbitmap to examine. This is either the breserved_tags member
 *		or the bitmap_tags member of struct blk_mq_tags.
 * @fn:		Pointer to the function that will be called for each request
 *		associated with @hctx that has been assigned a driver tag.
 *		@fn will be called as follows: @fn(@hctx, rq, @data, @reserved)
231 232
 *		where rq is a pointer to a request. Return true to continue
 *		iterating tags, false to stop.
233 234 235 236
 * @data:	Will be passed as third argument to @fn.
 * @reserved:	Indicates whether @bt is the breserved_tags member or the
 *		bitmap_tags member of struct blk_mq_tags.
 */
237 238 239 240 241 242 243 244 245 246 247
static void bt_for_each(struct blk_mq_hw_ctx *hctx, struct sbitmap_queue *bt,
			busy_iter_fn *fn, void *data, bool reserved)
{
	struct bt_iter_data iter_data = {
		.hctx = hctx,
		.fn = fn,
		.data = data,
		.reserved = reserved,
	};

	sbitmap_for_each_set(&bt->sb, bt_iter, &iter_data);
248 249
}

250 251 252 253
struct bt_tags_iter_data {
	struct blk_mq_tags *tags;
	busy_tag_iter_fn *fn;
	void *data;
M
Ming Lei 已提交
254
	unsigned int flags;
255 256
};

M
Ming Lei 已提交
257 258
#define BT_TAG_ITER_RESERVED		(1 << 0)
#define BT_TAG_ITER_STARTED		(1 << 1)
M
Ming Lei 已提交
259
#define BT_TAG_ITER_STATIC_RQS		(1 << 2)
M
Ming Lei 已提交
260

261
static bool bt_tags_iter(struct sbitmap *bitmap, unsigned int bitnr, void *data)
K
Keith Busch 已提交
262
{
263 264
	struct bt_tags_iter_data *iter_data = data;
	struct blk_mq_tags *tags = iter_data->tags;
M
Ming Lei 已提交
265
	bool reserved = iter_data->flags & BT_TAG_ITER_RESERVED;
K
Keith Busch 已提交
266 267
	struct request *rq;

268 269
	if (!reserved)
		bitnr += tags->nr_reserved_tags;
270 271 272

	/*
	 * We can hit rq == NULL here, because the tagging functions
M
Ming Lei 已提交
273
	 * test and set the bit before assigning ->rqs[].
274
	 */
M
Ming Lei 已提交
275 276 277 278
	if (iter_data->flags & BT_TAG_ITER_STATIC_RQS)
		rq = tags->static_rqs[bitnr];
	else
		rq = tags->rqs[bitnr];
M
Ming Lei 已提交
279 280 281 282 283 284
	if (!rq)
		return true;
	if ((iter_data->flags & BT_TAG_ITER_STARTED) &&
	    !blk_mq_request_started(rq))
		return true;
	return iter_data->fn(rq, iter_data->data, reserved);
285 286
}

287 288 289 290 291 292 293
/**
 * bt_tags_for_each - iterate over the requests in a tag map
 * @tags:	Tag map to iterate over.
 * @bt:		sbitmap to examine. This is either the breserved_tags member
 *		or the bitmap_tags member of struct blk_mq_tags.
 * @fn:		Pointer to the function that will be called for each started
 *		request. @fn will be called as follows: @fn(rq, @data,
294 295
 *		@reserved) where rq is a pointer to a request. Return true
 *		to continue iterating tags, false to stop.
296
 * @data:	Will be passed as second argument to @fn.
M
Ming Lei 已提交
297
 * @flags:	BT_TAG_ITER_*
298
 */
299
static void bt_tags_for_each(struct blk_mq_tags *tags, struct sbitmap_queue *bt,
M
Ming Lei 已提交
300
			     busy_tag_iter_fn *fn, void *data, unsigned int flags)
301 302 303 304 305
{
	struct bt_tags_iter_data iter_data = {
		.tags = tags,
		.fn = fn,
		.data = data,
M
Ming Lei 已提交
306
		.flags = flags,
307 308 309 310
	};

	if (tags->rqs)
		sbitmap_for_each_set(&bt->sb, bt_tags_iter, &iter_data);
K
Keith Busch 已提交
311 312
}

M
Ming Lei 已提交
313 314 315 316 317 318
static void __blk_mq_all_tag_iter(struct blk_mq_tags *tags,
		busy_tag_iter_fn *fn, void *priv, unsigned int flags)
{
	WARN_ON_ONCE(flags & BT_TAG_ITER_RESERVED);

	if (tags->nr_reserved_tags)
319
		bt_tags_for_each(tags, tags->breserved_tags, fn, priv,
M
Ming Lei 已提交
320
				 flags | BT_TAG_ITER_RESERVED);
321
	bt_tags_for_each(tags, tags->bitmap_tags, fn, priv, flags);
M
Ming Lei 已提交
322 323
}

324
/**
M
Ming Lei 已提交
325
 * blk_mq_all_tag_iter - iterate over all requests in a tag map
326
 * @tags:	Tag map to iterate over.
M
Ming Lei 已提交
327
 * @fn:		Pointer to the function that will be called for each
328 329
 *		request. @fn will be called as follows: @fn(rq, @priv,
 *		reserved) where rq is a pointer to a request. 'reserved'
330 331
 *		indicates whether or not @rq is a reserved request. Return
 *		true to continue iterating tags, false to stop.
332
 * @priv:	Will be passed as second argument to @fn.
M
Ming Lei 已提交
333 334
 *
 * Caller has to pass the tag map from which requests are allocated.
335
 */
M
Ming Lei 已提交
336 337
void blk_mq_all_tag_iter(struct blk_mq_tags *tags, busy_tag_iter_fn *fn,
		void *priv)
K
Keith Busch 已提交
338
{
339
	__blk_mq_all_tag_iter(tags, fn, priv, BT_TAG_ITER_STATIC_RQS);
K
Keith Busch 已提交
340 341
}

342 343 344 345 346 347
/**
 * blk_mq_tagset_busy_iter - iterate over all started requests in a tag set
 * @tagset:	Tag set to iterate over.
 * @fn:		Pointer to the function that will be called for each started
 *		request. @fn will be called as follows: @fn(rq, @priv,
 *		reserved) where rq is a pointer to a request. 'reserved'
348 349
 *		indicates whether or not @rq is a reserved request. Return
 *		true to continue iterating tags, false to stop.
350 351
 * @priv:	Will be passed as second argument to @fn.
 */
352 353 354 355 356 357 358
void blk_mq_tagset_busy_iter(struct blk_mq_tag_set *tagset,
		busy_tag_iter_fn *fn, void *priv)
{
	int i;

	for (i = 0; i < tagset->nr_hw_queues; i++) {
		if (tagset->tags && tagset->tags[i])
M
Ming Lei 已提交
359 360
			__blk_mq_all_tag_iter(tagset->tags[i], fn, priv,
					      BT_TAG_ITER_STARTED);
361 362 363 364
	}
}
EXPORT_SYMBOL(blk_mq_tagset_busy_iter);

365 366 367 368 369 370 371 372 373 374 375
static bool blk_mq_tagset_count_completed_rqs(struct request *rq,
		void *data, bool reserved)
{
	unsigned *count = data;

	if (blk_mq_request_completed(rq))
		(*count)++;
	return true;
}

/**
376 377
 * blk_mq_tagset_wait_completed_request - Wait until all scheduled request
 * completions have finished.
378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395
 * @tagset:	Tag set to drain completed request
 *
 * Note: This function has to be run after all IO queues are shutdown
 */
void blk_mq_tagset_wait_completed_request(struct blk_mq_tag_set *tagset)
{
	while (true) {
		unsigned count = 0;

		blk_mq_tagset_busy_iter(tagset,
				blk_mq_tagset_count_completed_rqs, &count);
		if (!count)
			break;
		msleep(5);
	}
}
EXPORT_SYMBOL(blk_mq_tagset_wait_completed_request);

396 397 398 399 400 401 402 403 404 405 406 407 408 409
/**
 * blk_mq_queue_tag_busy_iter - iterate over all requests with a driver tag
 * @q:		Request queue to examine.
 * @fn:		Pointer to the function that will be called for each request
 *		on @q. @fn will be called as follows: @fn(hctx, rq, @priv,
 *		reserved) where rq is a pointer to a request and hctx points
 *		to the hardware queue associated with the request. 'reserved'
 *		indicates whether or not @rq is a reserved request.
 * @priv:	Will be passed as third argument to @fn.
 *
 * Note: if @q->tag_set is shared with other request queues then @fn will be
 * called for all requests on all queues that share that tag set and not only
 * for requests associated with @q.
 */
410
void blk_mq_queue_tag_busy_iter(struct request_queue *q, busy_iter_fn *fn,
411
		void *priv)
412
{
413 414 415
	struct blk_mq_hw_ctx *hctx;
	int i;

416
	/*
417 418
	 * __blk_mq_update_nr_hw_queues() updates nr_hw_queues and queue_hw_ctx
	 * while the queue is frozen. So we can use q_usage_counter to avoid
419
	 * racing with it.
420
	 */
421
	if (!percpu_ref_tryget(&q->q_usage_counter))
422
		return;
423 424 425 426 427

	queue_for_each_hw_ctx(q, hctx, i) {
		struct blk_mq_tags *tags = hctx->tags;

		/*
428
		 * If no software queues are currently mapped to this
429 430 431 432 433 434
		 * hardware queue, there's nothing to check
		 */
		if (!blk_mq_hw_queue_mapped(hctx))
			continue;

		if (tags->nr_reserved_tags)
435 436
			bt_for_each(hctx, tags->breserved_tags, fn, priv, true);
		bt_for_each(hctx, tags->bitmap_tags, fn, priv, false);
437
	}
438
	blk_queue_exit(q);
439 440
}

441 442
static int bt_alloc(struct sbitmap_queue *bt, unsigned int depth,
		    bool round_robin, int node)
443
{
444 445
	return sbitmap_queue_init_node(bt, depth, -1, round_robin, GFP_KERNEL,
				       node);
446 447
}

448 449
static int blk_mq_init_bitmap_tags(struct blk_mq_tags *tags,
				   int node, int alloc_policy)
450 451
{
	unsigned int depth = tags->nr_tags - tags->nr_reserved_tags;
452
	bool round_robin = alloc_policy == BLK_TAG_ALLOC_RR;
453

454
	if (bt_alloc(&tags->__bitmap_tags, depth, round_robin, node))
455
		return -ENOMEM;
456 457
	if (bt_alloc(&tags->__breserved_tags, tags->nr_reserved_tags,
		     round_robin, node))
458
		goto free_bitmap_tags;
459

460 461 462
	tags->bitmap_tags = &tags->__bitmap_tags;
	tags->breserved_tags = &tags->__breserved_tags;

463
	return 0;
464
free_bitmap_tags:
465
	sbitmap_queue_free(&tags->__bitmap_tags);
466
	return -ENOMEM;
467 468
}

469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500
int blk_mq_init_shared_sbitmap(struct blk_mq_tag_set *set, unsigned int flags)
{
	unsigned int depth = set->queue_depth - set->reserved_tags;
	int alloc_policy = BLK_MQ_FLAG_TO_ALLOC_POLICY(set->flags);
	bool round_robin = alloc_policy == BLK_TAG_ALLOC_RR;
	int i, node = set->numa_node;

	if (bt_alloc(&set->__bitmap_tags, depth, round_robin, node))
		return -ENOMEM;
	if (bt_alloc(&set->__breserved_tags, set->reserved_tags,
		     round_robin, node))
		goto free_bitmap_tags;

	for (i = 0; i < set->nr_hw_queues; i++) {
		struct blk_mq_tags *tags = set->tags[i];

		tags->bitmap_tags = &set->__bitmap_tags;
		tags->breserved_tags = &set->__breserved_tags;
	}

	return 0;
free_bitmap_tags:
	sbitmap_queue_free(&set->__bitmap_tags);
	return -ENOMEM;
}

void blk_mq_exit_shared_sbitmap(struct blk_mq_tag_set *set)
{
	sbitmap_queue_free(&set->__bitmap_tags);
	sbitmap_queue_free(&set->__breserved_tags);
}

501
struct blk_mq_tags *blk_mq_init_tags(unsigned int total_tags,
S
Shaohua Li 已提交
502
				     unsigned int reserved_tags,
503
				     int node, unsigned int flags)
504
{
505
	int alloc_policy = BLK_MQ_FLAG_TO_ALLOC_POLICY(flags);
506 507 508 509 510 511 512 513 514 515 516 517 518 519
	struct blk_mq_tags *tags;

	if (total_tags > BLK_MQ_TAG_MAX) {
		pr_err("blk-mq: tag depth too large\n");
		return NULL;
	}

	tags = kzalloc_node(sizeof(*tags), GFP_KERNEL, node);
	if (!tags)
		return NULL;

	tags->nr_tags = total_tags;
	tags->nr_reserved_tags = reserved_tags;

520
	if (blk_mq_is_sbitmap_shared(flags))
521 522
		return tags;

523 524 525 526 527
	if (blk_mq_init_bitmap_tags(tags, node, alloc_policy) < 0) {
		kfree(tags);
		return NULL;
	}
	return tags;
528 529
}

530
void blk_mq_free_tags(struct blk_mq_tags *tags, unsigned int flags)
531
{
532
	if (!blk_mq_is_sbitmap_shared(flags)) {
533 534 535
		sbitmap_queue_free(tags->bitmap_tags);
		sbitmap_queue_free(tags->breserved_tags);
	}
536 537 538
	kfree(tags);
}

539 540 541
int blk_mq_tag_update_depth(struct blk_mq_hw_ctx *hctx,
			    struct blk_mq_tags **tagsptr, unsigned int tdepth,
			    bool can_grow)
542
{
543 544 545
	struct blk_mq_tags *tags = *tagsptr;

	if (tdepth <= tags->nr_reserved_tags)
546 547 548
		return -EINVAL;

	/*
549 550
	 * If we are allowed to grow beyond the original size, allocate
	 * a new set of tags before freeing the old one.
551
	 */
552 553
	if (tdepth > tags->nr_tags) {
		struct blk_mq_tag_set *set = hctx->queue->tag_set;
554 555
		/* Only sched tags can grow, so clear HCTX_SHARED flag  */
		unsigned int flags = set->flags & ~BLK_MQ_F_TAG_HCTX_SHARED;
556 557 558 559 560 561 562 563 564 565 566 567 568
		struct blk_mq_tags *new;
		bool ret;

		if (!can_grow)
			return -EINVAL;

		/*
		 * We need some sort of upper limit, set it high enough that
		 * no valid use cases should require more.
		 */
		if (tdepth > 16 * BLKDEV_MAX_RQ)
			return -EINVAL;

M
Ming Lei 已提交
569
		new = blk_mq_alloc_rq_map(set, hctx->queue_num, tdepth,
570
				tags->nr_reserved_tags, flags);
571 572 573 574
		if (!new)
			return -ENOMEM;
		ret = blk_mq_alloc_rqs(set, new, hctx->queue_num, tdepth);
		if (ret) {
575
			blk_mq_free_rq_map(new, flags);
576 577 578 579
			return -ENOMEM;
		}

		blk_mq_free_rqs(set, *tagsptr, hctx->queue_num);
580
		blk_mq_free_rq_map(*tagsptr, flags);
581 582 583 584 585 586
		*tagsptr = new;
	} else {
		/*
		 * Don't need (or can't) update reserved tags here, they
		 * remain static and should never need resizing.
		 */
587
		sbitmap_queue_resize(tags->bitmap_tags,
M
Ming Lei 已提交
588
				tdepth - tags->nr_reserved_tags);
589
	}
590

591 592 593
	return 0;
}

594 595 596 597 598
void blk_mq_tag_resize_shared_sbitmap(struct blk_mq_tag_set *set, unsigned int size)
{
	sbitmap_queue_resize(&set->__bitmap_tags, size - set->reserved_tags);
}

B
Bart Van Assche 已提交
599 600 601 602 603 604 605 606 607 608 609 610 611 612
/**
 * blk_mq_unique_tag() - return a tag that is unique queue-wide
 * @rq: request for which to compute a unique tag
 *
 * The tag field in struct request is unique per hardware queue but not over
 * all hardware queues. Hence this function that returns a tag with the
 * hardware context index in the upper bits and the per hardware queue tag in
 * the lower bits.
 *
 * Note: When called for a request that is queued on a non-multiqueue request
 * queue, the hardware context index is set to zero.
 */
u32 blk_mq_unique_tag(struct request *rq)
{
613
	return (rq->mq_hctx->queue_num << BLK_MQ_UNIQUE_TAG_BITS) |
B
Bart Van Assche 已提交
614 615 616
		(rq->tag & BLK_MQ_UNIQUE_TAG_MASK);
}
EXPORT_SYMBOL(blk_mq_unique_tag);