[PATCH] clocksource: arm_arch_timer: Don't wait for probe of unexisting timers
Laurent Pinchart
laurent.pinchart at ideasonboard.com
Thu Oct 23 10:43:08 PDT 2014
Hi Stephen,
On Thursday 23 October 2014 10:39:18 Stephen Boyd wrote:
> On 10/23/2014 10:32 AM, Laurent Pinchart wrote:
> > Commit c387f07e6205 ("clocksource: arm_arch_timer: Discard unavailable
> > timers correctly") attempted to avoid waiting for probe of disabled
> > timers, but got its condition check wrong and resulted in the driver
> > waiting for probe of timers not present in DT at all. Fix it.
> >
> > Fixes: c387f07e6205 ("clocksource: arm_arch_timer: Discard unavailable
> > timers correctly") Signed-off-by: Laurent Pinchart
> > <laurent.pinchart+renesas at ideasonboard.com> ---
>
> You're the third one.
Sorry about that.
> I like how the function has been renamed in this patch. arch_timer_probed()
> is not accurately describing the intention of the code so
> arch_timer_need_probe() reads better. Maybe your rename of the function can
> be squashed into Marc's patch.
Sure, that's fine with me.
> > drivers/clocksource/arm_arch_timer.c | 15 ++++++++-------
> > 1 file changed, 8 insertions(+), 7 deletions(-)
> >
> > This patch fixes a regression introduced in v3.18-rc1.
> >
> > diff --git a/drivers/clocksource/arm_arch_timer.c
> > b/drivers/clocksource/arm_arch_timer.c index 2133f9d..5caf32c 100644
> > --- a/drivers/clocksource/arm_arch_timer.c
> > +++ b/drivers/clocksource/arm_arch_timer.c
> > @@ -657,17 +657,17 @@ static const struct of_device_id
> > arch_timer_mem_of_match[] __initconst = {>
> > };
> >
> > static bool __init
> > -arch_timer_probed(int type, const struct of_device_id *matches)
> > +arch_timer_need_probe(int type, const struct of_device_id *matches)
> > {
> > struct device_node *dn;
> > - bool probed = false;
> > + bool need_probe = false;
> >
> > dn = of_find_matching_node(NULL, matches);
> > - if (dn && of_device_is_available(dn) && (arch_timers_present & type))
> > - probed = true;
> > + if (dn && of_device_is_available(dn) && !(arch_timers_present &
> > type))
> > + need_probe = true;
> > of_node_put(dn);
> >
> > - return probed;
> > + return need_probe;
> > }
> >
> > static void __init arch_timer_common_init(void)
> > @@ -676,9 +676,10 @@ static void __init arch_timer_common_init(void)
> >
> > /* Wait until both nodes are probed if we have two timers */
> > if ((arch_timers_present & mask) != mask) {
> > - if (!arch_timer_probed(ARCH_MEM_TIMER, arch_timer_mem_of_match))
> > + if (arch_timer_need_probe(ARCH_MEM_TIMER,
> > + arch_timer_mem_of_match))
> > return;
> > - if (!arch_timer_probed(ARCH_CP15_TIMER, arch_timer_of_match))
> > + if (arch_timer_need_probe(ARCH_CP15_TIMER, arch_timer_of_match))
> > return;
> > }
--
Regards,
Laurent Pinchart
More information about the linux-arm-kernel
mailing list