drm/amdgpu: Add amdgpu_ras_eeprom_reset_table
authorAndrey Grodzovsky <andrey.grodzovsky@amd.com>
Mon, 9 Sep 2019 19:59:45 +0000 (15:59 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Mon, 16 Sep 2019 15:06:27 +0000 (10:06 -0500)
This will allow to reset the table on the fly.

Signed-off-by: Andrey Grodzovsky <andrey.grodzovsky@amd.com>
Reviewed-by: Tao Zhou <tao.zhou1@amd.com>
Reviewed-by: Guchun Chen <guchun.chen@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_ras_eeprom.c
drivers/gpu/drm/amd/amdgpu/amdgpu_ras_eeprom.h

index 43dd4ab9b6d5cb7d001782bbd6c28d7e93c66928..11a8445cf7340278a5b57e13bf5ca8bd6348626b 100644 (file)
@@ -102,6 +102,22 @@ static int __update_table_header(struct amdgpu_ras_eeprom_control *control,
 
 static uint32_t  __calc_hdr_byte_sum(struct amdgpu_ras_eeprom_control *control);
 
+int amdgpu_ras_eeprom_reset_table(struct amdgpu_ras_eeprom_control *control)
+{
+       unsigned char buff[EEPROM_ADDRESS_SIZE + EEPROM_TABLE_HEADER_SIZE] = { 0 };
+       struct amdgpu_device *adev = to_amdgpu_device(control);
+       struct amdgpu_ras_eeprom_table_header *hdr = &control->tbl_hdr;
+
+       hdr->header = EEPROM_TABLE_HDR_VAL;
+       hdr->version = EEPROM_TABLE_VER;
+       hdr->first_rec_offset = EEPROM_RECORD_START;
+       hdr->tbl_size = EEPROM_TABLE_HEADER_SIZE;
+
+       adev->psp.ras.ras->eeprom_control.tbl_byte_sum =
+                       __calc_hdr_byte_sum(&adev->psp.ras.ras->eeprom_control);
+       return __update_table_header(control, buff);
+}
+
 int amdgpu_ras_eeprom_init(struct amdgpu_ras_eeprom_control *control)
 {
        int ret = 0;
@@ -149,14 +165,7 @@ int amdgpu_ras_eeprom_init(struct amdgpu_ras_eeprom_control *control)
        } else {
                DRM_INFO("Creating new EEPROM table");
 
-               hdr->header = EEPROM_TABLE_HDR_VAL;
-               hdr->version = EEPROM_TABLE_VER;
-               hdr->first_rec_offset = EEPROM_RECORD_START;
-               hdr->tbl_size = EEPROM_TABLE_HEADER_SIZE;
-
-               adev->psp.ras.ras->eeprom_control.tbl_byte_sum =
-                               __calc_hdr_byte_sum(&adev->psp.ras.ras->eeprom_control);
-               ret = __update_table_header(control, buff);
+               ret = amdgpu_ras_eeprom_reset_table(control);
        }
 
        /* Start inserting records from here */
index 41f3fcb9a29bfce68ad9a457c7560d45246f888a..622269957c1b992ed9d38106aa02bcae081e722a 100644 (file)
@@ -79,6 +79,7 @@ struct eeprom_table_record {
 
 int amdgpu_ras_eeprom_init(struct amdgpu_ras_eeprom_control *control);
 void amdgpu_ras_eeprom_fini(struct amdgpu_ras_eeprom_control *control);
+int amdgpu_ras_eeprom_reset_table(struct amdgpu_ras_eeprom_control *control);
 
 int amdgpu_ras_eeprom_process_recods(struct amdgpu_ras_eeprom_control *control,
                                            struct eeprom_table_record *records,