diff options
| author | Keerthy <j-keerthy@ti.com> | 2014-11-10 13:19:48 -0500 |
|---|---|---|
| committer | Tony Lindgren <tony@atomide.com> | 2014-11-12 10:16:27 -0500 |
| commit | c4cf0935a2d8fe6d186bf4253ea3c4b4a8a8a710 (patch) | |
| tree | 7e8ef2f43c8ea1e16d5d935ed7d57feb8261cec8 /drivers | |
| parent | 61b43d4e919e8fa5e10c77ee32ba328da07e0264 (diff) | |
bus: omap_l3_noc: Correct returning IRQ_HANDLED unconditionally in the irq handler
Correct returning IRQ_HANDLED unconditionally in the irq handler.
Return IRQ_NONE for some interrupt which we do not expect to be
handled in this handler. This prevents kernel stalling with back
to back spurious interrupts.
Fixes: 2722e56de6 ("OMAP4: l3: Introduce l3-interconnect error handling driver")
Acked-by: Nishanth Menon <nm@ti.com>
Signed-off-by: Keerthy <j-keerthy@ti.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'drivers')
| -rw-r--r-- | drivers/bus/omap_l3_noc.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/bus/omap_l3_noc.c b/drivers/bus/omap_l3_noc.c index b5eac29d8f6e..17d86595951c 100644 --- a/drivers/bus/omap_l3_noc.c +++ b/drivers/bus/omap_l3_noc.c | |||
| @@ -222,10 +222,14 @@ static irqreturn_t l3_interrupt_handler(int irq, void *_l3) | |||
| 222 | } | 222 | } |
| 223 | 223 | ||
| 224 | /* Error found so break the for loop */ | 224 | /* Error found so break the for loop */ |
| 225 | break; | 225 | return IRQ_HANDLED; |
| 226 | } | 226 | } |
| 227 | } | 227 | } |
| 228 | return IRQ_HANDLED; | 228 | |
| 229 | dev_err(l3->dev, "L3 %s IRQ not handled!!\n", | ||
| 230 | inttype ? "debug" : "application"); | ||
| 231 | |||
| 232 | return IRQ_NONE; | ||
| 229 | } | 233 | } |
| 230 | 234 | ||
| 231 | static const struct of_device_id l3_noc_match[] = { | 235 | static const struct of_device_id l3_noc_match[] = { |
