aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu/cik.c
diff options
context:
space:
mode:
authorAlex Deucher <alexander.deucher@amd.com>2017-09-06 18:06:01 -0400
committerAlex Deucher <alexander.deucher@amd.com>2018-02-19 14:17:12 -0500
commit13854c60d7753cbb2bb1db6463df220164ec001a (patch)
tree6fa4be313e7dcbeba0b3b7e823069d704421b828 /drivers/gpu/drm/amd/amdgpu/cik.c
parent2d5e0807edf3a3ff44e52ab8ab3cfd675f6c8dad (diff)
drm/amdgpu: add HDP asic callbacks for CIK
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/cik.c')
-rw-r--r--drivers/gpu/drm/amd/amdgpu/cik.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/cik.c b/drivers/gpu/drm/amd/amdgpu/cik.c
index 8e59e65efd44..204ce807372c 100644
--- a/drivers/gpu/drm/amd/amdgpu/cik.c
+++ b/drivers/gpu/drm/amd/amdgpu/cik.c
@@ -1715,6 +1715,18 @@ static void cik_detect_hw_virtualization(struct amdgpu_device *adev)
1715 adev->virt.caps |= AMDGPU_PASSTHROUGH_MODE; 1715 adev->virt.caps |= AMDGPU_PASSTHROUGH_MODE;
1716} 1716}
1717 1717
1718static void cik_flush_hdp(struct amdgpu_device *adev)
1719{
1720 WREG32(mmHDP_MEM_COHERENCY_FLUSH_CNTL, 1);
1721 RREG32(mmHDP_MEM_COHERENCY_FLUSH_CNTL);
1722}
1723
1724static void cik_invalidate_hdp(struct amdgpu_device *adev)
1725{
1726 WREG32(mmHDP_DEBUG0, 1);
1727 RREG32(mmHDP_DEBUG0);
1728}
1729
1718static const struct amdgpu_asic_funcs cik_asic_funcs = 1730static const struct amdgpu_asic_funcs cik_asic_funcs =
1719{ 1731{
1720 .read_disabled_bios = &cik_read_disabled_bios, 1732 .read_disabled_bios = &cik_read_disabled_bios,
@@ -1726,6 +1738,8 @@ static const struct amdgpu_asic_funcs cik_asic_funcs =
1726 .set_uvd_clocks = &cik_set_uvd_clocks, 1738 .set_uvd_clocks = &cik_set_uvd_clocks,
1727 .set_vce_clocks = &cik_set_vce_clocks, 1739 .set_vce_clocks = &cik_set_vce_clocks,
1728 .get_config_memsize = &cik_get_config_memsize, 1740 .get_config_memsize = &cik_get_config_memsize,
1741 .flush_hdp = &cik_flush_hdp,
1742 .invalidate_hdp = &cik_invalidate_hdp,
1729}; 1743};
1730 1744
1731static int cik_common_early_init(void *handle) 1745static int cik_common_early_init(void *handle)