Commit 72be7316 authored by Yifan Zha's avatar Yifan Zha Committed by Alex Deucher

drm/amd: Skip smu_v13 register irq on SRIOV VF

[Why]
VF do not need to handle SMU IRQ state.
L1 Policy will block VF access THM_THERMAL_INT_CTRL and MP1_SMN_IH_SW_INT/CNTL.

[How]
Skip smu_v13 init register_irq_handler under SRIOV VF.
And add irq_src check in enable/disable thermal alert
to avoid thermal alert enable/disable fail.
Acked-by: default avatarChristian König <christian.koenig@amd.com>
Signed-off-by: default avatarYifan Zha <Yifan.Zha@amd.com>
Reviewed-by: default avatarHawking Zhang <Hawking.Zhang@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 82841825
...@@ -1108,6 +1108,9 @@ int smu_v13_0_enable_thermal_alert(struct smu_context *smu) ...@@ -1108,6 +1108,9 @@ int smu_v13_0_enable_thermal_alert(struct smu_context *smu)
{ {
int ret = 0; int ret = 0;
if (!smu->irq_source.num_types)
return 0;
ret = amdgpu_irq_get(smu->adev, &smu->irq_source, 0); ret = amdgpu_irq_get(smu->adev, &smu->irq_source, 0);
if (ret) if (ret)
return ret; return ret;
...@@ -1117,6 +1120,9 @@ int smu_v13_0_enable_thermal_alert(struct smu_context *smu) ...@@ -1117,6 +1120,9 @@ int smu_v13_0_enable_thermal_alert(struct smu_context *smu)
int smu_v13_0_disable_thermal_alert(struct smu_context *smu) int smu_v13_0_disable_thermal_alert(struct smu_context *smu)
{ {
if (!smu->irq_source.num_types)
return 0;
return amdgpu_irq_put(smu->adev, &smu->irq_source, 0); return amdgpu_irq_put(smu->adev, &smu->irq_source, 0);
} }
...@@ -1488,6 +1494,9 @@ int smu_v13_0_register_irq_handler(struct smu_context *smu) ...@@ -1488,6 +1494,9 @@ int smu_v13_0_register_irq_handler(struct smu_context *smu)
struct amdgpu_irq_src *irq_src = &smu->irq_source; struct amdgpu_irq_src *irq_src = &smu->irq_source;
int ret = 0; int ret = 0;
if (amdgpu_sriov_vf(adev))
return 0;
irq_src->num_types = 1; irq_src->num_types = 1;
irq_src->funcs = &smu_v13_0_irq_funcs; irq_src->funcs = &smu_v13_0_irq_funcs;
......
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