aboutsummaryrefslogtreecommitdiffstats
path: root/common/recipes-kernel/linux/linux-yocto-4.19.8/1732-drm-amd-powerplay-simplify-the-code-of-get-set-_acti.patch
diff options
context:
space:
mode:
Diffstat (limited to 'common/recipes-kernel/linux/linux-yocto-4.19.8/1732-drm-amd-powerplay-simplify-the-code-of-get-set-_acti.patch')
-rw-r--r--common/recipes-kernel/linux/linux-yocto-4.19.8/1732-drm-amd-powerplay-simplify-the-code-of-get-set-_acti.patch156
1 files changed, 156 insertions, 0 deletions
diff --git a/common/recipes-kernel/linux/linux-yocto-4.19.8/1732-drm-amd-powerplay-simplify-the-code-of-get-set-_acti.patch b/common/recipes-kernel/linux/linux-yocto-4.19.8/1732-drm-amd-powerplay-simplify-the-code-of-get-set-_acti.patch
new file mode 100644
index 00000000..71ce6290
--- /dev/null
+++ b/common/recipes-kernel/linux/linux-yocto-4.19.8/1732-drm-amd-powerplay-simplify-the-code-of-get-set-_acti.patch
@@ -0,0 +1,156 @@
+From 0ca05cc32644f6a390efd8ed168037126c08bedb Mon Sep 17 00:00:00 2001
+From: Kevin Wang <kevin1.wang@amd.com>
+Date: Mon, 8 Apr 2019 16:29:49 +0800
+Subject: [PATCH 1732/2940] drm/amd/powerplay: simplify the code of
+ [get|set]_activity_monitor_coeff
+
+use smu_update_table_with_arg to replace old code logic
+
+Signed-off-by: Kevin Wang <kevin1.wang@amd.com>
+Reviewed-by: Evan Quan <evan.quan@amd.com>
+---
+ .../gpu/drm/amd/powerplay/inc/amdgpu_smu.h | 6 --
+ drivers/gpu/drm/amd/powerplay/smu_v11_0.c | 75 ++-----------------
+ 2 files changed, 7 insertions(+), 74 deletions(-)
+
+diff --git a/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h b/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h
+index c146b5e884f8..26a7d2c7f4fa 100644
+--- a/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h
++++ b/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h
+@@ -524,12 +524,6 @@ struct smu_funcs
+ struct dm_pp_wm_sets_with_clock_ranges_soc15 *clock_ranges);
+ int (*set_od8_default_settings)(struct smu_context *smu,
+ bool initialize);
+- int (*get_activity_monitor_coeff)(struct smu_context *smu,
+- uint8_t *table,
+- uint16_t workload_type);
+- int (*set_activity_monitor_coeff)(struct smu_context *smu,
+- uint8_t *table,
+- uint16_t workload_type);
+ int (*conv_power_profile_to_pplib_workload)(int power_profile);
+ int (*get_power_profile_mode)(struct smu_context *smu, char *buf);
+ int (*set_power_profile_mode)(struct smu_context *smu, long *input, uint32_t size);
+diff --git a/drivers/gpu/drm/amd/powerplay/smu_v11_0.c b/drivers/gpu/drm/amd/powerplay/smu_v11_0.c
+index 0e4b4b88af24..d2e2a4e2d0eb 100644
+--- a/drivers/gpu/drm/amd/powerplay/smu_v11_0.c
++++ b/drivers/gpu/drm/amd/powerplay/smu_v11_0.c
+@@ -1460,62 +1460,6 @@ static int smu_v11_0_set_od8_default_settings(struct smu_context *smu,
+ return 0;
+ }
+
+-static int smu_v11_0_set_activity_monitor_coeff(struct smu_context *smu,
+- uint8_t *table, uint16_t workload_type)
+-{
+- int ret = 0;
+- memcpy(smu->smu_table.tables[TABLE_ACTIVITY_MONITOR_COEFF].cpu_addr,
+- table, smu->smu_table.tables[TABLE_ACTIVITY_MONITOR_COEFF].size);
+- ret = smu_send_smc_msg_with_param(smu, SMU_MSG_SetDriverDramAddrHigh,
+- upper_32_bits(smu->smu_table.tables[TABLE_ACTIVITY_MONITOR_COEFF].mc_address));
+- if (ret) {
+- pr_err("[%s] Attempt to Set Dram Addr High Failed!", __func__);
+- return ret;
+- }
+- ret = smu_send_smc_msg_with_param(smu, SMU_MSG_SetDriverDramAddrLow,
+- lower_32_bits(smu->smu_table.tables[TABLE_ACTIVITY_MONITOR_COEFF].mc_address));
+- if (ret) {
+- pr_err("[%s] Attempt to Set Dram Addr Low Failed!", __func__);
+- return ret;
+- }
+- ret = smu_send_smc_msg_with_param(smu, SMU_MSG_TransferTableSmu2Dram,
+- TABLE_ACTIVITY_MONITOR_COEFF | (workload_type << 16));
+- if (ret) {
+- pr_err("[%s] Attempt to Transfer Table From SMU Failed!", __func__);
+- return ret;
+- }
+-
+- return ret;
+-}
+-
+-static int smu_v11_0_get_activity_monitor_coeff(struct smu_context *smu,
+- uint8_t *table, uint16_t workload_type)
+-{
+- int ret = 0;
+- ret = smu_send_smc_msg_with_param(smu, SMU_MSG_SetDriverDramAddrHigh,
+- upper_32_bits(smu->smu_table.tables[TABLE_ACTIVITY_MONITOR_COEFF].mc_address));
+- if (ret) {
+- pr_err("[%s] Attempt to Set Dram Addr High Failed!", __func__);
+- return ret;
+- }
+-
+- ret = smu_send_smc_msg_with_param(smu, SMU_MSG_SetDriverDramAddrLow,
+- lower_32_bits(smu->smu_table.tables[TABLE_ACTIVITY_MONITOR_COEFF].mc_address));
+- if (ret) {
+- pr_err("[%s] Attempt to Set Dram Addr Low Failed!", __func__);
+- return ret;
+- }
+-
+- ret = smu_send_smc_msg_with_param(smu, SMU_MSG_TransferTableSmu2Dram,
+- TABLE_ACTIVITY_MONITOR_COEFF | (workload_type << 16));
+- if (ret) {
+- pr_err("[%s] Attempt to Transfer Table From SMU Failed!", __func__);
+- return ret;
+- }
+-
+- return ret;
+-}
+-
+ static int smu_v11_0_conv_power_profile_to_pplib_workload(int power_profile)
+ {
+ int pplib_workload = 0;
+@@ -1584,9 +1528,8 @@ static int smu_v11_0_get_power_profile_mode(struct smu_context *smu, char *buf)
+ for (i = 0; i <= PP_SMC_POWER_PROFILE_CUSTOM; i++) {
+ /* conv PP_SMC_POWER_PROFILE* to WORKLOAD_PPLIB_*_BIT */
+ workload_type = smu_v11_0_conv_power_profile_to_pplib_workload(i);
+- result = smu_v11_0_get_activity_monitor_coeff(smu,
+- (uint8_t *)(&activity_monitor),
+- workload_type);
++ result = smu_update_table_with_arg(smu, TABLE_ACTIVITY_MONITOR_COEFF,
++ workload_type, &activity_monitor, false);
+ if (result) {
+ pr_err("[%s] Failed to get activity monitor!", __func__);
+ return result;
+@@ -1658,7 +1601,7 @@ static int smu_v11_0_get_power_profile_mode(struct smu_context *smu, char *buf)
+ static int smu_v11_0_set_power_profile_mode(struct smu_context *smu, long *input, uint32_t size)
+ {
+ DpmActivityMonitorCoeffInt_t activity_monitor;
+- int workload_type, ret = 0;
++ int workload_type = 0, ret = 0;
+
+ smu->power_profile_mode = input[size];
+
+@@ -1668,9 +1611,8 @@ static int smu_v11_0_set_power_profile_mode(struct smu_context *smu, long *input
+ }
+
+ if (smu->power_profile_mode == PP_SMC_POWER_PROFILE_CUSTOM) {
+- ret = smu_v11_0_get_activity_monitor_coeff(smu,
+- (uint8_t *)(&activity_monitor),
+- WORKLOAD_PPLIB_CUSTOM_BIT);
++ ret = smu_update_table_with_arg(smu, TABLE_ACTIVITY_MONITOR_COEFF,
++ WORKLOAD_PPLIB_CUSTOM_BIT, &activity_monitor, false);
+ if (ret) {
+ pr_err("[%s] Failed to get activity monitor!", __func__);
+ return ret;
+@@ -1723,9 +1665,8 @@ static int smu_v11_0_set_power_profile_mode(struct smu_context *smu, long *input
+ break;
+ }
+
+- ret = smu_v11_0_set_activity_monitor_coeff(smu,
+- (uint8_t *)(&activity_monitor),
+- WORKLOAD_PPLIB_CUSTOM_BIT);
++ ret = smu_update_table_with_arg(smu, TABLE_ACTIVITY_MONITOR_COEFF,
++ WORKLOAD_PPLIB_COMPUTE_BIT, &activity_monitor, true);
+ if (ret) {
+ pr_err("[%s] Failed to set activity monitor!", __func__);
+ return ret;
+@@ -1994,8 +1935,6 @@ static const struct smu_funcs smu_v11_0_funcs = {
+ .get_sclk = smu_v11_0_dpm_get_sclk,
+ .get_mclk = smu_v11_0_dpm_get_mclk,
+ .set_od8_default_settings = smu_v11_0_set_od8_default_settings,
+- .get_activity_monitor_coeff = smu_v11_0_get_activity_monitor_coeff,
+- .set_activity_monitor_coeff = smu_v11_0_set_activity_monitor_coeff,
+ .conv_power_profile_to_pplib_workload = smu_v11_0_conv_power_profile_to_pplib_workload,
+ .get_power_profile_mode = smu_v11_0_get_power_profile_mode,
+ .set_power_profile_mode = smu_v11_0_set_power_profile_mode,
+--
+2.17.1
+