If some invalid workload types exposed by the power profile sysfs node,
it will be failed to set the unsuported profiles.
So we can skip to show the invalid workload type in the profiles list to
avoid that failure happen.

Signed-off-by: Perry Yuan <perry.y...@amd.com>
---
 drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_0_ppt.c | 4 +++-
 drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_7_ppt.c | 4 +++-
 2 files changed, 6 insertions(+), 2 deletions(-)

diff --git a/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_0_ppt.c 
b/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_0_ppt.c
index aebdd9747c37..c76dced727b9 100644
--- a/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_0_ppt.c
+++ b/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_0_ppt.c
@@ -1561,7 +1561,9 @@ static int smu_v13_0_0_get_power_profile_mode(struct 
smu_context *smu,
                workload_type = smu_cmn_to_asic_specific_index(smu,
                                                               
CMN2ASIC_MAPPING_WORKLOAD,
                                                               i);
-               if (workload_type < 0)
+               if (workload_type == -ENOTSUPP)
+                       continue;
+               else if (workload_type < 0)
                        return -EINVAL;
 
                result = smu_cmn_update_table(smu,
diff --git a/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_7_ppt.c 
b/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_7_ppt.c
index 5c6c6ad011ca..8aa3fda156a6 100644
--- a/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_7_ppt.c
+++ b/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_7_ppt.c
@@ -1477,7 +1477,9 @@ static int smu_v13_0_7_get_power_profile_mode(struct 
smu_context *smu, char *buf
                workload_type = smu_cmn_to_asic_specific_index(smu,
                                                               
CMN2ASIC_MAPPING_WORKLOAD,
                                                               i);
-               if (workload_type < 0) {
+               if (workload_type == -ENOTSUPP)
+                       continue;
+               else if (workload_type < 0) {
                        result = -EINVAL;
                        goto out;
                }
-- 
2.34.1

Reply via email to