Received: by 2002:a05:6358:45e:b0:b5:b6eb:e1f9 with SMTP id 30csp574671rwe; Thu, 1 Sep 2022 04:39:34 -0700 (PDT) X-Google-Smtp-Source: AA6agR6lI1twByYyTg2xL5oSrZIoyj3/gas/ZhM4zz45MRKDWg/3HIhHVpbxN0bPklee6QRB/BbH X-Received: by 2002:a05:6402:4282:b0:43e:612c:fcf7 with SMTP id g2-20020a056402428200b0043e612cfcf7mr28079585edc.242.1662032373735; Thu, 01 Sep 2022 04:39:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662032373; cv=none; d=google.com; s=arc-20160816; b=wP8oecy5mO9h69830dBxz5e5f7uYVuPpVPXHoBRW8w7eFH5sPcweZ/u0bZMKvmfVnO CdG3VJiBoUpJ2PuJ9AO7lfI5KT1AUtq0hu7nR0rQ+ukYrALQbIrBcuZFFPaQtoGrG5pg KeLeBmRXSC5lxlEa50JAwPTUokplIg/ogTdPtN0jh3aQEdLsOxaqAToPyWwc2wAD4BCJ V3Rn9jzfuywb3cQiK4J38JKWlajBRnlyezJTILhLUy3kaMJGNxl+aRubF1UFS1yfXwID 8rMyIGxLMEnrJIl/03jlv7SRsp9CWvo5H4D09kuG4V6gaPBkngRu+9ERF9SOGXhIFBqF rKew== 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=uoUsyV/EK/wmkARQyeyEwjOvF60gUyVj2DrhWWojGks=; b=OqHiURXTXUqBpsodwK0GkKqblGR00O+bDPLClOGefzxFPRK2DxOIsF+zPWIkLA4IqV DYEbscfA02VAjiwQI40BtTxQyTof14OdcdJaNRXr0RvZbTFJt7lj46pPtxajPE728pml BZounwsZXWWF+kI7Q5tgdxDtN3n7K1AsKaxoyj5K+s8Ne5zrHwV/gMtthupuUJdTdryX PrUMwYQVRKqQ3kUYqnvInBFEj26X0qRjFF4qs0BzEA/epl6u6qtPTcckvz1Q7jiFPuUS PybrDwp2hbcn7EmLBBpFtOfKGPJLm0VKgF7X5m3sydga2pQkdyJq8RAv7L25/bQ4UJaE xfCw== ARC-Authentication-Results: i=1; mx.google.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 t9-20020a056402524900b00446190ccceesi1695803edd.10.2022.09.01.04.39.05; Thu, 01 Sep 2022 04:39:33 -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; 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 S234491AbiIAL1h (ORCPT + 99 others); Thu, 1 Sep 2022 07:27:37 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54694 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233617AbiIAL1f (ORCPT ); Thu, 1 Sep 2022 07:27:35 -0400 Received: from metis.ext.pengutronix.de (metis.ext.pengutronix.de [IPv6:2001:67c:670:201:290:27ff:fe1d:cc33]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2D776132EFA for ; Thu, 1 Sep 2022 04:27:34 -0700 (PDT) Received: from ptx.hi.pengutronix.de ([2001:67c:670:100:1d::c0]) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1oTiM0-0007V9-K9; Thu, 01 Sep 2022 13:27:24 +0200 Received: from ore by ptx.hi.pengutronix.de with local (Exim 4.92) (envelope-from ) id 1oTiLx-0003ZO-Gd; Thu, 01 Sep 2022 13:27:21 +0200 Date: Thu, 1 Sep 2022 13:27:21 +0200 From: Oleksij Rempel To: Arun.Ramadoss@microchip.com Cc: olteanv@gmail.com, andrew@lunn.ch, linux-kernel@vger.kernel.org, UNGLinuxDriver@microchip.com, vivien.didelot@gmail.com, san@skov.dk, linux@armlinux.org.uk, f.fainelli@gmail.com, kuba@kernel.org, edumazet@google.com, pabeni@redhat.com, netdev@vger.kernel.org, Woojung.Huh@microchip.com, davem@davemloft.net Subject: Re: [Patch net-next v2 0/9] net: dsa: microchip: add support for phylink mac config and link up Message-ID: <20220901112721.GB2479@pengutronix.de> References: <20220724092823.24567-1-arun.ramadoss@microchip.com> <20220830065533.GA18106@pengutronix.de> <67690ec6367c9dc6d2df720dcf98e6e332d2105b.camel@microchip.com> <20220830095830.flxd3fw4sqyn425m@skbuf> <20220830160546.GB16715@pengutronix.de> <20220831074324.GD16715@pengutronix.de> <20220831151859.ubpkt5aljrp3hiph@skbuf> <20220831161055.GA2479@pengutronix.de> <6c4666fd48ce41f84dbdad63a5cd6f4d3be25f4a.camel@microchip.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <6c4666fd48ce41f84dbdad63a5cd6f4d3be25f4a.camel@microchip.com> 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: 2001:67c:670:100:1d::c0 X-SA-Exim-Mail-From: ore@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham 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 Thu, Sep 01, 2022 at 08:51:44AM +0000, Arun.Ramadoss@microchip.com wrote: > On Wed, 2022-08-31 at 18:10 +0200, Oleksij Rempel wrote: > > EXTERNAL EMAIL: Do not click links or open attachments unless you > > know the content is safe > > > > On Wed, Aug 31, 2022 at 06:18:59PM +0300, Vladimir Oltean wrote: > > > On Wed, Aug 31, 2022 at 09:43:24AM +0200, Oleksij Rempel wrote: > > > > > > Should we point them to ksz8795_xmii_ctrl0 and > > > > > > ksz8795_xmii_ctrl1? I don't know. > > > > > > Could you find out what these should be set to? > > > > > > > > > > xmii_ctrl0/1 are missing and it make no sense to add it. > > > > > KSZ8873 switch is controlling CPU port MII configuration over > > > > > global, > > > > > not port based register. > > > > > > > > > > I'll better define separate ops for this chip. > > > > > > > > Hm, not only KSZ8830/KSZ8863/KSZ8873 are affected. ksz8795 > > > > compatible > > > > series with defined .xmii_ctrl0/.xmii_ctrl1 are broken too. > > > > Because it > > > > is writing to the global config register over ksz_pwrite8 > > > > function. It > > > > means, we are writing to 0xa6 instead of 0x06. And to 0xf6 > > > > instead of > > > > 0x56. > > > What do you mean by "global config register"? The Is_1Gbps bit is > > > still > > > part of a port register, it's just that this particular register is > > > only > > > defined for the 5th port (port #4, the only xMII port on KSZ7895 > > > AFAIU). > > > That doesn't necessarily make it a "global" register. > > > > > > Datasheet says: > > > > > > Register 22 (0x16): Reserved > > > Register 38 (0x26): Reserved > > > Register 54 (0x36): Reserved > > > Register 70 (0x46): Reserved > > > Register 86 (0x56): Port 5 Interface Control 6 > > > > > > I wonder if it's ok to modify the regs table like this, because we > > > should then only touch P_XMII_CTRL_1 using port 4: > > > > > > static const u16 ksz8795_regs[] = { > > > [REG_IND_CTRL_0] = 0x6E, > > > [REG_IND_DATA_8] = 0x70, > > > [REG_IND_DATA_CHECK] = 0x72, > > > [REG_IND_DATA_HI] = 0x71, > > > [REG_IND_DATA_LO] = 0x75, > > > [REG_IND_MIB_CHECK] = 0x74, > > > [REG_IND_BYTE] = 0xA0, > > > [P_FORCE_CTRL] = 0x0C, > > > [P_LINK_STATUS] = 0x0E, > > > [P_LOCAL_CTRL] = 0x07, > > > [P_NEG_RESTART_CTRL] = 0x0D, > > > [P_REMOTE_STATUS] = 0x08, > > > [P_SPEED_STATUS] = 0x09, > > > [S_TAIL_TAG_CTRL] = 0x0C, > > > [P_STP_CTRL] = 0x02, > > > [S_START_CTRL] = 0x01, > > > [S_BROADCAST_CTRL] = 0x06, > > > [S_MULTICAST_CTRL] = 0x04, > > > [P_XMII_CTRL_0] = 0x06, > > > - [P_XMII_CTRL_1] = 0x56, > > > + [P_XMII_CTRL_1] = 0x06, > > > }; > > > > > > > Speed configuration on ksz8795 is done over two registers: > > Register 86 (0x56): Port 5 Interface Control 6: Is_1Gbps - BIT(6) > > and > > Register 6 (0x06): Global Control 4: Switch SW5-MII/RMII Speed > > -BIT(4) > > > > both are accessed on wrong offsets. > > > > I would prefer to do following steps: > > - remove everything from ksz_phylink_mac_link_up() except of > > dev->dev_ops->phylink_mac_link_up > > - move ksz_duplex_flowctrl(), ksz_port_set_xmii_speed()... to > > ksz9477.c > > and rename them. Assign ksz9477_phylink_mac_link_up() > > dev->dev_ops->phylink_mac_link_up > > - create separate function ksz8795_phylink_mac_link_up() > > - use documented, not generic register names. > > > > In the original code, the ksz8795_cpu_interface_select (which does the > xmii and speed configuration) is called only ksz87xx switch not for the > ksz88x3. > During refactoring, I intentionally did not add the P_XMII_CTRL0/1 for > the ksz88xx in the chip_data structure. > I added check that if switch belong to ksz88x3 then return in the > phylink_mac_config function but I missed to add in the > phylink_mac_link_up. Thats the mistake I have done. So, for the ksz88xx > switch code breakage, it could be fixed by adding the check in the > phylink_mac_link_up as well. > > For the code breakage in ksz8795/ksz8794, the original code has only > provision for configuring xmii mode and choosing the 100/1000Mbps speed > selection which could be selected using is_1Gbps bit of > port5_interface_control6 register (0x56). But it didn't have provision > to select speed between 10/100Mbps, flow control and duplex. > > As per vladimir suggestion, P_XMII_CTRL1 can be changed from 0x56 to > 0x06. It fixes the problem for ksz_set_xmii, ksz_set_gbit since this is > the port based register not the global register. > > The global register 0x06 responsibilities are bit 4 for 10/100mbps > speed selection, bit 5 for flow control and bit 6 for duplex > operation. Since these three are new features added during refactoring > I overlooked it. > To fix this, either I need to return from the ksz_set_100_10mbit & > ksz_duplex_flowctrl function if the chip_id is ksz87xx or add dev- > >dev_ops for this alone. > Kindly suggest on how to proceed. Do not worry, every one makes mistakes ;) I just scared how easy it is to make them in this driver. I assume, that initially the good idea to make things more generic in this driver is working against us. The register- and bit-mapping functionally is already biting us: - it is hard to review, due to different register naming schema for different switch families. Especially the old ones. - we are using naming from one documentation to map to other documentation. - some times we need to map some registers multiple times with different names: P_REMOTE_STATUS and P_LINK_STATUS I would prefer to got ops way, to clean things up. 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 |