xref: /openbmc/linux/Documentation/devicetree/bindings/interrupt-controller/nvidia,tegra20-ictlr.txt (revision 7f2e85840871f199057e65232ebde846192ed989)
1NVIDIA Legacy Interrupt Controller
2
3All Tegra SoCs contain a legacy interrupt controller that routes
4interrupts to the GIC, and also serves as a wakeup source. It is also
5referred to as "ictlr", hence the name of the binding.
6
7The HW block exposes a number of interrupt controllers, each
8implementing a set of 32 interrupts.
9
10Required properties:
11
12- compatible : should be: "nvidia,tegra<chip>-ictlr". The LIC on
13  subsequent SoCs remained backwards-compatible with Tegra30, so on
14  Tegra generations later than Tegra30 the compatible value should
15  include "nvidia,tegra30-ictlr".
16- reg : Specifies base physical address and size of the registers.
17  Each controller must be described separately (Tegra20 has 4 of them,
18  whereas Tegra30 and later have 5"
19- interrupt-controller : Identifies the node as an interrupt controller.
20- #interrupt-cells : Specifies the number of cells needed to encode an
21  interrupt source. The value must be 3.
22- interrupt-parent : a phandle to the GIC these interrupts are routed
23  to.
24
25Notes:
26
27- Because this HW ultimately routes interrupts to the GIC, the
28  interrupt specifier must be that of the GIC.
29- Only SPIs can use the ictlr as an interrupt parent. SGIs and PPIs
30  are explicitly forbidden.
31
32Example:
33
34	ictlr: interrupt-controller@60004000 {
35		compatible = "nvidia,tegra20-ictlr", "nvidia,tegra-ictlr";
36		reg = <0x60004000 64>,
37		      <0x60004100 64>,
38		      <0x60004200 64>,
39		      <0x60004300 64>;
40		interrupt-controller;
41		#interrupt-cells = <3>;
42		interrupt-parent = <&intc>;
43	};
44