scsi: lpfc: avoid double free of resource identifiers
[ Upstream commit cd60be4916ae689387d04b86b6fc15931e4c95ae ] Set variables initialized in lpfc_sli4_alloc_resource_identifiers() to NULL if an error occurred. Otherwise, lpfc_sli4_driver_resource_unset() attempts to free the memory again. Signed-off-by: Roberto Sassu <rsassu@suse.de> Signed-off-by: Johannes Thumshirn <jthumshirn@suse.de> Acked-by: James Smart <james.smart@broadcom.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> Signed-off-by: Sasha Levin <alexander.levin@verizon.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
582c1ca0ea
commit
c32462d0b5
@ -5951,18 +5951,25 @@ lpfc_sli4_alloc_resource_identifiers(struct lpfc_hba *phba)
|
||||
|
||||
free_vfi_bmask:
|
||||
kfree(phba->sli4_hba.vfi_bmask);
|
||||
phba->sli4_hba.vfi_bmask = NULL;
|
||||
free_xri_ids:
|
||||
kfree(phba->sli4_hba.xri_ids);
|
||||
phba->sli4_hba.xri_ids = NULL;
|
||||
free_xri_bmask:
|
||||
kfree(phba->sli4_hba.xri_bmask);
|
||||
phba->sli4_hba.xri_bmask = NULL;
|
||||
free_vpi_ids:
|
||||
kfree(phba->vpi_ids);
|
||||
phba->vpi_ids = NULL;
|
||||
free_vpi_bmask:
|
||||
kfree(phba->vpi_bmask);
|
||||
phba->vpi_bmask = NULL;
|
||||
free_rpi_ids:
|
||||
kfree(phba->sli4_hba.rpi_ids);
|
||||
phba->sli4_hba.rpi_ids = NULL;
|
||||
free_rpi_bmask:
|
||||
kfree(phba->sli4_hba.rpi_bmask);
|
||||
phba->sli4_hba.rpi_bmask = NULL;
|
||||
err_exit:
|
||||
return rc;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user