Free all allocated resources on error recovery path in function amdgpu_ras_init(). Signed-off-by: Jiang Liu <gerry@xxxxxxxxxxxxxxxxx> --- drivers/gpu/drm/amd/amdgpu/amdgpu_ras.c | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ras.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ras.c index efd72b07a185..5e8838ffccaa 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ras.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ras.c @@ -3670,6 +3670,7 @@ static void amdgpu_ras_init_reserved_vram_size(struct amdgpu_device *adev) int amdgpu_ras_init(struct amdgpu_device *adev) { struct amdgpu_ras *con = amdgpu_ras_get_context(adev); + struct amdgpu_ras_block_list *ras_node, *tmp; int r; if (con) @@ -3747,20 +3748,20 @@ int amdgpu_ras_init(struct amdgpu_device *adev) * to handle fatal error */ r = amdgpu_nbio_ras_sw_init(adev); if (r) - return r; + goto release_con; if (adev->nbio.ras && adev->nbio.ras->init_ras_controller_interrupt) { r = adev->nbio.ras->init_ras_controller_interrupt(adev); if (r) - goto release_con; + goto free_blocks; } if (adev->nbio.ras && adev->nbio.ras->init_ras_err_event_athub_interrupt) { r = adev->nbio.ras->init_ras_err_event_athub_interrupt(adev); if (r) - goto release_con; + goto free_blocks; } /* Packed socket_id to ras feature mask bits[31:29] */ @@ -3776,7 +3777,7 @@ int amdgpu_ras_init(struct amdgpu_device *adev) if (amdgpu_ras_fs_init(adev)) { r = -EINVAL; - goto release_con; + goto free_blocks; } if (amdgpu_ras_aca_is_supported(adev)) { @@ -3785,7 +3786,7 @@ int amdgpu_ras_init(struct amdgpu_device *adev) else r = amdgpu_mca_init(adev); if (r) - goto release_con; + goto clear_ras_fs; } dev_info(adev->dev, "RAS INFO: ras initialized successfully, " @@ -3793,6 +3794,14 @@ int amdgpu_ras_init(struct amdgpu_device *adev) adev->ras_hw_enabled, adev->ras_enabled); return 0; + +clear_ras_fs: + amdgpu_ras_fs_fini(adev); +free_blocks: + list_for_each_entry_safe(ras_node, tmp, &adev->ras_list, node) { + list_del(&ras_node->node); + kfree(ras_node); + } release_con: amdgpu_ras_set_context(adev, NULL); kfree(con); -- 2.43.5