]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/amdkfd: add kgd control interface for ptl
authorPerry Yuan <perry.yuan@amd.com>
Sun, 8 Feb 2026 16:42:04 +0000 (00:42 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Mon, 11 May 2026 19:55:55 +0000 (15:55 -0400)
Add kgd->ptl_ctrl() callback so KFD can query/enable/disable
PTL state through the PSP performance monitor interface.

Signed-off-by: Perry Yuan <perry.yuan@amd.com>
Reviewed-by: Lijo Lazar <lijo.lazar@amd.com>
Acked-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_gc_9_4_3.c
drivers/gpu/drm/amd/include/kgd_kfd_interface.h

index f35947be376328e570adc081e7343c9f43105e95..6ed399163547a2c5e901134acd34961eb0d6dab3 100644 (file)
@@ -520,6 +520,16 @@ static uint32_t kgd_gfx_v9_4_3_hqd_sdma_get_doorbell(struct amdgpu_device *adev,
        return is_active ? doorbell_off >> 2 : 0;
 }
 
+static uint32_t kgd_v9_4_3_ptl_ctrl(struct amdgpu_device *adev,
+                               uint32_t cmd,
+                               uint32_t *ptl_state,
+                               enum amdgpu_ptl_fmt *fmt1,
+                               enum amdgpu_ptl_fmt *fmt2)
+{
+       return amdgpu_ptl_perf_monitor_ctrl(adev, cmd,
+                       ptl_state, fmt1, fmt2);
+}
+
 const struct kfd2kgd_calls gc_9_4_3_kfd2kgd = {
        .program_sh_mem_settings = kgd_gfx_v9_program_sh_mem_settings,
        .set_pasid_vmid_mapping = kgd_gfx_v9_4_3_set_pasid_vmid_mapping,
@@ -555,5 +565,6 @@ const struct kfd2kgd_calls gc_9_4_3_kfd2kgd = {
        .clear_address_watch = kgd_gfx_v9_4_3_clear_address_watch,
        .hqd_get_pq_addr = kgd_gfx_v9_hqd_get_pq_addr,
        .hqd_reset = kgd_gfx_v9_hqd_reset,
-       .hqd_sdma_get_doorbell = kgd_gfx_v9_4_3_hqd_sdma_get_doorbell
+       .hqd_sdma_get_doorbell = kgd_gfx_v9_4_3_hqd_sdma_get_doorbell,
+       .ptl_ctrl = kgd_v9_4_3_ptl_ctrl
 };
index 6df5afb242aeffc8028923c424abe189f9e0ba77..44e225e097d0c8f1ec9645e6fb17c9425cecf084 100644 (file)
@@ -334,6 +334,11 @@ struct kfd2kgd_calls {
                              uint32_t inst, unsigned int utimeout);
        uint32_t (*hqd_sdma_get_doorbell)(struct amdgpu_device *adev,
                                          int engine, int queue);
+       uint32_t (*ptl_ctrl)(struct amdgpu_device *adev,
+                            uint32_t cmd,
+                            uint32_t *ptl_state,
+                            enum amdgpu_ptl_fmt *fmt1,
+                            enum amdgpu_ptl_fmt *fmt2);
 };
 
 #endif /* KGD_KFD_INTERFACE_H_INCLUDED */