55 lines
1.9 KiB
Diff
55 lines
1.9 KiB
Diff
From 651aabc9fb0f354ad2ba5fd06a6011e652447489 Mon Sep 17 00:00:00 2001
|
|
From: Yao Zi <ziyao@disroot.org>
|
|
Date: Mon, 17 Feb 2025 06:11:43 +0000
|
|
Subject: [PATCH] clk: rockchip: Add PLL flag ROCKCHIP_PLL_FIXED_MODE
|
|
|
|
RK3528 comes with a new PLL variant: its "PPLL", which mainly generates
|
|
clocks for the PCIe controller, operates in normal mode only. Let's
|
|
describe it with flag ROCKCHIP_PLL_FIXED_MODE and handle it in code.
|
|
|
|
Signed-off-by: Yao Zi <ziyao@disroot.org>
|
|
Link: https://lore.kernel.org/r/20250217061142.38480-7-ziyao@disroot.org
|
|
Signed-off-by: Heiko Stuebner <heiko@sntech.de>
|
|
---
|
|
drivers/clk/rockchip/clk-pll.c | 10 ++++++----
|
|
drivers/clk/rockchip/clk.h | 2 ++
|
|
2 files changed, 8 insertions(+), 4 deletions(-)
|
|
|
|
--- a/drivers/clk/rockchip/clk-pll.c
|
|
+++ b/drivers/clk/rockchip/clk-pll.c
|
|
@@ -204,10 +204,12 @@ static int rockchip_rk3036_pll_set_param
|
|
rockchip_rk3036_pll_get_params(pll, &cur);
|
|
cur.rate = 0;
|
|
|
|
- cur_parent = pll_mux_ops->get_parent(&pll_mux->hw);
|
|
- if (cur_parent == PLL_MODE_NORM) {
|
|
- pll_mux_ops->set_parent(&pll_mux->hw, PLL_MODE_SLOW);
|
|
- rate_change_remuxed = 1;
|
|
+ if (!(pll->flags & ROCKCHIP_PLL_FIXED_MODE)) {
|
|
+ cur_parent = pll_mux_ops->get_parent(&pll_mux->hw);
|
|
+ if (cur_parent == PLL_MODE_NORM) {
|
|
+ pll_mux_ops->set_parent(&pll_mux->hw, PLL_MODE_SLOW);
|
|
+ rate_change_remuxed = 1;
|
|
+ }
|
|
}
|
|
|
|
/* update pll values */
|
|
--- a/drivers/clk/rockchip/clk.h
|
|
+++ b/drivers/clk/rockchip/clk.h
|
|
@@ -469,6 +469,7 @@ struct rockchip_pll_rate_table {
|
|
* Flags:
|
|
* ROCKCHIP_PLL_SYNC_RATE - check rate parameters to match against the
|
|
* rate_table parameters and ajust them if necessary.
|
|
+ * ROCKCHIP_PLL_FIXED_MODE - the pll operates in normal mode only
|
|
*/
|
|
struct rockchip_pll_clock {
|
|
unsigned int id;
|
|
@@ -486,6 +487,7 @@ struct rockchip_pll_clock {
|
|
};
|
|
|
|
#define ROCKCHIP_PLL_SYNC_RATE BIT(0)
|
|
+#define ROCKCHIP_PLL_FIXED_MODE BIT(1)
|
|
|
|
#define PLL(_type, _id, _name, _pnames, _flags, _con, _mode, _mshift, \
|
|
_lshift, _pflags, _rtable) \
|