]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
ARM: dts: renesas: r8a73a4: Describe coresight on R-Mobile APE6
authorMarek Vasut <marek.vasut+renesas@mailbox.org>
Sat, 2 May 2026 18:55:45 +0000 (20:55 +0200)
committerGeert Uytterhoeven <geert+renesas@glider.be>
Fri, 15 May 2026 09:35:25 +0000 (11:35 +0200)
Describe coresight topology on R-Mobile APE6. Extend the current PTM node
with connection funnel, TPIU, ETB and replicator. The coresight on this
hardware is clocked from the ZT/ZTR trace clock.

Note that only core 0 part of the topology is described, because the
other cores are still not present in the DT.

Signed-off-by: Marek Vasut <marek.vasut+renesas@mailbox.org>
Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be>
Link: https://patch.msgid.link/20260502185557.93061-5-marek.vasut+renesas@mailbox.org
Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
arch/arm/boot/dts/renesas/r8a73a4.dtsi

index a70a0dc402a5f90f0f36e01417b5bceb3cb2749a..c3427dc7cf7dda4b00af7cb2ab90b9109c76e8ce 100644 (file)
                };
        };
 
-       ptm {
-               compatible = "arm,coresight-etm3x";
+       replicator {
+               compatible = "arm,coresight-static-replicator";
+               clocks = <&cpg_clocks R8A73A4_CLK_ZTR>;
+               clock-names = "atclk";
                power-domains = <&pd_d4>;
+
+               out-ports {
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+
+                       /* replicator output ports */
+                       port@0 {
+                               reg = <0>;
+
+                               replicator_out_port0: endpoint {
+                                       remote-endpoint = <&tpiu_in_port>;
+                               };
+                       };
+                       port@1 {
+                               reg = <1>;
+
+                               replicator_out_port1: endpoint {
+                                       remote-endpoint = <&etb_in_port>;
+                               };
+                       };
+               };
+
+               in-ports {
+                       /* replicator input port */
+                       port {
+                               replicator_in_port0: endpoint {
+                                       remote-endpoint = <&funnel_out_port>;
+                               };
+                       };
+               };
+       };
+
+       etb@e6f81000 {
+               compatible = "arm,coresight-etb10", "arm,primecell";
+               reg = <0 0xe6f81000 0 0x1000>;
+               clocks = <&cpg_clocks R8A73A4_CLK_ZT>, <&cpg_clocks R8A73A4_CLK_ZTR>;
+               clock-names = "apb_pclk", "atclk";
+               power-domains = <&pd_d4>;
+
+               in-ports {
+                       port {
+                               etb_in_port: endpoint {
+                                       remote-endpoint = <&replicator_out_port1>;
+                               };
+                       };
+               };
+       };
+
+       tpiu@e6f83000 {
+               compatible = "arm,coresight-tpiu", "arm,primecell";
+               reg = <0 0xe6f83000 0 0x1000>;
+               clocks = <&cpg_clocks R8A73A4_CLK_ZT>, <&cpg_clocks R8A73A4_CLK_ZTR>;
+               clock-names = "apb_pclk", "atclk";
+               power-domains = <&pd_d4>;
+
+               in-ports {
+                       port {
+                               tpiu_in_port: endpoint {
+                                       remote-endpoint = <&replicator_out_port0>;
+                               };
+                       };
+               };
+       };
+
+       funnel {
+               compatible = "arm,coresight-static-funnel";
+
+               /* funnel output ports */
+               out-ports {
+                       port {
+                               funnel_out_port: endpoint {
+                                       remote-endpoint =
+                                               <&replicator_in_port0>;
+                               };
+                       };
+               };
+
+               in-ports {
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+
+                       /* funnel input ports */
+                       port@0 {
+                               reg = <0>;
+                               funnel0_in_port0: endpoint {
+                                       remote-endpoint = <&ptm0_out_port>;
+                               };
+                       };
+               };
+       };
+
+       ptm@e6fbc000 {
+               compatible = "arm,coresight-etm3x", "arm,primecell";
+               reg = <0 0xe6fbc000 0 0x1000>;
+               clocks = <&cpg_clocks R8A73A4_CLK_ZT>, <&cpg_clocks R8A73A4_CLK_ZTR>;
+               clock-names = "apb_pclk", "atclk";
+               cpu = <&cpu0>;
+               power-domains = <&pd_d4>;
+
+               out-ports {
+                       port {
+                               ptm0_out_port: endpoint {
+                                       remote-endpoint = <&funnel0_in_port0>;
+                               };
+                       };
+               };
        };
 
        timer {