Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp1142103rwl; Fri, 31 Mar 2023 07:15:37 -0700 (PDT) X-Google-Smtp-Source: AKy350aSyO7k2XbMG4IP8dJrinxFrxS1RIUQII1GIyl8oUpiYDz/LaHRT9yfVNQrmDHyAx0P3AQ5 X-Received: by 2002:a17:906:3f4f:b0:945:394a:d0fc with SMTP id f15-20020a1709063f4f00b00945394ad0fcmr5454697ejj.6.1680272136844; Fri, 31 Mar 2023 07:15:36 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1680272136; cv=pass; d=google.com; s=arc-20160816; b=Pakank/6aTM2AaJDcA4nRVGan0K2yk+ubWT1KEPCqX4KJXezoWNZeiMV58D8IAHobv Pb/Zc/YCdweA3PXj7Ows2QG/lHKF595cNuxw53wBhJwyMxsN7+5rVKX2tpqZ4tc0bQjJ kBFBHIB0X67E+tpcYke4mbE5oPr7uufiySAhb1ljeFAUnkSPzFtp/XQ+xubrn0CS3j9S SNKC2S27TZyzMbcMEWmcOkQxx0LL29CJBQ2W2s5yRvj16Y2hX0JPwuQuuQjFTZ5NPvFP 6BoC8gjMPPOpRq03peYDT+tDGkaNGY7yrvxXFZF9/8ArN4yw3uzGSnkll7cLdWWOz0Xj 3wXA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :content-language:references:cc:to:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=fvqueTr1axbZTkd/DDdsj9eDNXuFB6DZ6SIlUCC7OW8=; b=bJ02HYD3y4lWIoyOyFppFTubYI5casatIE8iFEtmJOaqN+flvweN8MDl9aFBHUu5b7 26e0EWd9O0niaYmIhLC5hZy/HxpnslUsg2+DEJset+fMHBeHql+ZsDB9tjdAsbLMfSOF k2uUz10BXVeDefa2tB3haR+aBa+US8lmrFmYXFQYocDIowE12JehBKWaaraps4lHPYY6 NBm2fElLBOWA6VpD4x24AbwWZhrPNI3AddSspyLcSVok9C059cz3GQiV9kALx/M/Px0o Tr2DVFLa/sa4VxiXRDNilH4u5BKqBeRkyAJCvRjgsuIWYUmY4hOt7CjLRVHZ3Nb5QHqS Yn1A== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@arinc9.com header.s=zmail header.b="L/Ii5xrR"; arc=pass (i=1 spf=pass spfdomain=arinc9.com dkim=pass dkdomain=arinc9.com dmarc=pass fromdomain=arinc9.com>); spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id q8-20020a170906360800b0093fcc6295ffsi1962925ejb.771.2023.03.31.07.15.11; Fri, 31 Mar 2023 07:15:36 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@arinc9.com header.s=zmail header.b="L/Ii5xrR"; arc=pass (i=1 spf=pass spfdomain=arinc9.com dkim=pass dkdomain=arinc9.com dmarc=pass fromdomain=arinc9.com>); spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232376AbjCaOMr (ORCPT + 99 others); Fri, 31 Mar 2023 10:12:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39566 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231284AbjCaOMp (ORCPT ); Fri, 31 Mar 2023 10:12:45 -0400 Received: from sender3-op-o19.zoho.com (sender3-op-o19.zoho.com [136.143.184.19]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 90F4B1D2EF; Fri, 31 Mar 2023 07:12:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680271924; cv=none; d=zohomail.com; s=zohoarc; b=nLWZqL3VGtftDDr223aU7F1ygfkJqZP9pQ6OEX5/6sXAhS7bBTyn5ZotycUo1BqLGfzT95c7iZ48MZtJB29Ke57Jlj3UAhid/DCqye5OWXbrTEKlN+loDHirfGXlvutMTDV1wLAurChdIhSco+gRAibJwYmC/LEWwavfUbhtDME= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1680271924; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:MIME-Version:Message-ID:References:Subject:To; bh=fvqueTr1axbZTkd/DDdsj9eDNXuFB6DZ6SIlUCC7OW8=; b=k6ZgK6mwLrLWKX3+sjZbUlVEbS9DQWfLlyDB5jjFYBHZcHal3yhvaSzwvWwHJ5MueKt7vXU/1F1JVanF19ihu4XAb0qoIXvF5jYnn6oSCu+3R5uxbCowrEVCqPwmzbwSPj5rDg8TPG0VwO6XLRoyn9XiehAl0m9Ii4l45E72XWY= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass header.i=arinc9.com; spf=pass smtp.mailfrom=arinc.unal@arinc9.com; dmarc=pass header.from= DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; t=1680271924; s=zmail; d=arinc9.com; i=arinc.unal@arinc9.com; h=Message-ID:Date:Date:MIME-Version:Subject:Subject:To:To:Cc:Cc:References:From:From:In-Reply-To:Content-Type:Content-Transfer-Encoding:Message-Id:Reply-To; bh=fvqueTr1axbZTkd/DDdsj9eDNXuFB6DZ6SIlUCC7OW8=; b=L/Ii5xrR/kwrgNt27UHf04se6aI7F7XcAT7m9d83n3GUOfFcE2eGEqJncUdeHQPV 3IUo2G/MGHhZ1GP2hnrab4tucSuSJQrrpwNIJihmsN8hFgrIaglqdiBp7GquvpRwdpN qAQt6ASdOfQTH5BTcu9vyi1R1pX7F8Vj7X1+4OA4= Received: from [10.10.10.3] (149.91.1.15 [149.91.1.15]) by mx.zohomail.com with SMTPS id 1680271923083110.294415338504; Fri, 31 Mar 2023 07:12:03 -0700 (PDT) Message-ID: <00200328-1d29-4290-85ad-a7229e5fde47@arinc9.com> Date: Fri, 31 Mar 2023 17:11:56 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.9.0 Subject: Re: [PATCH net-next 14/15] net: dsa: mt7530: introduce driver for MT7988 built-in switch To: Daniel Golle Cc: netdev@vger.kernel.org, linux-mediatek@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux@armlinux.org.uk, linux-kernel@vger.kernel.org, Andrew Lunn , Florian Fainelli , Vladimir Oltean , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Matthias Brugger , AngeloGioacchino Del Regno , Sean Wang , Landen Chao , DENG Qingfang , Philipp Zabel , Sam Shih , Lorenzo Bianconi , John Crispin , Felix Fietkau , Luiz Angelo Daros de Luca References: <6a7c5f81-a8a3-27b5-4af3-7175a3313f9a@arinc9.com> <7d0acaef-0cec-91b9-a5c6-d094b71e3dbd@arinc9.com> <28d048c9-6389-749b-d0eb-18a9c2d83c4e@arinc9.com> Content-Language: en-US From: =?UTF-8?B?QXLEsW7DpyDDnE5BTA==?= In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-ZohoMailClient: External X-Spam-Status: No, score=-0.2 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 31.03.2023 17:10, Daniel Golle wrote: > On Fri, Mar 31, 2023 at 04:18:19PM +0300, Arınç ÜNAL wrote: >> On 31.03.2023 15:06, Arınç ÜNAL wrote: >>> On 31.03.2023 13:16, Daniel Golle wrote: >>>> On Fri, Mar 31, 2023 at 08:50:28AM +0300, Arınç ÜNAL wrote: >>>>> On 30.03.2023 18:23, Daniel Golle wrote: >>>>>> Add driver for the built-in Gigabit Ethernet switch which can be found >>>>>> in the MediaTek MT7988 SoC. >>>>>> >>>>>> The switch shares most of its design with MT7530 and MT7531, but has >>>>>> it's registers mapped into the SoCs register space rather than being >>>>>> connected externally or internally via MDIO. >>>>>> >>>>>> Introduce a new platform driver to support that. >>>>>> >>>>>> Signed-off-by: Daniel Golle >>>>>> --- >>>>>>    MAINTAINERS                   |   2 + >>>>>>    drivers/net/dsa/Kconfig       |  12 ++++ >>>>>>    drivers/net/dsa/Makefile      |   1 + >>>>>>    drivers/net/dsa/mt7530-mmio.c | 101 >>>>>> ++++++++++++++++++++++++++++++++++ >>>>>>    drivers/net/dsa/mt7530.c      |  86 ++++++++++++++++++++++++++++- >>>>>>    drivers/net/dsa/mt7530.h      |  12 ++-- >>>>>>    6 files changed, 206 insertions(+), 8 deletions(-) >>>>>>    create mode 100644 drivers/net/dsa/mt7530-mmio.c >>>>>> >>>>>> diff --git a/MAINTAINERS b/MAINTAINERS >>>>>> index 14924aed15ca7..674673dbdfd8b 100644 >>>>>> --- a/MAINTAINERS >>>>>> +++ b/MAINTAINERS >>>>>> @@ -13174,9 +13174,11 @@ MEDIATEK SWITCH DRIVER >>>>>>    M:    Sean Wang >>>>>>    M:    Landen Chao >>>>>>    M:    DENG Qingfang >>>>>> +M:    Daniel Golle >>>>>>    L:    netdev@vger.kernel.org >>>>>>    S:    Maintained >>>>>>    F:    drivers/net/dsa/mt7530-mdio.c >>>>>> +F:    drivers/net/dsa/mt7530-mmio.c >>>>>>    F:    drivers/net/dsa/mt7530.* >>>>>>    F:    net/dsa/tag_mtk.c >>>>>> diff --git a/drivers/net/dsa/Kconfig b/drivers/net/dsa/Kconfig >>>>>> index c2551b13324c2..de4d86e37973f 100644 >>>>>> --- a/drivers/net/dsa/Kconfig >>>>>> +++ b/drivers/net/dsa/Kconfig >>>>>> @@ -52,6 +52,18 @@ config NET_DSA_MT7530 >>>>>>          Multi-chip module MT7530 in MT7621AT, MT7621DAT, MT7621ST and >>>>>>          MT7623AI SoCs is supported as well. >>>>>> +config NET_DSA_MT7988 >>>>>> +    tristate "MediaTek MT7988 built-in Ethernet switch support" >>>>>> +    select NET_DSA_MT7530_COMMON >>>>>> +    depends on HAS_IOMEM >>>>>> +    help >>>>>> +      This enables support for the built-in Ethernet switch found >>>>>> +      in the MediaTek MT7988 SoC. >>>>>> +      The switch is a similar design as MT7531, however, unlike >>>>>> +      other MT7530 and MT7531 the switch registers are directly >>>>>> +      mapped into the SoCs register space rather than being accessible >>>>>> +      via MDIO. >>>>>> + >>>>>>    config NET_DSA_MV88E6060 >>>>>>        tristate "Marvell 88E6060 ethernet switch chip support" >>>>>>        select NET_DSA_TAG_TRAILER >>>>>> diff --git a/drivers/net/dsa/Makefile b/drivers/net/dsa/Makefile >>>>>> index 71250d7dd41af..103a33e20de4b 100644 >>>>>> --- a/drivers/net/dsa/Makefile >>>>>> +++ b/drivers/net/dsa/Makefile >>>>>> @@ -8,6 +8,7 @@ endif >>>>>>    obj-$(CONFIG_NET_DSA_LANTIQ_GSWIP) += lantiq_gswip.o >>>>>>    obj-$(CONFIG_NET_DSA_MT7530_COMMON) += mt7530.o >>>>>>    obj-$(CONFIG_NET_DSA_MT7530)    += mt7530-mdio.o >>>>>> +obj-$(CONFIG_NET_DSA_MT7988)    += mt7530-mmio.o >>>>> >>>>> I'm not fond of this way. Wouldn't it be better if we split the mdio and >>>>> mmio drivers to separate modules and kept switch hardware support on >>>>> mt7530.c? >>>> >>>> You mean this in terms of Kconfig symbols? >>>> Because the way you describe is basically what I'm doing here: >>>>   * mt7530.c is the shared/common switch hardware driver >>>>   * mt7530-mdio.c contains the MDIO accessors and MDIO device drivers for >>>>     MT7530, MT7531, MT7621, MT7623, ... >>>>   * mt7530-mmio.c contains the platform device driver for in-SoC switches >>>>     which are accessed via MMIO, ie. MT7988 (and yes, this could be >>>>     extended to also support MT7620A/N). >>> >>> Ok great. >>> >>>> >>>> In early drafts I also named the Kconfig symbols >>>> CONFIG_NET_DSA_MT7530 for mt7530.c (ie. the common part) >>>> CONFIG_NET_DSA_MT7530_MDIO for the MDIO driver >>>> CONFIG_NET_DSA_MT7530_MMIO for the MMIO driver >>>> >>>> However, as existing kernel configurations expect >>>> CONFIG_NET_DSA_MT7530 to >>>> select the MDIO driver, I decided it would be better to hide the >>>> symbol of >>>> the common part and have CONFIG_NET_DSA_MT7530 select the MDIO >>>> driver like >>>> it was before. >>> >>> You can "imply NET_DSA_MT7530_MDIO" from NET_DSA_MT7530 so the MDIO >>> driver is also enabled when NET_DSA_MT7530 is selected. For example, on >>> Realtek, both MDIO and SMI drivers are enabled by default when either of >>> the main drivers are selected. >>> >>> config NET_DSA_MT7530 >>>     tristate "MediaTek MT7530 and MT7531 Ethernet switch support" >>>     select NET_DSA_TAG_MTK >>>     select MEDIATEK_GE_PHY >>>     select PCS_MTK_LYNXI >>>     imply NET_DSA_MT7530_MDIO >>>     imply NET_DSA_MT7530_MMIO >> >> The final kconfig should look like this: >> >> config NET_DSA_MT7530 >> tristate "MediaTek MT7530 and MT7531 Ethernet switch support" >> select NET_DSA_TAG_MTK >> select MEDIATEK_GE_PHY >> select PCS_MTK_LYNXI >> imply NET_DSA_MT7530_MDIO >> imply NET_DSA_MT7530_MMIO >> help >> This enables support for the MediaTek MT7530 and MT7531 Ethernet >> switch chips. Multi-chip module MT7530 in MT7621AT, MT7621DAT, >> MT7621ST and MT7623AI SoCs, and built-in switch in MT7688 SoC is > ^^^^^^ > You probably meant MT7988. > > The built-in Fast Ethernet switch of older Ralink SoCs as well as MT7628 and > MT7688 is a whole different story: > https://github.com/stroese/linux/blob/gardena-v5.5/drivers/net/dsa/mt7628-esw.c Yup, typo. "is" at the end should also be "are". Arınç