[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20240722094226.21602-8-ysionneau@kalrayinc.com>
Date: Mon, 22 Jul 2024 11:41:18 +0200
From: ysionneau@...rayinc.com
To: linux-kernel@...r.kernel.org, Thomas Gleixner <tglx@...utronix.de>, Rob
Herring <robh@...nel.org>, Krzysztof Kozlowski <krzk+dt@...nel.org>, Conor
Dooley <conor+dt@...nel.org>, Jonathan Borne <jborne@...rayinc.com>, Julian
Vetter <jvetter@...rayinc.com>, Yann Sionneau <ysionneau@...rayinc.com>
Cc: Jules Maselbas <jmaselbas@...v.net>, devicetree@...r.kernel.org
Subject: [RFC PATCH v3 07/37] dt-bindings: Add binding for
kalray,coolidge-ipi-ctrl
From: Yann Sionneau <ysionneau@...rayinc.com>
Add binding for Kalray Coolidge IPI controller.
Co-developed-by: Jules Maselbas <jmaselbas@...v.net>
Signed-off-by: Jules Maselbas <jmaselbas@...v.net>
Signed-off-by: Yann Sionneau <ysionneau@...rayinc.com>
---
Notes:
V2 -> V3:
- fixed bindings to adhere to dt-schema
- moved to interrupt-controller directory, like the related driver
---
.../kalray,coolidge-ipi-ctrl.yaml | 79 +++++++++++++++++++
1 file changed, 79 insertions(+)
create mode 100644 Documentation/devicetree/bindings/interrupt-controller/kalray,coolidge-ipi-ctrl.yaml
diff --git a/Documentation/devicetree/bindings/interrupt-controller/kalray,coolidge-ipi-ctrl.yaml b/Documentation/devicetree/bindings/interrupt-controller/kalray,coolidge-ipi-ctrl.yaml
new file mode 100644
index 0000000000000..91e3afe4f1ca5
--- /dev/null
+++ b/Documentation/devicetree/bindings/interrupt-controller/kalray,coolidge-ipi-ctrl.yaml
@@ -0,0 +1,79 @@
+# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/interrupt-controller/kalray,coolidge-ipi-ctrl.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Kalray Coolidge SoC Inter-Processor Interrupt Controller (IPI)
+
+maintainers:
+ - Jonathan Borne <jborne@...rayinc.com>
+ - Julian Vetter <jvetter@...rayinc.com>
+ - Yann Sionneau <ysionneau@...rayinc.com>
+
+description: |
+ The Inter-Processor Interrupt Controller (IPI) provides a fast synchronization
+ mechanism to the software. It exposes eight independent set of registers that
+ can be use to notify each processor in the cluster.
+ A set of registers contains two 32-bit registers:
+ - 17-bit interrupt control, one bit per core, raise an interrupt on write
+ - 17-bit mask, one per core, to enable interrupts
+
+ Bit at offsets 0 to 15 selects cores in the cluster, respectively PE0 to PE15,
+ while bit at offset 16 is for the cluster Resource Manager (RM) core.
+
+ The eight output interrupts are connected to each processor core interrupt
+ controller (intc).
+
+properties:
+ compatible:
+ const: kalray,coolidge-ipi-ctrl
+
+ reg:
+ maxItems: 1
+
+ interrupts-extended:
+ maxItems: 16
+ description: |
+ Specifies the interrupt line the IPI controller will raise on the core INTC.
+
+ interrupt-controller: true
+
+ '#interrupt-cells':
+ const: 0
+
+additionalProperties: false
+
+required:
+ - compatible
+ - reg
+ - interrupts-extended
+ - interrupt-controller
+ - '#interrupt-cells'
+
+examples:
+ - |
+ ipi: inter-processor-interrupt@...000 {
+ compatible = "kalray,coolidge-ipi-ctrl";
+ reg = <0x00 0xad0000 0x00 0x1000>;
+ #interrupt-cells = <0>;
+ interrupt-controller;
+ interrupts-extended = <&core_intc0 24>,
+ <&core_intc1 24>,
+ <&core_intc2 24>,
+ <&core_intc3 24>,
+ <&core_intc4 24>,
+ <&core_intc5 24>,
+ <&core_intc6 24>,
+ <&core_intc7 24>,
+ <&core_intc8 24>,
+ <&core_intc9 24>,
+ <&core_intc10 24>,
+ <&core_intc11 24>,
+ <&core_intc12 24>,
+ <&core_intc13 24>,
+ <&core_intc14 24>,
+ <&core_intc15 24>;
+ };
+
+...
--
2.45.2
Powered by blists - more mailing lists