diff options
Diffstat (limited to 'drivers/scsi/lpfc/lpfc_init.c')
-rw-r--r-- | drivers/scsi/lpfc/lpfc_init.c | 42 |
1 files changed, 23 insertions, 19 deletions
diff --git a/drivers/scsi/lpfc/lpfc_init.c b/drivers/scsi/lpfc/lpfc_init.c index 8c7fdb8487e..729694d9759 100644 --- a/drivers/scsi/lpfc/lpfc_init.c +++ b/drivers/scsi/lpfc/lpfc_init.c | |||
@@ -1143,9 +1143,8 @@ lpfc_post_buffer(struct lpfc_hba *phba, struct lpfc_sli_ring *pring, int cnt, | |||
1143 | /* Allocate buffer to post */ | 1143 | /* Allocate buffer to post */ |
1144 | mp1 = kmalloc(sizeof (struct lpfc_dmabuf), GFP_KERNEL); | 1144 | mp1 = kmalloc(sizeof (struct lpfc_dmabuf), GFP_KERNEL); |
1145 | if (mp1) | 1145 | if (mp1) |
1146 | mp1->virt = lpfc_mbuf_alloc(phba, MEM_PRI, | 1146 | mp1->virt = lpfc_mbuf_alloc(phba, MEM_PRI, &mp1->phys); |
1147 | &mp1->phys); | 1147 | if (!mp1 || !mp1->virt) { |
1148 | if (mp1 == 0 || mp1->virt == 0) { | ||
1149 | kfree(mp1); | 1148 | kfree(mp1); |
1150 | lpfc_sli_release_iocbq(phba, iocb); | 1149 | lpfc_sli_release_iocbq(phba, iocb); |
1151 | pring->missbufcnt = cnt; | 1150 | pring->missbufcnt = cnt; |
@@ -1159,7 +1158,7 @@ lpfc_post_buffer(struct lpfc_hba *phba, struct lpfc_sli_ring *pring, int cnt, | |||
1159 | if (mp2) | 1158 | if (mp2) |
1160 | mp2->virt = lpfc_mbuf_alloc(phba, MEM_PRI, | 1159 | mp2->virt = lpfc_mbuf_alloc(phba, MEM_PRI, |
1161 | &mp2->phys); | 1160 | &mp2->phys); |
1162 | if (mp2 == 0 || mp2->virt == 0) { | 1161 | if (!mp2 || !mp2->virt) { |
1163 | kfree(mp2); | 1162 | kfree(mp2); |
1164 | lpfc_mbuf_free(phba, mp1->virt, mp1->phys); | 1163 | lpfc_mbuf_free(phba, mp1->virt, mp1->phys); |
1165 | kfree(mp1); | 1164 | kfree(mp1); |
@@ -1762,7 +1761,7 @@ lpfc_pci_probe_one(struct pci_dev *pdev, const struct pci_device_id *pid) | |||
1762 | struct Scsi_Host *shost = NULL; | 1761 | struct Scsi_Host *shost = NULL; |
1763 | void *ptr; | 1762 | void *ptr; |
1764 | unsigned long bar0map_len, bar2map_len; | 1763 | unsigned long bar0map_len, bar2map_len; |
1765 | int error = -ENODEV; | 1764 | int error = -ENODEV, retval; |
1766 | int i, hbq_count; | 1765 | int i, hbq_count; |
1767 | uint16_t iotag; | 1766 | uint16_t iotag; |
1768 | 1767 | ||
@@ -1878,9 +1877,11 @@ lpfc_pci_probe_one(struct pci_dev *pdev, const struct pci_device_id *pid) | |||
1878 | lpfc_sli_setup(phba); | 1877 | lpfc_sli_setup(phba); |
1879 | lpfc_sli_queue_setup(phba); | 1878 | lpfc_sli_queue_setup(phba); |
1880 | 1879 | ||
1881 | error = lpfc_mem_alloc(phba); | 1880 | retval = lpfc_mem_alloc(phba); |
1882 | if (error) | 1881 | if (retval) { |
1882 | error = retval; | ||
1883 | goto out_free_hbqslimp; | 1883 | goto out_free_hbqslimp; |
1884 | } | ||
1884 | 1885 | ||
1885 | /* Initialize and populate the iocb list per host. */ | 1886 | /* Initialize and populate the iocb list per host. */ |
1886 | INIT_LIST_HEAD(&phba->lpfc_iocb_list); | 1887 | INIT_LIST_HEAD(&phba->lpfc_iocb_list); |
@@ -1946,8 +1947,8 @@ lpfc_pci_probe_one(struct pci_dev *pdev, const struct pci_device_id *pid) | |||
1946 | pci_set_drvdata(pdev, shost); | 1947 | pci_set_drvdata(pdev, shost); |
1947 | 1948 | ||
1948 | if (phba->cfg_use_msi) { | 1949 | if (phba->cfg_use_msi) { |
1949 | error = pci_enable_msi(phba->pcidev); | 1950 | retval = pci_enable_msi(phba->pcidev); |
1950 | if (!error) | 1951 | if (!retval) |
1951 | phba->using_msi = 1; | 1952 | phba->using_msi = 1; |
1952 | else | 1953 | else |
1953 | lpfc_printf_log(phba, KERN_INFO, LOG_INIT, | 1954 | lpfc_printf_log(phba, KERN_INFO, LOG_INIT, |
@@ -1955,11 +1956,12 @@ lpfc_pci_probe_one(struct pci_dev *pdev, const struct pci_device_id *pid) | |||
1955 | "with IRQ\n"); | 1956 | "with IRQ\n"); |
1956 | } | 1957 | } |
1957 | 1958 | ||
1958 | error = request_irq(phba->pcidev->irq, lpfc_intr_handler, IRQF_SHARED, | 1959 | retval = request_irq(phba->pcidev->irq, lpfc_intr_handler, IRQF_SHARED, |
1959 | LPFC_DRIVER_NAME, phba); | 1960 | LPFC_DRIVER_NAME, phba); |
1960 | if (error) { | 1961 | if (retval) { |
1961 | lpfc_printf_log(phba, KERN_ERR, LOG_INIT, | 1962 | lpfc_printf_log(phba, KERN_ERR, LOG_INIT, |
1962 | "0451 Enable interrupt handler failed\n"); | 1963 | "0451 Enable interrupt handler failed\n"); |
1964 | error = retval; | ||
1963 | goto out_disable_msi; | 1965 | goto out_disable_msi; |
1964 | } | 1966 | } |
1965 | 1967 | ||
@@ -1969,11 +1971,15 @@ lpfc_pci_probe_one(struct pci_dev *pdev, const struct pci_device_id *pid) | |||
1969 | phba->HSregaddr = phba->ctrl_regs_memmap_p + HS_REG_OFFSET; | 1971 | phba->HSregaddr = phba->ctrl_regs_memmap_p + HS_REG_OFFSET; |
1970 | phba->HCregaddr = phba->ctrl_regs_memmap_p + HC_REG_OFFSET; | 1972 | phba->HCregaddr = phba->ctrl_regs_memmap_p + HC_REG_OFFSET; |
1971 | 1973 | ||
1972 | if (lpfc_alloc_sysfs_attr(vport)) | 1974 | if (lpfc_alloc_sysfs_attr(vport)) { |
1975 | error = -ENOMEM; | ||
1973 | goto out_free_irq; | 1976 | goto out_free_irq; |
1977 | } | ||
1974 | 1978 | ||
1975 | if (lpfc_sli_hba_setup(phba)) | 1979 | if (lpfc_sli_hba_setup(phba)) { |
1980 | error = -ENODEV; | ||
1976 | goto out_remove_device; | 1981 | goto out_remove_device; |
1982 | } | ||
1977 | 1983 | ||
1978 | /* | 1984 | /* |
1979 | * hba setup may have changed the hba_queue_depth so we need to adjust | 1985 | * hba setup may have changed the hba_queue_depth so we need to adjust |
@@ -2303,14 +2309,12 @@ lpfc_init(void) | |||
2303 | if (lpfc_transport_template == NULL) | 2309 | if (lpfc_transport_template == NULL) |
2304 | return -ENOMEM; | 2310 | return -ENOMEM; |
2305 | if (lpfc_enable_npiv) { | 2311 | if (lpfc_enable_npiv) { |
2306 | lpfc_transport_functions.vport_create = NULL; | ||
2307 | lpfc_transport_functions.vport_delete = NULL; | ||
2308 | lpfc_transport_functions.issue_fc_host_lip = NULL; | ||
2309 | lpfc_transport_functions.vport_disable = lpfc_vport_disable; | ||
2310 | lpfc_vport_transport_template = | 2312 | lpfc_vport_transport_template = |
2311 | fc_attach_transport(&lpfc_transport_functions); | 2313 | fc_attach_transport(&lpfc_vport_transport_functions); |
2312 | if (lpfc_vport_transport_template == NULL) | 2314 | if (lpfc_vport_transport_template == NULL) { |
2315 | fc_release_transport(lpfc_transport_template); | ||
2313 | return -ENOMEM; | 2316 | return -ENOMEM; |
2317 | } | ||
2314 | } | 2318 | } |
2315 | error = pci_register_driver(&lpfc_driver); | 2319 | error = pci_register_driver(&lpfc_driver); |
2316 | if (error) { | 2320 | if (error) { |