Received: by 2002:ac0:a679:0:0:0:0:0 with SMTP id p54csp311502imp; Thu, 21 Feb 2019 01:53:00 -0800 (PST) X-Google-Smtp-Source: AHgI3Ia1EAo6DLDXEpJlHvTeacFPu3xfrfFU9QNcgzygbSIJk25IRaCd8DPKbnvUBPync38GMpdL X-Received: by 2002:a63:6506:: with SMTP id z6mr33677106pgb.334.1550742780683; Thu, 21 Feb 2019 01:53:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550742780; cv=none; d=google.com; s=arc-20160816; b=YCRj9lGBZw9yHi5usMwU5BINfKm9SuQ+R+SQtnzjU0ppUQNlr+sNhZGgAOJ+j/j7X/ rPtfHMFS7mj4jt/ACl7GbWYJl1r0zQ4HasOmKjrUpG0tLgRwOqWvOyLy9yh4S8OK4HfU OiAsZbM21Yhm0HZgQvW9gIXSPKPknEKh4tt1jFZpT2/hCD+Z54Z1/n+5z2X1aO8GopBk nDhAySnJ+6cEa0rT9j5+LDrtSOwPvEBRN9b8NUdXXmXs8saqwRHMeKPx2Aztz+SIWFeG +83rZ9JoR5X+dNdhZVxA2iBiuom7X+K6Db1IsRkL3ixDKPjky+FPFTeieB+yhoAicv9+ cryA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=ge39/ksXjVJRxTMyLOCFBx3IqHqkh4aLwvflstnTRbI=; b=DFsASmYNzyfu9RhH0QdaYKqnQkyuwQY0q4VWZ1nvuzmuGu723W9fRNaSc8h05fGunL lCLU3HCqyXysIUQqbUxpklaaYIW1Ox7q83G4qJpQNx3lOZASxfYDV+GFWUTALo04Mq/+ RwsI+aYVgt7pMyhvtr1O4N1CHMZn6Ykdj6+YFs6hRUxQWn5DOxKwdw/INClMHfSRLdVT 5D9+GfTo2uaDwzZD5amIjt5/bAb//nTf1Gl5N0DkQEc5g8Mjd9cs00DvQjje0wSpAb0F Z4rM8+zhmaudcl8LuBFORiJFjcmYLSGxTqkACH2grKgw+0IjxnDfuxzDVadAtyNmvSFs J+Jg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q11si19293765pgv.595.2019.02.21.01.52.45; Thu, 21 Feb 2019 01:53:00 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727765AbfBUJvx (ORCPT + 99 others); Thu, 21 Feb 2019 04:51:53 -0500 Received: from relay6-d.mail.gandi.net ([217.70.183.198]:42951 "EHLO relay6-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727682AbfBUJvu (ORCPT ); Thu, 21 Feb 2019 04:51:50 -0500 X-Originating-IP: 90.88.23.190 Received: from mc-bl-xps13.lan (aaubervilliers-681-1-81-190.w90-88.abo.wanadoo.fr [90.88.23.190]) (Authenticated sender: maxime.chevallier@bootlin.com) by relay6-d.mail.gandi.net (Postfix) with ESMTPSA id A5707C0017; Thu, 21 Feb 2019 09:51:45 +0000 (UTC) From: Maxime Chevallier To: davem@davemloft.net Cc: Maxime Chevallier , netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Andrew Lunn , Florian Fainelli , Heiner Kallweit , Russell King , linux-arm-kernel@lists.infradead.org, Antoine Tenart , thomas.petazzoni@bootlin.com, gregory.clement@bootlin.com, miquel.raynal@bootlin.com, nadavh@marvell.com, stefanc@marvell.com, mw@semihalf.com Subject: [PATCH net-next 5/7] net: phy: marvell10g: Force reading of 2.5/5G Date: Thu, 21 Feb 2019 10:51:26 +0100 Message-Id: <20190221095128.28188-6-maxime.chevallier@bootlin.com> X-Mailer: git-send-email 2.19.2 In-Reply-To: <20190221095128.28188-1-maxime.chevallier@bootlin.com> References: <20190221095128.28188-1-maxime.chevallier@bootlin.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org As per 802.3bz, if bit 14 of (1.11) "PMA Extended Abilities" indicates whether or not we should read register (1.21) "2.52/5G PMA Extended Abilities", which contains information on the support of 2.5GBASET and 5GBASET. After testing on several variants of PHYS of this family, it appears that bit 14 in (1.11) isn't always set when it should be. PHYs 88X3310 (on MacchiatoBin) and 88E2010 do support 2.5G and 5GBASET, but don't have 1.11.14 set. Their register 1.21 is filled with the correct values, indicating 2.5G and 5G support. PHYs 88E2110 do have their 1.11.14 bit set, as it should. Signed-off-by: Maxime Chevallier --- drivers/net/phy/marvell10g.c | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/drivers/net/phy/marvell10g.c b/drivers/net/phy/marvell10g.c index 9323bcf15dbd..c48669d50653 100644 --- a/drivers/net/phy/marvell10g.c +++ b/drivers/net/phy/marvell10g.c @@ -27,6 +27,9 @@ #include #include +#define MV_PHY_ALASKA_NBT_QUIRK_MASK 0xfffffffe +#define MV_PHY_ALASKA_NBT_QUIRK_REV (MARVELL_PHY_ID_88X3310 | 0xa) + enum { MV_PCS_BASE_T = 0x0000, MV_PCS_BASE_R = 0x1000, @@ -231,6 +234,23 @@ static int mv3310_resume(struct phy_device *phydev) return mv3310_hwmon_config(phydev, true); } +/* Some PHYs in the Alaska family such as the 88X3310 and the 88E2010 + * don't set bit 14 in PMA Extended Abilities (1.11), although they do + * support 2.5GBASET and 5GBASET. For these models, we can still read their + * 2.5G/5G extended abilities register (1.21). We detect these models based on + * the PMA device identifier, with a mask matching models known to have this + * issue + */ +static bool mv3310_has_pma_ngbaset_quirk(struct phy_device *phydev) +{ + if (!(phydev->c45_ids.devices_in_package & MDIO_DEVS_PMAPMD)) + return false; + + /* Only some revisions of the 88X3310 family PMA seem to be impacted */ + return (phydev->c45_ids.device_ids[MDIO_MMD_PMAPMD] & + MV_PHY_ALASKA_NBT_QUIRK_MASK) == MV_PHY_ALASKA_NBT_QUIRK_REV; +} + static int mv3310_config_init(struct phy_device *phydev) { /* Check that the PHY interface type is compatible */ @@ -261,6 +281,21 @@ static int mv3310_get_features(struct phy_device *phydev) if (ret) return ret; + if (mv3310_has_pma_ngbaset_quirk(phydev)) { + val = phy_read_mmd(phydev, MDIO_MMD_PMAPMD, + MDIO_PMA_NG_EXTABLE); + if (val < 0) + return val; + + linkmode_mod_bit(ETHTOOL_LINK_MODE_2500baseT_Full_BIT, + phydev->supported, + val & MDIO_PMA_NG_EXTABLE_2_5GBT); + + linkmode_mod_bit(ETHTOOL_LINK_MODE_5000baseT_Full_BIT, + phydev->supported, + val & MDIO_PMA_NG_EXTABLE_5GBT); + } + return 0; } -- 2.19.2