mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-12 16:15:05 -04:00
scsi: smartpqi: Fix rare SAS transport memory leak
Free rphy when pqi_sas_port_add_rphy() returns an error. If pqi_sas_port_add_rphy() returns an error, the 'rphy' allocated in sas_end_device_alloc() needs to be freed. It should be noted that no issues were ever reported. Reviewed-by: Scott Benesh <scott.benesh@microchip.com> Reviewed-by: Scott Teel <scott.teel@microchip.com> Reviewed-by: Mike McGowen <mike.mcgowen@microchip.com> Reviewed-by: Kevin Barnett <kevin.barnett@microchip.com> Suggested-by: Yang Yingliang <yangyingliang@huawei.com> Signed-off-by: Don Brace <don.brace@microchip.com> Link: https://lore.kernel.org/r/20230428153712.297638-5-don.brace@microchip.com Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
committed by
Martin K. Petersen
parent
889cda36db
commit
2312e844dc
@@ -293,10 +293,12 @@ int pqi_add_sas_device(struct pqi_sas_node *pqi_sas_node,
|
||||
|
||||
rc = pqi_sas_port_add_rphy(pqi_sas_port, rphy);
|
||||
if (rc)
|
||||
goto free_sas_port;
|
||||
goto free_sas_rphy;
|
||||
|
||||
return 0;
|
||||
|
||||
free_sas_rphy:
|
||||
sas_rphy_free(rphy);
|
||||
free_sas_port:
|
||||
pqi_free_sas_port(pqi_sas_port);
|
||||
device->sas_port = NULL;
|
||||
|
||||
Reference in New Issue
Block a user