Re: [PATCH] clk: rockchip: convert rk3036 pll type to use internal lock status
From: Heiko Stuebner <heiko@sntech.de>
Date: 2020-01-28 10:26:43
Also in:
linux-clk, linux-rockchip, lkml
Am Dienstag, 14. Januar 2020, 06:05:18 CET schrieb Stephen Boyd:
Quoting Heiko Stuebner (2020-01-13 07:26:56)quoted
diff --git a/drivers/clk/rockchip/clk-pll.c b/drivers/clk/rockchip/clk-pll.c index 198417d56300..37378ded0993 100644 --- a/drivers/clk/rockchip/clk-pll.c +++ b/drivers/clk/rockchip/clk-pll.c@@ -118,12 +118,30 @@ static int rockchip_pll_wait_lock(struct rockchip_clk_pll *pll) #define RK3036_PLLCON1_REFDIV_SHIFT 0 #define RK3036_PLLCON1_POSTDIV2_MASK 0x7 #define RK3036_PLLCON1_POSTDIV2_SHIFT 6 +#define RK3036_PLLCON1_LOCK_STATUS BIT(10) #define RK3036_PLLCON1_DSMPD_MASK 0x1 #define RK3036_PLLCON1_DSMPD_SHIFT 12 +#define RK3036_PLLCON1_PWRDOWN BIT(13) #define RK3036_PLLCON2_FRAC_MASK 0xffffff #define RK3036_PLLCON2_FRAC_SHIFT 0 -#define RK3036_PLLCON1_PWRDOWN (1 << 13) +static int rockchip_rk3036_pll_wait_lock(struct rockchip_clk_pll *pll) +{ + u32 pllcon; + int delay = 24000000; + + /* poll check the lock status in rk3399 xPLLCON2 */ + while (delay > 0) { + pllcon = readl_relaxed(pll->reg_base + RK3036_PLLCON(1)); + if (pllcon & RK3036_PLLCON1_LOCK_STATUS) + return 0; + + delay--;There isn't any udelay here. So the timeout is just as fast as the CPU can churn through this? Why not use an actual time? Or use the readl_poll_timeout() APIs?
Done in http://lore.kernel.org/r/20200128100204.1318450-3-heiko@sntech.de (local) and to keep things similar, I did a conversion to iopoll helpers for the other variants too. Heiko _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel