[PATCH 1/1] arm64: zynqmp: Add CoreSight components

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Wojciech Zmuda <wzmuda@xxxxxxxxxxx>

Add nodes for the following CoreSight components:
 - ETMs for A53 cores
 - debug components for A53 cores
 - funnel gathering outputs from A53 ETMs and SoC-wide funnels
 - the only replicator
 - all TMCs: 4k ETF, 8k ETF and ETR
 - TPIU

Signed-off-by: Wojciech Zmuda <wzmuda@xxxxxxxxxxx>
---
 arch/arm64/boot/dts/xilinx/zynqmp-coresight.dtsi | 272 +++++++++++++++++++++++
 arch/arm64/boot/dts/xilinx/zynqmp.dtsi           |   2 +
 2 files changed, 274 insertions(+)
 create mode 100644 arch/arm64/boot/dts/xilinx/zynqmp-coresight.dtsi

diff --git a/arch/arm64/boot/dts/xilinx/zynqmp-coresight.dtsi b/arch/arm64/boot/dts/xilinx/zynqmp-coresight.dtsi
new file mode 100644
index 000000000000..8b7579ad89cc
--- /dev/null
+++ b/arch/arm64/boot/dts/xilinx/zynqmp-coresight.dtsi
@@ -0,0 +1,272 @@
+// SPDX-License-Identifier: GPL-2.0+
+
+/*
+ * dtsi for Xilinx Ultrascale+ MPSoC CoreSight components
+ *
+ * Copyright (C) 2019-2020 N7 Space Sp. z o.o.
+ *
+ * Author: Wojciech Zmuda <wzmuda@xxxxxxxxxxx>
+ *
+ */
+/ {
+	etm0@fec40000 {
+		compatible = "arm,coresight-etm4x", "arm,primecell";
+		reg = <0 0xfec40000 0 0x1000>;
+		cpu = <&cpu0>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+		out-ports {
+			port {
+				etm0_out_port: endpoint {
+					remote-endpoint = <&funnel1_in_port0>;
+				};
+			};
+		};
+	};
+
+	etm1@fed40000 {
+		compatible = "arm,coresight-etm4x", "arm,primecell";
+		reg = <0 0xfed40000 0 0x1000>;
+		cpu = <&cpu1>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+		out-ports {
+			port {
+				etm1_out_port: endpoint {
+					remote-endpoint = <&funnel1_in_port1>;
+				};
+			};
+		};
+	};
+
+	etm2@fee40000 {
+		compatible = "arm,coresight-etm4x", "arm,primecell";
+		reg = <0 0xfee40000 0 0x1000>;
+		cpu = <&cpu2>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+		out-ports {
+			port {
+				etm2_out_port: endpoint {
+					remote-endpoint = <&funnel1_in_port2>;
+				};
+			};
+		};
+	};
+
+	etm3@fef40000 {
+		compatible = "arm,coresight-etm4x", "arm,primecell";
+		reg = <0 0xfef40000 0 0x1000>;
+		cpu = <&cpu3>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+		out-ports {
+			port {
+				etm3_out_port: endpoint {
+					remote-endpoint = <&funnel1_in_port3>;
+				};
+			};
+		};
+	};
+
+	debug0@fec10000 {
+		compatible = "arm,coresight-cpu-debug", "arm,primecell";
+		reg = <0 0xfec10000 0 0x1000>;
+		cpu = <&cpu0>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+	};
+
+	debug1@fed10000 {
+		compatible = "arm,coresight-cpu-debug", "arm,primecell";
+		reg = <0 0xfed10000 0 0x1000>;
+		cpu = <&cpu1>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+	};
+
+	debug2@fee10000 {
+		compatible = "arm,coresight-cpu-debug", "arm,primecell";
+		reg = <0 0xfee10000 0 0x1000>;
+		cpu = <&cpu2>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+	};
+
+	debug3@fee10000 {
+		compatible = "arm,coresight-cpu-debug", "arm,primecell";
+		reg = <0 0xfef10000 0 0x1000>;
+		cpu = <&cpu3>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+	};
+
+	funnel1@fe920000 {
+		compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
+		reg = <0 0xfe920000 0 0x1000>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+		in-ports {
+			#address-cells = <0x1>;
+			#size-cells = <0x0>;
+			port@0 {
+				reg = <0x0>;
+				funnel1_in_port0: endpoint {
+					remote-endpoint = <&etm0_out_port>;
+				};
+			};
+			port@1 {
+				reg = <0x1>;
+				funnel1_in_port1: endpoint {
+					remote-endpoint = <&etm1_out_port>;
+				};
+			};
+			port@2 {
+				reg = <0x2>;
+				funnel1_in_port2: endpoint {
+					remote-endpoint = <&etm2_out_port>;
+				};
+			};
+			port@3 {
+				reg = <0x3>;
+				funnel1_in_port3: endpoint {
+					remote-endpoint = <&etm3_out_port>;
+				};
+			};
+		};
+		out-ports {
+			port {
+				funnel1_out_port0: endpoint {
+					remote-endpoint = <&etf1_in_port>;
+				};
+			};
+		};
+	};
+
+	funnel2@fe930000 {
+		compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
+		reg = <0 0xfe930000 0 0x1000>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+		in-ports {
+			#address-cells = <0x1>;
+			#size-cells = <0x0>;
+			port@2 {
+				reg = <0x2>;
+				funnel2_in_port2: endpoint {
+					remote-endpoint = <&etf1_out_port>;
+				};
+			};
+			// Funnel2 has another input port connected to
+			// funnel0's output. Funnel0 gathers Cortex-R5 ETMs.
+		};
+		out-ports {
+			port {
+				funnel2_out_port0: endpoint {
+					remote-endpoint = <&etf2_in_port>;
+				};
+			};
+		};
+	};
+
+	etf1@fe940000 {
+		compatible = "arm,coresight-tmc", "arm,primecell";
+		reg = <0 0xfe940000 0 0x1000>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+		in-ports {
+			port {
+				etf1_in_port: endpoint {
+					remote-endpoint = <&funnel1_out_port0>;
+				};
+			};
+		};
+		out-ports {
+			port {
+				etf1_out_port: endpoint {
+					remote-endpoint = <&funnel2_in_port2>;
+				};
+			};
+		};
+	};
+
+	etf2@fe950000 {
+		compatible = "arm,coresight-tmc", "arm,primecell";
+		reg = <0 0xfe950000 0 0x1000>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+		in-ports {
+			port {
+				etf2_in_port: endpoint {
+					remote-endpoint = <&funnel2_out_port0>;
+				};
+			};
+		};
+		out-ports {
+			port {
+				etf2_out_port: endpoint {
+					remote-endpoint =
+						<&replicator_in_port0>;
+				};
+			};
+		};
+	};
+
+	replicator {
+		compatible = "arm,coresight-static-replicator";
+		in-ports {
+			port {
+				replicator_in_port0: endpoint {
+					remote-endpoint = <&etf2_out_port>;
+				};
+			};
+		};
+		out-ports {
+			#address-cells = <0x1>;
+			#size-cells = <0x0>;
+			port@0 {
+				reg = <0x0>;
+				replicator_out_port0: endpoint {
+					remote-endpoint = <&etr_in_port>;
+				};
+			};
+			port@1 {
+				reg = <0x1>;
+				replicator_out_port1: endpoint {
+					remote-endpoint = <&tpiu_in_port>;
+				};
+			};
+		};
+	};
+
+	etr@fe970000 {
+		compatible = "arm,coresight-tmc", "arm,primecell";
+		reg = <0 0xfe970000 0 0x1000>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+		in-ports {
+			port {
+				etr_in_port: endpoint {
+					remote-endpoint =
+						<&replicator_out_port0>;
+				};
+			};
+		};
+	};
+
+	tpiu@fe980000  {
+		compatible = "arm,coresight-tpiu", "arm,primecell";
+		reg = <0 0xfe980000 0 0x1000>;
+		clocks = <&clk100>;
+		clock-names = "apb_pclk";
+		in-ports {
+			port {
+				tpiu_in_port: endpoint {
+					remote-endpoint =
+						<&replicator_out_port1>;
+				};
+			};
+		};
+	};
+};
+
diff --git a/arch/arm64/boot/dts/xilinx/zynqmp.dtsi b/arch/arm64/boot/dts/xilinx/zynqmp.dtsi
index 3c731e73903a..ca0a6b9f4445 100644
--- a/arch/arm64/boot/dts/xilinx/zynqmp.dtsi
+++ b/arch/arm64/boot/dts/xilinx/zynqmp.dtsi
@@ -12,6 +12,8 @@
  * the License, or (at your option) any later version.
  */
 
+#include "zynqmp-coresight.dtsi"
+
 / {
 	compatible = "xlnx,zynqmp";
 	#address-cells = <2>;
-- 
2.11.0





[Index of Archives]     [Device Tree Compilter]     [Device Tree Spec]     [Linux Driver Backports]     [Video for Linux]     [Linux USB Devel]     [Linux PCI Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Yosemite Backpacking]


  Powered by Linux