Lines Matching +full:pru +full:- +full:icss
1 # SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
3 ---
5 $schema: http://devicetree.org/meta-schemas/core.yaml#
8 TI Programmable Real-Time Unit and Industrial Communication Subsystem
11 - Suman Anna <s-anna@ti.com>
15 The Programmable Real-Time Unit and Industrial Communication Subsystem
16 (PRU-ICSS a.k.a. PRUSS) is present on various TI SoCs such as AM335x, AM437x,
17 Keystone 66AK2G, OMAP-L138/DA850 etc. A PRUSS consists of dual 32-bit RISC
18 cores (Programmable Real-Time Units, or PRUs), shared RAM, data and
23 peripheral interfaces, fast real-time responses, or specialized data handling.
25 - an Ethernet MII_RT module with two MII ports
26 - an MDIO port to control external Ethernet PHYs
27 - an Industrial Ethernet Peripheral (IEP) to manage/generate Industrial
29 - an Enhanced Capture Module (eCAP)
30 - an Industrial Ethernet Timer with 7/9 capture and 16 compare events
31 - a 16550-compatible UART to support PROFIBUS
32 - Enhanced GPIO with async capture and serial support
34 A PRU-ICSS subsystem can have up to three shared data memories. A PRU core
36 0x0, but also has access to a secondary Data RAM (primary to the other PRU
38 by both the PRU cores. The Interrupt Controller (INTC) and a CFG module are
39 common to both the PRU cores. Each PRU core also has a private instruction
42 Various sub-modules within a PRU-ICSS subsystem are represented as individual
43 nodes and are defined using a parent-child hierarchy depending on their
48 PRU-ICSS Node
50 Each PRU-ICSS instance is represented as its own node with the individual PRU
53 corresponding interconnect bus nodes or target-module nodes.
60 pattern: "^(pruss|icssg)@[0-9a-f]+$"
64 - ti,am3356-pruss # for AM335x SoC family
65 - ti,am4376-pruss0 # for AM437x SoC family and PRUSS unit 0
66 - ti,am4376-pruss1 # for AM437x SoC family and PRUSS unit 1
67 - ti,am5728-pruss # for AM57xx SoC family
68 - ti,am625-pruss # for K3 AM62x SoC family
69 - ti,am642-icssg # for K3 AM64x SoC family
70 - ti,am654-icssg # for K3 AM65x SoC family
71 - ti,j721e-icssg # for K3 J721E SoC family
72 - ti,k2g-pruss # for 66AK2G SoC family
77 "#address-cells":
80 "#size-cells":
86 dma-ranges:
89 dma-coherent: true
91 power-domains:
93 This property is as per sci-pm-domain.txt.
97 memories@[a-f0-9]+$:
99 The various Data RAMs within a single PRU-ICSS unit are represented as a
108 - description: Address and size of the Data RAM0.
109 - description: Address and size of the Data RAM1.
110 - description: |
115 reg-names:
118 - const: dram0
119 - const: dram1
120 - const: shrdram2
123 - reg
124 - reg-names
128 cfg@[a-f0-9]+$:
130 PRU-ICSS configuration space. CFG sub-module represented as a SysCon.
138 - const: ti,pruss-cfg
139 - const: syscon
141 "#address-cells":
144 "#size-cells":
157 "#address-cells":
160 "#size-cells":
164 coreclk-mux@[a-f0-9]+$:
169 name "coreclk-mux".
174 '#clock-cells':
179 - description: ICSSG_CORE Clock
180 - description: ICSSG_ICLK Clock
182 assigned-clocks:
185 assigned-clock-parents:
188 Standard assigned-clocks-parents definition used for selecting
195 - clocks
199 iepclk-mux@[a-f0-9]+$:
203 mux and should have the name "iepclk-mux".
208 '#clock-cells':
213 - description: ICSSG_IEP Clock
214 - description: Core Clock (OCP Clock in older SoCs)
216 assigned-clocks:
219 assigned-clock-parents:
222 Standard assigned-clocks-parents definition used for selecting
229 - clocks
235 iep@[a-f0-9]+$:
244 mii-rt@[a-f0-9]+$:
246 Real-Time Ethernet to support multiple industrial communication protocols.
247 MII-RT sub-module represented as a SysCon.
254 - const: ti,pruss-mii
255 - const: syscon
262 mii-g-rt@[a-f0-9]+$:
264 The Real-time Media Independent Interface to support multiple industrial
265 communication protocols (G stands for Gigabit). MII-G-RT sub-module
273 - const: ti,pruss-mii-g
274 - const: syscon
281 ^pa-stats@[a-f0-9]+$:
283 PA-STATS sub-module represented as a SysCon. PA_STATS is a set of
285 ICSSG firmware. This syscon sub-module will help the device to
295 - const: ti,pruss-pa-st
296 - const: syscon
301 interrupt-controller@[a-f0-9]+$:
304 that is common to all the PRU cores. This should be represented as an
305 interrupt-controller node.
306 $ref: /schemas/interrupt-controller/ti,pruss-intc.yaml#
309 mdio@[a-f0-9]+$:
312 external PHYs. The MDIO module used within the PRU-ICSS is an instance of
314 $ref: /schemas/net/ti,davinci-mdio.yaml#
317 "^(pru|rtu|txpru)@[0-9a-f]+$":
319 PRU Node. Each PRUSS has dual PRU cores, each represented as a RemoteProc
320 device through a PRU child node each. Each node can optionally be rendered
322 present on K3 SoCs have additional auxiliary PRU cores with slightly
324 $ref: /schemas/remoteproc/ti,pru-rproc.yaml#
328 - compatible
329 - reg
330 - ranges
334 # Due to inability of correctly verifying sub-nodes with an @address through
335 # the "required" list, the required sub-nodes below are commented out for now.
338 # - memories
339 # - interrupt-controller
340 # - pru
343 - if:
348 - ti,k2g-pruss
349 - ti,am654-icssg
350 - ti,j721e-icssg
351 - ti,am642-icssg
354 - power-domains
356 - if:
361 - ti,k2g-pruss
364 - dma-coherent
367 - |
369 /* Example 1 AM33xx PRU-ICSS */
371 compatible = "ti,am3356-pruss";
373 #address-cells = <1>;
374 #size-cells = <1>;
381 reg-names = "dram0", "dram1", "shrdram2";
385 compatible = "ti,pruss-cfg", "syscon";
386 #address-cells = <1>;
387 #size-cells = <1>;
392 #address-cells = <1>;
393 #size-cells = <0>;
395 pruss_iepclk_mux: iepclk-mux@30 {
397 #clock-cells = <0>;
404 pruss_mii_rt: mii-rt@32000 {
405 compatible = "ti,pruss-mii", "syscon";
409 pruss_intc: interrupt-controller@20000 {
410 compatible = "ti,pruss-intc";
412 interrupt-controller;
413 #interrupt-cells = <3>;
415 interrupt-names = "host_intr0", "host_intr1",
421 pru0: pru@34000 {
422 compatible = "ti,am3356-pru";
426 reg-names = "iram", "control", "debug";
427 firmware-name = "am335x-pru0-fw";
430 pru1: pru@38000 {
431 compatible = "ti,am3356-pru";
435 reg-names = "iram", "control", "debug";
436 firmware-name = "am335x-pru1-fw";
443 clock-names = "fck";
445 #address-cells = <1>;
446 #size-cells = <0>;
450 - |
452 /* Example 2 AM43xx PRU-ICSS with PRUSS1 node */
453 #include <dt-bindings/interrupt-controller/arm-gic.h>
455 compatible = "ti,am4376-pruss1";
457 #address-cells = <1>;
458 #size-cells = <1>;
465 reg-names = "dram0", "dram1", "shrdram2";
469 compatible = "ti,pruss-cfg", "syscon";
470 #address-cells = <1>;
471 #size-cells = <1>;
476 #address-cells = <1>;
477 #size-cells = <0>;
479 pruss1_iepclk_mux: iepclk-mux@30 {
481 #clock-cells = <0>;
488 pruss1_mii_rt: mii-rt@32000 {
489 compatible = "ti,pruss-mii", "syscon";
493 pruss1_intc: interrupt-controller@20000 {
494 compatible = "ti,pruss-intc";
496 interrupt-controller;
497 #interrupt-cells = <3>;
505 interrupt-names = "host_intr0", "host_intr1",
509 ti,irqs-reserved = /bits/ 8 <0x20>; /* BIT(5) */
512 pru1_0: pru@34000 {
513 compatible = "ti,am4376-pru";
517 reg-names = "iram", "control", "debug";
518 firmware-name = "am437x-pru1_0-fw";
521 pru1_1: pru@38000 {
522 compatible = "ti,am4376-pru";
526 reg-names = "iram", "control", "debug";
527 firmware-name = "am437x-pru1_1-fw";
534 clock-names = "fck";
536 #address-cells = <1>;
537 #size-cells = <0>;