[PATCH 01/12] omap: McBSP: Fix possible port lockout
Janusz Krzysztofik
jkrzyszt at tis.icnet.pl
Sun Jan 10 14:55:39 EST 2010
Friday 08 January 2010 18:14:06 Sergei Shtylyov napisał(a):
> Tony Lindgren wrote:
> > From: Janusz Krzysztofik <jkrzyszt at tis.icnet.pl>
> >
> > In its current form, the omap_mcbsp_request() function can return after
> > irq_request() failure without any cleanups, effectively locking out the
> > port forever with clocks left running. Fix it.
> >
> > Signed-off-by: Janusz Krzysztofik <jkrzyszt at tis.icnet.pl>
> > Acked-by: Jarkko Nikula <jhnikula at gmail.com>
> > Acked-by: Peter Ujfalusi <peter.ujfalusi at nokia.com>
> > Signed-off-by: Tony Lindgren <tony at atomide.com>
>
> [...]
>
> > diff --git a/arch/arm/plat-omap/mcbsp.c b/arch/arm/plat-omap/mcbsp.c
> > index 2cc1cc3..f757672 100644
> > --- a/arch/arm/plat-omap/mcbsp.c
> > +++ b/arch/arm/plat-omap/mcbsp.c
> > @@ -436,7 +436,7 @@ int omap_mcbsp_request(unsigned int id)
> > dev_err(mcbsp->dev, "Unable to request TX IRQ %d "
> > "for McBSP%d\n", mcbsp->tx_irq,
> > mcbsp->id);
> > - return err;
> > + goto error;
> > }
> >
> > init_completion(&mcbsp->rx_irq_completion);
> > @@ -446,12 +446,26 @@ int omap_mcbsp_request(unsigned int id)
> > dev_err(mcbsp->dev, "Unable to request RX IRQ %d "
> > "for McBSP%d\n", mcbsp->rx_irq,
> > mcbsp->id);
> > - free_irq(mcbsp->tx_irq, (void *)mcbsp);
> > - return err;
> > + goto tx_irq;
> > }
> > }
> >
> > return 0;
> > +tx_irq:
>
> As if this wasn't a label for error cleanup, i.e. labels could be named
> more consistently, both including 'err' or 'error'...
>
> > + free_irq(mcbsp->tx_irq, (void *)mcbsp);
> > +error:
> > + if (mcbsp->pdata && mcbsp->pdata->ops && mcbsp->pdata->ops->free)
> > + mcbsp->pdata->ops->free(id);
>
> This line is overindented.
>
Sergei,
Thanks for pointing these out.
Tony,
Since you have already sent a pull request covering this patch, I propose I
will address both issues soon when I revisit the source while further
modifying this function for McBSP register cache support, OK?
Thanks,
Janusz
More information about the linux-arm-kernel
mailing list