Commit cc188a73 authored by Evan Quan's avatar Evan Quan Committed by Alex Deucher

drm/amd/pm: fix enabled features retrieving on Renoir and Cyan Skillfish

For Cyan Skillfish and Renoir, there is no interface provided by PMFW
to retrieve the enabled features. So, we assume all features are enabled.

Fixes: 7ade3ca9 ("drm/amd/pm: correct the usage for 'supported' member of smu_feature structure")
Signed-off-by: default avatarEvan Quan <evan.quan@amd.com>
Tested-by: default avatarNathan Chancellor <nathan@kernel.org>
Acked-by: default avatarAlex Deucher <alexander.deucher@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 63b5fa9d
...@@ -562,6 +562,7 @@ static const struct pptable_funcs cyan_skillfish_ppt_funcs = { ...@@ -562,6 +562,7 @@ static const struct pptable_funcs cyan_skillfish_ppt_funcs = {
.fini_smc_tables = smu_v11_0_fini_smc_tables, .fini_smc_tables = smu_v11_0_fini_smc_tables,
.read_sensor = cyan_skillfish_read_sensor, .read_sensor = cyan_skillfish_read_sensor,
.print_clk_levels = cyan_skillfish_print_clk_levels, .print_clk_levels = cyan_skillfish_print_clk_levels,
.get_enabled_mask = smu_cmn_get_enabled_mask,
.is_dpm_running = cyan_skillfish_is_dpm_running, .is_dpm_running = cyan_skillfish_is_dpm_running,
.get_gpu_metrics = cyan_skillfish_get_gpu_metrics, .get_gpu_metrics = cyan_skillfish_get_gpu_metrics,
.od_edit_dpm_table = cyan_skillfish_od_edit_dpm_table, .od_edit_dpm_table = cyan_skillfish_od_edit_dpm_table,
......
...@@ -500,7 +500,17 @@ int smu_cmn_feature_is_enabled(struct smu_context *smu, ...@@ -500,7 +500,17 @@ int smu_cmn_feature_is_enabled(struct smu_context *smu,
uint64_t enabled_features; uint64_t enabled_features;
int feature_id; int feature_id;
if (smu->is_apu && adev->family < AMDGPU_FAMILY_VGH) if (smu_cmn_get_enabled_mask(smu, &enabled_features)) {
dev_err(adev->dev, "Failed to retrieve enabled ppfeatures!\n");
return 0;
}
/*
* For Renoir and Cyan Skillfish, they are assumed to have all features
* enabled. Also considering they have no feature_map available, the
* check here can avoid unwanted feature_map check below.
*/
if (enabled_features == ULLONG_MAX)
return 1; return 1;
feature_id = smu_cmn_to_asic_specific_index(smu, feature_id = smu_cmn_to_asic_specific_index(smu,
...@@ -509,11 +519,6 @@ int smu_cmn_feature_is_enabled(struct smu_context *smu, ...@@ -509,11 +519,6 @@ int smu_cmn_feature_is_enabled(struct smu_context *smu,
if (feature_id < 0) if (feature_id < 0)
return 0; return 0;
if (smu_cmn_get_enabled_mask(smu, &enabled_features)) {
dev_err(adev->dev, "Failed to retrieve enabled ppfeatures!\n");
return 0;
}
return test_bit(feature_id, (unsigned long *)&enabled_features); return test_bit(feature_id, (unsigned long *)&enabled_features);
} }
...@@ -559,7 +564,7 @@ int smu_cmn_get_enabled_mask(struct smu_context *smu, ...@@ -559,7 +564,7 @@ int smu_cmn_get_enabled_mask(struct smu_context *smu,
feature_mask_high = &((uint32_t *)feature_mask)[1]; feature_mask_high = &((uint32_t *)feature_mask)[1];
switch (adev->ip_versions[MP1_HWIP][0]) { switch (adev->ip_versions[MP1_HWIP][0]) {
case IP_VERSION(11, 0, 8): /* For Vangogh and Yellow Carp */
case IP_VERSION(11, 5, 0): case IP_VERSION(11, 5, 0):
case IP_VERSION(13, 0, 1): case IP_VERSION(13, 0, 1):
case IP_VERSION(13, 0, 3): case IP_VERSION(13, 0, 3):
...@@ -575,8 +580,16 @@ int smu_cmn_get_enabled_mask(struct smu_context *smu, ...@@ -575,8 +580,16 @@ int smu_cmn_get_enabled_mask(struct smu_context *smu,
1, 1,
feature_mask_high); feature_mask_high);
break; break;
/*
* For Cyan Skillfish and Renoir, there is no interface provided by PMFW
* to retrieve the enabled features. So, we assume all features are enabled.
* TODO: add other APU ASICs which suffer from the same issue here
*/
case IP_VERSION(11, 0, 8):
case IP_VERSION(12, 0, 0): case IP_VERSION(12, 0, 0):
case IP_VERSION(12, 0, 1): case IP_VERSION(12, 0, 1):
memset(feature_mask, 0xff, sizeof(*feature_mask));
break;
/* other dGPU ASICs */ /* other dGPU ASICs */
default: default:
ret = smu_cmn_send_smc_msg(smu, ret = smu_cmn_send_smc_msg(smu,
......
...@@ -55,7 +55,7 @@ ...@@ -55,7 +55,7 @@
#define smu_send_smc_msg(smu, msg, read_arg) smu_ppt_funcs(send_smc_msg, 0, smu, msg, read_arg) #define smu_send_smc_msg(smu, msg, read_arg) smu_ppt_funcs(send_smc_msg, 0, smu, msg, read_arg)
#define smu_init_display_count(smu, count) smu_ppt_funcs(init_display_count, 0, smu, count) #define smu_init_display_count(smu, count) smu_ppt_funcs(init_display_count, 0, smu, count)
#define smu_feature_set_allowed_mask(smu) smu_ppt_funcs(set_allowed_mask, 0, smu) #define smu_feature_set_allowed_mask(smu) smu_ppt_funcs(set_allowed_mask, 0, smu)
#define smu_feature_get_enabled_mask(smu, mask) smu_ppt_funcs(get_enabled_mask, 0, smu, mask) #define smu_feature_get_enabled_mask(smu, mask) smu_ppt_funcs(get_enabled_mask, -EOPNOTSUPP, smu, mask)
#define smu_feature_is_enabled(smu, mask) smu_ppt_funcs(feature_is_enabled, 0, smu, mask) #define smu_feature_is_enabled(smu, mask) smu_ppt_funcs(feature_is_enabled, 0, smu, mask)
#define smu_disable_all_features_with_exception(smu, mask) smu_ppt_funcs(disable_all_features_with_exception, 0, smu, mask) #define smu_disable_all_features_with_exception(smu, mask) smu_ppt_funcs(disable_all_features_with_exception, 0, smu, mask)
#define smu_is_dpm_running(smu) smu_ppt_funcs(is_dpm_running, 0 , smu) #define smu_is_dpm_running(smu) smu_ppt_funcs(is_dpm_running, 0 , smu)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment