Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp483146imu; Tue, 11 Dec 2018 02:28:44 -0800 (PST) X-Google-Smtp-Source: AFSGD/X6e66uoBTsHZ/cSHzFgyMsOP3YKyTaUsZlQeZrnJUeh9Jplt77kslV3GIPJuEy181NFJO/ X-Received: by 2002:a62:3141:: with SMTP id x62mr15669668pfx.12.1544524124289; Tue, 11 Dec 2018 02:28:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544524124; cv=none; d=google.com; s=arc-20160816; b=BNOgAA7D/lVtZfRKBQKBYPuB/wUw2fvMQ20HZSJnP+xVvHGfRqJS1DrNB1T+YpRoj2 cpLos9fS0ut2xdHwk4rYEcSsMpuzqLnOYtzx/THiFdIxHs8EuqLLEkq5s0Uim9wgU7zJ lY2f+B6nzKupaI0ngiu+FiUQDlQ6z3gjs0V1z1dXfmhT1aicAzG/kAadza/Cd8Mj1gdJ 65jI7XJi3b5Rr+ffGNq9TcmE62h9YKBt0wNO7lFNWIm+1+pQMlGhDiciVhCKocWlq3f8 dKBGy4GgV0pDaavCmWROvGtgWTi2iYdDe2vHMJIlm54MjgHCj1yecTLzNMLVa0HmAST9 upOw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from; bh=DrCe++Acrf15mW+VEMN3JeIheqGQL0lDfGBVShc0hsc=; b=yPuUmMTer2eKnKdsQMX1yVfXJHwhPGMcLhRAr8Sj18Mj8VyUaUDjrnMQam/A+pcdz7 t2kaMnxW7WQ/BQGoUhLrFGee8ZGgNWkSgYxJbzyR9BRNmfWyOjPQWW1VYUQlGO0gu5Av +xYh7DTUpw9N58zMmOYF/0Bdd3WYpvh3KU65iodSJ8RxR1sQPdZ8Nz8k/g4dp4LSprl+ 2uk9S7BcYD9xVWiXRvWw9ou/zbuzcT5gl30wbaDNa2BBHA8I9VMBgRUxBIOD1fz5U1CQ lq8Cxy1l5b2MTc+pVO0YuUDZ/rbm5k/a73Ip8QApCKdTCVWBaAFOZ0aiaw57b9j/y8iy fABg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id bg7si11897886plb.149.2018.12.11.02.28.29; Tue, 11 Dec 2018 02:28:44 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726394AbeLKKPz (ORCPT + 99 others); Tue, 11 Dec 2018 05:15:55 -0500 Received: from szxga04-in.huawei.com ([45.249.212.190]:16109 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726114AbeLKKPz (ORCPT ); Tue, 11 Dec 2018 05:15:55 -0500 Received: from DGGEMS413-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id DE7798645B31F; Tue, 11 Dec 2018 18:15:51 +0800 (CST) Received: from SHA1000170415.huawei.com (100.106.92.139) by DGGEMS413-HUB.china.huawei.com (10.3.19.213) with Microsoft SMTP Server id 14.3.408.0; Tue, 11 Dec 2018 18:15:47 +0800 From: Wanglai Shi To: , CC: , , , , , Subject: [PATCH] dts: arm64: add CoreSight trace support for hi3660 Date: Tue, 11 Dec 2018 18:05:49 +0800 Message-ID: <1544522749-54071-1-git-send-email-shiwanglai@hisilicon.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [100.106.92.139] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch adds devicetree entries for the CoreSight trace components on hi3660. Signed-off-by: Wanglai Shi --- .../arm64/boot/dts/hisilicon/hi3660-coresight.dtsi | 428 +++++++++++++++++++++ 1 file changed, 428 insertions(+) create mode 100644 arch/arm64/boot/dts/hisilicon/hi3660-coresight.dtsi diff --git a/arch/arm64/boot/dts/hisilicon/hi3660-coresight.dtsi b/arch/arm64/boot/dts/hisilicon/hi3660-coresight.dtsi new file mode 100644 index 0000000..95c79e4 --- /dev/null +++ b/arch/arm64/boot/dts/hisilicon/hi3660-coresight.dtsi @@ -0,0 +1,428 @@ +/* + * dtsi for Hisilicon Hi3660 Coresight + * + * Copyright (C) 2016-2017 Hisilicon Ltd. + * + * Author: Wanglai Shi + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * publishhed by the Free Software Foundation. + */ +/ { + amba { + #address-cells = <2>; + #size-cells = <2>; + compatible = "arm,amba-bus"; + ranges; + + /* A53 cluster internal coresight */ + etm@0,ecc40000 { + compatible = "arm,coresight-etm4x","arm,primecell"; + reg = <0 0xecc40000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + cpu = <&cpu0>; + port { + etm0_out_port: endpoint { + remote-endpoint = <&funnel0_in_port0>; + }; + }; + }; + + etm@1,ecd40000 { + compatible = "arm,coresight-etm4x","arm,primecell"; + reg = <0 0xecd40000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + cpu = <&cpu1>; + port { + etm1_out_port: endpoint { + remote-endpoint = <&funnel0_in_port1>; + }; + }; + }; + + etm@2,ece40000 { + compatible = "arm,coresight-etm4x","arm,primecell"; + reg = <0 0xece40000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + cpu = <&cpu2>; + port { + etm2_out_port: endpoint { + remote-endpoint = <&funnel0_in_port2>; + }; + }; + }; + + etm@3,ecf40000 { + compatible = "arm,coresight-etm4x","arm,primecell"; + reg = <0 0xecf40000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + cpu = <&cpu3>; + port { + etm3_out_port: endpoint { + remote-endpoint = <&funnel0_in_port3>; + }; + }; + }; + + funnel0:funnel@0,ec801000 { + compatible = "arm,coresight-funnel","arm,primecell"; + reg = <0 0xec801000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + ports { + #address-cells = <1>; + #size-cells = <0>; + + /* funnel output port */ + port@0 { + reg = <0>; + funnel0_out_port: endpoint { + remote-endpoint = + <&etf0_in_port>; + }; + }; + + /* funnel input ports */ + port@1 { + reg = <0>; + funnel0_in_port0: endpoint { + slave-mode; + remote-endpoint = + <&etm0_out_port>; + }; + }; + + port@2 { + reg = <1>; + funnel0_in_port1: endpoint { + slave-mode; + remote-endpoint = + <&etm1_out_port>; + }; + }; + + port@3 { + reg = <2>; + funnel0_in_port2: endpoint { + slave-mode; + remote-endpoint = + <&etm2_out_port>; + }; + }; + + port@4 { + reg = <3>; + funnel0_in_port3: endpoint { + slave-mode; + remote-endpoint = + <&etm3_out_port>; + }; + }; + }; + }; + + etf0:etf@0,ec802000 { + compatible = "arm,coresight-tmc","arm,primecell"; + reg = <0 0xec802000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + ports { + #address-cells = <1>; + #size-cells = <0>; + /* input port */ + port@0 { + reg = <0>; + etf0_in_port: endpoint { + slave-mode; + remote-endpoint = + <&funnel0_out_port>; + }; + }; + + /* output port */ + port@1 { + reg = <0>; + etf0_out_port: endpoint { + remote-endpoint = + <&funnel2_in_port0>; + }; + }; + }; + }; + + /* A73 cluster internal coresight */ + etm@4,ed440000 { + compatible = "arm,coresight-etm4x","arm,primecell"; + reg = <0 0xed440000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + cpu = <&cpu4>; + port { + etm4_out_port: endpoint { + remote-endpoint = <&funnel1_in_port0>; + }; + }; + }; + + etm@5,ed540000 { + compatible = "arm,coresight-etm4x","arm,primecell"; + reg = <0 0xed540000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + cpu = <&cpu5>; + port { + etm5_out_port: endpoint { + remote-endpoint = <&funnel1_in_port1>; + }; + }; + }; + + etm@6,ed640000 { + compatible = "arm,coresight-etm4x","arm,primecell"; + reg = <0 0xed640000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + cpu = <&cpu6>; + port { + etm6_out_port: endpoint { + remote-endpoint = <&funnel1_in_port2>; + }; + }; + }; + + etm@7,ed740000 { + compatible = "arm,coresight-etm4x","arm,primecell"; + reg = <0 0xed740000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + cpu = <&cpu7>; + port { + etm7_out_port: endpoint { + remote-endpoint = <&funnel1_in_port3>; + }; + }; + }; + + funnel1:funnel@1,ed001000 { + compatible = "arm,coresight-funnel","arm,primecell"; + reg = <0 0xed001000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + ports { + #address-cells = <1>; + #size-cells = <0>; + + /* funnel output port */ + port@0 { + reg = <0>; + funnel1_out_port: endpoint { + remote-endpoint = + <&etf1_in_port>; + }; + }; + + /* funnel input ports */ + port@1 { + reg = <0>; + funnel1_in_port0: endpoint { + slave-mode; + remote-endpoint = + <&etm4_out_port>; + }; + }; + + port@2 { + reg = <1>; + funnel1_in_port1: endpoint { + slave-mode; + remote-endpoint = + <&etm5_out_port>; + }; + }; + + port@3 { + reg = <2>; + funnel1_in_port2: endpoint { + slave-mode; + remote-endpoint = + <&etm6_out_port>; + }; + }; + + port@4 { + reg = <3>; + funnel1_in_port3: endpoint { + slave-mode; + remote-endpoint = + <&etm7_out_port>; + }; + }; + }; + }; + + etf1:etf@1,ed002000 { + compatible = "arm,coresight-tmc","arm,primecell"; + reg = <0 0xed002000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + ports { + #address-cells = <1>; + #size-cells = <0>; + /* input port */ + port@0 { + reg = <0>; + etf1_in_port: endpoint { + slave-mode; + remote-endpoint = + <&funnel1_out_port>; + }; + }; + + /* output port */ + port@1 { + reg = <0>; + etf1_out_port: endpoint { + remote-endpoint = + <&funnel2_in_port0>; + }; + }; + }; + }; + + /* Top coresight config */ + funnel@2,ec031000 { + compatible = "arm,coresight-funnel","arm,primecell"; + reg = <0 0xec031000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + ports { + #address-cells = <1>; + #size-cells = <0>; + + /* funnel output port */ + port@0 { + reg = <0>; + funnel2_out_port: endpoint { + remote-endpoint = + <&etf2_in_port>; + }; + }; + + /* funnel input ports */ + port@1 { + reg = <0>; + funnel2_in_port0: endpoint { + slave-mode; + remote-endpoint = + <&etf0_out_port>; + }; + }; + }; + }; + + etf@2,ec036000 { + compatible = "arm,coresight-tmc","arm,primecell"; + reg = <0 0xec036000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + ports { + #address-cells = <1>; + #size-cells = <0>; + /* input port */ + port@0 { + reg = <0>; + etf2_in_port: endpoint { + slave-mode; + remote-endpoint = + <&funnel2_out_port>; + }; + }; + + /* output port */ + port@1 { + reg = <0>; + etf2_out_port: endpoint { + remote-endpoint = + <&replicator0_in_port>; + }; + }; + }; + }; + + replicator { + compatible = "arm,coresight-replicator"; + + ports { + #address-cells = <1>; + #size-cells = <0>; + + /* etr out port */ + port@0 { + reg = <0>; + replicator0_out_port0: endpoint { + remote-endpoint = + <&etr_in_port>; + }; + }; + /* TPIU out port */ + port@1 { + reg = <1>; + replicator0_out_port1: endpoint { + remote-endpoint = + <&tpiu_in_port>; + }; + }; + /* input port */ + port@2 { + reg = <0>; + replicator0_in_port: endpoint { + slave-mode; + remote-endpoint = + <&etf2_out_port>; + }; + }; + }; + }; + + etr@0,ec033000 { + compatible = "arm,coresight-tmc","arm,primecell"; + reg = <0 0xec033000 0 0x1000>; + clocks = <&pclk>; + clock-names = "apb_pclk"; + ports { + #address-cells = <1>; + #size-cells = <0>; + + /* etr input port */ + port@0 { + reg = <0>; + etr_in_port: endpoint { + slave-mode; + remote-endpoint = + <&replicator0_out_port0>; + }; + }; + }; + }; + + tpiu@ec032000 { + compatible = "arm,coresight-tpiu", "arm,primecell"; + reg = <0 0xec032000 0 0x1000>; + + clocks = <&pclk>; + clock-names = "apb_pclk"; + port { + tpiu_in_port: endpoint { + slave-mode; + remote-endpoint = + <&replicator0_out_port1>; + }; + }; + }; + }; +}; -- 2.7.4