scsi: lpfc: Fix possible memory leak when failing to issue CMF WQE
authorJames Smart <jsmart2021@gmail.com>
Fri, 1 Jul 2022 21:14:18 +0000 (14:14 -0700)
committerMartin K. Petersen <martin.petersen@oracle.com>
Thu, 7 Jul 2022 21:21:43 +0000 (17:21 -0400)
There is no corresponding free routine if lpfc_sli4_issue_wqe fails to
issue the CMF WQE in lpfc_issue_cmf_sync_wqe.

If ret_val is non-zero, then free the iocbq request structure.

Link: https://lore.kernel.org/r/20220701211425.2708-6-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_sli.c

index 98fef63..81c61d3 100644 (file)
@@ -2003,10 +2003,12 @@ initpath:
 
        sync_buf->cmd_flag |= LPFC_IO_CMF;
        ret_val = lpfc_sli4_issue_wqe(phba, &phba->sli4_hba.hdwq[0], sync_buf);
-       if (ret_val)
+       if (ret_val) {
                lpfc_printf_log(phba, KERN_INFO, LOG_CGN_MGMT,
                                "6214 Cannot issue CMF_SYNC_WQE: x%x\n",
                                ret_val);
+               __lpfc_sli_release_iocbq(phba, sync_buf);
+       }
 out_unlock:
        spin_unlock_irqrestore(&phba->hbalock, iflags);
        return ret_val;