]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
drm/amdgpu: added RAS EEPROM device support check
authorJohn Clements <john.clements@amd.com>
Mon, 3 Aug 2020 07:52:52 +0000 (15:52 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 4 Aug 2020 21:29:18 +0000 (17:29 -0400)
updated RAS EEPROM init/threshold sequences to check for device support

Reviewed-by: Guchun Chen <guchun.chen@amd.com>
Signed-off-by: John Clements <john.clements@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_ras_eeprom.c

index e5e3ed113d63c297fb4697451fcb3f85df036f47..0e64c39a23722ac82572649a2a63d907ebe75ce6 100644 (file)
 
 #define to_amdgpu_device(x) (container_of(x, struct amdgpu_ras, eeprom_control))->adev
 
+static bool __is_ras_eeprom_supported(struct amdgpu_device *adev)
+{
+       if ((adev->asic_type == CHIP_VEGA20) ||
+           (adev->asic_type == CHIP_ARCTURUS))
+               return true;
+
+       return false;
+}
+
 static bool __get_eeprom_i2c_addr_arct(struct amdgpu_device *adev,
                                       uint16_t *i2c_addr)
 {
@@ -276,6 +285,9 @@ int amdgpu_ras_eeprom_init(struct amdgpu_ras_eeprom_control *control,
 
        *exceed_err_limit = false;
 
+       if (!__is_ras_eeprom_supported(adev))
+               return 0;
+
        /* Verify i2c adapter is initialized */
        if (!adev->pm.smu_i2c.algo)
                return -ENOENT;
@@ -430,6 +442,9 @@ int amdgpu_ras_eeprom_check_err_threshold(
 
        *exceed_err_limit = false;
 
+       if (!__is_ras_eeprom_supported(adev))
+               return 0;
+
        /* read EEPROM table header */
        mutex_lock(&control->tbl_mutex);
        ret = i2c_transfer(&adev->pm.smu_i2c, &msg, 1);
@@ -465,7 +480,7 @@ int amdgpu_ras_eeprom_process_recods(struct amdgpu_ras_eeprom_control *control,
        struct amdgpu_device *adev = to_amdgpu_device(control);
        struct amdgpu_ras *ras = amdgpu_ras_get_context(adev);
 
-       if (adev->asic_type != CHIP_VEGA20 && adev->asic_type != CHIP_ARCTURUS)
+       if (!__is_ras_eeprom_supported(adev))
                return 0;
 
        buffs = kcalloc(num, EEPROM_ADDRESS_SIZE + EEPROM_TABLE_RECORD_SIZE,