Commit 548ce815 authored by Miquel Raynal's avatar Miquel Raynal Committed by Marc Zyngier

dt-bindings/interrupt-controller: Update Marvell ICU bindings

Change the documentation to reflect the new bindings used for Marvell
ICU. This involves describing each interrupt group as a subnode of the
ICU node. Each of them having their own compatible.

The DT binding documentation still documents the legacy binding, where
there was a single node with no subnode.
Reviewed-by: default avatarRob Herring <robh@kernel.org>
Signed-off-by: default avatarMiquel Raynal <miquel.raynal@bootlin.com>
Signed-off-by: default avatarMarc Zyngier <marc.zyngier@arm.com>
parent 175c98aa
...@@ -5,6 +5,8 @@ The Marvell ICU (Interrupt Consolidation Unit) controller is ...@@ -5,6 +5,8 @@ The Marvell ICU (Interrupt Consolidation Unit) controller is
responsible for collecting all wired-interrupt sources in the CP and responsible for collecting all wired-interrupt sources in the CP and
communicating them to the GIC in the AP, the unit translates interrupt communicating them to the GIC in the AP, the unit translates interrupt
requests on input wires to MSG memory mapped transactions to the GIC. requests on input wires to MSG memory mapped transactions to the GIC.
These messages will access a different GIC memory area depending on
their type (NSR, SR, SEI, REI, etc).
Required properties: Required properties:
...@@ -12,20 +14,23 @@ Required properties: ...@@ -12,20 +14,23 @@ Required properties:
- reg: Should contain ICU registers location and length. - reg: Should contain ICU registers location and length.
- #interrupt-cells: Specifies the number of cells needed to encode an Subnodes: Each group of interrupt is declared as a subnode of the ICU,
interrupt source. The value shall be 3. with their own compatible.
Required properties for the icu_nsr/icu_sei subnodes:
The 1st cell is the group type of the ICU interrupt. Possible group - compatible: Should be one of:
types are: * "marvell,cp110-icu-nsr"
* "marvell,cp110-icu-sr"
* "marvell,cp110-icu-sei"
* "marvell,cp110-icu-rei"
ICU_GRP_NSR (0x0) : Shared peripheral interrupt, non-secure - #interrupt-cells: Specifies the number of cells needed to encode an
ICU_GRP_SR (0x1) : Shared peripheral interrupt, secure interrupt source. The value shall be 2.
ICU_GRP_SEI (0x4) : System error interrupt
ICU_GRP_REI (0x5) : RAM error interrupt
The 2nd cell is the index of the interrupt in the ICU unit. The 1st cell is the index of the interrupt in the ICU unit.
The 3rd cell is the type of the interrupt. See arm,gic.txt for The 2nd cell is the type of the interrupt. See arm,gic.txt for
details. details.
- interrupt-controller: Identifies the node as an interrupt - interrupt-controller: Identifies the node as an interrupt
...@@ -35,17 +40,73 @@ Required properties: ...@@ -35,17 +40,73 @@ Required properties:
that allows to trigger interrupts using MSG memory mapped that allows to trigger interrupts using MSG memory mapped
transactions. transactions.
Note: each 'interrupts' property referring to any 'icu_xxx' node shall
have a different number within [0:206].
Example:
icu: interrupt-controller@1e0000 {
compatible = "marvell,cp110-icu";
reg = <0x1e0000 0x440>;
CP110_LABEL(icu_nsr): interrupt-controller@10 {
compatible = "marvell,cp110-icu-nsr";
reg = <0x10 0x20>;
#interrupt-cells = <2>;
interrupt-controller;
msi-parent = <&gicp>;
};
CP110_LABEL(icu_sei): interrupt-controller@50 {
compatible = "marvell,cp110-icu-sei";
reg = <0x50 0x10>;
#interrupt-cells = <2>;
interrupt-controller;
msi-parent = <&sei>;
};
};
node1 {
interrupt-parent = <&icu_nsr>;
interrupts = <106 IRQ_TYPE_LEVEL_HIGH>;
};
node2 {
interrupt-parent = <&icu_sei>;
interrupts = <107 IRQ_TYPE_LEVEL_HIGH>;
};
/* Would not work with the above nodes */
node3 {
interrupt-parent = <&icu_nsr>;
interrupts = <107 IRQ_TYPE_LEVEL_HIGH>;
};
The legacy bindings were different in this way:
- #interrupt-cells: The value was 3.
The 1st cell was the group type of the ICU interrupt. Possible
group types were:
ICU_GRP_NSR (0x0) : Shared peripheral interrupt, non-secure
ICU_GRP_SR (0x1) : Shared peripheral interrupt, secure
ICU_GRP_SEI (0x4) : System error interrupt
ICU_GRP_REI (0x5) : RAM error interrupt
The 2nd cell was the index of the interrupt in the ICU unit.
The 3rd cell was the type of the interrupt. See arm,gic.txt for
details.
Example: Example:
icu: interrupt-controller@1e0000 { icu: interrupt-controller@1e0000 {
compatible = "marvell,cp110-icu"; compatible = "marvell,cp110-icu";
reg = <0x1e0000 0x440>; reg = <0x1e0000 0x440>;
#interrupt-cells = <3>; #interrupt-cells = <3>;
interrupt-controller; interrupt-controller;
msi-parent = <&gicp>; msi-parent = <&gicp>;
}; };
usb3h0: usb3@500000 { node1 {
interrupt-parent = <&icu>; interrupt-parent = <&icu>;
interrupts = <ICU_GRP_NSR 106 IRQ_TYPE_LEVEL_HIGH>; interrupts = <ICU_GRP_NSR 106 IRQ_TYPE_LEVEL_HIGH>;
}; };
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