Skip to content

Commit f82ddf1

Browse files
Ming Leiaxboe
authored andcommitted
blk-mq: introduce blk_mq_hw_queue_first_cpu() to figure out first cpu
This patch introduces helper of blk_mq_hw_queue_first_cpu() for figuring out the hctx's first cpu, and code duplication can be avoided. Cc: Stefan Haberland <sth@linux.vnet.ibm.com> Tested-by: Christian Borntraeger <borntraeger@de.ibm.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Sagi Grimberg <sagi@grimberg.me> Signed-off-by: Ming Lei <ming.lei@redhat.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
1 parent 476f8c9 commit f82ddf1

File tree

1 file changed

+11
-12
lines changed

1 file changed

+11
-12
lines changed

block/blk-mq.c

Lines changed: 11 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -1335,6 +1335,15 @@ static void __blk_mq_run_hw_queue(struct blk_mq_hw_ctx *hctx)
13351335
hctx_unlock(hctx, srcu_idx);
13361336
}
13371337

1338+
static inline int blk_mq_first_mapped_cpu(struct blk_mq_hw_ctx *hctx)
1339+
{
1340+
int cpu = cpumask_first_and(hctx->cpumask, cpu_online_mask);
1341+
1342+
if (cpu >= nr_cpu_ids)
1343+
cpu = cpumask_first(hctx->cpumask);
1344+
return cpu;
1345+
}
1346+
13381347
/*
13391348
* It'd be great if the workqueue API had a way to pass
13401349
* in a mask and had some smarts for more clever placement.
@@ -1354,14 +1363,7 @@ static int blk_mq_hctx_next_cpu(struct blk_mq_hw_ctx *hctx)
13541363
next_cpu = cpumask_next_and(next_cpu, hctx->cpumask,
13551364
cpu_online_mask);
13561365
if (next_cpu >= nr_cpu_ids)
1357-
next_cpu = cpumask_first_and(hctx->cpumask, cpu_online_mask);
1358-
1359-
/*
1360-
* No online CPU is found, so have to make sure hctx->next_cpu
1361-
* is set correctly for not breaking workqueue.
1362-
*/
1363-
if (next_cpu >= nr_cpu_ids)
1364-
next_cpu = cpumask_first(hctx->cpumask);
1366+
next_cpu = blk_mq_first_mapped_cpu(hctx);
13651367
hctx->next_cpu_batch = BLK_MQ_CPU_WORK_BATCH;
13661368
}
13671369

@@ -2430,10 +2432,7 @@ static void blk_mq_map_swqueue(struct request_queue *q)
24302432
/*
24312433
* Initialize batch roundrobin counts
24322434
*/
2433-
hctx->next_cpu = cpumask_first_and(hctx->cpumask,
2434-
cpu_online_mask);
2435-
if (hctx->next_cpu >= nr_cpu_ids)
2436-
hctx->next_cpu = cpumask_first(hctx->cpumask);
2435+
hctx->next_cpu = blk_mq_first_mapped_cpu(hctx);
24372436
hctx->next_cpu_batch = BLK_MQ_CPU_WORK_BATCH;
24382437
}
24392438
}

0 commit comments

Comments
 (0)