|
@@ -871,6 +871,11 @@ int blk_register_queue(struct gendisk *disk)
|
|
|
if (WARN_ON(!q))
|
|
|
return -ENXIO;
|
|
|
|
|
|
+ WARN_ONCE(test_bit(QUEUE_FLAG_REGISTERED, &q->queue_flags),
|
|
|
+ "%s is registering an already registered queue\n",
|
|
|
+ kobject_name(&dev->kobj));
|
|
|
+ queue_flag_set_unlocked(QUEUE_FLAG_REGISTERED, q);
|
|
|
+
|
|
|
/*
|
|
|
* SCSI probing may synchronously create and destroy a lot of
|
|
|
* request_queues for non-existent devices. Shutting down a fully
|
|
@@ -931,6 +936,8 @@ void blk_unregister_queue(struct gendisk *disk)
|
|
|
if (WARN_ON(!q))
|
|
|
return;
|
|
|
|
|
|
+ queue_flag_clear_unlocked(QUEUE_FLAG_REGISTERED, q);
|
|
|
+
|
|
|
if (q->mq_ops)
|
|
|
blk_mq_unregister_dev(disk_to_dev(disk), q);
|
|
|
|