From: Stefan Roese Date: Mon, 16 Jan 2023 08:01:48 +0000 (+0100) Subject: timer: orion-timer: Fix problem in early_init_done() X-Git-Tag: v2025.01-rc5-pxa1908~1147^2~1 X-Git-Url: http://git.dujemihanovic.xyz/html/%7B%7B%20.RelPermalink%20%7D%7D?a=commitdiff_plain;h=9a13a76e6256c51d04f41139733dbb31755e8d30;p=u-boot.git timer: orion-timer: Fix problem in early_init_done() It was noticed that Clearfog is currently broken with this newly introduced early_init_done() function. Apparently the timer is enabled here when U-Boot is run but not configured - at least not correctly. Resulting in a hangup in the timer reading functions. To fix this, also read the value of the reload register and check it's value with the one written to by U-Boot. Only if this matches, the init has already been done. Fixes: 5387b093cb79 ("timer: orion-timer: Fix problem with early static variable") Signed-off-by: Stefan Roese Acked-by: Pali Rohár Cc: Martin Rowe Cc: Tony Dinh Cc: Pali Rohár Cc: Michael Walle --- diff --git a/drivers/timer/orion-timer.c b/drivers/timer/orion-timer.c index 810a03d549..9cab27f2e4 100644 --- a/drivers/timer/orion-timer.c +++ b/drivers/timer/orion-timer.c @@ -25,7 +25,8 @@ struct orion_timer_priv { static bool early_init_done(void *base) { - if (readl(base + TIMER_CTRL) & TIMER0_EN) + if ((readl(base + TIMER_CTRL) & TIMER0_EN) && + (readl(base + TIMER0_RELOAD) == ~0)) return true; return false; }