drm/amdgpu: Fix amdgpu ras to ta enums conversion
authorxinhui pan <xinhui.pan@amd.com>
Thu, 21 Mar 2019 07:13:38 +0000 (15:13 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 28 Mar 2019 03:39:52 +0000 (22:39 -0500)
Add helpes to transalte the two enums. And it will catch bugs
easily.

Signed-off-by: xinhui pan <xinhui.pan@amd.com>
Signed-off-by: Nathan Chancellor <natechancellor@gmail.com>
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_ras.c
drivers/gpu/drm/amd/amdgpu/amdgpu_ras.h

index 5ece067..1e243e1 100644 (file)
@@ -539,13 +539,13 @@ int amdgpu_ras_feature_enable(struct amdgpu_device *adev,
 
        if (!enable) {
                info.disable_features = (struct ta_ras_disable_features_input) {
-                       .block_id =  head->block,
-                       .error_type = head->type,
+                       .block_id =  amdgpu_ras_block_to_ta(head->block),
+                       .error_type = amdgpu_ras_error_to_ta(head->type),
                };
        } else {
                info.enable_features = (struct ta_ras_enable_features_input) {
-                       .block_id =  head->block,
-                       .error_type = head->type,
+                       .block_id =  amdgpu_ras_block_to_ta(head->block),
+                       .error_type = amdgpu_ras_error_to_ta(head->type),
                };
        }
 
@@ -645,8 +645,8 @@ int amdgpu_ras_error_inject(struct amdgpu_device *adev,
 {
        struct ras_manager *obj = amdgpu_ras_find_obj(adev, &info->head);
        struct ta_ras_trigger_error_input block_info = {
-               .block_id = info->head.block,
-               .inject_error_type = info->head.type,
+               .block_id =  amdgpu_ras_block_to_ta(info->head.block),
+               .inject_error_type = amdgpu_ras_error_to_ta(info->head.type),
                .sub_block_index = info->head.sub_block_index,
                .address = info->address,
                .value = info->value,
index 7a35316..682f2be 100644 (file)
@@ -197,6 +197,62 @@ static inline int amdgpu_ras_reset_gpu(struct amdgpu_device *adev,
        return 0;
 }
 
+static inline enum ta_ras_block
+amdgpu_ras_block_to_ta(enum amdgpu_ras_block block) {
+       switch (block) {
+       case AMDGPU_RAS_BLOCK__UMC:
+               return TA_RAS_BLOCK__UMC;
+       case AMDGPU_RAS_BLOCK__SDMA:
+               return TA_RAS_BLOCK__SDMA;
+       case AMDGPU_RAS_BLOCK__GFX:
+               return TA_RAS_BLOCK__GFX;
+       case AMDGPU_RAS_BLOCK__MMHUB:
+               return TA_RAS_BLOCK__MMHUB;
+       case AMDGPU_RAS_BLOCK__ATHUB:
+               return TA_RAS_BLOCK__ATHUB;
+       case AMDGPU_RAS_BLOCK__PCIE_BIF:
+               return TA_RAS_BLOCK__PCIE_BIF;
+       case AMDGPU_RAS_BLOCK__HDP:
+               return TA_RAS_BLOCK__HDP;
+       case AMDGPU_RAS_BLOCK__XGMI_WAFL:
+               return TA_RAS_BLOCK__XGMI_WAFL;
+       case AMDGPU_RAS_BLOCK__DF:
+               return TA_RAS_BLOCK__DF;
+       case AMDGPU_RAS_BLOCK__SMN:
+               return TA_RAS_BLOCK__SMN;
+       case AMDGPU_RAS_BLOCK__SEM:
+               return TA_RAS_BLOCK__SEM;
+       case AMDGPU_RAS_BLOCK__MP0:
+               return TA_RAS_BLOCK__MP0;
+       case AMDGPU_RAS_BLOCK__MP1:
+               return TA_RAS_BLOCK__MP1;
+       case AMDGPU_RAS_BLOCK__FUSE:
+               return TA_RAS_BLOCK__FUSE;
+       default:
+               WARN_ONCE(1, "RAS ERROR: unexpected block id %d\n", block);
+               return TA_RAS_BLOCK__UMC;
+       }
+}
+
+static inline enum ta_ras_error_type
+amdgpu_ras_error_to_ta(enum amdgpu_ras_error_type error) {
+       switch (error) {
+       case AMDGPU_RAS_ERROR__NONE:
+               return TA_RAS_ERROR__NONE;
+       case AMDGPU_RAS_ERROR__PARITY:
+               return TA_RAS_ERROR__PARITY;
+       case AMDGPU_RAS_ERROR__SINGLE_CORRECTABLE:
+               return TA_RAS_ERROR__SINGLE_CORRECTABLE;
+       case AMDGPU_RAS_ERROR__MULTI_UNCORRECTABLE:
+               return TA_RAS_ERROR__MULTI_UNCORRECTABLE;
+       case AMDGPU_RAS_ERROR__POISON:
+               return TA_RAS_ERROR__POISON;
+       default:
+               WARN_ONCE(1, "RAS ERROR: unexpected error type %d\n", error);
+               return TA_RAS_ERROR__NONE;
+       }
+}
+
 /* called in ip_init and ip_fini */
 int amdgpu_ras_init(struct amdgpu_device *adev);
 void amdgpu_ras_post_init(struct amdgpu_device *adev);