Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp424540imu; Wed, 12 Dec 2018 20:32:10 -0800 (PST) X-Google-Smtp-Source: AFSGD/Wr6wGxCGkJAjdh7EzLD5ZlPF85IslfovkT9eHkHI1TdV59OAEI2QypI8DP1I4Ive4bkWXy X-Received: by 2002:a62:c302:: with SMTP id v2mr22962220pfg.155.1544675530527; Wed, 12 Dec 2018 20:32:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544675530; cv=none; d=google.com; s=arc-20160816; b=EMCaJEcY4iqCbPQT/ALXvjyl+rec7Q+LaovKVDnfDn/0+HOVw6987sGIlescxTKptv nOxnh79C2npTnXVHmLq8DGDvTV6V1u+Af6jvyIdPBvFmBV8mb3Bxx2IZUjgnf7jbPv/z jepHnY7UhfienIWgMEETpVZvxJ1XfKNBvZDKRXLcoeJWapPm/P0+wRsyLs22uoXkoo7k VVNAgg2xYMxtBCFcguIe06crPUNxeBSuKIdCcblXgpNS/l05WHSQeQrPxzm7VPo2sqDX A78OTPkv6kOmSpjgEzxKulcx9oJKOHZvlwC+U6KwrZkwKvamHmPVTXDrp4SEJ5IaUGFX JADA== 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 :dkim-signature; bh=4tmnTJR5f+/310WDKr/9+iIWca8hpK+zDQZlsR379KY=; b=eFU/XEvqDv5rXeMBTOC1z7Bn22kEocqAW29T9ml8vHmWha/vhSds+Z3RmQXMoFyIIq oFN4v2N8/EV/jEUEAmS/trQrCm45RHN0ujxKdVxnfUujrzRUos9qAk9HgLeiUNm5HWNa T9/crzP6YniyB0QgqgvNZfxkmZcVBOy30kB73uLEHCSkTqauVjtJHEUxMy670QdXL1j2 kB1ENe4juwHsz17P0YkQsh4xS2qCmqG886Xk15j6tlp0IIJjiLKGR1Ppapm0MsgBWdTp 2vsgZ7HmCGfTgzncLGTu4FR7hNn5yUaA1G8xxP3/zKUS8lJVVO82HoUh7BokUwVihlk2 I0mQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=O3pfzGe1; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j34si634258pgj.557.2018.12.12.20.31.56; Wed, 12 Dec 2018 20:32:10 -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; dkim=pass header.i=@kernel.org header.s=default header.b=O3pfzGe1; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728297AbeLMEab (ORCPT + 99 others); Wed, 12 Dec 2018 23:30:31 -0500 Received: from mail.kernel.org ([198.145.29.99]:43352 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727115AbeLMEa3 (ORCPT ); Wed, 12 Dec 2018 23:30:29 -0500 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 5FA7120879; Thu, 13 Dec 2018 04:30:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1544675428; bh=j+nFhipR8gsIQnF7hfYPS7wyNgp46yMvpxGdr+deyMs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=O3pfzGe1Dm5HoRjGFnguRvA5ek2mjpCKVhreUXkJABE6OvMHS9NkRM8T2hNyCkhP+ Mzk6UtpSus4ah8YJClLYJdUopnMU545XZPNV0IJFjJmCgLq8ik/xC1VSP+thmsSso7 u2IxJcxq2/eMfzbGcDnAeN7g+8lwRDcv1L1faHoY= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Baruch Siach , Maxime Chevallier , Antoine Tenart , "David S . Miller" , Sasha Levin , netdev@vger.kernel.org Subject: [PATCH AUTOSEL 4.19 57/73] net: mvpp2: fix phylink handling of invalid PHY modes Date: Wed, 12 Dec 2018 23:28:22 -0500 Message-Id: <20181213042838.75160-57-sashal@kernel.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181213042838.75160-1-sashal@kernel.org> References: <20181213042838.75160-1-sashal@kernel.org> MIME-Version: 1.0 X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Baruch Siach [ Upstream commit 0fb628f0f250c74b1023edd0ca4a57c8b35b9b2c ] The .validate phylink callback should empty the supported bitmap when the interface mode is invalid. Cc: Maxime Chevallier Cc: Antoine Tenart Reported-by: Russell King Signed-off-by: Baruch Siach Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- .../net/ethernet/marvell/mvpp2/mvpp2_main.c | 33 ++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) diff --git a/drivers/net/ethernet/marvell/mvpp2/mvpp2_main.c b/drivers/net/ethernet/marvell/mvpp2/mvpp2_main.c index 1b3b64fea038..6320e080b831 100644 --- a/drivers/net/ethernet/marvell/mvpp2/mvpp2_main.c +++ b/drivers/net/ethernet/marvell/mvpp2/mvpp2_main.c @@ -4262,8 +4262,27 @@ static void mvpp2_phylink_validate(struct net_device *dev, unsigned long *supported, struct phylink_link_state *state) { + struct mvpp2_port *port = netdev_priv(dev); __ETHTOOL_DECLARE_LINK_MODE_MASK(mask) = { 0, }; + /* Invalid combinations */ + switch (state->interface) { + case PHY_INTERFACE_MODE_10GKR: + case PHY_INTERFACE_MODE_XAUI: + if (port->gop_id != 0) + goto empty_set; + break; + case PHY_INTERFACE_MODE_RGMII: + case PHY_INTERFACE_MODE_RGMII_ID: + case PHY_INTERFACE_MODE_RGMII_RXID: + case PHY_INTERFACE_MODE_RGMII_TXID: + if (port->gop_id == 0) + goto empty_set; + break; + default: + break; + } + phylink_set(mask, Autoneg); phylink_set_port_modes(mask); phylink_set(mask, Pause); @@ -4271,6 +4290,7 @@ static void mvpp2_phylink_validate(struct net_device *dev, switch (state->interface) { case PHY_INTERFACE_MODE_10GKR: + case PHY_INTERFACE_MODE_XAUI: case PHY_INTERFACE_MODE_NA: phylink_set(mask, 10000baseCR_Full); phylink_set(mask, 10000baseSR_Full); @@ -4279,7 +4299,11 @@ static void mvpp2_phylink_validate(struct net_device *dev, phylink_set(mask, 10000baseER_Full); phylink_set(mask, 10000baseKR_Full); /* Fall-through */ - default: + case PHY_INTERFACE_MODE_RGMII: + case PHY_INTERFACE_MODE_RGMII_ID: + case PHY_INTERFACE_MODE_RGMII_RXID: + case PHY_INTERFACE_MODE_RGMII_TXID: + case PHY_INTERFACE_MODE_SGMII: phylink_set(mask, 10baseT_Half); phylink_set(mask, 10baseT_Full); phylink_set(mask, 100baseT_Half); @@ -4291,11 +4315,18 @@ static void mvpp2_phylink_validate(struct net_device *dev, phylink_set(mask, 1000baseT_Full); phylink_set(mask, 1000baseX_Full); phylink_set(mask, 2500baseX_Full); + break; + default: + goto empty_set; } bitmap_and(supported, supported, mask, __ETHTOOL_LINK_MODE_MASK_NBITS); bitmap_and(state->advertising, state->advertising, mask, __ETHTOOL_LINK_MODE_MASK_NBITS); + return; + +empty_set: + bitmap_zero(supported, __ETHTOOL_LINK_MODE_MASK_NBITS); } static void mvpp22_xlg_link_state(struct mvpp2_port *port, -- 2.19.1