]> git.ipfire.org Git - thirdparty/u-boot.git/commitdiff
drivers: clk: agilex: Replace status polling with wait_for_bit_le32()
authorAlif Zakuan Yuslaimi <alif.zakuan.yuslaimi@altera.com>
Mon, 4 Aug 2025 01:24:35 +0000 (18:24 -0700)
committerTien Fong Chee <tien.fong.chee@intel.com>
Fri, 8 Aug 2025 14:20:47 +0000 (22:20 +0800)
Replace cm_wait_for_fsm() function with wait_for_bit_le32() function
which supports accurate timeout.

Signed-off-by: Alif Zakuan Yuslaimi <alif.zakuan.yuslaimi@altera.com>
Reviewed-by: Tien Fong Chee <tien.fong.chee@altera.com>
drivers/clk/altera/clk-agilex.c

index b922723d8daa1b52b48df96a43e2a232bde05691..242740a4b00277f4dd07054dc1a3c2018bd652fa 100644 (file)
@@ -1,9 +1,11 @@
 // SPDX-License-Identifier: GPL-2.0
 /*
  * Copyright (C) 2019 Intel Corporation <www.intel.com>
+ * Copyright (C) 2025 Altera Corporation <www.altera.com>
  */
 
 #include <log.h>
+#include <wait_bit.h>
 #include <asm/global_data.h>
 #include <asm/io.h>
 #include <asm/system.h>
@@ -28,21 +30,33 @@ struct socfpga_clk_plat {
  */
 static void clk_write_bypass_mainpll(struct socfpga_clk_plat *plat, u32 val)
 {
+       void __iomem *base = plat->regs;
+
        CM_REG_WRITEL(plat, val, CLKMGR_MAINPLL_BYPASS);
-       cm_wait_for_fsm();
+
+       wait_for_bit_le32(base + CLKMGR_STAT,
+                         CLKMGR_STAT_BUSY, false, 20000, false);
 }
 
 static void clk_write_bypass_perpll(struct socfpga_clk_plat *plat, u32 val)
 {
+       void __iomem *base = plat->regs;
+
        CM_REG_WRITEL(plat, val, CLKMGR_PERPLL_BYPASS);
-       cm_wait_for_fsm();
+
+       wait_for_bit_le32(base + CLKMGR_STAT,
+                         CLKMGR_STAT_BUSY, false, 20000, false);
 }
 
 /* function to write the ctrl register which requires a poll of the busy bit */
 static void clk_write_ctrl(struct socfpga_clk_plat *plat, u32 val)
 {
+       void __iomem *base = plat->regs;
+
        CM_REG_WRITEL(plat, val, CLKMGR_CTRL);
-       cm_wait_for_fsm();
+
+       wait_for_bit_le32(base + CLKMGR_STAT,
+                         CLKMGR_STAT_BUSY, false, 20000, false);
 }
 
 #define MEMBUS_MAINPLL                         0
@@ -239,6 +253,7 @@ static void clk_basic_init(struct udevice *dev,
 {
        struct socfpga_clk_plat *plat = dev_get_plat(dev);
        u32 vcocalib;
+       uintptr_t base_addr = (uintptr_t)plat->regs;
 
        if (!cfg)
                return;
@@ -303,7 +318,8 @@ static void clk_basic_init(struct udevice *dev,
        /* Membus programming for peripll */
        membus_pll_configs(plat, MEMBUS_PERPLL);
 
-       cm_wait_for_lock(CLKMGR_STAT_ALLPLL_LOCKED_MASK);
+       wait_for_bit_le32((const void *)(base_addr + CLKMGR_STAT),
+                         CLKMGR_STAT_ALLPLL_LOCKED_MASK, true, 20000, false);
 
        /* Configure ping pong counters in altera group */
        CM_REG_WRITEL(plat, cfg->alt_emacactr, CLKMGR_ALTR_EMACACTR);