mirror of https://github.com/torvalds/linux.git
of/irq: Ignore interrupt parent for nodes without interrupts
The Devicetree Specification states:
The root of the interrupt tree is determined when traversal of the
interrupt tree reaches an interrupt controller node without an
interrupts property and thus no explicit interrupt parent.
However, of_irq_init() gratuitously assumes that a node without
interrupts has an actual interrupt parent if it finds an
interrupt-parent property higher up in the device tree. Hence when such
a property is present (e.g. in the root node), the root interrupt
controller may not be detected as such, causing a panic:
OF: of_irq_init: children remain, but no parents
Kernel panic - not syncing: No interrupt controller found.
Commit e91033621d ("of/irq: Use interrupts-extended to find
parent") already fixed a first part, by checking for the presence of an
interrupts-extended property. Fix the second part by only calling
of_irq_find_parent() when an interrupts property is present.
Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
Link: https://patch.msgid.link/fbe6fc3657070fe2df7f0529043542b52b827449.1763116833.git.geert+renesas@glider.be
Signed-off-by: Rob Herring (Arm) <robh@kernel.org>
This commit is contained in:
parent
c7496597ad
commit
1b1f04d827
|
|
@ -593,7 +593,7 @@ void __init of_irq_init(const struct of_device_id *matches)
|
||||||
* are the same distance away from the root irq controller.
|
* are the same distance away from the root irq controller.
|
||||||
*/
|
*/
|
||||||
desc->interrupt_parent = of_parse_phandle(np, "interrupts-extended", 0);
|
desc->interrupt_parent = of_parse_phandle(np, "interrupts-extended", 0);
|
||||||
if (!desc->interrupt_parent)
|
if (!desc->interrupt_parent && of_property_present(np, "interrupts"))
|
||||||
desc->interrupt_parent = of_irq_find_parent(np);
|
desc->interrupt_parent = of_irq_find_parent(np);
|
||||||
if (desc->interrupt_parent == np) {
|
if (desc->interrupt_parent == np) {
|
||||||
of_node_put(desc->interrupt_parent);
|
of_node_put(desc->interrupt_parent);
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue