Received: by 2002:a05:6a10:6006:0:0:0:0 with SMTP id w6csp264075pxa; Thu, 27 Aug 2020 01:21:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxzZHSn5eOCsvigOiQV8jx/eNd8bfLVoAs3VveDwhOl0aORcl/EslapE3aBuxuN2f1CBmu4 X-Received: by 2002:a05:6402:339:: with SMTP id q25mr17852806edw.268.1598516510752; Thu, 27 Aug 2020 01:21:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1598516510; cv=none; d=google.com; s=arc-20160816; b=U2HWiQLrz8xDHu337xixu0Y0u0VJD7H4oKrIq2Pa26qHNUZNjWQ+Wzl7vIOu3iG6y/ rvQSzSdnLFW1vZYot5AFN5Bq0+EddOt5GEU5Op91iZq8Wj9lefwgbP5hOLTzqgHtTFjj PAjOJzAXT7W916iVdYz4/kVyYgXO8Y2Wj9HhCBIW+p/CsLKztm+TVuyEq+2t2YZZnWVr lKV0Nw26pFU8mmXCu97XMbI/X3Eq6CfzyKikAb92AddE56rMEYZxbB/WWO14PW1WgGTI Bw+jR77EOnt7sAFiVlDNZvbLQ2mUQ8uzzXuR6jy19s6x/adnxIumWYuY9K8xpb1BsJBS yiew== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=I8aoxgojlTAwesb6xOwCww2FI/7WLwpEkMEc06OSWRE=; b=1B+xn7DMjsU4aarTNfYRfRzMMnNsEYoFo6X3H+u2nD26itQDN0cld3teWUJifn6vuo 34hq/6DyKF3IPo/SQV3j6Vm6OBWglGNcyRRM93Cqf7xljuv5GqvQsTRrD6U1RN8ccgZ/ t7iUxX0n7uSGb7g7tsbhLOfxnWI8yVNhvthiy2c4f32MKWXmJOMXgwHzdSFcyr6WrkSX 9aHbH5XlgVtLR2KWqvKuPSYOQWolOojGR2juUZWQcEPFTF5cS9wNenMIBlgec7b9YjoC p/3lKIOj6WFMF0UWQYbAfwU+94nACnKWS5OEcIaHe+aI4MwRpNfsy+I4QpXHuwGX0V6J d7tA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=sDvv88ye; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id c5si895519ejm.274.2020.08.27.01.21.27; Thu, 27 Aug 2020 01:21:50 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=sDvv88ye; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728010AbgH0IUU (ORCPT + 99 others); Thu, 27 Aug 2020 04:20:20 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56540 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726266AbgH0IUR (ORCPT ); Thu, 27 Aug 2020 04:20:17 -0400 Received: from mail-wr1-x443.google.com (mail-wr1-x443.google.com [IPv6:2a00:1450:4864:20::443]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8C760C061264; Thu, 27 Aug 2020 01:20:17 -0700 (PDT) Received: by mail-wr1-x443.google.com with SMTP id a5so4456155wrm.6; Thu, 27 Aug 2020 01:20:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=I8aoxgojlTAwesb6xOwCww2FI/7WLwpEkMEc06OSWRE=; b=sDvv88yea+EJLlaSJOOLGx4Um5zqEyzuDBsxny1K9ssukhB8MUVgkSnJG+fhUlCKMC DefIK69r39cusRTbSpd4APY6/D824GEFUs3nMjhVrUnP9nKFTjj2X5WoO5SobHH0zJgB epxZJfzNF+sVrsmONg++N/nk2/HQoelX5boy1LXcvcwrelxwkzk2yB/yZMxWiK2fNQxZ wfWIlsOa6K/ctkmkOmtviGgH07FqkP+TnJ0TZCvPeMY1m87EqvrcaCHkdj8bpbu6E19U BUxKlNtIlyVxDg3wZ+iFQag0oOwSdfK1pz5WY2e1RXc0KSzBKQuT8T0IZ5XagcGEJlzc /fmQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=I8aoxgojlTAwesb6xOwCww2FI/7WLwpEkMEc06OSWRE=; b=Y6MYHwihIAXiNaXHk4BIx5XF2wDkMomUW1if09iOaVC4urP8eEVY97d+xpmhGa0FL6 ra9CGsxUdHTbKT0qiNZE6vQXmJeQunJ14DU6ashZAeIznrY1GR1w9wVnv0ZMm74NNggM VU1opAsWStMjSx9FqvQUsUxPJl4dMAZ3YUMdS3VWMVRM6hjh8Nyx2XQz3AdQNrgGXDcQ h9GPviee9pB1u/syp5biyX5OAzP/jCmjNAgHmdDEvcveVDL13+18NK/7h4pvs4VPCmtQ NH6/fUKIOMX6nB7Jz5ZzMndBiOJRtsznVCoXwSFmMXVWVqOHil4xOJwGt/6SXID9UgD/ S9EA== X-Gm-Message-State: AOAM532mdiLcFvmyE/N0sdHRcVVEnUSXGpYmlIVmVk+63GscOjA/PFQ0 s9BC2OoCjISImBNOIsM/uWFO8wK6e+UMIQ== X-Received: by 2002:a5d:61ca:: with SMTP id q10mr18321117wrv.47.1598516416121; Thu, 27 Aug 2020 01:20:16 -0700 (PDT) Received: from ziggy.stardust ([213.195.119.187]) by smtp.gmail.com with ESMTPSA id f17sm4777078wru.13.2020.08.27.01.20.14 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 27 Aug 2020 01:20:15 -0700 (PDT) Subject: Re: [PATCH v10 2/3] arm64: dts: add dts nodes for MT6779 To: Hanks Chen , Linus Walleij Cc: Rob Herring , Michael Turquette , Stephen Boyd , mtk01761 , YueHaibing , Andy Teng , linux-gpio@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, linux-kernel@vger.kernel.org, linux-clk@vger.kernel.org, CC Hwang , Loda Chou References: <1596115816-11758-1-git-send-email-hanks.chen@mediatek.com> <1596115816-11758-3-git-send-email-hanks.chen@mediatek.com> <1596594249.11014.1.camel@mtkswgap22> From: Matthias Brugger Message-ID: <3648b63d-7521-fdfd-831e-6851fe555ca5@gmail.com> Date: Thu, 27 Aug 2020 10:20:14 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.11.0 MIME-Version: 1.0 In-Reply-To: <1596594249.11014.1.camel@mtkswgap22> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/08/2020 04:24, Hanks Chen wrote: > Hi Matthias and all, > > Gentle ping on this patch. > I'm fine with the patch. I'm waiting on the clk part to be accepted, then I'll take this one. Regards, Matthias > Thanks > > > Hanks Chen > > On Thu, 2020-07-30 at 21:30 +0800, Hanks Chen wrote: >> this adds initial MT6779 dts settings for board support, >> including cpu, gic, timer, ccf, pinctrl, uart, sysirq...etc. >> >> Signed-off-by: Hanks Chen >> --- >> arch/arm64/boot/dts/mediatek/Makefile | 1 + >> arch/arm64/boot/dts/mediatek/mt6779-evb.dts | 31 +++ >> arch/arm64/boot/dts/mediatek/mt6779.dtsi | 271 ++++++++++++++++++++ >> 3 files changed, 303 insertions(+) >> create mode 100644 arch/arm64/boot/dts/mediatek/mt6779-evb.dts >> create mode 100644 arch/arm64/boot/dts/mediatek/mt6779.dtsi >> >> diff --git a/arch/arm64/boot/dts/mediatek/Makefile b/arch/arm64/boot/dts/mediatek/Makefile >> index a57af9da9f5c..4d1b0f9d8d1c 100644 >> --- a/arch/arm64/boot/dts/mediatek/Makefile >> +++ b/arch/arm64/boot/dts/mediatek/Makefile >> @@ -1,6 +1,7 @@ >> # SPDX-License-Identifier: GPL-2.0 >> dtb-$(CONFIG_ARCH_MEDIATEK) += mt2712-evb.dtb >> dtb-$(CONFIG_ARCH_MEDIATEK) += mt6755-evb.dtb >> +dtb-$(CONFIG_ARCH_MEDIATEK) += mt6779-evb.dtb >> dtb-$(CONFIG_ARCH_MEDIATEK) += mt6795-evb.dtb >> dtb-$(CONFIG_ARCH_MEDIATEK) += mt6797-evb.dtb >> dtb-$(CONFIG_ARCH_MEDIATEK) += mt6797-x20-dev.dtb >> diff --git a/arch/arm64/boot/dts/mediatek/mt6779-evb.dts b/arch/arm64/boot/dts/mediatek/mt6779-evb.dts >> new file mode 100644 >> index 000000000000..164f5cbb3821 >> --- /dev/null >> +++ b/arch/arm64/boot/dts/mediatek/mt6779-evb.dts >> @@ -0,0 +1,31 @@ >> +// SPDX-License-Identifier: GPL-2.0+ >> +/* >> + * Copyright (c) 2019 MediaTek Inc. >> + * Author: Mars.C >> + * >> + */ >> + >> +/dts-v1/; >> +#include "mt6779.dtsi" >> + >> +/ { >> + model = "MediaTek MT6779 EVB"; >> + compatible = "mediatek,mt6779-evb", "mediatek,mt6779"; >> + >> + aliases { >> + serial0 = &uart0; >> + }; >> + >> + memory@40000000 { >> + device_type = "memory"; >> + reg = <0 0x40000000 0 0x1e800000>; >> + }; >> + >> + chosen { >> + stdout-path = "serial0:921600n8"; >> + }; >> +}; >> + >> +&uart0 { >> + status = "okay"; >> +}; >> diff --git a/arch/arm64/boot/dts/mediatek/mt6779.dtsi b/arch/arm64/boot/dts/mediatek/mt6779.dtsi >> new file mode 100644 >> index 000000000000..370f309d32de >> --- /dev/null >> +++ b/arch/arm64/boot/dts/mediatek/mt6779.dtsi >> @@ -0,0 +1,271 @@ >> +// SPDX-License-Identifier: GPL-2.0+ >> +/* >> + * Copyright (c) 2019 MediaTek Inc. >> + * Author: Mars.C >> + * >> + */ >> + >> +#include >> +#include >> +#include >> +#include >> + >> +/ { >> + compatible = "mediatek,mt6779"; >> + interrupt-parent = <&sysirq>; >> + #address-cells = <2>; >> + #size-cells = <2>; >> + >> + psci { >> + compatible = "arm,psci-0.2"; >> + method = "smc"; >> + }; >> + >> + cpus { >> + #address-cells = <1>; >> + #size-cells = <0>; >> + >> + cpu0: cpu@0 { >> + device_type = "cpu"; >> + compatible = "arm,cortex-a55"; >> + enable-method = "psci"; >> + reg = <0x000>; >> + }; >> + >> + cpu1: cpu@1 { >> + device_type = "cpu"; >> + compatible = "arm,cortex-a55"; >> + enable-method = "psci"; >> + reg = <0x100>; >> + }; >> + >> + cpu2: cpu@2 { >> + device_type = "cpu"; >> + compatible = "arm,cortex-a55"; >> + enable-method = "psci"; >> + reg = <0x200>; >> + }; >> + >> + cpu3: cpu@3 { >> + device_type = "cpu"; >> + compatible = "arm,cortex-a55"; >> + enable-method = "psci"; >> + reg = <0x300>; >> + }; >> + >> + cpu4: cpu@4 { >> + device_type = "cpu"; >> + compatible = "arm,cortex-a55"; >> + enable-method = "psci"; >> + reg = <0x400>; >> + }; >> + >> + cpu5: cpu@5 { >> + device_type = "cpu"; >> + compatible = "arm,cortex-a55"; >> + enable-method = "psci"; >> + reg = <0x500>; >> + }; >> + >> + cpu6: cpu@6 { >> + device_type = "cpu"; >> + compatible = "arm,cortex-a75"; >> + enable-method = "psci"; >> + reg = <0x600>; >> + }; >> + >> + cpu7: cpu@7 { >> + device_type = "cpu"; >> + compatible = "arm,cortex-a75"; >> + enable-method = "psci"; >> + reg = <0x700>; >> + }; >> + }; >> + >> + pmu { >> + compatible = "arm,armv8-pmuv3"; >> + interrupt-parent = <&gic>; >> + interrupts = ; >> + }; >> + >> + clk26m: oscillator@0 { >> + compatible = "fixed-clock"; >> + #clock-cells = <0>; >> + clock-frequency = <26000000>; >> + clock-output-names = "clk26m"; >> + }; >> + >> + clk32k: oscillator@1 { >> + compatible = "fixed-clock"; >> + #clock-cells = <0>; >> + clock-frequency = <32768>; >> + clock-output-names = "clk32k"; >> + }; >> + >> + timer { >> + compatible = "arm,armv8-timer"; >> + interrupt-parent = <&gic>; >> + interrupts = , >> + , >> + , >> + ; >> + }; >> + >> + soc { >> + #address-cells = <2>; >> + #size-cells = <2>; >> + compatible = "simple-bus"; >> + ranges; >> + >> + gic: interrupt-controller@0c000000 { >> + compatible = "arm,gic-v3"; >> + #interrupt-cells = <4>; >> + interrupt-parent = <&gic>; >> + interrupt-controller; >> + reg = <0 0x0c000000 0 0x40000>, /* GICD */ >> + <0 0x0c040000 0 0x200000>; /* GICR */ >> + interrupts = ; >> + >> + ppi-partitions { >> + ppi_cluster0: interrupt-partition-0 { >> + affinity = <&cpu0 &cpu1 \ >> + &cpu2 &cpu3 &cpu4 &cpu5>; >> + }; >> + ppi_cluster1: interrupt-partition-1 { >> + affinity = <&cpu6 &cpu7>; >> + }; >> + }; >> + >> + }; >> + >> + sysirq: intpol-controller@0c53a650 { >> + compatible = "mediatek,mt6779-sysirq", >> + "mediatek,mt6577-sysirq"; >> + interrupt-controller; >> + #interrupt-cells = <3>; >> + interrupt-parent = <&gic>; >> + reg = <0 0x0c53a650 0 0x50>; >> + }; >> + >> + topckgen: clock-controller@10000000 { >> + compatible = "mediatek,mt6779-topckgen", "syscon"; >> + reg = <0 0x10000000 0 0x1000>; >> + #clock-cells = <1>; >> + }; >> + >> + infracfg_ao: clock-controller@10001000 { >> + compatible = "mediatek,mt6779-infracfg_ao", "syscon"; >> + reg = <0 0x10001000 0 0x1000>; >> + #clock-cells = <1>; >> + }; >> + >> + pio: pinctrl@10005000 { >> + compatible = "mediatek,mt6779-pinctrl", "syscon"; >> + reg = <0 0x10005000 0 0x1000>, >> + <0 0x11c20000 0 0x1000>, >> + <0 0x11d10000 0 0x1000>, >> + <0 0x11e20000 0 0x1000>, >> + <0 0x11e70000 0 0x1000>, >> + <0 0x11ea0000 0 0x1000>, >> + <0 0x11f20000 0 0x1000>, >> + <0 0x11f30000 0 0x1000>, >> + <0 0x1000b000 0 0x1000>; >> + reg-names = "gpio", "iocfg_rm", >> + "iocfg_br", "iocfg_lm", >> + "iocfg_lb", "iocfg_rt", >> + "iocfg_lt", "iocfg_tl", >> + "eint"; >> + gpio-controller; >> + #gpio-cells = <2>; >> + gpio-ranges = <&pio 0 0 210>; >> + interrupt-controller; >> + #interrupt-cells = <2>; >> + interrupts = ; >> + }; >> + >> + apmixed: clock-controller@1000c000 { >> + compatible = "mediatek,mt6779-apmixed", "syscon"; >> + reg = <0 0x1000c000 0 0xe00>; >> + #clock-cells = <1>; >> + }; >> + >> + uart0: serial@11002000 { >> + compatible = "mediatek,mt6779-uart", >> + "mediatek,mt6577-uart"; >> + reg = <0 0x11002000 0 0x400>; >> + interrupts = ; >> + clocks = <&clk26m>, <&infracfg_ao CLK_INFRA_UART0>; >> + clock-names = "baud", "bus"; >> + status = "disabled"; >> + }; >> + >> + uart1: serial@11003000 { >> + compatible = "mediatek,mt6779-uart", >> + "mediatek,mt6577-uart"; >> + reg = <0 0x11003000 0 0x400>; >> + interrupts = ; >> + clocks = <&clk26m>, <&infracfg_ao CLK_INFRA_UART1>; >> + clock-names = "baud", "bus"; >> + status = "disabled"; >> + }; >> + >> + uart2: serial@11004000 { >> + compatible = "mediatek,mt6779-uart", >> + "mediatek,mt6577-uart"; >> + reg = <0 0x11004000 0 0x400>; >> + interrupts = ; >> + clocks = <&clk26m>, <&infracfg_ao CLK_INFRA_UART2>; >> + clock-names = "baud", "bus"; >> + status = "disabled"; >> + }; >> + >> + audio: clock-controller@11210000 { >> + compatible = "mediatek,mt6779-audio", "syscon"; >> + reg = <0 0x11210000 0 0x1000>; >> + #clock-cells = <1>; >> + }; >> + >> + mfgcfg: clock-controller@13fbf000 { >> + compatible = "mediatek,mt6779-mfgcfg", "syscon"; >> + reg = <0 0x13fbf000 0 0x1000>; >> + #clock-cells = <1>; >> + }; >> + >> + mmsys: syscon@14000000 { >> + compatible = "mediatek,mt6779-mmsys", "syscon"; >> + reg = <0 0x14000000 0 0x1000>; >> + #clock-cells = <1>; >> + }; >> + >> + imgsys: clock-controller@15020000 { >> + compatible = "mediatek,mt6779-imgsys", "syscon"; >> + reg = <0 0x15020000 0 0x1000>; >> + #clock-cells = <1>; >> + }; >> + >> + vdecsys: clock-controller@16000000 { >> + compatible = "mediatek,mt6779-vdecsys", "syscon"; >> + reg = <0 0x16000000 0 0x1000>; >> + #clock-cells = <1>; >> + }; >> + >> + vencsys: clock-controller@17000000 { >> + compatible = "mediatek,mt6779-vencsys", "syscon"; >> + reg = <0 0x17000000 0 0x1000>; >> + #clock-cells = <1>; >> + }; >> + >> + camsys: clock-controller@1a000000 { >> + compatible = "mediatek,mt6779-camsys", "syscon"; >> + reg = <0 0x1a000000 0 0x10000>; >> + #clock-cells = <1>; >> + }; >> + >> + ipesys: clock-controller@1b000000 { >> + compatible = "mediatek,mt6779-ipesys", "syscon"; >> + reg = <0 0x1b000000 0 0x1000>; >> + #clock-cells = <1>; >> + }; >> + >> + }; >> +}; >