Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp1084606rwl; Fri, 31 Mar 2023 06:34:37 -0700 (PDT) X-Google-Smtp-Source: AKy350ZnEGn7ugcY3/ibi4BYNt5Ll9ym5P2axwlWGihkvkqbNrZhwht0Cl2u4Y6daIjrBpKbf2wP X-Received: by 2002:a17:903:41cb:b0:1a2:9940:1f75 with SMTP id u11-20020a17090341cb00b001a299401f75mr3527730ple.0.1680269677317; Fri, 31 Mar 2023 06:34:37 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1680269677; cv=pass; d=google.com; s=arc-20160816; b=0AxLwEmdNLz/1nTACg2tgSrYm8sDBuSY+1z7zH1ThtuKBro/K8bI5xtZ0w0SHIqDP/ 9xWISnwLj4OgU630VKJLkxvBiyOVHTzCUEswdhV6/lXnyO+kcLzm5D5uqTIkZNpzO9qV U2SJm84Sc3uwIKuR7Frj5PTOKQRRCkmHaghkjGcPGThihUpzIwOzCkR8WTaqHXKyg0Lf SBAm1in0iRr0gYWMPXNmdfW7akDPsWL4ztVAgL6MJfbhmIPcR7/3+yHhg1Fa6CGKpsVT bbcbWLpZi9v2Un6dMXYTuucIjqr391JZSMp7Dn+abWouYj681OKJrpkTATU++yXI7aj0 Jflg== 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:references :cc:to:from:content-language:subject:user-agent:mime-version:date :message-id:dkim-signature; bh=cMHmrkdCRBs0b+cC5MrOaqU5ZtG6rlfwdpiKVRFq8U4=; b=YTJvIafn9Gh67BGFobKKpGZFQMv+lGk14A69YR/JtdEkGfHwF8N+KVg8qK+GnoF9ho SzDiMNUHXLramwiOA8pOmF2BgmWphfxA5KuYzD/zuPj0Bm9v2Dfw8t2LtaxhNEeBdrYT aIq8X6+tfOGHMDF9kdaDnKBOmyfEbeBGXB2mZPA/Z2grV2LxWAQ26Iqso185xhtujQzD nIng9aw7QnQc5SbsxlDylxSiKFEcMQAP6DmOvKzhvxpWKYNQnocuin9yUlpwR+ExfomX 2q516qcnlww9cpwKeV9j9xH7CzxjVfK/NPElOPFg0onmr0aKgHFgZRHlyT780n+Ogmwq am2w== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@arinc9.com header.s=zmail header.b=bbBo2JmZ; 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 ik3-20020a170902ab0300b0019ce74dd5c8si2052071plb.529.2023.03.31.06.34.25; Fri, 31 Mar 2023 06:34:37 -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=bbBo2JmZ; 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 S232474AbjCaNUr (ORCPT + 99 others); Fri, 31 Mar 2023 09:20:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55096 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232646AbjCaNUY (ORCPT ); Fri, 31 Mar 2023 09:20:24 -0400 Received: from sender3-op-o17.zoho.com (sender3-op-o17.zoho.com [136.143.184.17]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 93DAA1DFA5; Fri, 31 Mar 2023 06:20:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680268787; cv=none; d=zohomail.com; s=zohoarc; b=P7yZw+J0wyj4xrdmrqgiIoYYRx0enqLjrKRN0nO60uErKvMWcCUvVz6majD6O5X/KjhvJbdfKevlBH2xFV9g5wK2WWUyhbXqmbfl5W0S3k+iD0++5+4W/vn+x6I+AIAU/Stj+wd8gNRVuQxigBuX+7plyH6fBBhPAo6yD2WF79Y= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1680268787; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:MIME-Version:Message-ID:References:Subject:To; bh=cMHmrkdCRBs0b+cC5MrOaqU5ZtG6rlfwdpiKVRFq8U4=; b=GbO50moL7bzxLMI0MhSbyI1gTkc+cJmD7gq80V/rGEQESNR62F+Kp/1EhxLA71+3dHnlD1n/nzGUkHJWbDFup6FG29n5bdSoVjyT9UPB2ZUdm5i8HTX+WTvnuoLg0aHYkNnOZvs5WF6VDX5KcGYOK5yqaEONlXSP44PQrN3T9Jw= 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=1680268787; s=zmail; d=arinc9.com; i=arinc.unal@arinc9.com; h=Message-ID:Date:Date:MIME-Version:Subject:Subject:From:From:To:To:Cc:Cc:References:In-Reply-To:Content-Type:Content-Transfer-Encoding:Message-Id:Reply-To; bh=cMHmrkdCRBs0b+cC5MrOaqU5ZtG6rlfwdpiKVRFq8U4=; b=bbBo2JmZD+YJg81EOVWTEoHY+qHYXSXvWWr6+9kVG6MNb1HaLu5WVF0rBp01tTam w9ZIIDyWbvvN9yfwwpTmMT226TlA9D5ckoDLD0eKkd2XaPQtdtUXJM38DfSNxXqytWE 0l7JXZUyWpQ1LamukfdgsThREBcM60XolIkUujzI= Received: from [10.10.10.3] (149.91.1.15 [149.91.1.15]) by mx.zohomail.com with SMTPS id 168026878373195.65526317346269; Fri, 31 Mar 2023 06:19:43 -0700 (PDT) Message-ID: Date: Fri, 31 Mar 2023 16:19:37 +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 Content-Language: en-US From: =?UTF-8?B?QXLEsW7DpyDDnE5BTA==?= 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> In-Reply-To: <28d048c9-6389-749b-d0eb-18a9c2d83c4e@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 16:18, 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 >       supported. > > config NET_DSA_MT7530_MDIO >     tristate "MediaTek MT7530 MDIO interface driver" >     default NET_DSA_MT7530 This is unnecessary. Arınç