NVMe: Bring up cdev on set feature failure
authorKeith Busch <keith.busch@intel.com>
Mon, 29 Jul 2013 22:20:56 +0000 (16:20 -0600)
committerMatthew Wilcox <matthew.r.wilcox@intel.com>
Tue, 3 Sep 2013 20:32:26 +0000 (16:32 -0400)
This patch creates the character device as long as a device's admin queues
are usable so a user has an opprotunity to perform administration tasks.
A device may be in a state that does not allow IO and setting the queue
count feature in such a state returns an error. Previously the driver
would bail and the controller would be unusable.

Signed-off-by: Keith Busch <keith.busch@intel.com>
drivers/block/nvme-core.c

index f9244131b88a5e5039c2e9fd54af717b8b1a0c1d..8cfa4576d4242e4c8cab69b909de8408a80aeb1b 100644 (file)
@@ -1664,7 +1664,7 @@ static int set_queue_count(struct nvme_dev *dev, int count)
        status = nvme_set_features(dev, NVME_FEAT_NUM_QUEUES, q_count, 0,
                                                                &result);
        if (status)
-               return -EIO;
+               return status < 0 ? -EIO : -EBUSY;
        return min(result & 0xffff, result >> 16) + 1;
 }
 
@@ -2018,7 +2018,7 @@ static int nvme_probe(struct pci_dev *pdev, const struct pci_device_id *id)
        spin_unlock(&dev_list_lock);
 
        result = nvme_dev_add(dev);
-       if (result)
+       if (result && result != -EBUSY)
                goto delete;
 
        scnprintf(dev->name, sizeof(dev->name), "nvme%d", dev->instance);