Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp679624rwl; Fri, 7 Apr 2023 03:52:58 -0700 (PDT) X-Google-Smtp-Source: AKy350aScpK1UT0Da5LaZNHhNeRaHqdMlUj9AOPd7jkeF9ZDcTfc+KL6G1iXFlWnEpQbGWQ2Ym2I X-Received: by 2002:a17:906:a404:b0:92e:e9c2:7b9c with SMTP id l4-20020a170906a40400b0092ee9c27b9cmr1874042ejz.77.1680864777864; Fri, 07 Apr 2023 03:52:57 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1680864777; cv=pass; d=google.com; s=arc-20160816; b=zIXqLIO7kUE8e4qYkTj6aGqHbMCiSxGkfFAsWcfdXYTTWmaEiJs+4rD5GrmPd2zk/S t5VgxCRsZvlt2m6urRFd9f9PKaeOaDqzyBRWjHqU8ElSFJ9URaIjsmOUWomNe/X24HGQ CZ9x2o/CUuX+ZvMxTDDubd0jY4WzWDOMVd9BB5y+pJEaYtJ0OU1lYXnE/qCVAeTbx9Oc U8qX0iDjoDPofKz8hGhCv6ivo9v+zbDY+uYy8a+eLXyehly+PprcMQVqY3KLbj3AGgaA mxP35UmWpCohJA+mh/EX95vmSTQQl6IVvP+yQ4cTTqteQV/432fqF0r42WUC77JRDvyd tOcw== 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 :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=ojJKyaw8vqXUV3WbW1J5GErwx63Ht6m7F3xy+69k6+M=; b=H6tu7xYwKAJZ5k8Jx/RWpvHeovfkDVvzE7UjXVr0ZdSFWI2Ii2fQE5nHegBCVFqdLt 1RufhvcVwIbBnOOK2NU3JaKCpp5kl6bVwGS5uPYzlSBGgiQHa63Q5MT70yDNEeBCiQYU OG2gWrpeuE7kx94y9lZe0K0mD90pbLghB3S2yiZeB9o5HWi2FWgQSt5SgQoha5Wlhal+ KUe12xzTgiZNRngTuXZDJ35D9PdpryJvtkGqdKUyq+L98pFh2otF9M2sygG9TTBp3Xg7 bReROJv3MMqjq0Mgv2H3lbR87ybGxWtGGw31PucjAXQCN4ky6hTd/62nx0GZPJxHiQ3r +1lg== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@arinc9.com header.s=zmail header.b="N/gQ0jMr"; 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 r1-20020a170906a20100b009338f516161si2941505ejy.707.2023.04.07.03.52.32; Fri, 07 Apr 2023 03:52:57 -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="N/gQ0jMr"; 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 S240564AbjDGKrW (ORCPT + 99 others); Fri, 7 Apr 2023 06:47:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38672 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240596AbjDGKrL (ORCPT ); Fri, 7 Apr 2023 06:47:11 -0400 Received: from sender3-op-o18.zoho.com (sender3-op-o18.zoho.com [136.143.184.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 92A95A24F; Fri, 7 Apr 2023 03:47:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680864388; cv=none; d=zohomail.com; s=zohoarc; b=WQCZwOwtC+4wnKqjt7PKOA3N/krjJwf5UXgcpY+iHDYgNm9MsvZcVJzXLplaFrO+B9hiGROY6XPhdnzB2qSAX8X+mnRFn3toAgy6Hg1syQOLcGeFT3/5JaRBqywPn1/Mzfa/EGCrDWng7PfMCVsD1cn6yK9YdQp/VqkOVayRdXs= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1680864388; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:MIME-Version:Message-ID:References:Subject:To; bh=ojJKyaw8vqXUV3WbW1J5GErwx63Ht6m7F3xy+69k6+M=; b=gqxVTuDGorITq3Kkz8p6O/2N2DxuDr8C93mRVHSy4jsYnZjuX2aCF55a2gdJ8N6X5G2AsZ9JoiDJ0YbRZxuW991Fr7SoshteDd+6VzRzLyIOzOkBgJAR5Kv4gXJ82Trk8U7je4yo8OPVKFhXTXh2ZjEzSf+aYQrNzKo+yj68q3M= 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=1680864388; 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=ojJKyaw8vqXUV3WbW1J5GErwx63Ht6m7F3xy+69k6+M=; b=N/gQ0jMrxkCPfc61qLYMAji56wcmOqN4MnNeOJVd0/mcc9T7/gQAeFP7uQndbi/z D+xPf6UT6m3CB3jqqL1c0kZnhwQK7cLxPpCNmt+B4XnnO9qhPPeepiKQ+bwMRTbqEeB hIYEULKOLirC0FeUGngwF8u2Y4Ki4xfIu8m2oZRk= Received: from [10.10.10.3] (149.91.1.15 [149.91.1.15]) by mx.zohomail.com with SMTPS id 1680864386413993.8772578271102; Fri, 7 Apr 2023 03:46:26 -0700 (PDT) Message-ID: <574460f4-5e22-3154-809d-42ca7aa53c1b@arinc9.com> Date: Fri, 7 Apr 2023 13:46:20 +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: [RFC PATCH net-next] net: dsa: mt7530: fix port specifications for MT7988 Content-Language: en-US To: Daniel Golle Cc: "Russell King (Oracle)" , Sean Wang , Landen Chao , DENG Qingfang , Andrew Lunn , Florian Fainelli , Vladimir Oltean , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Matthias Brugger , AngeloGioacchino Del Regno , erkin.bozoglu@xeront.com, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org References: <20230406100445.52915-1-arinc.unal@arinc9.com> <0cdb0504-bc1e-c255-a7d2-4dd96bd8e6e3@arinc9.com> 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=-2.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 7.04.2023 12:28, Daniel Golle wrote: > On Fri, Apr 07, 2023 at 11:56:08AM +0300, Arınç ÜNAL wrote: >> On 7.04.2023 00:57, Daniel Golle wrote: >>> On Fri, Apr 07, 2023 at 12:43:41AM +0300, Arınç ÜNAL wrote: >>>> On 6.04.2023 14:07, Russell King (Oracle) wrote: >>>>> On Thu, Apr 06, 2023 at 01:04:45PM +0300, arinc9.unal@gmail.com wrote: >>>>>> From: Arınç ÜNAL >>>>>> >>>>>> On the switch on the MT7988 SoC, there are only 4 PHYs. There's only port 6 >>>>>> as the CPU port, there's no port 5. Split the switch statement with a check >>>>>> to enforce these for the switch on the MT7988 SoC. The internal phy-mode is >>>>>> specific to MT7988 so put it for MT7988 only. >>>>>> >>>>>> Signed-off-by: Arınç ÜNAL >>>>>> --- >>>>>> >>>>>> Daniel, this is based on the information you provided me about the switch. >>>>>> I will add this to my current patch series if it looks good to you. >>>>>> >>>>>> Arınç >>>>>> >>>>>> --- >>>>>> drivers/net/dsa/mt7530.c | 67 ++++++++++++++++++++++++++-------------- >>>>>> 1 file changed, 43 insertions(+), 24 deletions(-) >>>>>> >>>>>> diff --git a/drivers/net/dsa/mt7530.c b/drivers/net/dsa/mt7530.c >>>>>> index 6fbbdcb5987f..f167fa135ef1 100644 >>>>>> --- a/drivers/net/dsa/mt7530.c >>>>>> +++ b/drivers/net/dsa/mt7530.c >>>>>> @@ -2548,7 +2548,7 @@ static void mt7988_mac_port_get_caps(struct dsa_switch *ds, int port, >>>>>> phy_interface_zero(config->supported_interfaces); >>>>>> switch (port) { >>>>>> - case 0 ... 4: /* Internal phy */ >>>>>> + case 0 ... 3: /* Internal phy */ >>>>>> __set_bit(PHY_INTERFACE_MODE_INTERNAL, >>>>>> config->supported_interfaces); >>>>>> break; >>>>>> @@ -2710,37 +2710,56 @@ mt753x_phylink_mac_config(struct dsa_switch *ds, int port, unsigned int mode, >>>>>> struct mt7530_priv *priv = ds->priv; >>>>>> u32 mcr_cur, mcr_new; >>>>>> - switch (port) { >>>>>> - case 0 ... 4: /* Internal phy */ >>>>>> - if (state->interface != PHY_INTERFACE_MODE_GMII && >>>>>> - state->interface != PHY_INTERFACE_MODE_INTERNAL) >>>>>> - goto unsupported; >>>>>> - break; >>>>>> - case 5: /* Port 5, a CPU port. */ >>>>>> - if (priv->p5_interface == state->interface) >>>>>> + if (priv->id == ID_MT7988) { >>>>>> + switch (port) { >>>>>> + case 0 ... 3: /* Internal phy */ >>>>>> + if (state->interface != PHY_INTERFACE_MODE_INTERNAL) >>>>> >>>>> How do these end up with PHY_INTERFACE_MODE_INTERNAL ? phylib defaults >>>>> to GMII mode without something else being specified in DT. >>>>> >>>>> Also note that you should *not* be validating state->interface in the >>>>> mac_config() method because it's way too late to reject it - if you get >>>>> an unsupported interface here, then that is down to the get_caps() >>>>> method being buggy. Only report interfaces in get_caps() that you are >>>>> prepared to handle in the rest of the system. >>>> >>>> This is already the case for all three get_caps(). The supported interfaces >>>> for each port are properly defined. >>>> >>>> Though mt7988_mac_port_get_caps() clears the config->supported_interfaces >>>> bitmap before reporting the supported interfaces. I don't think this is >>>> needed as all bits in the bitmap should already be initialized to zero when >>>> the phylink_config structure is allocated. >>>> >>>> I'm not sure if your suggestion is to make sure the supported interfaces are >>>> properly reported on get_caps(), or validate state->interface somewhere >>>> else. >>> >>> I think what Russell meant is just there is no point in being overly >>> precise about permitted interface modes in mt753x_phylink_mac_config, >>> as this function is not meant and called too late to validate the >>> validity of the selected interface mode. >>> >>> You change to mt7988_mac_port_get_caps looks correct to me and doing >>> this will already prevent mt753x_phylink_mac_config from ever being >>> called on MT7988 for port == 4 as well as and port == 5. >> >> Ah, thanks for pointing this out Daniel. I see ds->ops->phylink_get_caps() >> is run right before phylink_create() on dsa_port_phylink_create(), as it >> should get the capabilities before creating an instance. >> >> Should I remove phy_interface_zero(config->supported_interfaces); >> mt7988_mac_port_get_caps()? I'd prefer to do identical operations on each >> get_caps(), if there's no apparent reason for this to be on >> mt7988_mac_port_get_caps(). > > Yes, sounds sane to me, please do so. > > Also we could make .mac_port_config optional, as for MT7988 we actually > won't need it at all: > > diff --git a/drivers/net/dsa/mt7530.c b/drivers/net/dsa/mt7530.c > index e4bb5037d3525..5efcb9897eb18 100644 > --- a/drivers/net/dsa/mt7530.c > +++ b/drivers/net/dsa/mt7530.c > @@ -2653,17 +2653,6 @@ static bool mt753x_is_mac_port(u32 port) > return (port == 5 || port == 6); > } > > -static int > -mt7988_mac_config(struct dsa_switch *ds, int port, unsigned int mode, > - phy_interface_t interface) > -{ > - if (dsa_is_cpu_port(ds, port) && > - interface == PHY_INTERFACE_MODE_INTERNAL) > - return 0; > - > - return -EINVAL; > -} > - > static int > mt7531_mac_config(struct dsa_switch *ds, int port, unsigned int mode, > phy_interface_t interface) > @@ -2704,6 +2693,9 @@ mt753x_mac_config(struct dsa_switch *ds, int port, unsigned int mode, > { > struct mt7530_priv *priv = ds->priv; > > + if (!priv->info->mac_port_config) > + return 0; > + > return priv->info->mac_port_config(ds, port, mode, state->interface); > } > > @@ -3157,7 +3149,6 @@ const struct mt753x_info mt753x_table[] = { > .pad_setup = mt7988_pad_setup, > .cpu_port_config = mt7988_cpu_port_config, > .mac_port_get_caps = mt7988_mac_port_get_caps, > - .mac_port_config = mt7988_mac_config, > }, > }; > EXPORT_SYMBOL_GPL(mt753x_table); > @@ -3186,8 +3177,7 @@ mt7530_probe_common(struct mt7530_priv *priv) > */ > if (!priv->info->sw_setup || !priv->info->pad_setup || > !priv->info->phy_read_c22 || !priv->info->phy_write_c22 || > - !priv->info->mac_port_get_caps || > - !priv->info->mac_port_config) > + !priv->info->mac_port_get_caps) Why split the sanity check? Isn't just removing mt7988_mac_config() and .mac_port_config = mt7988_mac_config enough? Arınç