mirror of
https://source.denx.de/u-boot/u-boot.git
synced 2026-06-02 09:46:37 +03:00
drivers: clk: agilex: Replace status polling with wait_for_bit_le32()
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>
This commit is contained in:
committed by
Tien Fong Chee
parent
6a4453ab06
commit
a44423e7e9
@@ -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);
|
||||
|
||||
Reference in New Issue
Block a user