drm/amdgpu: initialize RAS for gfx_v9_4_3
authorTao Zhou <tao.zhou1@amd.com>
Wed, 8 Feb 2023 09:05:08 +0000 (17:05 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Fri, 9 Jun 2023 14:37:50 +0000 (10:37 -0400)
Register GFX RAS functions and initialize GFX RAS.

v2: remove xcp operations.
v3: reuse the return value of gfx_ras_sw_init.

Signed-off-by: Tao Zhou <tao.zhou1@amd.com>
Reviewed-by: Hawking Zhang <Hawking.Zhang@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/gfx_v9_4_3.c

index 5bd2f40a817e6b428937595dbd14c4e80316934f..e5cfb3adb3b3f776a889777f92fa13c4162dce5f 100644 (file)
@@ -47,6 +47,8 @@ MODULE_FIRMWARE("amdgpu/gc_9_4_3_rlc.bin");
 #define GFX9_MEC_HPD_SIZE 4096
 #define RLCG_UCODE_LOADING_START_ADDRESS 0x00002000L
 
+struct amdgpu_gfx_ras gfx_v9_4_3_ras;
+
 static void gfx_v9_4_3_set_ring_funcs(struct amdgpu_device *adev);
 static void gfx_v9_4_3_set_irq_funcs(struct amdgpu_device *adev);
 static void gfx_v9_4_3_set_gds_init(struct amdgpu_device *adev);
@@ -659,6 +661,7 @@ static int gfx_v9_4_3_gpu_early_init(struct amdgpu_device *adev)
        u32 gb_addr_config;
 
        adev->gfx.funcs = &gfx_v9_4_3_gfx_funcs;
+       adev->gfx.ras = &gfx_v9_4_3_ras;
 
        switch (adev->ip_versions[GC_HWIP][0]) {
        case IP_VERSION(9, 4, 3):
@@ -845,7 +848,7 @@ static int gfx_v9_4_3_sw_init(void *handle)
        if (r)
                return r;
 
-       return 0;
+       return amdgpu_gfx_ras_sw_init(adev);
 }
 
 static int gfx_v9_4_3_sw_fini(void *handle)
@@ -4342,3 +4345,16 @@ struct amdgpu_xcp_ip_funcs gfx_v9_4_3_xcp_funcs = {
        .suspend = &gfx_v9_4_3_xcp_suspend,
        .resume = &gfx_v9_4_3_xcp_resume
 };
+
+struct amdgpu_ras_block_hw_ops  gfx_v9_4_3_ras_ops = {
+       .query_ras_error_count = &gfx_v9_4_3_query_ras_error_count,
+       .reset_ras_error_count = &gfx_v9_4_3_reset_ras_error_count,
+       .query_ras_error_status = &gfx_v9_4_3_query_ras_error_status,
+       .reset_ras_error_status = &gfx_v9_4_3_reset_ras_error_status,
+};
+
+struct amdgpu_gfx_ras gfx_v9_4_3_ras = {
+       .ras_block = {
+               .hw_ops = &gfx_v9_4_3_ras_ops,
+       },
+};