aboutsummaryrefslogtreecommitdiffstats
path: root/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3184-drm-amd-powerplay-support-real-time-clock-retrieval-.patch
diff options
context:
space:
mode:
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3184-drm-amd-powerplay-support-real-time-clock-retrieval-.patch')
-rw-r--r--meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3184-drm-amd-powerplay-support-real-time-clock-retrieval-.patch61
1 files changed, 61 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3184-drm-amd-powerplay-support-real-time-clock-retrieval-.patch b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3184-drm-amd-powerplay-support-real-time-clock-retrieval-.patch
new file mode 100644
index 00000000..720a7b44
--- /dev/null
+++ b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3184-drm-amd-powerplay-support-real-time-clock-retrieval-.patch
@@ -0,0 +1,61 @@
+From 9404288acc547c838bb96804be30acd62c2b9e09 Mon Sep 17 00:00:00 2001
+From: Evan Quan <evan.quan@amd.com>
+Date: Fri, 19 Jul 2019 17:18:34 +0800
+Subject: [PATCH 3184/4256] drm/amd/powerplay: support real-time clock
+ retrieval on arcturus
+
+Enable arcturus real-time clock retrieval.
+
+Signed-off-by: Evan Quan <evan.quan@amd.com>
+Reviewed-by: Kevin Wang <kevin1.wang@amd.com>
+Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
+Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
+---
+ drivers/gpu/drm/amd/powerplay/arcturus_ppt.c | 24 ++++++++++++++++++++
+ 1 file changed, 24 insertions(+)
+
+diff --git a/drivers/gpu/drm/amd/powerplay/arcturus_ppt.c b/drivers/gpu/drm/amd/powerplay/arcturus_ppt.c
+index 6aa7f1f62a81..6d1691d9ac7c 100644
+--- a/drivers/gpu/drm/amd/powerplay/arcturus_ppt.c
++++ b/drivers/gpu/drm/amd/powerplay/arcturus_ppt.c
+@@ -994,6 +994,29 @@ static int arcturus_read_sensor(struct smu_context *smu,
+ return ret;
+ }
+
++static int arcturus_get_current_clk_freq_by_table(struct smu_context *smu,
++ enum smu_clk_type clk_type,
++ uint32_t *value)
++{
++ static SmuMetrics_t metrics;
++ int ret = 0, clk_id = 0;
++
++ if (!value)
++ return -EINVAL;
++
++ clk_id = smu_clk_get_index(smu, clk_type);
++ if (clk_id < 0)
++ return -EINVAL;
++
++ ret = arcturus_get_metrics_table(smu, &metrics);
++ if (ret)
++ return ret;
++
++ *value = metrics.CurrClock[clk_id];
++
++ return ret;
++}
++
+ static void arcturus_dump_pptable(struct smu_context *smu)
+ {
+ struct smu_table_context *table_context = &smu->smu_table;
+@@ -1448,6 +1471,7 @@ static const struct pptable_funcs arcturus_ppt_funcs = {
+ .set_default_dpm_table = arcturus_set_default_dpm_table,
+ .populate_umd_state_clk = arcturus_populate_umd_state_clk,
+ .get_thermal_temperature_range = arcturus_get_thermal_temperature_range,
++ .get_current_clk_freq_by_table = arcturus_get_current_clk_freq_by_table,
+ .print_clk_levels = arcturus_print_clk_levels,
+ .force_clk_levels = arcturus_force_clk_levels,
+ .read_sensor = arcturus_read_sensor,
+--
+2.17.1
+