scsi: lpfc: Fix diagnostic fw logging after a function reset
authorJames Smart <jsmart2021@gmail.com>
Tue, 12 Apr 2022 22:19:45 +0000 (15:19 -0700)
committerMartin K. Petersen <martin.petersen@oracle.com>
Tue, 19 Apr 2022 02:48:44 +0000 (22:48 -0400)
The lpfc_sli4_ras_setup() routine is only called from the
lpfc_pci_probe_one_s4() routine, which means diagnostic fw logging
initialization only occurs during probing.

Thus, any path involving a reset of the HBA that restarts the state of the
SLI port does not reinitialize diagnostic fw logging.

Move lpfc_sli4_ras_setup() into lpfc_sli4_hba_setup() so that the
LOWLEVEL_SET_DIAG_LOG_OPTIONS mailbox command can be sent after a function
reset.

Link: https://lore.kernel.org/r/20220412222008.126521-4-jsmart2021@gmail.com
Co-developed-by: Justin Tee <justin.tee@broadcom.com>
Signed-off-by: Justin Tee <justin.tee@broadcom.com>
Signed-off-by: James Smart <jsmart2021@gmail.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/lpfc/lpfc_init.c
drivers/scsi/lpfc/lpfc_sli.c

index f9cd4b72d949a69a8080760b83cd43de1aa211fe..7dfd47dcaad937c59d149ed18f53f665da6b987f 100644 (file)
@@ -14832,9 +14832,6 @@ lpfc_pci_probe_one_s4(struct pci_dev *pdev, const struct pci_device_id *pid)
        /* Check if there are static vports to be created. */
        lpfc_create_static_vport(phba);
 
-       /* Enable RAS FW log support */
-       lpfc_sli4_ras_setup(phba);
-
        timer_setup(&phba->cpuhp_poll_timer, lpfc_sli4_poll_hbtimer, 0);
        cpuhp_state_add_instance_nocalls(lpfc_cpuhp_state, &phba->cpuhp);
 
index bda2a7ba4e77fe5f19c7c60521ac6a9ea5d7424f..7c86271f05fdc0ca00087083b4c2b621b1500a0b 100644 (file)
@@ -8864,6 +8864,9 @@ lpfc_sli4_hba_setup(struct lpfc_hba *phba)
        }
        mempool_free(mboxq, phba->mbox_mem_pool);
 
+       /* Enable RAS FW log support */
+       lpfc_sli4_ras_setup(phba);
+
        phba->hba_flag |= HBA_SETUP;
        return rc;