]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
drm/amdgpu: refine aca error cache for gfx v9.4.3
authorYang Wang <kevinyang.wang@amd.com>
Thu, 22 Feb 2024 02:10:43 +0000 (10:10 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 20 Mar 2024 17:38:14 +0000 (13:38 -0400)
refine aca error cache for gfx 9.4.3

Signed-off-by: Yang Wang <kevinyang.wang@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 bb5be8c4cf11a176faab8a825009e6bb5daf5064..cc7cccf0b2b2d12525e22476873c81ca310b5426 100644 (file)
@@ -684,33 +684,36 @@ static int gfx_v9_4_3_aca_bank_generate_report(struct aca_handle *handle,
                                               struct aca_bank *bank, enum aca_smu_type type,
                                               struct aca_bank_report *report, void *data)
 {
+       struct aca_bank_info info;
        u64 misc0;
        u32 instlo;
        int ret;
 
-       ret = aca_bank_info_decode(bank, &report->info);
+       ret = aca_bank_info_decode(bank, &info);
        if (ret)
                return ret;
 
        /* NOTE: overwrite info.die_id with xcd id for gfx */
        instlo = ACA_REG__IPID__INSTANCEIDLO(bank->regs[ACA_REG_IDX_IPID]);
        instlo &= GENMASK(31, 1);
-       report->info.die_id = instlo == mmSMNAID_XCD0_MCA_SMU ? 0 : 1;
+       info.die_id = instlo == mmSMNAID_XCD0_MCA_SMU ? 0 : 1;
 
        misc0 = bank->regs[ACA_REG_IDX_MISC0];
 
        switch (type) {
        case ACA_SMU_TYPE_UE:
-               report->count[ACA_ERROR_TYPE_UE] = 1ULL;
+               ret = aca_error_cache_log_bank_error(handle, &info,
+                                                    ACA_ERROR_TYPE_UE, 1ULL);
                break;
        case ACA_SMU_TYPE_CE:
-               report->count[ACA_ERROR_TYPE_CE] = ACA_REG__MISC0__ERRCNT(misc0);
+               ret = aca_error_cache_log_bank_error(handle, &info,
+                                                    ACA_ERROR_TYPE_CE, ACA_REG__MISC0__ERRCNT(misc0));
                break;
        default:
                return -EINVAL;
        }
 
-       return 0;
+       return ret;
 }
 
 static bool gfx_v9_4_3_aca_bank_is_valid(struct aca_handle *handle, struct aca_bank *bank,