Commit 5f40067f authored by Sebastian Hesselbarth's avatar Sebastian Hesselbarth Committed by Jason Cooper

irqchip: orion: use handle_edge_irq on bridge irqs

Bridge irqs are edge-triggered, i.e. they get asserted on low-to-high
transitions and not on the level of the downstream interrupt line.
This replaces handle_level_irq by the more appropriate handle_edge_irq.
Signed-off-by: default avatarSebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
Tested-by: default avatarEzequiel Garcia <ezequiel.garcia@free-electrons.com>
Cc: <stable@vger.kernel.org>: f56c0738b5c2: "irqchip: orion: clear bridge cause register on init"
Cc: <stable@vger.kernel.org> # v3.10+
Signed-off-by: default avatarJason Cooper <jason@lakedaemon.net>
parent 7b119fd1
...@@ -143,7 +143,7 @@ static int __init orion_bridge_irq_init(struct device_node *np, ...@@ -143,7 +143,7 @@ static int __init orion_bridge_irq_init(struct device_node *np,
} }
ret = irq_alloc_domain_generic_chips(domain, nrirqs, 1, np->name, ret = irq_alloc_domain_generic_chips(domain, nrirqs, 1, np->name,
handle_level_irq, clr, 0, IRQ_GC_INIT_MASK_CACHE); handle_edge_irq, clr, 0, IRQ_GC_INIT_MASK_CACHE);
if (ret) { if (ret) {
pr_err("%s: unable to alloc irq domain gc\n", np->name); pr_err("%s: unable to alloc irq domain gc\n", np->name);
return ret; return ret;
......
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