aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/ipq806x/patches-5.15/121-09-clk-qcom-krait-cc-rework-mux-reset-logic-and-reset-h.patch
blob: fb5cb14a79297eb376b497026ac48bc535fb2988 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
From 6a77cf3f5f95ec0058e1b4d1ada018748cb0b83b Mon Sep 17 00:00:00 2001
From: Christian Marangi <ansuelsmth@gmail.com>
Date: Thu, 15 Sep 2022 03:33:13 +0200
Subject: [PATCH 9/9] clk: qcom: krait-cc: rework mux reset logic and reset
 hfpll

Rework and clean mux reset logic.
Compact it to a for loop to handle both CPU and L2 in one place.
Move hardcoded aux_rate to define and add a new hfpll_rate value to
reset hfpll settings.
Change logic to now reset the hfpll to the lowest value of 600 Mhz and
then restoring the previous frequency. This permits to reset the hfpll if
the primary mux was set to source out of the secondary mux.

Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
---
 drivers/clk/qcom/krait-cc.c | 50 +++++++++++++++++--------------------
 1 file changed, 23 insertions(+), 27 deletions(-)

diff --git a/drivers/clk/qcom/krait-cc.c b/drivers/clk/qcom/krait-cc.c
index 717eff44b6a4..90dee71e7c38 100644
--- a/drivers/clk/qcom/krait-cc.c
+++ b/drivers/clk/qcom/krait-cc.c
@@ -15,7 +15,9 @@
 
 #include "clk-krait.h"
 
-#define QSB_RATE	2250000000
+#define QSB_RATE	225000000
+#define AUX_RATE	384000000
+#define HFPLL_RATE	600000000
 
 static unsigned int sec_mux_map[] = {
 	2,
@@ -317,7 +319,7 @@ static int krait_cc_probe(struct platform_device *pdev)
 {
 	struct device *dev = &pdev->dev;
 	const struct of_device_id *id;
-	unsigned long cur_rate, aux_rate, qsb_rate, pxo_rate;
+	unsigned long cur_rate, qsb_rate, pxo_rate;
 	int cpu;
 	struct clk *clk;
 	struct clk **clks;
@@ -397,36 +399,30 @@ static int krait_cc_probe(struct platform_device *pdev)
 	 * two different rates to force a HFPLL reinit under all
 	 * circumstances.
 	 */
-	cur_rate = clk_get_rate(l2_pri_mux_clk);
-	aux_rate = 384000000;
-	if (cur_rate == qsb_rate) {
-		dev_info(dev, "L2 @ QSB rate. Forcing new rate.\n");
-		cur_rate = aux_rate;
-	}
-	if (cur_rate == pxo_rate) {
-		dev_info(dev, "L2 @ PXO rate. Forcing new rate.\n");
-		cur_rate = aux_rate;
-	}
-	clk_set_rate(l2_pri_mux_clk, aux_rate);
-	clk_set_rate(l2_pri_mux_clk, 2);
-	clk_set_rate(l2_pri_mux_clk, cur_rate);
-	dev_info(dev, "L2 @ %lu KHz\n", clk_get_rate(l2_pri_mux_clk) / 1000);
-	for_each_possible_cpu(cpu) {
+	for (cpu = 0; cpu < 5; cpu++) {
+		const char *l2_s = "L2";
+		char cpu_s[5];
+
 		clk = clks[cpu];
+		if (!clk)
+			continue;
+
+		if (cpu < 4)
+			snprintf(cpu_s, 5, "CPU%d", cpu);
+
 		cur_rate = clk_get_rate(clk);
-		if (cur_rate == qsb_rate) {
-			dev_info(dev, "CPU%d @ QSB rate. Forcing new rate.\n", cpu);
-			cur_rate = aux_rate;
-		}
-		if (cur_rate ==pxo_rate) {
-			dev_info(dev, "CPU%d @ PXO rate. Forcing new rate.\n", cpu);
-			cur_rate = aux_rate;
+		if (cur_rate == qsb_rate || cur_rate == pxo_rate) {
+			dev_info(dev, "%s @ %s rate. Forcing new rate.\n",
+				 cpu < 4 ? cpu_s : l2_s,
+				 cur_rate == qsb_rate ? "QSB" : "PXO");
+			cur_rate = AUX_RATE;
 		}
 
-		clk_set_rate(clk, aux_rate);
-		clk_set_rate(clk, 2);
+		clk_set_rate(clk, AUX_RATE);
+		clk_set_rate(clk, HFPLL_RATE);
 		clk_set_rate(clk, cur_rate);
-		dev_info(dev, "CPU%d @ %lu KHz\n", cpu, clk_get_rate(clk) / 1000);
+		dev_info(dev, "%s @ %lu KHz\n", cpu < 4 ? cpu_s : l2_s,
+			 clk_get_rate(clk) / 1000);
 	}
 
 	of_clk_add_provider(dev->of_node, krait_of_get, clks);
-- 
2.37.2