Commit e2c34219 authored by Alice Wong's avatar Alice Wong Committed by Alex Deucher

drm/amdgpu/psp: deallocate memory when psp_load_fw failed

psp_load_fw failure would cause memory leak for psp tmr and psp ring
because psp_hw_init is not called as psp block is not fully initialized.
Clean up psp tmr and psp ring when psp_load_fw fail by calling
psp_free_shared_bufs and psp_ring_destroy.
Reviewed-by: default avatarHawking Zhang <Hawking.Zhang@amd.com>
Signed-off-by: default avatarAlice Wong <shiwei.wong@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent da40bf8f
...@@ -153,6 +153,12 @@ static int psp_early_init(void *handle) ...@@ -153,6 +153,12 @@ static int psp_early_init(void *handle)
return 0; return 0;
} }
void psp_ta_free_shared_buf(struct ta_mem_context *mem_ctx)
{
amdgpu_bo_free_kernel(&mem_ctx->shared_bo, &mem_ctx->shared_mc_addr,
&mem_ctx->shared_buf);
}
static void psp_free_shared_bufs(struct psp_context *psp) static void psp_free_shared_bufs(struct psp_context *psp)
{ {
void *tmr_buf; void *tmr_buf;
...@@ -1003,12 +1009,6 @@ int psp_ta_init_shared_buf(struct psp_context *psp, ...@@ -1003,12 +1009,6 @@ int psp_ta_init_shared_buf(struct psp_context *psp,
&mem_ctx->shared_buf); &mem_ctx->shared_buf);
} }
void psp_ta_free_shared_buf(struct ta_mem_context *mem_ctx)
{
amdgpu_bo_free_kernel(&mem_ctx->shared_bo, &mem_ctx->shared_mc_addr,
&mem_ctx->shared_buf);
}
static void psp_prep_ta_invoke_indirect_cmd_buf(struct psp_gfx_cmd_resp *cmd, static void psp_prep_ta_invoke_indirect_cmd_buf(struct psp_gfx_cmd_resp *cmd,
uint32_t ta_cmd_id, uint32_t ta_cmd_id,
struct ta_context *context) struct ta_context *context)
...@@ -2409,18 +2409,18 @@ static int psp_load_fw(struct amdgpu_device *adev) ...@@ -2409,18 +2409,18 @@ static int psp_load_fw(struct amdgpu_device *adev)
ret = psp_load_non_psp_fw(psp); ret = psp_load_non_psp_fw(psp);
if (ret) if (ret)
goto failed; goto failed1;
ret = psp_asd_initialize(psp); ret = psp_asd_initialize(psp);
if (ret) { if (ret) {
DRM_ERROR("PSP load asd failed!\n"); DRM_ERROR("PSP load asd failed!\n");
return ret; goto failed1;
} }
ret = psp_rl_load(adev); ret = psp_rl_load(adev);
if (ret) { if (ret) {
DRM_ERROR("PSP load RL failed!\n"); DRM_ERROR("PSP load RL failed!\n");
return ret; goto failed1;
} }
if (amdgpu_sriov_vf(adev) && amdgpu_in_reset(adev)) { if (amdgpu_sriov_vf(adev) && amdgpu_in_reset(adev)) {
...@@ -2464,12 +2464,15 @@ static int psp_load_fw(struct amdgpu_device *adev) ...@@ -2464,12 +2464,15 @@ static int psp_load_fw(struct amdgpu_device *adev)
return 0; return 0;
failed1:
psp_free_shared_bufs(psp);
failed: failed:
/* /*
* all cleanup jobs (xgmi terminate, ras terminate, * all cleanup jobs (xgmi terminate, ras terminate,
* ring destroy, cmd/fence/fw buffers destory, * ring destroy, cmd/fence/fw buffers destory,
* psp->cmd destory) are delayed to psp_hw_fini * psp->cmd destory) are delayed to psp_hw_fini
*/ */
psp_ring_destroy(psp, PSP_RING_TYPE__KM);
return ret; return ret;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment