]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
drm/amd/pm: update workload mask after the setting
authorKenneth Feng <kenneth.feng@amd.com>
Fri, 20 Sep 2024 11:05:37 +0000 (19:05 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 4 Oct 2024 14:38:35 +0000 (16:38 +0200)
commit d7d2688bf4ea58734d73e18edcbf4684b1496d30 upstream.

update workload mask after the setting.

Link: https://gitlab.freedesktop.org/drm/amd/-/issues/3625
Signed-off-by: Kenneth Feng <kenneth.feng@amd.com>
Acked-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Cc: stable@vger.kernel.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_0_ppt.c
drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_7_ppt.c
drivers/gpu/drm/amd/pm/swsmu/smu14/smu_v14_0_2_ppt.c

index a887ab945dfa2f5e28fcdfcdc9bee9ae7a134d70..1d024b122b0c02a94a44b82faf248a38448a1809 100644 (file)
@@ -2569,10 +2569,14 @@ static int smu_v13_0_0_set_power_profile_mode(struct smu_context *smu,
                }
        }
 
-       return smu_cmn_send_smc_msg_with_param(smu,
+       ret = smu_cmn_send_smc_msg_with_param(smu,
                                               SMU_MSG_SetWorkloadMask,
                                               workload_mask,
                                               NULL);
+       if (!ret)
+               smu->workload_mask = workload_mask;
+
+       return ret;
 }
 
 static bool smu_v13_0_0_is_mode1_reset_supported(struct smu_context *smu)
index 7bc95c4043778d128859928f18f69ed9d4dd757e..b891a5e0a3969a82cd9740a51a27149d65643900 100644 (file)
@@ -2501,8 +2501,11 @@ static int smu_v13_0_7_set_power_profile_mode(struct smu_context *smu, long *inp
                return -EINVAL;
        ret = smu_cmn_send_smc_msg_with_param(smu, SMU_MSG_SetWorkloadMask,
                                    1 << workload_type, NULL);
+
        if (ret)
                dev_err(smu->adev->dev, "[%s] Failed to set work load mask!", __func__);
+       else
+               smu->workload_mask = (1 << workload_type);
 
        return ret;
 }
index 2b45adecbed2e54e9b6cb35dba4e35a99e874c1f..ba17d01e64396abb26ef14f3f05781551af60473 100644 (file)
@@ -1570,10 +1570,14 @@ static int smu_v14_0_2_set_power_profile_mode(struct smu_context *smu,
        if (workload_type < 0)
                return -EINVAL;
 
-       return smu_cmn_send_smc_msg_with_param(smu,
+       ret = smu_cmn_send_smc_msg_with_param(smu,
                                               SMU_MSG_SetWorkloadMask,
                                               1 << workload_type,
                                               NULL);
+       if (!ret)
+               smu->workload_mask = 1 << workload_type;
+
+       return ret;
 }
 
 static int smu_v14_0_2_baco_enter(struct smu_context *smu)