diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/soc15.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/soc15.c | 43 | 
1 files changed, 23 insertions, 20 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/soc15.c b/drivers/gpu/drm/amd/amdgpu/soc15.c index 3808402cd964..75008cc5f189 100644 --- a/drivers/gpu/drm/amd/amdgpu/soc15.c +++ b/drivers/gpu/drm/amd/amdgpu/soc15.c @@ -76,7 +76,6 @@  #include "smuio_v13_0.h"  #include "dce_virtual.h"  #include "mxgpu_ai.h" -#include "amdgpu_smu.h"  #include "amdgpu_ras.h"  #include "amdgpu_xgmi.h"  #include <uapi/linux/kfd_ioctl.h> @@ -303,6 +302,7 @@ static int soc15_query_video_codecs(struct amdgpu_device *adev, bool encode,  			*codecs = &rv_video_codecs_decode;  		return 0;  	case CHIP_ARCTURUS: +	case CHIP_ALDEBARAN:  	case CHIP_RENOIR:  		if (encode)  			*codecs = &vega_video_codecs_encode; @@ -656,7 +656,7 @@ static int soc15_asic_baco_reset(struct amdgpu_device *adev)  	int ret = 0;  	/* avoid NBIF got stuck when do RAS recovery in BACO reset */ -	if (ras && ras->supported) +	if (ras && adev->ras_enabled)  		adev->nbio.funcs->enable_doorbell_interrupt(adev, false);  	ret = amdgpu_dpm_baco_reset(adev); @@ -664,7 +664,7 @@ static int soc15_asic_baco_reset(struct amdgpu_device *adev)  		return ret;  	/* re-enable doorbell interrupt after BACO exit */ -	if (ras && ras->supported) +	if (ras && adev->ras_enabled)  		adev->nbio.funcs->enable_doorbell_interrupt(adev, true);  	return 0; @@ -711,7 +711,8 @@ soc15_asic_reset_method(struct amdgpu_device *adev)  		 * 1. PMFW version > 0x284300: all cases use baco  		 * 2. PMFW version <= 0x284300: only sGPU w/o RAS use baco  		 */ -		if ((ras && ras->supported) && adev->pm.fw_version <= 0x283400) +		if (ras && adev->ras_enabled && +		    adev->pm.fw_version <= 0x283400)  			baco_reset = false;  		break;  	case CHIP_ALDEBARAN: @@ -817,11 +818,12 @@ static void soc15_pcie_gen3_enable(struct amdgpu_device *adev)  static void soc15_program_aspm(struct amdgpu_device *adev)  { - -	if (amdgpu_aspm == 0) +	if (!amdgpu_aspm)  		return; -	/* todo */ +	if (!(adev->flags & AMD_IS_APU) && +	    (adev->nbio.funcs->program_aspm)) +		adev->nbio.funcs->program_aspm(adev);  }  static void soc15_enable_doorbell_aperture(struct amdgpu_device *adev, @@ -1392,7 +1394,6 @@ static int soc15_common_early_init(void *handle)  			adev->cg_flags = AMD_CG_SUPPORT_GFX_MGCG |  				AMD_CG_SUPPORT_GFX_MGLS |  				AMD_CG_SUPPORT_GFX_CP_LS | -				AMD_CG_SUPPORT_GFX_3D_CGCG |  				AMD_CG_SUPPORT_GFX_3D_CGLS |  				AMD_CG_SUPPORT_GFX_CGCG |  				AMD_CG_SUPPORT_GFX_CGLS | @@ -1401,7 +1402,8 @@ static int soc15_common_early_init(void *handle)  				AMD_CG_SUPPORT_MC_MGCG |  				AMD_CG_SUPPORT_MC_LS |  				AMD_CG_SUPPORT_SDMA_MGCG | -				AMD_CG_SUPPORT_SDMA_LS; +				AMD_CG_SUPPORT_SDMA_LS | +				AMD_CG_SUPPORT_VCN_MGCG;  			adev->pg_flags = AMD_PG_SUPPORT_SDMA |  				AMD_PG_SUPPORT_MMHUB | @@ -1411,7 +1413,6 @@ static int soc15_common_early_init(void *handle)  				AMD_CG_SUPPORT_GFX_MGLS |  				AMD_CG_SUPPORT_GFX_RLC_LS |  				AMD_CG_SUPPORT_GFX_CP_LS | -				AMD_CG_SUPPORT_GFX_3D_CGCG |  				AMD_CG_SUPPORT_GFX_3D_CGLS |  				AMD_CG_SUPPORT_GFX_CGCG |  				AMD_CG_SUPPORT_GFX_CGLS | @@ -1495,8 +1496,8 @@ static int soc15_common_early_init(void *handle)  			AMD_CG_SUPPORT_HDP_LS |  			AMD_CG_SUPPORT_SDMA_MGCG |  			AMD_CG_SUPPORT_SDMA_LS | -			AMD_CG_SUPPORT_IH_CG; -			/*AMD_CG_SUPPORT_VCN_MGCG |AMD_CG_SUPPORT_JPEG_MGCG;*/ +			AMD_CG_SUPPORT_IH_CG | +			AMD_CG_SUPPORT_VCN_MGCG | AMD_CG_SUPPORT_JPEG_MGCG;  		adev->pg_flags = AMD_PG_SUPPORT_VCN_DPG;  		adev->external_rev_id = adev->rev_id + 0x3c;  		break; @@ -1521,11 +1522,9 @@ static int soc15_common_late_init(void *handle)  	if (amdgpu_sriov_vf(adev))  		xgpu_ai_mailbox_get_irq(adev); -	if (adev->hdp.funcs->reset_ras_error_count) -		adev->hdp.funcs->reset_ras_error_count(adev); - -	if (adev->nbio.funcs->ras_late_init) -		r = adev->nbio.funcs->ras_late_init(adev); +	if (adev->nbio.ras_funcs && +	    adev->nbio.ras_funcs->ras_late_init) +		r = adev->nbio.ras_funcs->ras_late_init(adev);  	return r;  } @@ -1546,7 +1545,9 @@ static int soc15_common_sw_fini(void *handle)  {  	struct amdgpu_device *adev = (struct amdgpu_device *)handle; -	amdgpu_nbio_ras_fini(adev); +	if (adev->nbio.ras_funcs && +	    adev->nbio.ras_funcs->ras_fini) +		adev->nbio.ras_funcs->ras_fini(adev);  	adev->df.funcs->sw_fini(adev);  	return 0;  } @@ -1610,9 +1611,11 @@ static int soc15_common_hw_fini(void *handle)  	if (adev->nbio.ras_if &&  	    amdgpu_ras_is_supported(adev, adev->nbio.ras_if->block)) { -		if (adev->nbio.funcs->init_ras_controller_interrupt) +		if (adev->nbio.ras_funcs && +		    adev->nbio.ras_funcs->init_ras_controller_interrupt)  			amdgpu_irq_put(adev, &adev->nbio.ras_controller_irq, 0); -		if (adev->nbio.funcs->init_ras_err_event_athub_interrupt) +		if (adev->nbio.ras_funcs && +		    adev->nbio.ras_funcs->init_ras_err_event_athub_interrupt)  			amdgpu_irq_put(adev, &adev->nbio.ras_err_event_athub_irq, 0);  	} | 
