mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-31 23:27:20 +00:00

The arm dts directory has grown to 1559 boards which makes it a bit unwieldy to maintain and use. Past attempts stalled out due to plans to move .dts files out of the kernel tree. Doing that is no longer planned (any time soon at least), so let's go ahead and group .dts files by vendors. This move aligns arm with arm64 .dts file structure. There's no change to dtbs_install as the flat structure is maintained on install. The naming of vendor directories is roughly in this order of preference: - Matching original and current SoC vendor prefix/name (e.g. ti, qcom) - Current vendor prefix/name if still actively sold (SoCs which have been aquired) (e.g. nxp/imx) - Existing platform name for older platforms not sold/maintained by any company (e.g. gemini, nspire) The whole move was scripted with the exception of MAINTAINERS and a few makefile fixups. Acked-by: Viresh Kumar <viresh.kumar@linaro.org> Acked-by: Michal Simek <michal.simek@amd.com> #Xilinx Acked-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> Acked-by: Neil Armstrong <neil.armstrong@linaro.org> Acked-by: Paul Barker <paul.barker@sancloud.com> Acked-by: Tony Lindgren <tony@atomide.com> Acked-by: Gregory CLEMENT <gregory.clement@bootlin.com> Acked-by: Heiko Stuebner <heiko@sntech.de> Acked-by: Wei Xu <xuwei5@hisilicon.com> #hisilicon Acked-by: Geert Uytterhoeven <geert+renesas@glider.be> Acked-by: Nick Hawkins <nick.hawkins@hpe.com> Acked-by: Baruch Siach <baruch@tkos.co.il> Reviewed-by: Linus Walleij <linus.walleij@linaro.org> Reviewed-by: Andre Przywara <andre.przywara@arm.com> Acked-by: Andre Przywara <andre.przywara@arm.com> Reviewed-by: Claudiu Beznea <claudiu.beznea@microchip.com> Acked-by: Peter Rosin <peda@axentia.se> Acked-by: Jesper Nilsson <jesper.nilsson@axis.com> Acked-by: Sudeep Holla <sudeep.holla@arm.com> Acked-by: Florian Fainelli <f.fainelli@gmail.com> #broadcom Acked-by: Manivannan Sadhasivam <mani@kernel.org> Reviewed-by: Jisheng Zhang <jszhang@kernel.org> Acked-by: Patrice Chotard <patrice.chotard@foss.st.com> Acked-by: Romain Perier <romain.perier@gmail.com> Acked-by: Alexandre TORGUE <alexandre.torgue@st.com> Acked-by: Shawn Guo <shawnguo@kernel.org> Acked-by: Kunihiko Hayashi <hayashi.kunihiko@socionext.com> Acked-by: Enric Balletbo i Serra <eballetbo@gmail.com> Signed-off-by: Rob Herring <robh@kernel.org>
986 lines
18 KiB
Text
986 lines
18 KiB
Text
// SPDX-License-Identifier: GPL-2.0-only
|
|
/*
|
|
* HiSilicon Ltd. HiP04 SoC
|
|
*
|
|
* Copyright (C) 2013-2014 HiSilicon Ltd.
|
|
* Copyright (C) 2013-2014 Linaro Ltd.
|
|
*
|
|
* Author: Haojian Zhuang <haojian.zhuang@linaro.org>
|
|
*/
|
|
|
|
/ {
|
|
/* memory bus is 64-bit */
|
|
#address-cells = <2>;
|
|
#size-cells = <2>;
|
|
|
|
aliases {
|
|
serial0 = &uart0;
|
|
};
|
|
|
|
bootwrapper {
|
|
compatible = "hisilicon,hip04-bootwrapper";
|
|
boot-method = <0x10c00000 0x10000>, <0xe0000100 0x1000>;
|
|
};
|
|
|
|
cpus {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
cpu-map {
|
|
cluster0 {
|
|
core0 {
|
|
cpu = <&CPU0>;
|
|
};
|
|
core1 {
|
|
cpu = <&CPU1>;
|
|
};
|
|
core2 {
|
|
cpu = <&CPU2>;
|
|
};
|
|
core3 {
|
|
cpu = <&CPU3>;
|
|
};
|
|
};
|
|
cluster1 {
|
|
core0 {
|
|
cpu = <&CPU4>;
|
|
};
|
|
core1 {
|
|
cpu = <&CPU5>;
|
|
};
|
|
core2 {
|
|
cpu = <&CPU6>;
|
|
};
|
|
core3 {
|
|
cpu = <&CPU7>;
|
|
};
|
|
};
|
|
cluster2 {
|
|
core0 {
|
|
cpu = <&CPU8>;
|
|
};
|
|
core1 {
|
|
cpu = <&CPU9>;
|
|
};
|
|
core2 {
|
|
cpu = <&CPU10>;
|
|
};
|
|
core3 {
|
|
cpu = <&CPU11>;
|
|
};
|
|
};
|
|
cluster3 {
|
|
core0 {
|
|
cpu = <&CPU12>;
|
|
};
|
|
core1 {
|
|
cpu = <&CPU13>;
|
|
};
|
|
core2 {
|
|
cpu = <&CPU14>;
|
|
};
|
|
core3 {
|
|
cpu = <&CPU15>;
|
|
};
|
|
};
|
|
};
|
|
CPU0: cpu@0 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0>;
|
|
};
|
|
CPU1: cpu@1 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <1>;
|
|
};
|
|
CPU2: cpu@2 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <2>;
|
|
};
|
|
CPU3: cpu@3 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <3>;
|
|
};
|
|
CPU4: cpu@100 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x100>;
|
|
};
|
|
CPU5: cpu@101 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x101>;
|
|
};
|
|
CPU6: cpu@102 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x102>;
|
|
};
|
|
CPU7: cpu@103 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x103>;
|
|
};
|
|
CPU8: cpu@200 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x200>;
|
|
};
|
|
CPU9: cpu@201 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x201>;
|
|
};
|
|
CPU10: cpu@202 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x202>;
|
|
};
|
|
CPU11: cpu@203 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x203>;
|
|
};
|
|
CPU12: cpu@300 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x300>;
|
|
};
|
|
CPU13: cpu@301 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x301>;
|
|
};
|
|
CPU14: cpu@302 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x302>;
|
|
};
|
|
CPU15: cpu@303 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-a15";
|
|
reg = <0x303>;
|
|
};
|
|
};
|
|
|
|
timer {
|
|
compatible = "arm,armv7-timer";
|
|
interrupt-parent = <&gic>;
|
|
interrupts = <1 13 0xf08>,
|
|
<1 14 0xf08>,
|
|
<1 11 0xf08>,
|
|
<1 10 0xf08>;
|
|
};
|
|
|
|
clk_50m: clk_50m {
|
|
#clock-cells = <0>;
|
|
compatible = "fixed-clock";
|
|
clock-frequency = <50000000>;
|
|
};
|
|
|
|
clk_168m: clk_168m {
|
|
#clock-cells = <0>;
|
|
compatible = "fixed-clock";
|
|
clock-frequency = <168000000>;
|
|
};
|
|
|
|
clk_375m: clk_375m {
|
|
#clock-cells = <0>;
|
|
compatible = "fixed-clock";
|
|
clock-frequency = <375000000>;
|
|
};
|
|
|
|
soc {
|
|
/* It's a 32-bit SoC. */
|
|
#address-cells = <1>;
|
|
#size-cells = <1>;
|
|
compatible = "simple-bus";
|
|
interrupt-parent = <&gic>;
|
|
ranges = <0 0 0xe0000000 0x10000000>;
|
|
|
|
gic: interrupt-controller@c01000 {
|
|
compatible = "hisilicon,hip04-intc";
|
|
#interrupt-cells = <3>;
|
|
#address-cells = <0>;
|
|
interrupt-controller;
|
|
interrupts = <1 9 0xf04>;
|
|
|
|
reg = <0xc01000 0x1000>, <0xc02000 0x1000>,
|
|
<0xc04000 0x2000>, <0xc06000 0x2000>;
|
|
};
|
|
|
|
sysctrl: sysctrl {
|
|
compatible = "hisilicon,sysctrl", "syscon";
|
|
reg = <0x3e00000 0x00100000>;
|
|
};
|
|
|
|
fabric: fabric {
|
|
compatible = "hisilicon,hip04-fabric";
|
|
reg = <0x302a000 0x1000>;
|
|
};
|
|
|
|
dual_timer0: dual_timer@3000000 {
|
|
compatible = "arm,sp804", "arm,primecell";
|
|
reg = <0x3000000 0x1000>;
|
|
interrupts = <0 224 4>;
|
|
clocks = <&clk_50m>, <&clk_50m>, <&clk_50m>;
|
|
clock-names = "timer0clk", "timer1clk", "apb_pclk";
|
|
};
|
|
|
|
arm-pmu {
|
|
compatible = "arm,cortex-a15-pmu";
|
|
interrupts = <0 64 4>,
|
|
<0 65 4>,
|
|
<0 66 4>,
|
|
<0 67 4>,
|
|
<0 68 4>,
|
|
<0 69 4>,
|
|
<0 70 4>,
|
|
<0 71 4>,
|
|
<0 72 4>,
|
|
<0 73 4>,
|
|
<0 74 4>,
|
|
<0 75 4>,
|
|
<0 76 4>,
|
|
<0 77 4>,
|
|
<0 78 4>,
|
|
<0 79 4>;
|
|
};
|
|
|
|
uart0: serial@4007000 {
|
|
compatible = "snps,dw-apb-uart";
|
|
reg = <0x4007000 0x1000>;
|
|
interrupts = <0 381 4>;
|
|
clocks = <&clk_168m>, <&clk_168m>;
|
|
clock-names = "baudclk", "apb_pclk";
|
|
reg-shift = <2>;
|
|
status = "disabled";
|
|
};
|
|
|
|
sata0: sata@a000000 {
|
|
compatible = "hisilicon,hisi-ahci";
|
|
reg = <0xa000000 0x1000000>;
|
|
interrupts = <0 372 4>;
|
|
};
|
|
|
|
};
|
|
|
|
etb@0,e3c42000 {
|
|
compatible = "arm,coresight-etb10", "arm,primecell";
|
|
reg = <0 0xe3c42000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
in-ports {
|
|
port {
|
|
etb0_in_port: endpoint@0 {
|
|
remote-endpoint = <&replicator0_out_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
etb@0,e3c82000 {
|
|
compatible = "arm,coresight-etb10", "arm,primecell";
|
|
reg = <0 0xe3c82000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
in-ports {
|
|
port {
|
|
etb1_in_port: endpoint@0 {
|
|
remote-endpoint = <&replicator1_out_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
etb@0,e3cc2000 {
|
|
compatible = "arm,coresight-etb10", "arm,primecell";
|
|
reg = <0 0xe3cc2000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
in-ports {
|
|
port {
|
|
etb2_in_port: endpoint@0 {
|
|
remote-endpoint = <&replicator2_out_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
etb@0,e3d02000 {
|
|
compatible = "arm,coresight-etb10", "arm,primecell";
|
|
reg = <0 0xe3d02000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
in-ports {
|
|
port {
|
|
etb3_in_port: endpoint@0 {
|
|
remote-endpoint = <&replicator3_out_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
tpiu@0,e3c05000 {
|
|
compatible = "arm,coresight-tpiu", "arm,primecell";
|
|
reg = <0 0xe3c05000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
in-ports {
|
|
port {
|
|
tpiu_in_port: endpoint@0 {
|
|
remote-endpoint = <&funnel4_out_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
replicator0 {
|
|
/* non-configurable replicators don't show up on the
|
|
* AMBA bus. As such no need to add "arm,primecell".
|
|
*/
|
|
compatible = "arm,coresight-static-replicator";
|
|
|
|
out-ports {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
/* replicator output ports */
|
|
port@0 {
|
|
reg = <0>;
|
|
replicator0_out_port0: endpoint {
|
|
remote-endpoint = <&etb0_in_port>;
|
|
};
|
|
};
|
|
|
|
port@1 {
|
|
reg = <1>;
|
|
replicator0_out_port1: endpoint {
|
|
remote-endpoint = <&funnel4_in_port0>;
|
|
};
|
|
};
|
|
};
|
|
|
|
in-ports {
|
|
port {
|
|
replicator0_in_port0: endpoint {
|
|
remote-endpoint = <&funnel0_out_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
replicator1 {
|
|
/* non-configurable replicators don't show up on the
|
|
* AMBA bus. As such no need to add "arm,primecell".
|
|
*/
|
|
compatible = "arm,coresight-static-replicator";
|
|
|
|
out-ports {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
/* replicator output ports */
|
|
port@0 {
|
|
reg = <0>;
|
|
replicator1_out_port0: endpoint {
|
|
remote-endpoint = <&etb1_in_port>;
|
|
};
|
|
};
|
|
|
|
port@1 {
|
|
reg = <1>;
|
|
replicator1_out_port1: endpoint {
|
|
remote-endpoint = <&funnel4_in_port1>;
|
|
};
|
|
};
|
|
};
|
|
|
|
in-ports {
|
|
port {
|
|
replicator1_in_port0: endpoint {
|
|
remote-endpoint = <&funnel1_out_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
replicator2 {
|
|
/* non-configurable replicators don't show up on the
|
|
* AMBA bus. As such no need to add "arm,primecell".
|
|
*/
|
|
compatible = "arm,coresight-static-replicator";
|
|
|
|
out-ports {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
port@0 {
|
|
reg = <0>;
|
|
replicator2_out_port0: endpoint {
|
|
remote-endpoint = <&etb2_in_port>;
|
|
};
|
|
};
|
|
|
|
port@1 {
|
|
reg = <1>;
|
|
replicator2_out_port1: endpoint {
|
|
remote-endpoint = <&funnel4_in_port2>;
|
|
};
|
|
};
|
|
};
|
|
|
|
in-ports {
|
|
port {
|
|
replicator2_in_port0: endpoint {
|
|
remote-endpoint = <&funnel2_out_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
replicator3 {
|
|
/* non-configurable replicators don't show up on the
|
|
* AMBA bus. As such no need to add "arm,primecell".
|
|
*/
|
|
compatible = "arm,coresight-static-replicator";
|
|
|
|
out-ports {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
port@0 {
|
|
reg = <0>;
|
|
replicator3_out_port0: endpoint {
|
|
remote-endpoint = <&etb3_in_port>;
|
|
};
|
|
};
|
|
|
|
port@1 {
|
|
reg = <1>;
|
|
replicator3_out_port1: endpoint {
|
|
remote-endpoint = <&funnel4_in_port3>;
|
|
};
|
|
};
|
|
};
|
|
|
|
in-ports {
|
|
port {
|
|
replicator3_in_port0: endpoint {
|
|
remote-endpoint = <&funnel3_out_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
funnel@0,e3c41000 {
|
|
compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
|
|
reg = <0 0xe3c41000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
out-ports {
|
|
port {
|
|
funnel0_out_port0: endpoint {
|
|
remote-endpoint =
|
|
<&replicator0_in_port0>;
|
|
};
|
|
};
|
|
};
|
|
|
|
in-ports {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
port@0 {
|
|
reg = <0>;
|
|
funnel0_in_port0: endpoint {
|
|
remote-endpoint = <&ptm0_out_port>;
|
|
};
|
|
};
|
|
|
|
port@1 {
|
|
reg = <1>;
|
|
funnel0_in_port1: endpoint {
|
|
remote-endpoint = <&ptm1_out_port>;
|
|
};
|
|
};
|
|
|
|
port@2 {
|
|
reg = <2>;
|
|
funnel0_in_port2: endpoint {
|
|
remote-endpoint = <&ptm2_out_port>;
|
|
};
|
|
};
|
|
|
|
port@3 {
|
|
reg = <3>;
|
|
funnel0_in_port3: endpoint {
|
|
remote-endpoint = <&ptm3_out_port>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
funnel@0,e3c81000 {
|
|
compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
|
|
reg = <0 0xe3c81000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
out-ports {
|
|
port {
|
|
funnel1_out_port0: endpoint {
|
|
remote-endpoint =
|
|
<&replicator1_in_port0>;
|
|
};
|
|
};
|
|
};
|
|
|
|
in-ports {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
port@0 {
|
|
reg = <0>;
|
|
funnel1_in_port0: endpoint {
|
|
remote-endpoint = <&ptm4_out_port>;
|
|
};
|
|
};
|
|
|
|
port@1 {
|
|
reg = <1>;
|
|
funnel1_in_port1: endpoint {
|
|
remote-endpoint = <&ptm5_out_port>;
|
|
};
|
|
};
|
|
|
|
port@2 {
|
|
reg = <2>;
|
|
funnel1_in_port2: endpoint {
|
|
remote-endpoint = <&ptm6_out_port>;
|
|
};
|
|
};
|
|
|
|
port@3 {
|
|
reg = <3>;
|
|
funnel1_in_port3: endpoint {
|
|
remote-endpoint = <&ptm7_out_port>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
funnel@0,e3cc1000 {
|
|
compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
|
|
reg = <0 0xe3cc1000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
out-ports {
|
|
port {
|
|
funnel2_out_port0: endpoint {
|
|
remote-endpoint =
|
|
<&replicator2_in_port0>;
|
|
};
|
|
};
|
|
};
|
|
|
|
in-ports {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
port@0 {
|
|
reg = <0>;
|
|
funnel2_in_port0: endpoint {
|
|
remote-endpoint = <&ptm8_out_port>;
|
|
};
|
|
};
|
|
|
|
port@1 {
|
|
reg = <1>;
|
|
funnel2_in_port1: endpoint {
|
|
remote-endpoint = <&ptm9_out_port>;
|
|
};
|
|
};
|
|
|
|
port@2 {
|
|
reg = <2>;
|
|
funnel2_in_port2: endpoint {
|
|
remote-endpoint = <&ptm10_out_port>;
|
|
};
|
|
};
|
|
|
|
port@3 {
|
|
reg = <3>;
|
|
funnel2_in_port3: endpoint {
|
|
remote-endpoint = <&ptm11_out_port>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
funnel@0,e3d01000 {
|
|
compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
|
|
reg = <0 0xe3d01000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
out-ports {
|
|
port {
|
|
funnel3_out_port0: endpoint {
|
|
remote-endpoint =
|
|
<&replicator3_in_port0>;
|
|
};
|
|
};
|
|
};
|
|
|
|
in-ports {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
port@0 {
|
|
reg = <0>;
|
|
funnel3_in_port0: endpoint {
|
|
remote-endpoint = <&ptm12_out_port>;
|
|
};
|
|
};
|
|
|
|
port@1 {
|
|
reg = <1>;
|
|
funnel3_in_port1: endpoint {
|
|
remote-endpoint = <&ptm13_out_port>;
|
|
};
|
|
};
|
|
|
|
port@2 {
|
|
reg = <2>;
|
|
funnel3_in_port2: endpoint {
|
|
remote-endpoint = <&ptm14_out_port>;
|
|
};
|
|
};
|
|
|
|
port@3 {
|
|
reg = <3>;
|
|
funnel3_in_port3: endpoint {
|
|
remote-endpoint = <&ptm15_out_port>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
funnel@0,e3c04000 {
|
|
compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
|
|
reg = <0 0xe3c04000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
out-ports {
|
|
port {
|
|
funnel4_out_port0: endpoint {
|
|
remote-endpoint = <&tpiu_in_port>;
|
|
};
|
|
};
|
|
};
|
|
|
|
in-ports {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
port@0 {
|
|
reg = <0>;
|
|
funnel4_in_port0: endpoint {
|
|
remote-endpoint =
|
|
<&replicator0_out_port1>;
|
|
};
|
|
};
|
|
|
|
port@1 {
|
|
reg = <1>;
|
|
funnel4_in_port1: endpoint {
|
|
remote-endpoint =
|
|
<&replicator1_out_port1>;
|
|
};
|
|
};
|
|
|
|
port@2 {
|
|
reg = <2>;
|
|
funnel4_in_port2: endpoint {
|
|
remote-endpoint =
|
|
<&replicator2_out_port1>;
|
|
};
|
|
};
|
|
|
|
port@3 {
|
|
reg = <3>;
|
|
funnel4_in_port3: endpoint {
|
|
remote-endpoint =
|
|
<&replicator3_out_port1>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3c7c000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3c7c000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU0>;
|
|
out-ports {
|
|
port {
|
|
ptm0_out_port: endpoint {
|
|
remote-endpoint = <&funnel0_in_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3c7d000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3c7d000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU1>;
|
|
out-ports {
|
|
port {
|
|
ptm1_out_port: endpoint {
|
|
remote-endpoint = <&funnel0_in_port1>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3c7e000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3c7e000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU2>;
|
|
out-ports {
|
|
port {
|
|
ptm2_out_port: endpoint {
|
|
remote-endpoint = <&funnel0_in_port2>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3c7f000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3c7f000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU3>;
|
|
out-ports {
|
|
port {
|
|
ptm3_out_port: endpoint {
|
|
remote-endpoint = <&funnel0_in_port3>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3cbc000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3cbc000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU4>;
|
|
out-ports {
|
|
port {
|
|
ptm4_out_port: endpoint {
|
|
remote-endpoint = <&funnel1_in_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3cbd000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3cbd000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU5>;
|
|
out-ports {
|
|
port {
|
|
ptm5_out_port: endpoint {
|
|
remote-endpoint = <&funnel1_in_port1>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3cbe000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3cbe000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU6>;
|
|
out-ports {
|
|
port {
|
|
ptm6_out_port: endpoint {
|
|
remote-endpoint = <&funnel1_in_port2>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3cbf000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3cbf000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU7>;
|
|
out-ports {
|
|
port {
|
|
ptm7_out_port: endpoint {
|
|
remote-endpoint = <&funnel1_in_port3>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3cfc000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3cfc000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU8>;
|
|
out-ports {
|
|
port {
|
|
ptm8_out_port: endpoint {
|
|
remote-endpoint = <&funnel2_in_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3cfd000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3cfd000 0 0x1000>;
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU9>;
|
|
out-ports {
|
|
port {
|
|
ptm9_out_port: endpoint {
|
|
remote-endpoint = <&funnel2_in_port1>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3cfe000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3cfe000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU10>;
|
|
out-ports {
|
|
port {
|
|
ptm10_out_port: endpoint {
|
|
remote-endpoint = <&funnel2_in_port2>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3cff000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3cff000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU11>;
|
|
out-ports {
|
|
port {
|
|
ptm11_out_port: endpoint {
|
|
remote-endpoint = <&funnel2_in_port3>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3d3c000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3d3c000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU12>;
|
|
out-ports {
|
|
port {
|
|
ptm12_out_port: endpoint {
|
|
remote-endpoint = <&funnel3_in_port0>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3d3d000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3d3d000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU13>;
|
|
out-ports {
|
|
port {
|
|
ptm13_out_port: endpoint {
|
|
remote-endpoint = <&funnel3_in_port1>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3d3e000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3d3e000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU14>;
|
|
out-ports {
|
|
port {
|
|
ptm14_out_port: endpoint {
|
|
remote-endpoint = <&funnel3_in_port2>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ptm@0,e3d3f000 {
|
|
compatible = "arm,coresight-etm3x", "arm,primecell";
|
|
reg = <0 0xe3d3f000 0 0x1000>;
|
|
|
|
clocks = <&clk_375m>;
|
|
clock-names = "apb_pclk";
|
|
cpu = <&CPU15>;
|
|
out-ports {
|
|
port {
|
|
ptm15_out_port: endpoint {
|
|
remote-endpoint = <&funnel3_in_port3>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|