]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
scsi: lpfc: Add log messages to fabric login error labels
authorJustin Tee <justin.tee@broadcom.com>
Thu, 12 Feb 2026 21:29:58 +0000 (13:29 -0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Tue, 24 Feb 2026 18:06:51 +0000 (13:06 -0500)
Should fabric login or related initialization mailbox commands fail,
there are no log messages to notify which step encountered an issue.
Update error label paths to log when unexpected fabric login issues
occur.

Signed-off-by: Justin Tee <justin.tee@broadcom.com>
Link: https://patch.msgid.link/20260212213008.149873-4-justintee8345@gmail.com
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/lpfc/lpfc_els.c
drivers/scsi/lpfc/lpfc_hbadisc.c

index cee709617a3130ffd37f1b27032b6e36ccdc209b..5ea7cc5f16af0529887dcdae0cfd045d6e28e325 100644 (file)
@@ -1,7 +1,7 @@
 /*******************************************************************
  * This file is part of the Emulex Linux Device Driver for         *
  * Fibre Channel Host Bus Adapters.                                *
- * Copyright (C) 2017-2025 Broadcom. All Rights Reserved. The term *
+ * Copyright (C) 2017-2026 Broadcom. All Rights Reserved. The term *
  * “Broadcom” refers to Broadcom Inc. and/or its subsidiaries.     *
  * Copyright (C) 2004-2016 Emulex.  All rights reserved.           *
  * EMULEX and SLI are trademarks of Emulex.                        *
@@ -1303,8 +1303,12 @@ lpfc_issue_els_flogi(struct lpfc_vport *vport, struct lpfc_nodelist *ndlp,
        elsiocb = lpfc_prep_els_iocb(vport, 1, cmdsize, retry, ndlp,
                                     ndlp->nlp_DID, ELS_CMD_FLOGI);
 
-       if (!elsiocb)
+       if (!elsiocb) {
+               lpfc_vport_set_state(vport, FC_VPORT_FAILED);
+               lpfc_printf_vlog(vport, KERN_WARNING, LOG_ELS | LOG_DISCOVERY,
+                                "4296 Unable to prepare FLOGI iocb\n");
                return 1;
+       }
 
        wqe = &elsiocb->wqe;
        pcmd = (uint8_t *)elsiocb->cmd_dmabuf->virt;
@@ -1394,10 +1398,8 @@ lpfc_issue_els_flogi(struct lpfc_vport *vport, struct lpfc_nodelist *ndlp,
                phba->sli3_options, 0, 0);
 
        elsiocb->ndlp = lpfc_nlp_get(ndlp);
-       if (!elsiocb->ndlp) {
-               lpfc_els_free_iocb(phba, elsiocb);
-               return 1;
-       }
+       if (!elsiocb->ndlp)
+               goto err_out;
 
        /* Avoid race with FLOGI completion and hba_flags. */
        set_bit(HBA_FLOGI_ISSUED, &phba->hba_flag);
@@ -1407,9 +1409,8 @@ lpfc_issue_els_flogi(struct lpfc_vport *vport, struct lpfc_nodelist *ndlp,
        if (rc == IOCB_ERROR) {
                clear_bit(HBA_FLOGI_ISSUED, &phba->hba_flag);
                clear_bit(HBA_FLOGI_OUTSTANDING, &phba->hba_flag);
-               lpfc_els_free_iocb(phba, elsiocb);
                lpfc_nlp_put(ndlp);
-               return 1;
+               goto err_out;
        }
 
        /* Clear external loopback plug detected flag */
@@ -1474,6 +1475,13 @@ lpfc_issue_els_flogi(struct lpfc_vport *vport, struct lpfc_nodelist *ndlp,
        }
 
        return 0;
+
+ err_out:
+       lpfc_els_free_iocb(phba, elsiocb);
+       lpfc_vport_set_state(vport, FC_VPORT_FAILED);
+       lpfc_printf_vlog(vport, KERN_WARNING, LOG_ELS | LOG_DISCOVERY,
+                        "4297 Issue FLOGI: Cannot send IOCB\n");
+       return 1;
 }
 
 /**
index e4b32bbfe7511c5530b9d7b565c675ead2a15db1..be8e1debed4298d21e9fd5fb1994eef1a23edcd9 100644 (file)
@@ -3174,7 +3174,11 @@ lpfc_init_vfi_cmpl(struct lpfc_hba *phba, LPFC_MBOXQ_t *mboxq)
                return;
        }
 
-       lpfc_initial_flogi(vport);
+       if (!lpfc_initial_flogi(vport)) {
+               lpfc_printf_vlog(vport, KERN_ERR, LOG_MBOX | LOG_ELS,
+                                "2345 Can't issue initial FLOGI\n");
+               lpfc_vport_set_state(vport, FC_VPORT_FAILED);
+       }
        mempool_free(mboxq, phba->mbox_mem_pool);
        return;
 }
@@ -3247,8 +3251,14 @@ lpfc_init_vpi_cmpl(struct lpfc_hba *phba, LPFC_MBOXQ_t *mboxq)
                        return;
        }
 
-       if (phba->link_flag & LS_NPIV_FAB_SUPPORTED)
-               lpfc_initial_fdisc(vport);
+       if (phba->link_flag & LS_NPIV_FAB_SUPPORTED) {
+               if (!lpfc_initial_fdisc(vport)) {
+                       lpfc_printf_vlog(vport, KERN_WARNING,
+                                        LOG_MBOX | LOG_ELS,
+                                        "2346 Can't issue initial FDISC\n");
+                       lpfc_vport_set_state(vport, FC_VPORT_FAILED);
+               }
+       }
        else {
                lpfc_vport_set_state(vport, FC_VPORT_NO_FABRIC_SUPP);
                lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT,