mirror of https://gitee.com/openkylin/linux.git
drm/amdgpu: Fix amdgpu ras to ta enums conversion
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>
This commit is contained in:
parent
9f491d731c
commit
828cfa2909
|
@ -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,
|
||||
|
|
|
@ -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);
|
||||
|
|
Loading…
Reference in New Issue