xref: /openbmc/linux/Documentation/devicetree/bindings/interrupt-controller/marvell,icu.txt (revision 7a846d3c43b0b6d04300be9ba666b102b57a391a)
1Marvell ICU Interrupt Controller
2--------------------------------
3
4The Marvell ICU (Interrupt Consolidation Unit) controller is
5responsible for collecting all wired-interrupt sources in the CP and
6communicating them to the GIC in the AP, the unit translates interrupt
7requests on input wires to MSG memory mapped transactions to the GIC.
8
9Required properties:
10
11- compatible: Should be "marvell,cp110-icu"
12
13- reg: Should contain ICU registers location and length.
14
15- #interrupt-cells: Specifies the number of cells needed to encode an
16  interrupt source. The value shall be 3.
17
18  The 1st cell is the group type of the ICU interrupt. Possible group
19  types are:
20
21   ICU_GRP_NSR (0x0) : Shared peripheral interrupt, non-secure
22   ICU_GRP_SR  (0x1) : Shared peripheral interrupt, secure
23   ICU_GRP_SEI (0x4) : System error interrupt
24   ICU_GRP_REI (0x5) : RAM error interrupt
25
26  The 2nd cell is the index of the interrupt in the ICU unit.
27
28  The 3rd cell is the type of the interrupt. See arm,gic.txt for
29  details.
30
31- interrupt-controller: Identifies the node as an interrupt
32  controller.
33
34- msi-parent: Should point to the GICP controller, the GIC extension
35  that allows to trigger interrupts using MSG memory mapped
36  transactions.
37
38Example:
39
40icu: interrupt-controller@1e0000 {
41	compatible = "marvell,cp110-icu";
42	reg = <0x1e0000 0x10>;
43	#interrupt-cells = <3>;
44	interrupt-controller;
45	msi-parent = <&gicp>;
46};
47
48usb3h0: usb3@500000 {
49	interrupt-parent = <&icu>;
50	interrupts = <ICU_GRP_NSR 106 IRQ_TYPE_LEVEL_HIGH>;
51};
52