[PATCH] drm/amdgpu:fix firmware memoryleak

Deucher, Alexander Alexander.Deucher at amd.com
Thu Sep 21 07:07:02 UTC 2017


> -----Original Message-----
> From: amd-gfx [mailto:amd-gfx-bounces at lists.freedesktop.org] On Behalf
> Of Monk Liu
> Sent: Wednesday, September 20, 2017 5:49 AM
> To: amd-gfx at lists.freedesktop.org
> Cc: Liu, Monk
> Subject: [PATCH] drm/amdgpu:fix firmware memoryleak
> 
> this fix memory leak due to request_firmware after driver
> unloaded
> 
> Change-Id: I7b4724deea0a095189c344eea3801e456e9cced0
> Signed-off-by: Monk Liu <Monk.Liu at amd.com>

Reviewed-by: Alex Deucher <alexander.deucher at amd.com>

Bonus points for fixing the gmc modules (mc ucode) as well.

Alex

> ---
>  drivers/gpu/drm/amd/amdgpu/amdgpu_psp.c |  6 ++++++
>  drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c   | 20 ++++++++++++++++++++
>  drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c  |  5 +++++
>  3 files changed, 31 insertions(+)
> 
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_psp.c
> b/drivers/gpu/drm/amd/amdgpu/amdgpu_psp.c
> index e028286..447d446 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_psp.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_psp.c
> @@ -92,6 +92,12 @@ static int psp_sw_init(void *handle)
> 
>  static int psp_sw_fini(void *handle)
>  {
> +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;
> +
> +	release_firmware(adev->psp.sos_fw);
> +	adev->psp.sos_fw = NULL;
> +	release_firmware(adev->psp.asd_fw);
> +	adev->psp.asd_fw = NULL;
>  	return 0;
>  }
> 
> diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> index f1f34a8..2bf884d 100644
> --- a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> @@ -384,6 +384,25 @@ static int gfx_v9_0_ring_test_ib(struct amdgpu_ring
> *ring, long timeout)
>          return r;
>  }
> 
> +
> +static void gfx_v9_0_free_microcode(struct amdgpu_device *adev)
> +{
> +	release_firmware(adev->gfx.pfp_fw);
> +	adev->gfx.pfp_fw = NULL;
> +	release_firmware(adev->gfx.me_fw);
> +	adev->gfx.me_fw = NULL;
> +	release_firmware(adev->gfx.ce_fw);
> +	adev->gfx.ce_fw = NULL;
> +	release_firmware(adev->gfx.rlc_fw);
> +	adev->gfx.rlc_fw = NULL;
> +	release_firmware(adev->gfx.mec_fw);
> +	adev->gfx.mec_fw = NULL;
> +	release_firmware(adev->gfx.mec2_fw);
> +	adev->gfx.mec2_fw = NULL;
> +
> +	kfree(adev->gfx.rlc.register_list_format);
> +}
> +
>  static int gfx_v9_0_init_microcode(struct amdgpu_device *adev)
>  {
>  	const char *chip_name;
> @@ -1429,6 +1448,7 @@ static int gfx_v9_0_sw_fini(void *handle)
> 
>  	gfx_v9_0_mec_fini(adev);
>  	gfx_v9_0_ngg_fini(adev);
> +	gfx_v9_0_free_microcode(adev);
> 
>  	return 0;
>  }
> diff --git a/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c
> b/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c
> index d5f3848..d052922 100644
> --- a/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c
> +++ b/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c
> @@ -1264,6 +1264,11 @@ static int sdma_v4_0_sw_fini(void *handle)
>  	for (i = 0; i < adev->sdma.num_instances; i++)
>  		amdgpu_ring_fini(&adev->sdma.instance[i].ring);
> 
> +	for (i = 0; i < adev->sdma.num_instances; i++) {
> +		release_firmware(adev->sdma.instance[i].fw);
> +		adev->sdma.instance[i].fw = NULL;
> +	}
> +
>  	return 0;
>  }
> 
> --
> 2.7.4
> 
> _______________________________________________
> amd-gfx mailing list
> amd-gfx at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/amd-gfx


More information about the amd-gfx mailing list