drm/amdgpu: add atomfirmware helper function to query ecc status
authorHawking Zhang <Hawking.Zhang@amd.com>
Thu, 7 Mar 2019 02:14:13 +0000 (10:14 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 19 Mar 2019 20:36:51 +0000 (15:36 -0500)
ecc default status (enabled or disabled) could be get from umc_config field in umc_info table

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

index ea917d6406886071be8726b37eefcc228fe4509a..742af0ed94d74e64c7a025355be90a4512a10789 100644 (file)
@@ -236,6 +236,37 @@ int amdgpu_atomfirmware_get_vram_type(struct amdgpu_device *adev)
        return 0;
 }
 
+/*
+ * Return true if vbios enabled ecc by default, if umc info table is available
+ * or false if ecc is not enabled or umc info table is not available
+ */
+bool amdgpu_atomfirmware_mem_ecc_supported(struct amdgpu_device *adev)
+{
+       struct amdgpu_mode_info *mode_info = &adev->mode_info;
+       int index;
+       u16 data_offset, size;
+       union umc_info *umc_info;
+       u8 frev, crev;
+       bool ecc_default_enabled = false;
+
+       index = get_index_into_master_table(atom_master_list_of_data_tables_v2_1,
+                       umc_info);
+
+       if (amdgpu_atom_parse_data_header(mode_info->atom_context,
+                               index, &size, &frev, &crev, &data_offset)) {
+               /* support umc_info 3.1+ */
+               if ((frev == 3 && crev >= 1) || (frev > 3)) {
+                       umc_info = (union umc_info *)
+                               (mode_info->atom_context->bios + data_offset);
+                       ecc_default_enabled =
+                               (le32_to_cpu(umc_info->v31.umc_config) &
+                                UMC_CONFIG__DEFAULT_MEM_ECC_ENABLE) ? true : false;
+               }
+       }
+
+       return ecc_default_enabled;
+}
+
 union firmware_info {
        struct atom_firmware_info_v3_1 v31;
 };
index f8ea77d4e863eeceb4e81c4c5dafb9094b2fd5a6..6da079e606197626af0dc1b7d2d02b7ac88a3ed7 100644 (file)
@@ -33,5 +33,6 @@ int amdgpu_atomfirmware_get_vram_width(struct amdgpu_device *adev);
 int amdgpu_atomfirmware_get_vram_type(struct amdgpu_device *adev);
 int amdgpu_atomfirmware_get_clock_info(struct amdgpu_device *adev);
 int amdgpu_atomfirmware_get_gfx_info(struct amdgpu_device *adev);
+bool amdgpu_atomfirmware_mem_ecc_supported(struct amdgpu_device *adev);
 
 #endif