scsi: lpfc: Driver fails to detect direct attach storage array
The driver does not respond to PLOGI from the direct attach target. The driver uses incorrect S_ID in CONFIG_LINK, after FLOGI completion Correct by issuing CONFIG_LINK with the correct S_ID after receiving the PLOGI from the target Signed-off-by: Dick Kennedy <dick.kennedy@broadcom.com> Signed-off-by: James Smart <james.smart@broadcom.com> Reviewed-by: Hannes Reinecke <hare@suse.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
d73154ba32
commit
d33d0eb28b
|
@ -858,6 +858,9 @@ lpfc_cmpl_els_flogi_nport(struct lpfc_vport *vport, struct lpfc_nodelist *ndlp,
|
||||||
vport->fc_flag |= FC_PT2PT;
|
vport->fc_flag |= FC_PT2PT;
|
||||||
spin_unlock_irq(shost->host_lock);
|
spin_unlock_irq(shost->host_lock);
|
||||||
|
|
||||||
|
/* If we are pt2pt with another NPort, force NPIV off! */
|
||||||
|
phba->sli3_options &= ~LPFC_SLI3_NPIV_ENABLED;
|
||||||
|
|
||||||
/* If physical FC port changed, unreg VFI and ALL VPIs / RPIs */
|
/* If physical FC port changed, unreg VFI and ALL VPIs / RPIs */
|
||||||
if ((phba->sli_rev == LPFC_SLI_REV4) && phba->fc_topology_changed) {
|
if ((phba->sli_rev == LPFC_SLI_REV4) && phba->fc_topology_changed) {
|
||||||
lpfc_unregister_fcf_prep(phba);
|
lpfc_unregister_fcf_prep(phba);
|
||||||
|
@ -916,28 +919,29 @@ lpfc_cmpl_els_flogi_nport(struct lpfc_vport *vport, struct lpfc_nodelist *ndlp,
|
||||||
spin_lock_irq(shost->host_lock);
|
spin_lock_irq(shost->host_lock);
|
||||||
ndlp->nlp_flag |= NLP_NPR_2B_DISC;
|
ndlp->nlp_flag |= NLP_NPR_2B_DISC;
|
||||||
spin_unlock_irq(shost->host_lock);
|
spin_unlock_irq(shost->host_lock);
|
||||||
} else
|
|
||||||
|
mbox = mempool_alloc(phba->mbox_mem_pool, GFP_KERNEL);
|
||||||
|
if (!mbox)
|
||||||
|
goto fail;
|
||||||
|
|
||||||
|
lpfc_config_link(phba, mbox);
|
||||||
|
|
||||||
|
mbox->mbox_cmpl = lpfc_mbx_cmpl_local_config_link;
|
||||||
|
mbox->vport = vport;
|
||||||
|
rc = lpfc_sli_issue_mbox(phba, mbox, MBX_NOWAIT);
|
||||||
|
if (rc == MBX_NOT_FINISHED) {
|
||||||
|
mempool_free(mbox, phba->mbox_mem_pool);
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
/* This side will wait for the PLOGI, decrement ndlp reference
|
/* This side will wait for the PLOGI, decrement ndlp reference
|
||||||
* count indicating that ndlp can be released when other
|
* count indicating that ndlp can be released when other
|
||||||
* references to it are done.
|
* references to it are done.
|
||||||
*/
|
*/
|
||||||
lpfc_nlp_put(ndlp);
|
lpfc_nlp_put(ndlp);
|
||||||
|
|
||||||
/* If we are pt2pt with another NPort, force NPIV off! */
|
/* Start discovery - this should just do CLEAR_LA */
|
||||||
phba->sli3_options &= ~LPFC_SLI3_NPIV_ENABLED;
|
lpfc_disc_start(vport);
|
||||||
|
|
||||||
mbox = mempool_alloc(phba->mbox_mem_pool, GFP_KERNEL);
|
|
||||||
if (!mbox)
|
|
||||||
goto fail;
|
|
||||||
|
|
||||||
lpfc_config_link(phba, mbox);
|
|
||||||
|
|
||||||
mbox->mbox_cmpl = lpfc_mbx_cmpl_local_config_link;
|
|
||||||
mbox->vport = vport;
|
|
||||||
rc = lpfc_sli_issue_mbox(phba, mbox, MBX_NOWAIT);
|
|
||||||
if (rc == MBX_NOT_FINISHED) {
|
|
||||||
mempool_free(mbox, phba->mbox_mem_pool);
|
|
||||||
goto fail;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Reference in New Issue