aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu/si.c
diff options
context:
space:
mode:
authorAlex Deucher <alexander.deucher@amd.com>2017-09-06 18:05:43 -0400
committerAlex Deucher <alexander.deucher@amd.com>2018-02-19 14:17:12 -0500
commit2d5e0807edf3a3ff44e52ab8ab3cfd675f6c8dad (patch)
tree92524d92c361f9a92e8fbdd579eaaf07c0c5b32e /drivers/gpu/drm/amd/amdgpu/si.c
parent2df1b8b6a140147885a28612958226187f012e49 (diff)
drm/amdgpu: add HDP asic callbacks for SI
Needed to flush and invalidate the HDP block using the CPU. Reviewed-by: Christian König <christian.koenig@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com> Signed-off-by: Samuel Li <Samuel.Li@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/si.c')
-rw-r--r--drivers/gpu/drm/amd/amdgpu/si.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/si.c b/drivers/gpu/drm/amd/amdgpu/si.c
index 543101d5a5ed..f61a431b9553 100644
--- a/drivers/gpu/drm/amd/amdgpu/si.c
+++ b/drivers/gpu/drm/amd/amdgpu/si.c
@@ -1230,6 +1230,18 @@ static void si_detect_hw_virtualization(struct amdgpu_device *adev)
1230 adev->virt.caps |= AMDGPU_PASSTHROUGH_MODE; 1230 adev->virt.caps |= AMDGPU_PASSTHROUGH_MODE;
1231} 1231}
1232 1232
1233static void si_flush_hdp(struct amdgpu_device *adev)
1234{
1235 WREG32(mmHDP_MEM_COHERENCY_FLUSH_CNTL, 1);
1236 RREG32(mmHDP_MEM_COHERENCY_FLUSH_CNTL);
1237}
1238
1239static void si_invalidate_hdp(struct amdgpu_device *adev)
1240{
1241 WREG32(mmHDP_DEBUG0, 1);
1242 RREG32(mmHDP_DEBUG0);
1243}
1244
1233static const struct amdgpu_asic_funcs si_asic_funcs = 1245static const struct amdgpu_asic_funcs si_asic_funcs =
1234{ 1246{
1235 .read_disabled_bios = &si_read_disabled_bios, 1247 .read_disabled_bios = &si_read_disabled_bios,
@@ -1241,6 +1253,8 @@ static const struct amdgpu_asic_funcs si_asic_funcs =
1241 .set_uvd_clocks = &si_set_uvd_clocks, 1253 .set_uvd_clocks = &si_set_uvd_clocks,
1242 .set_vce_clocks = NULL, 1254 .set_vce_clocks = NULL,
1243 .get_config_memsize = &si_get_config_memsize, 1255 .get_config_memsize = &si_get_config_memsize,
1256 .flush_hdp = &si_flush_hdp,
1257 .invalidate_hdp = &si_invalidate_hdp,
1244}; 1258};
1245 1259
1246static uint32_t si_get_rev_id(struct amdgpu_device *adev) 1260static uint32_t si_get_rev_id(struct amdgpu_device *adev)