diff options
Diffstat (limited to 'drivers/message')
-rw-r--r-- | drivers/message/fusion/mptbase.c | 88 |
1 files changed, 50 insertions, 38 deletions
diff --git a/drivers/message/fusion/mptbase.c b/drivers/message/fusion/mptbase.c index a30084076ac8..164375eea896 100644 --- a/drivers/message/fusion/mptbase.c +++ b/drivers/message/fusion/mptbase.c | |||
@@ -1386,39 +1386,6 @@ mpt_attach(struct pci_dev *pdev, const struct pci_device_id *id) | |||
1386 | /* Set lookup ptr. */ | 1386 | /* Set lookup ptr. */ |
1387 | list_add_tail(&ioc->list, &ioc_list); | 1387 | list_add_tail(&ioc->list, &ioc_list); |
1388 | 1388 | ||
1389 | ioc->pci_irq = -1; | ||
1390 | if (pdev->irq) { | ||
1391 | if (mpt_msi_enable && !pci_enable_msi(pdev)) | ||
1392 | printk(MYIOC_s_INFO_FMT "PCI-MSI enabled\n", ioc->name); | ||
1393 | |||
1394 | r = request_irq(pdev->irq, mpt_interrupt, SA_SHIRQ, ioc->name, ioc); | ||
1395 | |||
1396 | if (r < 0) { | ||
1397 | #ifndef __sparc__ | ||
1398 | printk(MYIOC_s_ERR_FMT "Unable to allocate interrupt %d!\n", | ||
1399 | ioc->name, pdev->irq); | ||
1400 | #else | ||
1401 | printk(MYIOC_s_ERR_FMT "Unable to allocate interrupt %s!\n", | ||
1402 | ioc->name, __irq_itoa(pdev->irq)); | ||
1403 | #endif | ||
1404 | list_del(&ioc->list); | ||
1405 | iounmap(mem); | ||
1406 | kfree(ioc); | ||
1407 | return -EBUSY; | ||
1408 | } | ||
1409 | |||
1410 | ioc->pci_irq = pdev->irq; | ||
1411 | |||
1412 | pci_set_master(pdev); /* ?? */ | ||
1413 | pci_set_drvdata(pdev, ioc); | ||
1414 | |||
1415 | #ifndef __sparc__ | ||
1416 | dprintk((KERN_INFO MYNAM ": %s installed at interrupt %d\n", ioc->name, pdev->irq)); | ||
1417 | #else | ||
1418 | dprintk((KERN_INFO MYNAM ": %s installed at interrupt %s\n", ioc->name, __irq_itoa(pdev->irq))); | ||
1419 | #endif | ||
1420 | } | ||
1421 | |||
1422 | /* Check for "bound ports" (929, 929X, 1030, 1035) to reduce redundant resets. | 1389 | /* Check for "bound ports" (929, 929X, 1030, 1035) to reduce redundant resets. |
1423 | */ | 1390 | */ |
1424 | mpt_detect_bound_ports(ioc, pdev); | 1391 | mpt_detect_bound_ports(ioc, pdev); |
@@ -1428,11 +1395,7 @@ mpt_attach(struct pci_dev *pdev, const struct pci_device_id *id) | |||
1428 | printk(KERN_WARNING MYNAM | 1395 | printk(KERN_WARNING MYNAM |
1429 | ": WARNING - %s did not initialize properly! (%d)\n", | 1396 | ": WARNING - %s did not initialize properly! (%d)\n", |
1430 | ioc->name, r); | 1397 | ioc->name, r); |
1431 | |||
1432 | list_del(&ioc->list); | 1398 | list_del(&ioc->list); |
1433 | free_irq(ioc->pci_irq, ioc); | ||
1434 | if (mpt_msi_enable) | ||
1435 | pci_disable_msi(pdev); | ||
1436 | if (ioc->alt_ioc) | 1399 | if (ioc->alt_ioc) |
1437 | ioc->alt_ioc->alt_ioc = NULL; | 1400 | ioc->alt_ioc->alt_ioc = NULL; |
1438 | iounmap(mem); | 1401 | iounmap(mem); |
@@ -1651,6 +1614,7 @@ mpt_do_ioc_recovery(MPT_ADAPTER *ioc, u32 reason, int sleepFlag) | |||
1651 | int handlers; | 1614 | int handlers; |
1652 | int ret = 0; | 1615 | int ret = 0; |
1653 | int reset_alt_ioc_active = 0; | 1616 | int reset_alt_ioc_active = 0; |
1617 | int irq_allocated = 0; | ||
1654 | 1618 | ||
1655 | printk(KERN_INFO MYNAM ": Initiating %s %s\n", | 1619 | printk(KERN_INFO MYNAM ": Initiating %s %s\n", |
1656 | ioc->name, reason==MPT_HOSTEVENT_IOC_BRINGUP ? "bringup" : "recovery"); | 1620 | ioc->name, reason==MPT_HOSTEVENT_IOC_BRINGUP ? "bringup" : "recovery"); |
@@ -1734,6 +1698,48 @@ mpt_do_ioc_recovery(MPT_ADAPTER *ioc, u32 reason, int sleepFlag) | |||
1734 | } | 1698 | } |
1735 | } | 1699 | } |
1736 | 1700 | ||
1701 | /* | ||
1702 | * Device is reset now. It must have de-asserted the interrupt line | ||
1703 | * (if it was asserted) and it should be safe to register for the | ||
1704 | * interrupt now. | ||
1705 | */ | ||
1706 | if ((ret == 0) && (reason == MPT_HOSTEVENT_IOC_BRINGUP)) { | ||
1707 | ioc->pci_irq = -1; | ||
1708 | if (ioc->pcidev->irq) { | ||
1709 | if (mpt_msi_enable && !pci_enable_msi(ioc->pcidev)) | ||
1710 | printk(MYIOC_s_INFO_FMT "PCI-MSI enabled\n", | ||
1711 | ioc->name); | ||
1712 | rc = request_irq(ioc->pcidev->irq, mpt_interrupt, | ||
1713 | SA_SHIRQ, ioc->name, ioc); | ||
1714 | if (rc < 0) { | ||
1715 | #ifndef __sparc__ | ||
1716 | printk(MYIOC_s_ERR_FMT "Unable to allocate " | ||
1717 | "interrupt %d!\n", ioc->name, | ||
1718 | ioc->pcidev->irq); | ||
1719 | #else | ||
1720 | printk(MYIOC_s_ERR_FMT "Unable to allocate " | ||
1721 | "interrupt %s!\n", ioc->name, | ||
1722 | __irq_itoa(ioc->pcidev->irq)); | ||
1723 | #endif | ||
1724 | if (mpt_msi_enable) | ||
1725 | pci_disable_msi(ioc->pcidev); | ||
1726 | return -EBUSY; | ||
1727 | } | ||
1728 | irq_allocated = 1; | ||
1729 | ioc->pci_irq = ioc->pcidev->irq; | ||
1730 | pci_set_master(ioc->pcidev); /* ?? */ | ||
1731 | pci_set_drvdata(ioc->pcidev, ioc); | ||
1732 | #ifndef __sparc__ | ||
1733 | dprintk((KERN_INFO MYNAM ": %s installed at interrupt " | ||
1734 | "%d\n", ioc->name, ioc->pcidev->irq)); | ||
1735 | #else | ||
1736 | dprintk((KERN_INFO MYNAM ": %s installed at interrupt " | ||
1737 | "%s\n", ioc->name, | ||
1738 | __irq_itoa(ioc->pcidev->irq))); | ||
1739 | #endif | ||
1740 | } | ||
1741 | } | ||
1742 | |||
1737 | /* Prime reply & request queues! | 1743 | /* Prime reply & request queues! |
1738 | * (mucho alloc's) Must be done prior to | 1744 | * (mucho alloc's) Must be done prior to |
1739 | * init as upper addresses are needed for init. | 1745 | * init as upper addresses are needed for init. |
@@ -1833,7 +1839,7 @@ mpt_do_ioc_recovery(MPT_ADAPTER *ioc, u32 reason, int sleepFlag) | |||
1833 | ret = mptbase_sas_persist_operation(ioc, | 1839 | ret = mptbase_sas_persist_operation(ioc, |
1834 | MPI_SAS_OP_CLEAR_NOT_PRESENT); | 1840 | MPI_SAS_OP_CLEAR_NOT_PRESENT); |
1835 | if(ret != 0) | 1841 | if(ret != 0) |
1836 | return -1; | 1842 | goto out; |
1837 | } | 1843 | } |
1838 | 1844 | ||
1839 | /* Find IM volumes | 1845 | /* Find IM volumes |
@@ -1914,6 +1920,12 @@ mpt_do_ioc_recovery(MPT_ADAPTER *ioc, u32 reason, int sleepFlag) | |||
1914 | /* FIXME? Examine results here? */ | 1920 | /* FIXME? Examine results here? */ |
1915 | } | 1921 | } |
1916 | 1922 | ||
1923 | out: | ||
1924 | if ((ret != 0) && irq_allocated) { | ||
1925 | free_irq(ioc->pci_irq, ioc); | ||
1926 | if (mpt_msi_enable) | ||
1927 | pci_disable_msi(ioc->pcidev); | ||
1928 | } | ||
1917 | return ret; | 1929 | return ret; |
1918 | } | 1930 | } |
1919 | 1931 | ||