Commit a052ce84 authored by James Smart's avatar James Smart Committed by Martin K. Petersen

scsi: lpfc: Fix disablement of FC-AL on lpe35000 models

The order of the flags/checks for adapters where FC-AL is supported
erroneously excluded lpe35000 adapter models.  Also noted that the G7 flags
for Loop and Persistent topology are incorrect. They should follow the
rules as G6.

Rework the logic to enable LPe35000 FC-AL support.  Collapse G7 support
logic to the same rules as G6.

Link: https://lore.kernel.org/r/20191218235808.31922-7-jsmart2021@gmail.comSigned-off-by: default avatarDick Kennedy <dick.kennedy@broadcom.com>
Signed-off-by: default avatarJames Smart <jsmart2021@gmail.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 9a20cc10
...@@ -4123,14 +4123,13 @@ lpfc_topology_store(struct device *dev, struct device_attribute *attr, ...@@ -4123,14 +4123,13 @@ lpfc_topology_store(struct device *dev, struct device_attribute *attr,
/* /*
* The 'topology' is not a configurable parameter if : * The 'topology' is not a configurable parameter if :
* - persistent topology enabled * - persistent topology enabled
* - G7 adapters * - G7/G6 with no private loop support
* - G6 with no private loop support
*/ */
if (((phba->hba_flag & HBA_PERSISTENT_TOPO) || if ((phba->hba_flag & HBA_PERSISTENT_TOPO ||
(!phba->sli4_hba.pc_sli4_params.pls && (!phba->sli4_hba.pc_sli4_params.pls &&
phba->pcidev->device == PCI_DEVICE_ID_LANCER_G6_FC) || (phba->pcidev->device == PCI_DEVICE_ID_LANCER_G6_FC ||
phba->pcidev->device == PCI_DEVICE_ID_LANCER_G7_FC) && phba->pcidev->device == PCI_DEVICE_ID_LANCER_G7_FC))) &&
val == 4) { val == 4) {
lpfc_printf_vlog(vport, KERN_ERR, LOG_INIT, lpfc_printf_vlog(vport, KERN_ERR, LOG_INIT,
"3114 Loop mode not supported\n"); "3114 Loop mode not supported\n");
......
...@@ -8320,14 +8320,6 @@ lpfc_map_topology(struct lpfc_hba *phba, struct lpfc_mbx_read_config *rd_config) ...@@ -8320,14 +8320,6 @@ lpfc_map_topology(struct lpfc_hba *phba, struct lpfc_mbx_read_config *rd_config)
phba->hba_flag |= HBA_PERSISTENT_TOPO; phba->hba_flag |= HBA_PERSISTENT_TOPO;
switch (phba->pcidev->device) { switch (phba->pcidev->device) {
case PCI_DEVICE_ID_LANCER_G7_FC: case PCI_DEVICE_ID_LANCER_G7_FC:
if (tf || (pt == LINK_FLAGS_LOOP)) {
/* Invalid values from FW - use driver params */
phba->hba_flag &= ~HBA_PERSISTENT_TOPO;
} else {
/* Prism only supports PT2PT topology */
phba->cfg_topology = FLAGS_TOPOLOGY_MODE_PT_PT;
}
break;
case PCI_DEVICE_ID_LANCER_G6_FC: case PCI_DEVICE_ID_LANCER_G6_FC:
if (!tf) { if (!tf) {
phba->cfg_topology = ((pt == LINK_FLAGS_LOOP) phba->cfg_topology = ((pt == LINK_FLAGS_LOOP)
......
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