Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp1082403rwl; Fri, 31 Mar 2023 06:33:03 -0700 (PDT) X-Google-Smtp-Source: AKy350bJd9snksBpSPf4USJH6mwgdFb8t4W2mo/xMg1VY9j9F7Y+CUpo2mjb9Ld6ZTwZV9NGPviL X-Received: by 2002:a17:903:264b:b0:196:8d96:dc6b with SMTP id je11-20020a170903264b00b001968d96dc6bmr6340042plb.2.1680269582771; Fri, 31 Mar 2023 06:33:02 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1680269582; cv=pass; d=google.com; s=arc-20160816; b=UPBgm6Hs5xCMQsKSm4yxflXvvxVcMh0GkkTiSC2GtZR8OigV8pWuAdVW93Lf2RVrgq ADL4fV4Ro7kyV0t/N22NKzaNsjGG+bHUGvFZE0UM6l9q6qrfsoHI5wa4eIiiSI3RdIxQ kiOKS5QsuV9PWWTFgt4oPkJuCY3UHkEcuXOY2N3wzBlHz2Ow6cTNZvbaf+gLpMX93Agg CGnbCdeIwYpXn11OfBqEEd0G81RuLZBAdejMM9+1X59sUid1nVn6DCv7YtGtKJ0eVRiS ljcAEzss1Kug8PB9Nx1JCYq+MBL4XxBcIgBecY7TXDHLLvpGsRDuuZzKg0BKcxr08MVj zN+A== 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 :content-language:references:cc:to:subject:from:user-agent :mime-version:date:message-id:dkim-signature; bh=cS6yRpMy5ONg6KkXzeERv/t0GAI1/S3lgTKj9nCQWC0=; b=I/D3RVkPNYE/ioUlT18Am0TCaBSy05JUfmisOspz0Nw1jvMJOPPPSUJLKyTVYp3t4M YQ44W2y/j3ODZDMTSm5Hj7WtMXYuB6Xx3Fqko79gzBLTDkfyOZ3X463n4ly1Mf1zKbjP UyQ4iHZhOCOXedj56MwSp06zEQ3X57Ntm3Ieyij4ZQ/HkI9nNfd5Rk1nR1Z2HsnoxKl1 8h+3Y4BtZpHRbbf9JQN37ZeyK0I9bMjLm/Qzgp9weYmhPdrXsv7THIWhT6+SpMcbVmVQ QvM3K5jjL8MYQVGr+1nAd8sxS6tB1tWor7g3YnRNQUmpXNBBXX6PLoGMJ/On95zjkP30 OAyQ== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@arinc9.com header.s=zmail header.b="Ao/JolqJ"; 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 l7-20020a170903120700b001a1a5d21d5csi2381020plh.110.2023.03.31.06.32.47; Fri, 31 Mar 2023 06:33:02 -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="Ao/JolqJ"; 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 S232302AbjCaNTn (ORCPT + 99 others); Fri, 31 Mar 2023 09:19:43 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53908 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230332AbjCaNTT (ORCPT ); Fri, 31 Mar 2023 09:19:19 -0400 Received: from sender4-op-o10.zoho.com (sender4-op-o10.zoho.com [136.143.188.10]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6C972C174; Fri, 31 Mar 2023 06:19:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680268708; cv=none; d=zohomail.com; s=zohoarc; b=jLMmNuPdu9zY23HWl6d8MnTvG4eguPC8MQwvtsdZD01emM+b97kfUzJ9ZDunubUoof3MuaYwFQaQtFwie8PTS3rTUOhSENsGeXqppddrxOTUhkqQoH5OkdX/P+eLesjlVXtHOzZuu5ygACCrYWkJ4Mz5Ozm1Zj4Gqb/WHnPqQKE= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1680268708; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:MIME-Version:Message-ID:References:Subject:To; bh=cS6yRpMy5ONg6KkXzeERv/t0GAI1/S3lgTKj9nCQWC0=; b=IKVm6yvCODlkQwb15uw/a8b24dCv6iv9/arJz1sdVRCcyHwiuQpQTrh+k1I2GzpzJd8BFNri1XmMk/ukBV3nni59RjocMmKFDXMDJLjeu8jir3g4djGPw1G3izhKCDmEPmyVZ/sESTGfCoT3YsINjZnXkQD/m/fD3YGveFmW8rY= 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=1680268708; s=zmail; d=arinc9.com; i=arinc.unal@arinc9.com; h=Message-ID:Date:Date:MIME-Version:From:From:Subject:Subject:To:To:Cc:Cc:References:In-Reply-To:Content-Type:Content-Transfer-Encoding:Message-Id:Reply-To; bh=cS6yRpMy5ONg6KkXzeERv/t0GAI1/S3lgTKj9nCQWC0=; b=Ao/JolqJ49CHW/gvyzHiOhcncuN0BC4dL7axOpQ5LNfzDOpbU1UoVx8zVwhbn5R3 6R39bs5OoXiPnwcrzwL531tc0r+bmnfsmSl+aG5G50NjqLgo/QM8TJyQFJjg8IFVPQW snuHkF9mC8cs/nhIdSzYqjUyg8GoWHn4CJAESBbM= Received: from [10.10.10.3] (149.91.1.15 [149.91.1.15]) by mx.zohomail.com with SMTPS id 1680268706648901.7448659665515; Fri, 31 Mar 2023 06:18:26 -0700 (PDT) Message-ID: <28d048c9-6389-749b-d0eb-18a9c2d83c4e@arinc9.com> Date: Fri, 31 Mar 2023 16:18:19 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.9.0 From: =?UTF-8?B?QXLEsW7DpyDDnE5BTA==?= 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> Content-Language: en-US In-Reply-To: <7d0acaef-0cec-91b9-a5c6-d094b71e3dbd@arinc9.com> 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 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 supported. config NET_DSA_MT7530_MDIO tristate "MediaTek MT7530 MDIO interface driver" default NET_DSA_MT7530 depends on NET_DSA_MT7530 help This enables support for the MediaTek MT7530 switch chips which are connected via MDIO. config NET_DSA_MT7530_MMIO tristate "MediaTek MT7530 MMIO interface driver" depends on HAS_IOMEM depends on NET_DSA_MT7530 help This enables support for the MediaTek MT7530 switch chips which are connected via MMIO. You should also change MODULE_DESCRIPTION for both drivers to something like "Driver for MediaTek MT7530 ethernet switches connected via MMIO interface". Arınç