Received: by 2002:a05:7412:40d:b0:e2:908c:2ebd with SMTP id 13csp969299rdf; Wed, 22 Nov 2023 01:47:52 -0800 (PST) X-Google-Smtp-Source: AGHT+IG7DDQFYRNYZpS6Ze3xqTbZrbNxaGZM6J2fUjeNZWzMJnrDX+o0mgwtZtIMQtUkvfhUiGm1 X-Received: by 2002:a17:90a:1951:b0:280:a01a:906a with SMTP id 17-20020a17090a195100b00280a01a906amr1891867pjh.5.1700646471863; Wed, 22 Nov 2023 01:47:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700646471; cv=none; d=google.com; s=arc-20160816; b=XvXHUlznmsWAXNvd5G0dFD8NeraeYFLuWcksMdYpjCWT3hPK67XJtwUGHgoSjTRC4R BPTyKDQ617n73nmYfuWgUw1jiQa8Jfpq3e8yxjWGybpWEvf2FYd2mqE/lQfO2mKld9MH mK+ElRbPkJ9fSoGChzGng9ApeCrE/Xl9jlucvm4xP4oazT3Dg669Euj+LnOf/HIBv7fV kvuNWsbduhqoaTHlI+2LbUPD57KVFp1PIHVgdytcsBYS+Rn73BmKvRjZJyU9C6MT7sK+ xf/0rUNMcV1tMf+FjcYcdwAjDWmY9nuzRgWgqZpWldhBtxvz9zBOu2BFLKIjAGRFz/fW FNZQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=PdBVcC2vT01zVFxpZ2jiw5ZM8Gql+yitSI4+peOjFxU=; fh=kpbFcuuPj9pCCaQjXgt8ADFX/WHmNLQ1o6+PLozojeY=; b=JvyYO5h7joxT0JOn+EQztEA/Yjv/LHCFtumVLsGqxsb7yqkr4gB9xGmuJa0lq2eSZh LCRl7oXfQHBdeM1ck20X8QoQe8t7p3JWDrpasyoNufxMmkraDXEaxmMXWZynS/2Z4ig7 W2ag5a3Wj4RcxwsNcEXbLNtWfptmjKUvBx+5SkTdV/TWL6a27wpFA13irnD0ZqwFPraU zC0E8Lh1nOpLceE5z3XBXx/M3mt+0Y/OwzpLFj5sKThK0YBGLGajAyusiJkZ7SsnoTZo DJSP+6+WySn5HQUd531KzwmUsy3WAnYh55P0CL2X1AzrSzgH5+oTI9V3DlRwJZM52QxF kTtg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from agentk.vger.email (agentk.vger.email. [2620:137:e000::3:2]) by mx.google.com with ESMTPS id o13-20020a17090ac70d00b002850d8f9e1fsi1101160pjt.49.2023.11.22.01.47.51 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 22 Nov 2023 01:47:51 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) client-ip=2620:137:e000::3:2; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by agentk.vger.email (Postfix) with ESMTP id 9283D8163C1A; Wed, 22 Nov 2023 01:47:45 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at agentk.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1343757AbjKVJrX (ORCPT + 99 others); Wed, 22 Nov 2023 04:47:23 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48246 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343778AbjKVJq7 (ORCPT ); Wed, 22 Nov 2023 04:46:59 -0500 Received: from metis.whiteo.stw.pengutronix.de (metis.whiteo.stw.pengutronix.de [IPv6:2a0a:edc0:2:b01:1d::104]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 24C8DD7C for ; Wed, 22 Nov 2023 01:46:02 -0800 (PST) Received: from drehscheibe.grey.stw.pengutronix.de ([2a0a:edc0:0:c01:1d::a2]) by metis.whiteo.stw.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1r5jnv-0002VZ-G0; Wed, 22 Nov 2023 10:45:55 +0100 Received: from [2a0a:edc0:2:b01:1d::c0] (helo=ptx.whiteo.stw.pengutronix.de) by drehscheibe.grey.stw.pengutronix.de with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.94.2) (envelope-from ) id 1r5jnu-00AmUJ-6q; Wed, 22 Nov 2023 10:45:54 +0100 Received: from ore by ptx.whiteo.stw.pengutronix.de with local (Exim 4.92) (envelope-from ) id 1r5jnu-003H57-3w; Wed, 22 Nov 2023 10:45:54 +0100 Date: Wed, 22 Nov 2023 10:45:54 +0100 From: Oleksij Rempel To: "Russell King (Oracle)" Cc: "David S. Miller" , Andrew Lunn , Eric Dumazet , Florian Fainelli , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Woojung Huh , Arun Ramadoss , Simon Horman , kernel@pengutronix.de, linux-kernel@vger.kernel.org, netdev@vger.kernel.org, UNGLinuxDriver@microchip.com Subject: Re: [PATCH net-next v5 1/3] net: dsa: microchip: ksz8: Make flow control, speed, and duplex on CPU port configurable Message-ID: <20231122094554.GF590719@pengutronix.de> References: <20231122092545.2895635-1-o.rempel@pengutronix.de> <20231122092545.2895635-2-o.rempel@pengutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: X-Sent-From: Pengutronix Hildesheim X-URL: http://www.pengutronix.de/ X-Accept-Language: de,en X-Accept-Content-Type: text/plain User-Agent: Mutt/1.10.1 (2018-07-13) X-SA-Exim-Connect-IP: 2a0a:edc0:0:c01:1d::a2 X-SA-Exim-Mail-From: ore@pengutronix.de X-SA-Exim-Scanned: No (on metis.whiteo.stw.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org X-Spam-Status: No, score=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on agentk.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (agentk.vger.email [0.0.0.0]); Wed, 22 Nov 2023 01:47:45 -0800 (PST) On Wed, Nov 22, 2023 at 09:38:09AM +0000, Russell King (Oracle) wrote: > On Wed, Nov 22, 2023 at 10:25:43AM +0100, Oleksij Rempel wrote: > > Allow flow control, speed, and duplex settings on the CPU port to be > > configurable. Previously, the speed and duplex relied on default switch > > values, which limited flexibility. Additionally, flow control was > > hardcoded and only functional in duplex mode. This update enhances the > > configurability of these parameters. > > > > Signed-off-by: Oleksij Rempel > > Reviewed-by: Simon Horman > > Reviewed-by: Vladimir Oltean > > --- > > drivers/net/dsa/microchip/ksz8.h | 4 ++ > > drivers/net/dsa/microchip/ksz8795.c | 54 +++++++++++++++++++++++++- > > drivers/net/dsa/microchip/ksz_common.c | 1 + > > 3 files changed, 57 insertions(+), 2 deletions(-) > > > > diff --git a/drivers/net/dsa/microchip/ksz8.h b/drivers/net/dsa/microchip/ksz8.h > > index ef653bbfde75..571c26ce71e4 100644 > > --- a/drivers/net/dsa/microchip/ksz8.h > > +++ b/drivers/net/dsa/microchip/ksz8.h > > @@ -54,5 +54,9 @@ int ksz8_reset_switch(struct ksz_device *dev); > > int ksz8_switch_init(struct ksz_device *dev); > > void ksz8_switch_exit(struct ksz_device *dev); > > int ksz8_change_mtu(struct ksz_device *dev, int port, int mtu); > > +void ksz8_phylink_mac_link_up(struct ksz_device *dev, int port, > > + unsigned int mode, phy_interface_t interface, > > + struct phy_device *phydev, int speed, int duplex, > > + bool tx_pause, bool rx_pause); > > > > #endif > > diff --git a/drivers/net/dsa/microchip/ksz8795.c b/drivers/net/dsa/microchip/ksz8795.c > > index 8deb217638d3..3504e7238eba 100644 > > --- a/drivers/net/dsa/microchip/ksz8795.c > > +++ b/drivers/net/dsa/microchip/ksz8795.c > > @@ -1528,6 +1528,58 @@ void ksz8_config_cpu_port(struct dsa_switch *ds) > > } > > } > > > > +/** > > + * ksz8_cpu_port_link_up - Configures the CPU port of the switch. > > + * @dev: The KSZ device instance. > > + * @speed: The desired link speed. > > + * @duplex: The desired duplex mode. > > + * @tx_pause: If true, enables transmit pause. > > + * @rx_pause: If true, enables receive pause. > > + * > > + * Description: > > + * The function configures flow control and speed settings for the CPU > > + * port of the switch based on the desired settings, current duplex mode, and > > + * speed. > > + */ > > +static void ksz8_cpu_port_link_up(struct ksz_device *dev, int speed, int duplex, > > + bool tx_pause, bool rx_pause) > > +{ > > + const u16 *regs = dev->info->regs; > > + u8 ctrl = 0; > > + > > + /* SW_FLOW_CTRL, SW_HALF_DUPLEX, and SW_10_MBIT bits are bootstrappable > > + * at least on KSZ8873. They can have different values depending on your > > + * board setup. > > + */ > > + if (duplex) { > > + if (tx_pause || rx_pause) > > + ctrl |= SW_FLOW_CTRL; > > Please don't make this dependent on duplex, and allow phylink to enforce > that. For example, phylink_resolve_an_pause() will only enable tx/rx > pause if in full duplex mode. OK, thx. > > + } else { > > + ctrl |= SW_HALF_DUPLEX; > > + } > > + > > + /* This hardware only supports SPEED_10 and SPEED_100. For SPEED_10 > > + * we need to set the SW_10_MBIT bit. Otherwise, we can leave it 0. > > + */ > > + if (speed == SPEED_10) > > + ctrl |= SW_10_MBIT; > > + > > + ksz_rmw8(dev, regs[S_BROADCAST_CTRL], SW_HALF_DUPLEX | SW_FLOW_CTRL | > > + SW_10_MBIT, ctrl); > > So this is using SW_FLOW_CTRL with the S_BROADCAST_CTRL register... > > > @@ -1576,8 +1628,6 @@ int ksz8_setup(struct dsa_switch *ds) > > */ > > ds->vlan_filtering_is_global = true; > > > > - ksz_cfg(dev, S_REPLACE_VID_CTRL, SW_FLOW_CTRL, true); > > But previously it was being used with the S_REPLACE_VID_CTRL register. > Doesn't make sense to me. Yes, it looks suspicious. There are multiple ways to access same register. Vladimir pointed to in in the v4 review. S_BROADCAST_CTRL is used in most recent code. So, i decided to settle down to the variant. Regards, Oleksij -- Pengutronix e.K. | | Steuerwalder Str. 21 | http://www.pengutronix.de/ | 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |