[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20240625175147.94985-2-pengfei.li_1@nxp.com>
Date: Tue, 25 Jun 2024 10:51:46 -0700
From: Pengfei Li <pengfei.li_1@....com>
To: krzk+dt@...nel.org,
robh@...nel.org,
abelvesa@...nel.org,
mturquette@...libre.com,
sboyd@...nel.org,
conor+dt@...nel.org,
shawnguo@...nel.org,
s.hauer@...gutronix.de,
ping.bai@....com,
ye.li@....com,
peng.fan@....com,
aisheng.dong@....com,
frank.li@....com
Cc: kernel@...gutronix.de,
festevam@...il.com,
linux-clk@...r.kernel.org,
imx@...ts.linux.dev,
devicetree@...r.kernel.org,
linux-arm-kernel@...ts.infradead.org,
linux-kernel@...r.kernel.org
Subject: [PATCH 1/2] clk: imx93: Drop macro IMX93_CLK_END
IMX93_CLK_END was previously defined in imx93-clock.h to
indicate the number of clocks, but it is not part of the
ABI, so it should be dropped.
Now, the driver gets the number of clks by querying the
maximum index in the clk array. Due to the discontinuity
in the definition of clk index, with some gaps present,
the total count cannot be obtained by summing the array
size.
Signed-off-by: Pengfei Li <pengfei.li_1@....com>
---
drivers/clk/imx/clk-imx93.c | 25 +++++++++++++++++++++----
1 file changed, 21 insertions(+), 4 deletions(-)
diff --git a/drivers/clk/imx/clk-imx93.c b/drivers/clk/imx/clk-imx93.c
index c6a9bc8ecc1f..68c929512e16 100644
--- a/drivers/clk/imx/clk-imx93.c
+++ b/drivers/clk/imx/clk-imx93.c
@@ -257,6 +257,20 @@ static const struct imx93_clk_ccgr {
static struct clk_hw_onecell_data *clk_hw_data;
static struct clk_hw **clks;
+static int imx_clks_get_num(void)
+{
+ u32 val = 0;
+ int i;
+
+ for (i = 0; i < ARRAY_SIZE(root_array); i++)
+ val = max_t(u32, val, root_array[i].clk);
+
+ for (i = 0; i < ARRAY_SIZE(ccgr_array); i++)
+ val = max_t(u32, val, ccgr_array[i].clk);
+
+ return val + 1;
+}
+
static int imx93_clocks_probe(struct platform_device *pdev)
{
struct device *dev = &pdev->dev;
@@ -264,14 +278,17 @@ static int imx93_clocks_probe(struct platform_device *pdev)
const struct imx93_clk_root *root;
const struct imx93_clk_ccgr *ccgr;
void __iomem *base, *anatop_base;
+ int clks_num;
int i, ret;
+ clks_num = imx_clks_get_num();
+
clk_hw_data = devm_kzalloc(dev, struct_size(clk_hw_data, hws,
- IMX93_CLK_END), GFP_KERNEL);
+ clks_num), GFP_KERNEL);
if (!clk_hw_data)
return -ENOMEM;
- clk_hw_data->num = IMX93_CLK_END;
+ clk_hw_data->num = clks_num;
clks = clk_hw_data->hws;
clks[IMX93_CLK_DUMMY] = imx_clk_hw_fixed("dummy", 0);
@@ -335,7 +352,7 @@ static int imx93_clocks_probe(struct platform_device *pdev)
clks[IMX93_CLK_ARM_PLL]->clk,
clks[IMX93_CLK_A55_GATE]->clk);
- imx_check_clk_hws(clks, IMX93_CLK_END);
+ imx_check_clk_hws(clks, clks_num);
ret = of_clk_add_hw_provider(np, of_clk_hw_onecell_get, clk_hw_data);
if (ret < 0) {
@@ -348,7 +365,7 @@ static int imx93_clocks_probe(struct platform_device *pdev)
return 0;
unregister_hws:
- imx_unregister_hw_clocks(clks, IMX93_CLK_END);
+ imx_unregister_hw_clocks(clks, clks_num);
return ret;
}
--
2.34.1
Powered by blists - more mailing lists