Commit 0acbc8e5 authored by Dan Carpenter's avatar Dan Carpenter Committed by Ben Hutchings

sparc: leon: Fix a retry loop in leon_init_timers()

commit 601e6e3c upstream.

The original code causes a static checker warning because it has a
continue inside a do { } while (0); loop.  In that context, a continue
and a break are equivalent.  The intent was to go back to the start of
the loop so the continue was a bug.

I've added a retry label at the start and changed the continue to a goto
retry.  Then I removed the do { } while (0) loop and pulled the code in
one indent level.

Fixes: 2791c1a4 ("SPARC/LEON: added support for selecting Timer Core and Timer within core")
Signed-off-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent cc46a1d7
...@@ -339,37 +339,37 @@ void __init leon_init_timers(void) ...@@ -339,37 +339,37 @@ void __init leon_init_timers(void)
/* Find GPTIMER Timer Registers base address otherwise bail out. */ /* Find GPTIMER Timer Registers base address otherwise bail out. */
nnp = rootnp; nnp = rootnp;
do {
np = of_find_node_by_name(nnp, "GAISLER_GPTIMER");
if (!np) {
np = of_find_node_by_name(nnp, "01_011");
if (!np)
goto bad;
}
ampopts = 0; retry:
pp = of_find_property(np, "ampopts", &len); np = of_find_node_by_name(nnp, "GAISLER_GPTIMER");
if (pp) { if (!np) {
ampopts = *(int *)pp->value; np = of_find_node_by_name(nnp, "01_011");
if (ampopts == 0) { if (!np)
/* Skip this instance, resource already goto bad;
* allocated by other OS */ }
nnp = np;
continue; ampopts = 0;
} pp = of_find_property(np, "ampopts", &len);
if (pp) {
ampopts = *(int *)pp->value;
if (ampopts == 0) {
/* Skip this instance, resource already
* allocated by other OS */
nnp = np;
goto retry;
} }
}
/* Select Timer-Instance on Timer Core. Default is zero */
leon3_gptimer_idx = ampopts & 0x7;
/* Select Timer-Instance on Timer Core. Default is zero */ pp = of_find_property(np, "reg", &len);
leon3_gptimer_idx = ampopts & 0x7; if (pp)
leon3_gptimer_regs = *(struct leon3_gptimer_regs_map **)
pp = of_find_property(np, "reg", &len); pp->value;
if (pp) pp = of_find_property(np, "interrupts", &len);
leon3_gptimer_regs = *(struct leon3_gptimer_regs_map **) if (pp)
pp->value; leon3_gptimer_irq = *(unsigned int *)pp->value;
pp = of_find_property(np, "interrupts", &len);
if (pp)
leon3_gptimer_irq = *(unsigned int *)pp->value;
} while (0);
if (!(leon3_gptimer_regs && leon3_irqctrl_regs && leon3_gptimer_irq)) if (!(leon3_gptimer_regs && leon3_irqctrl_regs && leon3_gptimer_irq))
goto bad; goto bad;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment