diff options
| -rw-r--r-- | drivers/block/nvme-core.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/drivers/block/nvme-core.c b/drivers/block/nvme-core.c index 5ffc26937226..23728099e36f 100644 --- a/drivers/block/nvme-core.c +++ b/drivers/block/nvme-core.c | |||
| @@ -1075,7 +1075,7 @@ static void nvme_abort_cmd(int cmdid, struct nvme_queue *nvmeq) | |||
| 1075 | dev_warn(&dev->pci_dev->dev, | 1075 | dev_warn(&dev->pci_dev->dev, |
| 1076 | "I/O %d QID %d timeout, reset controller\n", cmdid, | 1076 | "I/O %d QID %d timeout, reset controller\n", cmdid, |
| 1077 | nvmeq->qid); | 1077 | nvmeq->qid); |
| 1078 | INIT_WORK(&dev->reset_work, nvme_reset_failed_dev); | 1078 | PREPARE_WORK(&dev->reset_work, nvme_reset_failed_dev); |
| 1079 | queue_work(nvme_workq, &dev->reset_work); | 1079 | queue_work(nvme_workq, &dev->reset_work); |
| 1080 | return; | 1080 | return; |
| 1081 | } | 1081 | } |
| @@ -1757,7 +1757,7 @@ static int nvme_kthread(void *data) | |||
| 1757 | list_del_init(&dev->node); | 1757 | list_del_init(&dev->node); |
| 1758 | dev_warn(&dev->pci_dev->dev, | 1758 | dev_warn(&dev->pci_dev->dev, |
| 1759 | "Failed status, reset controller\n"); | 1759 | "Failed status, reset controller\n"); |
| 1760 | INIT_WORK(&dev->reset_work, | 1760 | PREPARE_WORK(&dev->reset_work, |
| 1761 | nvme_reset_failed_dev); | 1761 | nvme_reset_failed_dev); |
| 1762 | queue_work(nvme_workq, &dev->reset_work); | 1762 | queue_work(nvme_workq, &dev->reset_work); |
| 1763 | continue; | 1763 | continue; |
| @@ -2460,7 +2460,7 @@ static int nvme_dev_resume(struct nvme_dev *dev) | |||
| 2460 | return ret; | 2460 | return ret; |
| 2461 | if (ret == -EBUSY) { | 2461 | if (ret == -EBUSY) { |
| 2462 | spin_lock(&dev_list_lock); | 2462 | spin_lock(&dev_list_lock); |
| 2463 | INIT_WORK(&dev->reset_work, nvme_remove_disks); | 2463 | PREPARE_WORK(&dev->reset_work, nvme_remove_disks); |
| 2464 | queue_work(nvme_workq, &dev->reset_work); | 2464 | queue_work(nvme_workq, &dev->reset_work); |
| 2465 | spin_unlock(&dev_list_lock); | 2465 | spin_unlock(&dev_list_lock); |
| 2466 | } | 2466 | } |
| @@ -2507,6 +2507,7 @@ static int nvme_probe(struct pci_dev *pdev, const struct pci_device_id *id) | |||
| 2507 | goto free; | 2507 | goto free; |
| 2508 | 2508 | ||
| 2509 | INIT_LIST_HEAD(&dev->namespaces); | 2509 | INIT_LIST_HEAD(&dev->namespaces); |
| 2510 | INIT_WORK(&dev->reset_work, nvme_reset_failed_dev); | ||
| 2510 | dev->pci_dev = pdev; | 2511 | dev->pci_dev = pdev; |
| 2511 | pci_set_drvdata(pdev, dev); | 2512 | pci_set_drvdata(pdev, dev); |
| 2512 | result = nvme_set_instance(dev); | 2513 | result = nvme_set_instance(dev); |
| @@ -2605,7 +2606,7 @@ static int nvme_resume(struct device *dev) | |||
| 2605 | struct nvme_dev *ndev = pci_get_drvdata(pdev); | 2606 | struct nvme_dev *ndev = pci_get_drvdata(pdev); |
| 2606 | 2607 | ||
| 2607 | if (nvme_dev_resume(ndev) && !work_busy(&ndev->reset_work)) { | 2608 | if (nvme_dev_resume(ndev) && !work_busy(&ndev->reset_work)) { |
| 2608 | INIT_WORK(&ndev->reset_work, nvme_reset_failed_dev); | 2609 | PREPARE_WORK(&ndev->reset_work, nvme_reset_failed_dev); |
| 2609 | queue_work(nvme_workq, &ndev->reset_work); | 2610 | queue_work(nvme_workq, &ndev->reset_work); |
| 2610 | } | 2611 | } |
| 2611 | return 0; | 2612 | return 0; |
