]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
drm/amdgpu: Switch to smuio func to get gpu clk counter
authorHawking Zhang <Hawking.Zhang@amd.com>
Sun, 17 Mar 2024 11:26:07 +0000 (19:26 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 2 May 2024 20:18:12 +0000 (16:18 -0400)
Switch to smuio callback to query gpu clock counter

Signed-off-by: Hawking Zhang <Hawking.Zhang@amd.com>
Reviewed-by: Likun Gao <Likun.Gao@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/gfx_v12_0.c

index 33fe519e617d65cadb10be0129cccd6fb1b9c39f..8147990ebefc3131186c42799fb3700c3b192967 100644 (file)
@@ -36,8 +36,6 @@
 
 #include "gc/gc_12_0_0_offset.h"
 #include "gc/gc_12_0_0_sh_mask.h"
-#include "smuio/smuio_14_0_2_offset.h"
-#include "smuio/smuio_14_0_2_sh_mask.h"
 #include "soc24_enum.h"
 #include "ivsrcid/gfx/irqsrcs_gfx_11_0_0.h"
 
@@ -3467,14 +3465,14 @@ static int gfx_v12_0_wait_for_idle(void *handle)
 
 static uint64_t gfx_v12_0_get_gpu_clock_counter(struct amdgpu_device *adev)
 {
-       uint64_t clock;
+       uint64_t clock = 0;
+
+       if (adev->smuio.funcs &&
+           adev->smuio.funcs->get_gpu_clock_counter)
+               clock = adev->smuio.funcs->get_gpu_clock_counter(adev);
+       else
+               dev_warn(adev->dev, "query gpu clock counter is not supported\n");
 
-       amdgpu_gfx_off_ctrl(adev, false);
-       mutex_lock(&adev->gfx.gpu_clock_mutex);
-       clock = (uint64_t)RREG32_SOC15(SMUIO, 0, regGOLDEN_TSC_COUNT_LOWER) |
-               ((uint64_t)RREG32_SOC15(SMUIO, 0, regGOLDEN_TSC_COUNT_UPPER) << 32ULL);
-       mutex_unlock(&adev->gfx.gpu_clock_mutex);
-       amdgpu_gfx_off_ctrl(adev, true);
        return clock;
 }