Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp3689432ybc; Thu, 14 Nov 2019 13:06:41 -0800 (PST) X-Google-Smtp-Source: APXvYqysM7qOWYUsDSe6BYCZeQU6qOvxnfUyankby9ixOpbE6/lSbZIm3muPfn9D2tHTXawJsMIR X-Received: by 2002:adf:db41:: with SMTP id f1mr10315008wrj.351.1573765601334; Thu, 14 Nov 2019 13:06:41 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573765601; cv=none; d=google.com; s=arc-20160816; b=WDWI6BAIhZK06Kp/P9+R1sOQPk9Wpo/485ZLDMdu5wobO09/FprWTXc3Yv+rieHXsh fR+KJvGsSosGEnoW2gX2MmFrQBdALOTH050+zp5IKUKgkqlK9diJMUjnso3bLo5cRZ82 XZa1zxaO7zJ6X/1k1YNlJg1Mozyet20mNvkgA4VAFZnDe+OiMu1+Dnb6+8J37TTcSrEn 7iiTbE0yIHaYogGuzKq7VWiGm3Qx6UeVaReKUP9fEVd1zflnuugOWmkhd3lJwQKwAQHH GoskjVG2bQp6W/FQCp1vkYMxxzRt0hZa6nlD2zST8Yt81A4eLUEjVA9d/7gT+sulXBh5 Ii4A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=xqx0FILlaJXYxfmFtCbpASCIe4dojKgn4AlJiFbJlxc=; b=jicKVyv27bELunlmK1+sezvuLCR44EJ2dxTK19WE8H4GXP9dpwD/ZKg9Qc+NMlJQpd 4edvkCgtOLWQ7KkFx0h+OhCreYd5x46HYpfN+h8t40KV5o/3U4urKYL9T8GAd7U6xOXB N/0gaQI3Ni3f6G5VUpxcJcqmWRmZBPpLIlyeWpmDaPcdw4rMhLB72GQbLhnygYbnc2st FPFqzmqFP6M7Gz0ra9qP0LXDWmRsZMNP2FGmqa2IWYuleGUvbXfIt4CoDpddejdSgzFp 3a6KJeYJE/TJNDz3n1kDgFyx2mf+9WpZbcX0t6FMxXy5uRpZAG9kbEXfdA1dAAkSQrKC /KSQ== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j26si4407443edq.389.2019.11.14.13.06.16; Thu, 14 Nov 2019 13:06:41 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727069AbfKNVFW (ORCPT + 99 others); Thu, 14 Nov 2019 16:05:22 -0500 Received: from mail-ot1-f67.google.com ([209.85.210.67]:39811 "EHLO mail-ot1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726592AbfKNVFW (ORCPT ); Thu, 14 Nov 2019 16:05:22 -0500 Received: by mail-ot1-f67.google.com with SMTP id w24so5664406otk.6; Thu, 14 Nov 2019 13:05:18 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=xqx0FILlaJXYxfmFtCbpASCIe4dojKgn4AlJiFbJlxc=; b=Th7qio2tWLFuTP2mX/6No74V6IX2iUQ3gBHH0S+zNFlKnzYaVZln18PdUOALRKO1WQ xn6LvD7bhQCsI6fsjL9G0Db8uHB+0nRyPREGxhHdvKfWSPsejNOJ93hZwJ/O3bmopTuB 3rx/BJmkX0Gc1S22pj8twMrCTneim5Utsez5Bo3FkSIehSqVsGJyhBsx51wreJ4AynET twigt7NGMZuV9kA/j5LC7G88btN5fSvpYukNV0TRlfEcxsDcGqOF3SO5ekXy3AL43sHM IinrN42CEQ4H8d1zrTU7UtKK3Nkz7u+IAfVyHwVSlechItenb8yA0tau93WFbs2NIIHy g71w== X-Gm-Message-State: APjAAAU83XWVcUDO8Mnh880Z2m7NndAS4R99EwbZ2dmm+aty/NknwOPh TPmHN1pDoVIAwyLGp12Z+w== X-Received: by 2002:a9d:71cc:: with SMTP id z12mr8336997otj.124.1573765518042; Thu, 14 Nov 2019 13:05:18 -0800 (PST) Received: from localhost (24-155-109-49.dyn.grandenetworks.net. [24.155.109.49]) by smtp.gmail.com with ESMTPSA id l13sm2147719otp.46.2019.11.14.13.05.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 14 Nov 2019 13:05:17 -0800 (PST) Date: Thu, 14 Nov 2019 15:05:16 -0600 From: Rob Herring To: Chunyan Zhang Cc: Mark Rutland , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Orson Zhai , Baolin Wang , Chunyan Zhang Subject: Re: [PATCH v2 5/5] arm64: dts: Add Unisoc's SC9863A SoC support Message-ID: <20191114210516.GB16668@bogus> References: <20191111090230.3402-1-chunyan.zhang@unisoc.com> <20191111090230.3402-6-chunyan.zhang@unisoc.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20191111090230.3402-6-chunyan.zhang@unisoc.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Nov 11, 2019 at 05:02:30PM +0800, Chunyan Zhang wrote: > > Add basic DT to support Unisoc's SC9863A, with this patch, > the board sp9863a-1h10 can run into console. > > Signed-off-by: Chunyan Zhang > --- > arch/arm64/boot/dts/sprd/Makefile | 3 +- > arch/arm64/boot/dts/sprd/sc9863a.dtsi | 536 ++++++++++++++++++++++ > arch/arm64/boot/dts/sprd/sharkl3.dtsi | 188 ++++++++ > arch/arm64/boot/dts/sprd/sp9863a-1h10.dts | 40 ++ > 4 files changed, 766 insertions(+), 1 deletion(-) > create mode 100644 arch/arm64/boot/dts/sprd/sc9863a.dtsi > create mode 100644 arch/arm64/boot/dts/sprd/sharkl3.dtsi > create mode 100644 arch/arm64/boot/dts/sprd/sp9863a-1h10.dts > > diff --git a/arch/arm64/boot/dts/sprd/Makefile b/arch/arm64/boot/dts/sprd/Makefile > index 2bdc23804f40..f4f1f5148cc2 100644 > --- a/arch/arm64/boot/dts/sprd/Makefile > +++ b/arch/arm64/boot/dts/sprd/Makefile > @@ -1,3 +1,4 @@ > # SPDX-License-Identifier: GPL-2.0 > dtb-$(CONFIG_ARCH_SPRD) += sc9836-openphone.dtb \ > - sp9860g-1h10.dtb > + sp9860g-1h10.dtb \ > + sp9863a-1h10.dtb > diff --git a/arch/arm64/boot/dts/sprd/sc9863a.dtsi b/arch/arm64/boot/dts/sprd/sc9863a.dtsi > new file mode 100644 > index 000000000000..578d71a932d9 > --- /dev/null > +++ b/arch/arm64/boot/dts/sprd/sc9863a.dtsi > @@ -0,0 +1,536 @@ > +// SPDX-License-Identifier: GPL-2.0-only > +/* > + * Unisoc SC9863A SoC DTS file > + * > + * Copyright (C) 2019, Unisoc Inc. > + */ > + > +#include > +#include "sharkl3.dtsi" > + > +/ { > + cpus { > + #address-cells = <2>; > + #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>; > + }; > + }; > + }; > + > + CPU0: cpu@0 { > + device_type = "cpu"; > + compatible = "arm,cortex-a55"; > + reg = <0x0 0x0>; > + enable-method = "psci"; > + cpu-idle-states = <&CORE_PD>; > + }; > + > + CPU1: cpu@100 { Your numbering seems odd. This follows the MPIDR reg? Normally a cluster would share the same number in one of the bytes. > + device_type = "cpu"; > + compatible = "arm,cortex-a55"; > + reg = <0x0 0x100>; > + enable-method = "psci"; > + cpu-idle-states = <&CORE_PD>; > + }; > + > + CPU2: cpu@200 { > + device_type = "cpu"; > + compatible = "arm,cortex-a55"; > + reg = <0x0 0x200>; > + enable-method = "psci"; > + cpu-idle-states = <&CORE_PD>; > + }; > + > + CPU3: cpu@300 { > + device_type = "cpu"; > + compatible = "arm,cortex-a55"; > + reg = <0x0 0x300>; > + enable-method = "psci"; > + cpu-idle-states = <&CORE_PD>; > + }; > + > + CPU4: cpu@400 { > + device_type = "cpu"; > + compatible = "arm,cortex-a55"; > + reg = <0x0 0x400>; > + enable-method = "psci"; > + cpu-idle-states = <&CORE_PD>; > + }; > + > + CPU5: cpu@500 { > + device_type = "cpu"; > + compatible = "arm,cortex-a55"; > + reg = <0x0 0x500>; > + enable-method = "psci"; > + cpu-idle-states = <&CORE_PD>; > + }; > + > + CPU6: cpu@600 { > + device_type = "cpu"; > + compatible = "arm,cortex-a55"; > + reg = <0x0 0x600>; > + enable-method = "psci"; > + cpu-idle-states = <&CORE_PD>; > + }; > + > + CPU7: cpu@700 { > + device_type = "cpu"; > + compatible = "arm,cortex-a55"; > + reg = <0x0 0x700>; > + enable-method = "psci"; > + cpu-idle-states = <&CORE_PD>; > + }; > + }; > + > + idle-states { > + entry-method = "arm,psci"; > + CORE_PD: core_pd { > + compatible = "arm,idle-state"; > + entry-latency-us = <4000>; > + exit-latency-us = <4000>; > + min-residency-us = <10000>; > + local-timer-stop; > + arm,psci-suspend-param = <0x00010000>; > + }; > + }; > + > + gic: interrupt-controller@14000000 { Should go under a bus node. > + compatible = "arm,gic-v3"; > + #interrupt-cells = <3>; > + #address-cells = <2>; > + #size-cells = <2>; > + ranges; > + redistributor-stride = <0x0 0x20000>; /* 128KB stride */ > + #redistributor-regions = <1>; > + interrupt-controller; > + reg = <0x0 0x14000000 0 0x20000>, /* GICD */ > + <0x0 0x14040000 0 0x100000>; /* GICR */ > + interrupts = ; > + > + v2m_0: v2m@0 { > + compatible = "arm,gic-v2m-frame"; This is a GICv2 thing... > + msi-controller; Goes in the parent. Please run your dts file with 'make W=12 dtbs_check' and fix the warnings. > + reg = <0 0 0 0x1000>; > + }; > + }; > + > + psci { > + compatible = "arm,psci-0.2"; > + method = "smc"; > + }; > + > + timer { > + compatible = "arm,armv8-timer"; > + interrupts = , /* Physical Secure PPI */ > + , /* Physical Non-Secure PPI */ > + , /* Virtual PPI */ > + ; /* Hipervisor PPI */ > + }; > + > + pmu { > + compatible = "arm,armv8-pmuv3"; > + interrupts = , > + , > + , > + , > + , > + , > + , > + ; > + }; > + > + soc { > + funnel@10001000 { > + compatible = "arm,coresight-dynamic-funnel", "arm,primecell"; > + reg = <0 0x10001000 0 0x1000>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + funnel_soc_out_port: endpoint { > + remote-endpoint = <&etb_in>; > + }; > + }; > + }; > + > + in-ports { > + #address-cells = <1>; > + #size-cells = <0>; > + > + port@0 { > + reg = <0>; > + funnel_soc_in_port: endpoint { > + remote-endpoint = > + <&funnel_ca55_out_port>; > + }; > + }; > + }; > + }; > + > + etb@10003000 { > + compatible = "arm,coresight-tmc", "arm,primecell"; > + reg = <0 0x10003000 0 0x1000>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + in-ports { > + port { > + etb_in: endpoint { > + remote-endpoint = > + <&funnel_soc_out_port>; > + }; > + }; > + }; > + }; > + > + funnel@12001000 { > + compatible = "arm,coresight-dynamic-funnel", "arm,primecell"; > + reg = <0 0x12001000 0 0x1000>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + funnel_little_out_port: endpoint { > + remote-endpoint = > + <&etf_little_in>; > + }; > + }; > + }; > + > + in-ports { > + #address-cells = <1>; > + #size-cells = <0>; > + > + port@0 { > + reg = <0>; > + funnel_little_in_port0: endpoint { > + remote-endpoint = <&etm0_out>; > + }; > + }; > + > + port@1 { > + reg = <1>; > + funnel_little_in_port1: endpoint { > + remote-endpoint = <&etm1_out>; > + }; > + }; > + > + port@2 { > + reg = <2>; > + funnel_little_in_port2: endpoint { > + remote-endpoint = <&etm2_out>; > + }; > + }; > + > + port@3 { > + reg = <3>; > + funnel_little_in_port3: endpoint { > + remote-endpoint = <&etm3_out>; > + }; > + }; > + }; > + }; > + > + etf@12002000 { > + compatible = "arm,coresight-tmc", "arm,primecell"; > + reg = <0 0x12002000 0 0x1000>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + etf_little_out: endpoint { > + remote-endpoint = > + <&funnel_ca55_in_port0>; > + }; > + }; > + }; > + > + in-port { > + port { > + etf_little_in: endpoint { > + remote-endpoint = > + <&funnel_little_out_port>; > + }; > + }; > + }; > + }; > + > + etf@12003000 { > + compatible = "arm,coresight-tmc", "arm,primecell"; > + reg = <0 0x12003000 0 0x1000>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + etf_big_out: endpoint { > + remote-endpoint = > + <&funnel_ca55_in_port1>; > + }; > + }; > + }; > + > + in-ports { > + port { > + etf_big_in: endpoint { > + remote-endpoint = > + <&funnel_big_out_port>; > + }; > + }; > + }; > + }; > + > + funnel@12004000 { > + compatible = "arm,coresight-dynamic-funnel", "arm,primecell"; > + reg = <0 0x12004000 0 0x1000>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + funnel_ca55_out_port: endpoint { > + remote-endpoint = > + <&funnel_soc_in_port>; > + }; > + }; > + }; > + > + in-ports { > + #address-cells = <1>; > + #size-cells = <0>; > + > + port@0 { > + reg = <0>; > + funnel_ca55_in_port0: endpoint { > + remote-endpoint = > + <&etf_little_out>; > + }; > + }; > + > + port@1 { > + reg = <1>; > + funnel_ca55_in_port1: endpoint { > + remote-endpoint = > + <&etf_big_out>; > + }; > + }; > + }; > + }; > + > + funnel@12005000 { > + compatible = "arm,coresight-dynamic-funnel", "arm,primecell"; > + reg = <0 0x12005000 0 0x1000>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + funnel_big_out_port: endpoint { > + remote-endpoint = > + <&etf_big_in>; > + }; > + }; > + }; > + > + in-ports { > + #address-cells = <1>; > + #size-cells = <0>; > + > + port@0 { > + reg = <0>; > + funnel_big_in_port0: endpoint { > + remote-endpoint = <&etm4_out>; > + }; > + }; > + > + port@1 { > + reg = <1>; > + funnel_big_in_port1: endpoint { > + remote-endpoint = <&etm5_out>; > + }; > + }; > + > + port@2 { > + reg = <2>; > + funnel_big_in_port2: endpoint { > + remote-endpoint = <&etm6_out>; > + }; > + }; > + > + port@3 { > + reg = <3>; > + funnel_big_in_port3: endpoint { > + remote-endpoint = <&etm7_out>; > + }; > + }; > + }; > + }; > + > + etm@13040000 { > + compatible = "arm,coresight-etm4x", "arm,primecell"; > + reg = <0 0x13040000 0 0x1000>; > + cpu = <&CPU0>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + etm0_out: endpoint { > + remote-endpoint = > + <&funnel_little_in_port0>; > + }; > + }; > + }; > + }; > + > + etm@13140000 { > + compatible = "arm,coresight-etm4x", "arm,primecell"; > + reg = <0 0x13140000 0 0x1000>; > + cpu = <&CPU1>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + etm1_out: endpoint { > + remote-endpoint = > + <&funnel_little_in_port1>; > + }; > + }; > + }; > + }; > + > + etm@13240000 { > + compatible = "arm,coresight-etm4x", "arm,primecell"; > + reg = <0 0x13240000 0 0x1000>; > + cpu = <&CPU2>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + etm2_out: endpoint { > + remote-endpoint = > + <&funnel_little_in_port2>; > + }; > + }; > + }; > + }; > + > + etm@13340000 { > + compatible = "arm,coresight-etm4x", "arm,primecell"; > + reg = <0 0x13340000 0 0x1000>; > + cpu = <&CPU3>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + etm3_out: endpoint { > + remote-endpoint = > + <&funnel_little_in_port3>; > + }; > + }; > + }; > + }; > + > + etm@13440000 { > + compatible = "arm,coresight-etm4x", "arm,primecell"; > + reg = <0 0x13440000 0 0x1000>; > + cpu = <&CPU4>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + etm4_out: endpoint { > + remote-endpoint = > + <&funnel_big_in_port0>; > + }; > + }; > + }; > + }; > + > + etm@13540000 { > + compatible = "arm,coresight-etm4x", "arm,primecell"; > + reg = <0 0x13540000 0 0x1000>; > + cpu = <&CPU5>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + etm5_out: endpoint { > + remote-endpoint = > + <&funnel_big_in_port1>; > + }; > + }; > + }; > + }; > + > + etm@13640000 { > + compatible = "arm,coresight-etm4x", "arm,primecell"; > + reg = <0 0x13640000 0 0x1000>; > + cpu = <&CPU6>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + etm6_out: endpoint { > + remote-endpoint = > + <&funnel_big_in_port2>; > + }; > + }; > + }; > + }; > + > + etm@13740000 { > + compatible = "arm,coresight-etm4x", "arm,primecell"; > + reg = <0 0x13740000 0 0x1000>; > + cpu = <&CPU7>; > + clocks = <&ext_26m>; > + clock-names = "apb_pclk"; > + > + out-ports { > + port { > + etm7_out: endpoint { > + remote-endpoint = > + <&funnel_big_in_port3>; > + }; > + }; > + }; > + }; > + }; > +}; > diff --git a/arch/arm64/boot/dts/sprd/sharkl3.dtsi b/arch/arm64/boot/dts/sprd/sharkl3.dtsi > new file mode 100644 > index 000000000000..3ef233f70dc4 > --- /dev/null > +++ b/arch/arm64/boot/dts/sprd/sharkl3.dtsi > @@ -0,0 +1,188 @@ > +// SPDX-License-Identifier: GPL-2.0-only > +/* > + * Unisoc Sharkl3 platform DTS file > + * > + * Copyright (C) 2019, Unisoc Inc. > + */ > + > +/ { > + interrupt-parent = <&gic>; > + #address-cells = <2>; > + #size-cells = <2>; > + > + soc: soc { > + compatible = "simple-bus"; > + #address-cells = <2>; > + #size-cells = <2>; > + ranges; > + > + ap_ahb_regs: syscon@20e00000 { > + compatible = "syscon"; > + reg = <0 0x20e00000 0 0x10000>; > + }; > + > + pub_apb_regs: syscon@300e0000 { > + compatible = "syscon"; "syscon" should also have a specific compatible. What are all these blocks? Looks like placeholders. If so, just drop them. > + reg = <0 0x300e0000 0 0x10000>; > + }; > + > + pub_ahb_regs: syscon@300f0000 { > + compatible = "syscon"; > + reg = <0 0x300f0000 0 0x10000>; > + }; > + > + aon_intc_regs: syscon@40200000 { > + compatible = "syscon"; > + reg = <0 0x40200000 0 0x10000>; > + }; > + > + pmu_regs: syscon@402b0000 { > + compatible = "syscon"; > + reg = <0 0x402b0000 0 0x10000>; > + }; > + > + aon_apb_regs: syscon@402e0000 { > + compatible = "syscon"; > + reg = <0 0x402e0000 0 0x10000>; > + }; > + > + anlg_phy_g1_regs: syscon@40350000 { > + compatible = "syscon"; > + reg = <0 0x40350000 0 0x3000>; > + }; > + > + anlg_phy_g2_regs: syscon@40353000 { > + compatible = "syscon"; > + reg = <0 0x40353000 0 0x6000>; > + }; > + > + anlg_phy_g4_regs: syscon@40359000 { > + compatible = "syscon"; > + reg = <0 0x40359000 0 0x3000>; > + }; > + > + anlg_phy_g5_regs: syscon@4035c000 { > + compatible = "syscon"; > + reg = <0 0x4035c000 0 0x3000>; > + }; > + > + anlg_phy_g7_regs: syscon@40363000 { > + compatible = "syscon"; > + reg = <0 0x40363000 0 0x3000>; > + }; > + > + anlg_wrap_wcn_regs: syscon@40366000 { > + compatible = "syscon"; > + reg = <0 0x40366000 0 0x3000>; > + }; > + > + wcn_regs: syscon@403a0000 { > + compatible = "syscon"; > + reg = <0 0x403a0000 0 0x10000>; > + }; > + > + ap_intc0_regs: syscon@40500000 { > + compatible = "syscon"; > + reg = <0 0x40500000 0 0x10000>; > + }; > + > + ap_intc1_regs: syscon@40510000 { > + compatible = "syscon"; > + reg = <0 0x40510000 0 0x10000>; > + }; > + > + ap_intc2_regs: syscon@40520000 { > + compatible = "syscon"; > + reg = <0 0x40520000 0 0x10000>; > + }; > + > + ap_intc3_regs: syscon@40530000 { > + compatible = "syscon"; > + reg = <0 0x40530000 0 0x10000>; > + }; > + > + ap_intc4_regs: syscon@40540000 { > + compatible = "syscon"; > + reg = <0 0x40540000 0 0x10000>; > + }; > + > + ap_intc5_regs: syscon@40550000 { > + compatible = "syscon"; > + reg = <0 0x40550000 0 0x10000>; > + }; > + > + mm_ahb_regs: syscon@60800000 { > + compatible = "syscon"; > + reg = <0 0x60800000 0 0x10000>; > + }; > + > + mm_vsp_ahb_regs: syscon@62000000 { > + compatible = "syscon"; > + reg = <0 0x62000000 0 0x10000>; > + }; > + > + ap_apb_regs: syscon@71300000 { > + compatible = "syscon"; > + reg = <0 0x71300000 0 0x40000>; > + }; > + > + ap-apb { apb@70000000 > + compatible = "simple-bus"; > + #address-cells = <1>; > + #size-cells = <1>; > + ranges = <0 0x0 0x70000000 0x10000000>; > + > + uart0: serial@0 { > + compatible = "sprd,sc9863a-uart", > + "sprd,sc9836-uart"; > + reg = <0x0 0x100>; > + interrupts = ; > + clocks = <&ext_26m>; > + status = "disabled"; > + }; > + > + uart1: serial@100000 { > + compatible = "sprd,sc9863a-uart", > + "sprd,sc9836-uart"; > + reg = <0x100000 0x100>; > + interrupts = ; > + clocks = <&ext_26m>; > + status = "disabled"; > + }; > + > + uart2: serial@200000 { > + compatible = "sprd,sc9863a-uart", > + "sprd,sc9836-uart"; > + reg = <0x200000 0x100>; > + interrupts = ; > + clocks = <&ext_26m>; > + status = "disabled"; > + }; > + > + uart3: serial@300000 { > + compatible = "sprd,sc9863a-uart", > + "sprd,sc9836-uart"; > + reg = <0x300000 0x100>; > + interrupts = ; > + clocks = <&ext_26m>; > + status = "disabled"; > + }; > + > + uart4: serial@400000 { > + compatible = "sprd,sc9863a-uart", > + "sprd,sc9836-uart"; > + reg = <0x400000 0x100>; > + interrupts = ; > + clocks = <&ext_26m>; > + status = "disabled"; > + }; > + }; > + }; > + > + ext_26m: ext-26m { > + compatible = "fixed-clock"; > + #clock-cells = <0>; > + clock-frequency = <26000000>; > + clock-output-names = "ext-26m"; > + }; > +}; > diff --git a/arch/arm64/boot/dts/sprd/sp9863a-1h10.dts b/arch/arm64/boot/dts/sprd/sp9863a-1h10.dts > new file mode 100644 > index 000000000000..b6fbb5ca37e1 > --- /dev/null > +++ b/arch/arm64/boot/dts/sprd/sp9863a-1h10.dts > @@ -0,0 +1,40 @@ > +// SPDX-License-Identifier: GPL-2.0-only > +/* > + * Unisoc SP9863A-1h10 boards DTS file > + * > + * Copyright (C) 2019, Unisoc Inc. > + */ > + > +/dts-v1/; > + > +#include "sc9863a.dtsi" > + > +/ { > + model = "Spreadtrum SP9863A-1H10 Board"; > + > + compatible = "sprd,sp9863a-1h10", "sprd,sc9863a"; > + > + sprd,sc-id = <9863 1 0x20000>; Not documented. > + > + aliases { > + serial0 = &uart0; > + serial1 = &uart1; > + }; > + > + memory { memory@80000000 > + device_type = "memory"; > + reg = <0x0 0x80000000 0x0 0x80000000>; > + }; > + > + chosen { > + stdout-path = "serial1:115200n8"; > + }; > +}; > + > +&uart0 { > + status = "okay"; > +}; > + > +&uart1 { > + status = "okay"; > +}; > -- > 2.20.1 > >