Change-Id: I9b925397d7ac61bcf9f0e8850f2d8b3dabd4a105
Signed-off-by: Evan Quan <evan.q...@amd.com>
---
 drivers/gpu/drm/amd/amdgpu/soc15.c | 24 ++++++++++++++++++++++++
 1 file changed, 24 insertions(+)

diff --git a/drivers/gpu/drm/amd/amdgpu/soc15.c 
b/drivers/gpu/drm/amd/amdgpu/soc15.c
index c0a5250..9cf7fb4 100644
--- a/drivers/gpu/drm/amd/amdgpu/soc15.c
+++ b/drivers/gpu/drm/amd/amdgpu/soc15.c
@@ -218,6 +218,28 @@ static void soc15_gc_cac_wreg(struct amdgpu_device *adev, 
u32 reg, u32 v)
        spin_unlock_irqrestore(&adev->gc_cac_idx_lock, flags);
 }
 
+static u32 soc15_se_cac_rreg(struct amdgpu_device *adev, u32 reg)
+{
+       unsigned long flags;
+       u32 r;
+
+       spin_lock_irqsave(&adev->se_cac_idx_lock, flags);
+       WREG32_SOC15(GC, 0, mmSE_CAC_IND_INDEX, (reg));
+       r = RREG32_SOC15(GC, 0, mmSE_CAC_IND_DATA);
+       spin_unlock_irqrestore(&adev->se_cac_idx_lock, flags);
+       return r;
+}
+
+static void soc15_se_cac_wreg(struct amdgpu_device *adev, u32 reg, u32 v)
+{
+       unsigned long flags;
+
+       spin_lock_irqsave(&adev->se_cac_idx_lock, flags);
+       WREG32_SOC15(GC, 0, mmSE_CAC_IND_INDEX, (reg));
+       WREG32_SOC15(GC, 0, mmSE_CAC_IND_DATA, (v));
+       spin_unlock_irqrestore(&adev->se_cac_idx_lock, flags);
+}
+
 static u32 soc15_get_config_memsize(struct amdgpu_device *adev)
 {
        if (adev->flags & AMD_IS_APU)
@@ -591,6 +613,8 @@ static int soc15_common_early_init(void *handle)
        adev->didt_wreg = &soc15_didt_wreg;
        adev->gc_cac_rreg = &soc15_gc_cac_rreg;
        adev->gc_cac_wreg = &soc15_gc_cac_wreg;
+       adev->se_cac_rreg = &soc15_se_cac_rreg;
+       adev->se_cac_wreg = &soc15_se_cac_wreg;
 
        adev->asic_funcs = &soc15_asic_funcs;
 
-- 
2.7.4

_______________________________________________
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx

Reply via email to