Commit 079b5c91 authored by James Smart's avatar James Smart Committed by James Bottomley

[SCSI] lpfc 8.3.26: Fix HBA initialization issues

Fix HBA initialization issues

- Swap all values that come from the firmware image on little endian systems.
  Created a new bf_get_be macro that does the same as the bf_get_le macro but
  for big endian data instead of little endian data.
- Moved the incrementing of temp_offset after the copy
  fixed the write object loop to use temp_offset to figure out where the end
  of the image is instead of offset.
- Added the necessary codes for properly bringing the driver instance offline
  and then trying to bring the port back online with the PCI function IP reset.
  If it fails to bring the SLI port back online, it will fall through to
  bringing the SLI port to HBA error offline.
- Add a call in the probe_one_s3 and probe_one_s4 routines to get the Modeldesc
- Change OCe50100 to OCe15100
- Made the error log also include the PCI BAR bitmap returned from kernel call
  pci_select_bars().
Signed-off-by: default avatarAlex Iannicelli <alex.iannicelli@emulex.com>
Signed-off-by: default avatarJames Smart <james.smart@emulex.com>
Signed-off-by: default avatarJames Bottomley <JBottomley@Parallels.com>
parent bf08611b
...@@ -41,6 +41,8 @@ ...@@ -41,6 +41,8 @@
* Or clear that bit field: * Or clear that bit field:
* bf_set(example_bit_field, &t1, 0); * bf_set(example_bit_field, &t1, 0);
*/ */
#define bf_get_be32(name, ptr) \
((be32_to_cpu((ptr)->name##_WORD) >> name##_SHIFT) & name##_MASK)
#define bf_get_le32(name, ptr) \ #define bf_get_le32(name, ptr) \
((le32_to_cpu((ptr)->name##_WORD) >> name##_SHIFT) & name##_MASK) ((le32_to_cpu((ptr)->name##_WORD) >> name##_SHIFT) & name##_MASK)
#define bf_get(name, ptr) \ #define bf_get(name, ptr) \
......
...@@ -1481,15 +1481,18 @@ lpfc_handle_eratt_s4(struct lpfc_hba *phba) ...@@ -1481,15 +1481,18 @@ lpfc_handle_eratt_s4(struct lpfc_hba *phba)
return; return;
} }
if (bf_get(lpfc_sliport_status_rn, &portstat_reg)) { if (bf_get(lpfc_sliport_status_rn, &portstat_reg)) {
/* /* need reset: attempt for port recovery */
* TODO: Attempt port recovery via a port reset.
* When fully implemented, the driver should
* attempt to recover the port here and return.
* For now, log an error and take the port offline.
*/
lpfc_printf_log(phba, KERN_ERR, LOG_INIT, lpfc_printf_log(phba, KERN_ERR, LOG_INIT,
"2887 Port Error: Attempting " "2887 Port Error: Attempting "
"Port Recovery\n"); "Port Recovery\n");
lpfc_offline_prep(phba);
lpfc_offline(phba);
lpfc_sli_brdrestart(phba);
if (lpfc_online(phba) == 0) {
lpfc_unblock_mgmt_io(phba);
return;
}
/* fall through for not able to recover */
} }
lpfc_sli4_offline_eratt(phba); lpfc_sli4_offline_eratt(phba);
break; break;
...@@ -1958,7 +1961,7 @@ lpfc_get_hba_model_desc(struct lpfc_hba *phba, uint8_t *mdp, uint8_t *descp) ...@@ -1958,7 +1961,7 @@ lpfc_get_hba_model_desc(struct lpfc_hba *phba, uint8_t *mdp, uint8_t *descp)
case PCI_DEVICE_ID_LANCER_FCOE: case PCI_DEVICE_ID_LANCER_FCOE:
case PCI_DEVICE_ID_LANCER_FCOE_VF: case PCI_DEVICE_ID_LANCER_FCOE_VF:
oneConnect = 1; oneConnect = 1;
m = (typeof(m)){"OCe50100", "PCIe", "FCoE"}; m = (typeof(m)){"OCe15100", "PCIe", "FCoE"};
break; break;
default: default:
m = (typeof(m)){"Unknown", "", ""}; m = (typeof(m)){"Unknown", "", ""};
...@@ -3949,7 +3952,7 @@ static int ...@@ -3949,7 +3952,7 @@ static int
lpfc_enable_pci_dev(struct lpfc_hba *phba) lpfc_enable_pci_dev(struct lpfc_hba *phba)
{ {
struct pci_dev *pdev; struct pci_dev *pdev;
int bars; int bars = 0;
/* Obtain PCI device reference */ /* Obtain PCI device reference */
if (!phba->pcidev) if (!phba->pcidev)
...@@ -3978,6 +3981,8 @@ lpfc_enable_pci_dev(struct lpfc_hba *phba) ...@@ -3978,6 +3981,8 @@ lpfc_enable_pci_dev(struct lpfc_hba *phba)
out_disable_device: out_disable_device:
pci_disable_device(pdev); pci_disable_device(pdev);
out_error: out_error:
lpfc_printf_log(phba, KERN_ERR, LOG_INIT,
"1401 Failed to enable pci device, bars:x%x\n", bars);
return -ENODEV; return -ENODEV;
} }
...@@ -8271,11 +8276,8 @@ lpfc_pci_probe_one_s3(struct pci_dev *pdev, const struct pci_device_id *pid) ...@@ -8271,11 +8276,8 @@ lpfc_pci_probe_one_s3(struct pci_dev *pdev, const struct pci_device_id *pid)
/* Perform generic PCI device enabling operation */ /* Perform generic PCI device enabling operation */
error = lpfc_enable_pci_dev(phba); error = lpfc_enable_pci_dev(phba);
if (error) { if (error)
lpfc_printf_log(phba, KERN_ERR, LOG_INIT,
"1401 Failed to enable pci device.\n");
goto out_free_phba; goto out_free_phba;
}
/* Set up SLI API function jump table for PCI-device group-0 HBAs */ /* Set up SLI API function jump table for PCI-device group-0 HBAs */
error = lpfc_api_table_setup(phba, LPFC_PCI_DEV_LP); error = lpfc_api_table_setup(phba, LPFC_PCI_DEV_LP);
...@@ -8322,6 +8324,9 @@ lpfc_pci_probe_one_s3(struct pci_dev *pdev, const struct pci_device_id *pid) ...@@ -8322,6 +8324,9 @@ lpfc_pci_probe_one_s3(struct pci_dev *pdev, const struct pci_device_id *pid)
goto out_free_iocb_list; goto out_free_iocb_list;
} }
/* Get the default values for Model Name and Description */
lpfc_get_hba_model_desc(phba, phba->ModelName, phba->ModelDesc);
/* Create SCSI host to the physical port */ /* Create SCSI host to the physical port */
error = lpfc_create_shost(phba); error = lpfc_create_shost(phba);
if (error) { if (error) {
...@@ -8885,16 +8890,17 @@ lpfc_write_firmware(struct lpfc_hba *phba, const struct firmware *fw) ...@@ -8885,16 +8890,17 @@ lpfc_write_firmware(struct lpfc_hba *phba, const struct firmware *fw)
uint32_t offset = 0, temp_offset = 0; uint32_t offset = 0, temp_offset = 0;
INIT_LIST_HEAD(&dma_buffer_list); INIT_LIST_HEAD(&dma_buffer_list);
if ((image->magic_number != LPFC_GROUP_OJECT_MAGIC_NUM) || if ((be32_to_cpu(image->magic_number) != LPFC_GROUP_OJECT_MAGIC_NUM) ||
(bf_get(lpfc_grp_hdr_file_type, image) != LPFC_FILE_TYPE_GROUP) || (bf_get_be32(lpfc_grp_hdr_file_type, image) !=
(bf_get(lpfc_grp_hdr_id, image) != LPFC_FILE_ID_GROUP) || LPFC_FILE_TYPE_GROUP) ||
(image->size != fw->size)) { (bf_get_be32(lpfc_grp_hdr_id, image) != LPFC_FILE_ID_GROUP) ||
(be32_to_cpu(image->size) != fw->size)) {
lpfc_printf_log(phba, KERN_ERR, LOG_INIT, lpfc_printf_log(phba, KERN_ERR, LOG_INIT,
"3022 Invalid FW image found. " "3022 Invalid FW image found. "
"Magic:%d Type:%x ID:%x\n", "Magic:%x Type:%x ID:%x\n",
image->magic_number, be32_to_cpu(image->magic_number),
bf_get(lpfc_grp_hdr_file_type, image), bf_get_be32(lpfc_grp_hdr_file_type, image),
bf_get(lpfc_grp_hdr_id, image)); bf_get_be32(lpfc_grp_hdr_id, image));
return -EINVAL; return -EINVAL;
} }
lpfc_decode_firmware_rev(phba, fwrev, 1); lpfc_decode_firmware_rev(phba, fwrev, 1);
...@@ -8924,11 +8930,11 @@ lpfc_write_firmware(struct lpfc_hba *phba, const struct firmware *fw) ...@@ -8924,11 +8930,11 @@ lpfc_write_firmware(struct lpfc_hba *phba, const struct firmware *fw)
while (offset < fw->size) { while (offset < fw->size) {
temp_offset = offset; temp_offset = offset;
list_for_each_entry(dmabuf, &dma_buffer_list, list) { list_for_each_entry(dmabuf, &dma_buffer_list, list) {
if (offset + SLI4_PAGE_SIZE > fw->size) { if (temp_offset + SLI4_PAGE_SIZE > fw->size) {
temp_offset += fw->size - offset;
memcpy(dmabuf->virt, memcpy(dmabuf->virt,
fw->data + temp_offset, fw->data + temp_offset,
fw->size - offset); fw->size - temp_offset);
temp_offset = fw->size;
break; break;
} }
memcpy(dmabuf->virt, fw->data + temp_offset, memcpy(dmabuf->virt, fw->data + temp_offset,
...@@ -8995,11 +9001,8 @@ lpfc_pci_probe_one_s4(struct pci_dev *pdev, const struct pci_device_id *pid) ...@@ -8995,11 +9001,8 @@ lpfc_pci_probe_one_s4(struct pci_dev *pdev, const struct pci_device_id *pid)
/* Perform generic PCI device enabling operation */ /* Perform generic PCI device enabling operation */
error = lpfc_enable_pci_dev(phba); error = lpfc_enable_pci_dev(phba);
if (error) { if (error)
lpfc_printf_log(phba, KERN_ERR, LOG_INIT,
"1409 Failed to enable pci device.\n");
goto out_free_phba; goto out_free_phba;
}
/* Set up SLI API function jump table for PCI-device group-1 HBAs */ /* Set up SLI API function jump table for PCI-device group-1 HBAs */
error = lpfc_api_table_setup(phba, LPFC_PCI_DEV_OC); error = lpfc_api_table_setup(phba, LPFC_PCI_DEV_OC);
...@@ -9054,6 +9057,9 @@ lpfc_pci_probe_one_s4(struct pci_dev *pdev, const struct pci_device_id *pid) ...@@ -9054,6 +9057,9 @@ lpfc_pci_probe_one_s4(struct pci_dev *pdev, const struct pci_device_id *pid)
goto out_free_iocb_list; goto out_free_iocb_list;
} }
/* Get the default values for Model Name and Description */
lpfc_get_hba_model_desc(phba, phba->ModelName, phba->ModelDesc);
/* Create SCSI host to the physical port */ /* Create SCSI host to the physical port */
error = lpfc_create_shost(phba); error = lpfc_create_shost(phba);
if (error) { if (error) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment