Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp896999ybz; Wed, 29 Apr 2020 11:18:31 -0700 (PDT) X-Google-Smtp-Source: APiQypJ5fP+f4QJo0ytsFe2s51o+VBuIMGjbyS/CVNyF62ie25SQJBru0cPkVWySiUywdurhuBWJ X-Received: by 2002:a17:906:e098:: with SMTP id gh24mr4022926ejb.44.1588184311262; Wed, 29 Apr 2020 11:18:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588184311; cv=none; d=google.com; s=arc-20160816; b=CCyuuchEK2WYc/mCiIs3tNa31d2zZKkJj911DtD7fw2Nv1iyuI7KpfCb5UdB9/Svcq vL1vn3zIPIqD4M0liVyN4CwOMzQfHz1Co73NQF/SxPFjqtbbEzBOzv2d23DI6BPcDSrX 2YTAGN0dn/ffdMOTm9nlv5S1blzuo0PBFfWXt3JpdlWA4y5QpA40rCEjnSx6P/+9j6L/ yC7kZPuoCqyoiTSNgvm1W73YFGwoO0hubkwDjJa+qmTtZzRwZrFd7gEnxv4NlxseYfhp UU7kZ8KnxxQ2lCKLtYevw1MxLrYDtWMKwQSUu/+rTZ0oN8i7D1WNTsfxSoi3OyoKXvjR mjfw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=htNy/yZSV8dTTKaFzroif1bSJdhUGBMPffp1OI7OoVg=; b=ROm89l4urobdLWszYHMWk/4QgUR7PgE3+WfsmaWJWJ+Z932mFvDmwiZwH8UlCNuoF5 Y5lZULS2Ph1lhDBYg1tAHuhnfQ0nFDSwdkIADGII/Lpd2JoMafaQ/H9e9ruKgfTx5+4w fwOO9J0uonlKz0dtrg3/Wv4bwqcL92vTewh0b23VQGpvmpNAxly0TYxehMckR2dOHyhM hmzkG4IXnboxMIHz320ZqV6BJgwo1CIIFri01S9w1w0KvFKRAc9wAn0BVSUlbqgtt3xX WetnzA3I/0euNUQWe0GTFkSirbAjasrG3mT7YCCo/kLUMP11u0e7QIoy/AppdxvmyIhV AH8g== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@lunn.ch header.s=20171124 header.b=vb+0Lti5; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q7si3926005eds.494.2020.04.29.11.18.06; Wed, 29 Apr 2020 11:18:31 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=fail header.i=@lunn.ch header.s=20171124 header.b=vb+0Lti5; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726955AbgD2SQ0 (ORCPT + 99 others); Wed, 29 Apr 2020 14:16:26 -0400 Received: from vps0.lunn.ch ([185.16.172.187]:60216 "EHLO vps0.lunn.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726511AbgD2SQ0 (ORCPT ); Wed, 29 Apr 2020 14:16:26 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lunn.ch; s=20171124; h=In-Reply-To:Content-Type:MIME-Version:References:Message-ID: Subject:Cc:To:From:Date:Sender:Reply-To:Content-Transfer-Encoding:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:List-Id:List-Help:List-Unsubscribe:List-Subscribe: List-Post:List-Owner:List-Archive; bh=htNy/yZSV8dTTKaFzroif1bSJdhUGBMPffp1OI7OoVg=; b=vb+0Lti5y17+Y5ZcvB29hOcG29 //qk7T77GMcVOPoie9JYtgjpm7Lvuq0gyycFfJx0p+HGeSpaeSb4x6Khm+1LMZjMy2i4nz3HvQ4hY 8sPJmK0DeT1ltSal1sJStVMR0pkbGFm9uRSdJZ30pDchObPlWpy6ZVOHcEcTqnyV5uHs=; Received: from andrew by vps0.lunn.ch with local (Exim 4.93) (envelope-from ) id 1jTrFm-000IzQ-Jx; Wed, 29 Apr 2020 20:16:14 +0200 Date: Wed, 29 Apr 2020 20:16:14 +0200 From: Andrew Lunn To: Oleksij Rempel Cc: "David S. Miller" , Florian Fainelli , Heiner Kallweit , Jakub Kicinski , Jonathan Corbet , Michal Kubecek , David Jander , kernel@pengutronix.de, linux-kernel@vger.kernel.org, netdev@vger.kernel.org, Russell King , mkl@pengutronix.de, Marek Vasut , Christian Herber Subject: Re: [PATCH net-next v3 1/2] ethtool: provide UAPI for PHY master/slave configuration. Message-ID: <20200429181614.GL30459@lunn.ch> References: <20200428075308.2938-1-o.rempel@pengutronix.de> <20200428075308.2938-2-o.rempel@pengutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200428075308.2938-2-o.rempel@pengutronix.de> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Apr 28, 2020 at 09:53:07AM +0200, Oleksij Rempel wrote: Hi Oleksij Sorry for taking a while to review this. I was busy fixing the FEC driver which i broke :-( > --- a/Documentation/networking/ethtool-netlink.rst > +++ b/Documentation/networking/ethtool-netlink.rst > @@ -399,6 +399,8 @@ Kernel response contents: > ``ETHTOOL_A_LINKMODES_PEER`` bitset partner link modes > ``ETHTOOL_A_LINKMODES_SPEED`` u32 link speed (Mb/s) > ``ETHTOOL_A_LINKMODES_DUPLEX`` u8 duplex mode > + ``ETHTOOL_A_LINKMODES_MASTER_SLAVE_CFG`` u8 Master/slave port mode > + ``ETHTOOL_A_LINKMODES_MASTER_SLAVE_STATE`` u8 Master/slave port mode > ==================================== ====== ========================== I've not used Sphinx for a while. But it used to be, tables had to be correctly aligned. I think you need to pad the other rows with spaces. Also, the comments should differ. The first is how we want it configured, the second is the current state. > > For ``ETHTOOL_A_LINKMODES_OURS``, value represents advertised modes and mask > @@ -421,6 +423,7 @@ Request contents: > ``ETHTOOL_A_LINKMODES_PEER`` bitset partner link modes > ``ETHTOOL_A_LINKMODES_SPEED`` u32 link speed (Mb/s) > ``ETHTOOL_A_LINKMODES_DUPLEX`` u8 duplex mode > + ``ETHTOOL_A_LINKMODES_MASTER_SLAVE_CFG`` u8 Master/slave port mode > ==================================== ====== ========================== Same table cleanup needed here. > +static int genphy_read_master_slave(struct phy_device *phydev) > +{ > + int cfg, state = 0; > + u16 val; > + > + phydev->master_slave_get = 0; > + phydev->master_slave_state = 0; Could you use the _UNKNOWN #defined here? > diff --git a/include/uapi/linux/ethtool.h b/include/uapi/linux/ethtool.h > index 92f737f101178..eb680e3d6bda5 100644 > --- a/include/uapi/linux/ethtool.h > +++ b/include/uapi/linux/ethtool.h > @@ -1666,6 +1666,31 @@ static inline int ethtool_validate_duplex(__u8 duplex) > return 0; > } > > +static inline int ethtool_validate_master_slave_cfg(__u8 cfg) > +{ > + switch (cfg) { > + case PORT_MODE_CFG_MASTER_PREFERRED: > + case PORT_MODE_CFG_SLAVE_PREFERRED: > + case PORT_MODE_CFG_MASTER_FORCE: > + case PORT_MODE_CFG_SLAVE_FORCE: > + case PORT_MODE_CFG_UNKNOWN: > + return 1; > + } > + > + return 0; > +} Does this need to be an inline function? Andrew