All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] NVMe: limit max completion iterations in nvme_process_cq()
@ 2014-11-14 16:48 Jens Axboe
  2014-11-14 17:56 ` Keith Busch
  0 siblings, 1 reply; 3+ messages in thread
From: Jens Axboe @ 2014-11-14 16:48 UTC (permalink / raw)


This is an unbounded loop. If we have per-cpu queues this is
usually not a problem, but if CPUs share a queue, then we could
have some of them continually queueing IO and the loop could take
forever to exit.

Limit max iterations to the queue depth of the given completion
queue, which seems like a nice number to use.

Signed-off-by: Jens Axboe <axboe at fb.com>
---
 drivers/block/nvme-core.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/drivers/block/nvme-core.c b/drivers/block/nvme-core.c
index f2964dfcea6c..fc2fc53992cb 100644
--- a/drivers/block/nvme-core.c
+++ b/drivers/block/nvme-core.c
@@ -697,12 +697,13 @@ static int nvme_queue_rq(struct blk_mq_hw_ctx *hctx,
 
 static int nvme_process_cq(struct nvme_queue *nvmeq)
 {
+	unsigned int max_iter = nvmeq->q_depth;
 	u16 head, phase;
 
 	head = nvmeq->cq_head;
 	phase = nvmeq->cq_phase;
 
-	for (;;) {
+	while (max_iter--) {
 		void *ctx;
 		nvme_completion_fn fn;
 		struct nvme_completion cqe = nvmeq->cqes[head];
-- 
1.9.1

-- 
Jens Axboe

^ permalink raw reply related	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2014-11-14 18:00 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-11-14 16:48 [PATCH] NVMe: limit max completion iterations in nvme_process_cq() Jens Axboe
2014-11-14 17:56 ` Keith Busch
2014-11-14 18:00   ` Jens Axboe

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.