mirror of
https://github.com/torvalds/linux.git
synced 2026-06-06 21:45:45 +02:00
nvme-loop: check for NVME_LOOP_Q_LIVE in nvme_loop_destroy_admin_queue()
[ Upstream commit 4237de2f73 ]
We need to check the NVME_LOOP_Q_LIVE flag in
nvme_loop_destroy_admin_queue() to protect against duplicate
invocations eg during concurrent reset and remove calls.
Signed-off-by: Hannes Reinecke <hare@suse.de>
Reviewed-by: Chaitanya Kulkarni <chaitanya.kulkarni@wdc.com>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
620424df29
commit
155c2fea4b
|
|
@ -251,7 +251,8 @@ static const struct blk_mq_ops nvme_loop_admin_mq_ops = {
|
||||||
|
|
||||||
static void nvme_loop_destroy_admin_queue(struct nvme_loop_ctrl *ctrl)
|
static void nvme_loop_destroy_admin_queue(struct nvme_loop_ctrl *ctrl)
|
||||||
{
|
{
|
||||||
clear_bit(NVME_LOOP_Q_LIVE, &ctrl->queues[0].flags);
|
if (!test_and_clear_bit(NVME_LOOP_Q_LIVE, &ctrl->queues[0].flags))
|
||||||
|
return;
|
||||||
nvmet_sq_destroy(&ctrl->queues[0].nvme_sq);
|
nvmet_sq_destroy(&ctrl->queues[0].nvme_sq);
|
||||||
blk_cleanup_queue(ctrl->ctrl.admin_q);
|
blk_cleanup_queue(ctrl->ctrl.admin_q);
|
||||||
blk_cleanup_queue(ctrl->ctrl.fabrics_q);
|
blk_cleanup_queue(ctrl->ctrl.fabrics_q);
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user