scsi: lpfc: Prevent duplicate requests to unregister with cpuhp framework
authorJames Smart <jsmart2021@gmail.com>
Mon, 4 Jan 2021 18:02:32 +0000 (10:02 -0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Fri, 8 Jan 2021 04:02:36 +0000 (23:02 -0500)
In the lpfc offline routine, called for various reasons such as sysfs
attribute, driver unload, or port error, the driver is calling
__lpfc_cpuhp_remove() to destroy the hot plug data. If the offline routine
is called while the driver is in the process of being unloaded, a request
using lpfc_cpuhp_remove() is also made from lpfc_sli4_hba_unset(). The
cpuhp elements are no longer valid when the second removal request is made.

Fix by only calling the cpuhp removal once when the adapter is in the
process of unloading.

Link: https://lore.kernel.org/r/20210104180240.46824-8-jsmart2021@gmail.com
Co-developed-by: Dick Kennedy <dick.kennedy@broadcom.com>
Signed-off-by: Dick Kennedy <dick.kennedy@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

index 593b175..af92676 100644 (file)
@@ -3602,7 +3602,11 @@ lpfc_offline(struct lpfc_hba *phba)
                        spin_unlock_irq(shost->host_lock);
                }
        lpfc_destroy_vport_work_array(phba, vports);
-       __lpfc_cpuhp_remove(phba);
+       /* If OFFLINE flag is clear (i.e. unloading), cpuhp removal is handled
+        * in hba_unset
+        */
+       if (phba->pport->fc_flag & FC_OFFLINE_MODE)
+               __lpfc_cpuhp_remove(phba);
 
        if (phba->cfg_xri_rebalancing)
                lpfc_destroy_multixri_pools(phba);