forked from luck/tmp_suning_uos_patched
gpio/omap: warn if bank is not enabled on setting irq type
For OMAP devices, if a gpio is being used as an interrupt source but has not been requested by calling gpio_request(), a call to request_irq() may cause the kernel hang because the gpio bank may be disabled and hence the register access will fail. To prevent such hangs, test for this case and warn if this is detected. Signed-off-by: Jon Hunter <jon-hunter@ti.com> Reviewed-by: Felipe Balbi <balbi@ti.com> Acked-by: Santosh Shilimkar <santosh.shilimkar@ti.com> Acked-by: Kevin Hilman <khilman@linaro.org> Tested-by: Javier Martinez Canillas <javier@dowhile0.org> Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
This commit is contained in:
parent
ede4d7a5b9
commit
8d4c277e18
|
@ -427,6 +427,9 @@ static int gpio_irq_type(struct irq_data *d, unsigned type)
|
||||||
int retval;
|
int retval;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
|
if (WARN_ON(!bank->mod_usage))
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
#ifdef CONFIG_ARCH_OMAP1
|
#ifdef CONFIG_ARCH_OMAP1
|
||||||
if (d->irq > IH_MPUIO_BASE)
|
if (d->irq > IH_MPUIO_BASE)
|
||||||
gpio = OMAP_MPUIO(d->irq - IH_MPUIO_BASE);
|
gpio = OMAP_MPUIO(d->irq - IH_MPUIO_BASE);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user