Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3618955pxb; Mon, 24 Jan 2022 13:39:11 -0800 (PST) X-Google-Smtp-Source: ABdhPJyS2afgLCuNDXujxOekv69/T30Qjr06U920pyc+olLTFcCOahiJnSN4i64zT8ZnrZ2OwvuT X-Received: by 2002:a17:902:8f94:b0:14a:cd21:ba6e with SMTP id z20-20020a1709028f9400b0014acd21ba6emr15957277plo.43.1643060351198; Mon, 24 Jan 2022 13:39:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643060351; cv=none; d=google.com; s=arc-20160816; b=I46as46DT4IsquMjtg4E4z3WVvbTXEVjL3BHnFyoOOyi/16k56ET0JZvGWy0+dnblb wOxceKiosDBHOUIX+gcVe/t7ULYQFmDPPHerYUxVr/pYEyPLaUxruPtsRFtqtXLds6/V afnxZIoXrWROgtPqyABWaFS/pVwPDppZBGeWBN/MAOmeO1OMxyrR2co1AjBQYfy0FhPT pKLGjMVXyG/hOxec6bEg2w7Sd8F18hLLjt6y3LkpaQ/1YFG2hpXGFJJAP2zU36N5hVuG IJ6C9xeE3HxsbCMOMYjp+X9x0uHW6YBFidd9fACVK178a8T6HtUR6fyWowPxdAXwKIZP 6+SA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=AQmIt790G/Ub7Tk7U0eSpwkffD/jURZQRurhxbNfhlg=; b=VvV8L6pRguZ5YWnJ/RsFripDApuaM/1TZOnM3W0cK+MccNcugDMAxT8k5SNx7qvB7u 7V2Yc4uQGmZJAV1DDvL4B36LngD8fz3xKXGHNrsDr9wgTHNFmqAvCdQEdXWniv3+rNxq QKMrBJyv3ydIijiExQKtVfd8xV3A4tbicqmza+BnN+WwK+jv1M/F1vT8AJ5RQSX4rDNu NhqaVSNpbgFE9TewwexAR1UqlESDfaM+FSDgOnykua9eWr2MBHmBbRFFUiIDO60d4y7o Uubk08VFG7AIuJbv6diPGrxx+l0+3SO/0ytI/gPohNnHftLAKbjwA/O/GpdleiKDzV93 ppDg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=Y4TdDGDP; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h7si9790684plf.337.2022.01.24.13.38.59; Mon, 24 Jan 2022 13:39:11 -0800 (PST) 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=pass header.i=@linuxfoundation.org header.s=korg header.b=Y4TdDGDP; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1450502AbiAXVUl (ORCPT + 99 others); Mon, 24 Jan 2022 16:20:41 -0500 Received: from dfw.source.kernel.org ([139.178.84.217]:45132 "EHLO dfw.source.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1441814AbiAXUvl (ORCPT ); Mon, 24 Jan 2022 15:51:41 -0500 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 6FCCF60C17; Mon, 24 Jan 2022 20:51:41 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 52F55C340E5; Mon, 24 Jan 2022 20:51:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643057500; bh=b9l0gqvoTDt6A/0QvDZYMLVha/WUwb9rjfjzdWEXvYg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Y4TdDGDPn9EkJBvFgooXFBeMFVg53dCYIP0VQEVawQONbPh3hO6iVdi2i870OXPPE oY9i1+WHGQ9wydmTVEfjHJuE3oVtOlnGNXMcZ8/CbmqZ8t4Idcvk9msKlkZKL3jGS5 DUfrxCd3jOcdUJwt3XBGuJZs9eDlxd3SZmD2tcCo= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, =?UTF-8?q?=E7=85=A7=E5=B1=B1=E5=91=A8=E4=B8=80=E9=83=8E?= , "Russell King (Oracle)" , "David S. Miller" Subject: [PATCH 5.15 834/846] net: sfp: fix high power modules without diagnostic monitoring Date: Mon, 24 Jan 2022 19:45:51 +0100 Message-Id: <20220124184129.683426948@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124184100.867127425@linuxfoundation.org> References: <20220124184100.867127425@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Russell King (Oracle) commit 5765cee119bf5a36c94d20eceb37c445508934be upstream. Commit 7cfa9c92d0a3 ("net: sfp: avoid power switch on address-change modules") unintetionally changed the semantics for high power modules without the digital diagnostics monitoring. We repeatedly attempt to read the power status from the non-existing 0xa2 address in a futile hope this failure is temporary: [ 8.856051] sfp sfp-eth3: module NTT 0000000000000000 rev 0000 sn 0000000000000000 dc 160408 [ 8.865843] mvpp2 f4000000.ethernet eth3: switched to inband/1000base-x link mode [ 8.873469] sfp sfp-eth3: Failed to read EEPROM: -5 [ 8.983251] sfp sfp-eth3: Failed to read EEPROM: -5 [ 9.103250] sfp sfp-eth3: Failed to read EEPROM: -5 We previosuly assumed such modules were powered up in the correct mode, continuing without further configuration as long as the required power class was supported by the host. Restore this behaviour, while preserving the intent of subsequent patches to avoid the "Address Change Sequence not supported" warning if we are not going to be accessing the DDM address. Fixes: 7cfa9c92d0a3 ("net: sfp: avoid power switch on address-change modules") Reported-by: 照山周一郎 Tested-by: 照山周一郎 Signed-off-by: Russell King (Oracle) Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/phy/sfp.c | 25 +++++++++++++++++++++---- 1 file changed, 21 insertions(+), 4 deletions(-) --- a/drivers/net/phy/sfp.c +++ b/drivers/net/phy/sfp.c @@ -1641,17 +1641,20 @@ static int sfp_sm_probe_for_phy(struct s static int sfp_module_parse_power(struct sfp *sfp) { u32 power_mW = 1000; + bool supports_a2; if (sfp->id.ext.options & cpu_to_be16(SFP_OPTIONS_POWER_DECL)) power_mW = 1500; if (sfp->id.ext.options & cpu_to_be16(SFP_OPTIONS_HIGH_POWER_LEVEL)) power_mW = 2000; + supports_a2 = sfp->id.ext.sff8472_compliance != + SFP_SFF8472_COMPLIANCE_NONE || + sfp->id.ext.diagmon & SFP_DIAGMON_DDM; + if (power_mW > sfp->max_power_mW) { /* Module power specification exceeds the allowed maximum. */ - if (sfp->id.ext.sff8472_compliance == - SFP_SFF8472_COMPLIANCE_NONE && - !(sfp->id.ext.diagmon & SFP_DIAGMON_DDM)) { + if (!supports_a2) { /* The module appears not to implement bus address * 0xa2, so assume that the module powers up in the * indicated mode. @@ -1668,11 +1671,25 @@ static int sfp_module_parse_power(struct } } + if (power_mW <= 1000) { + /* Modules below 1W do not require a power change sequence */ + sfp->module_power_mW = power_mW; + return 0; + } + + if (!supports_a2) { + /* The module power level is below the host maximum and the + * module appears not to implement bus address 0xa2, so assume + * that the module powers up in the indicated mode. + */ + return 0; + } + /* If the module requires a higher power mode, but also requires * an address change sequence, warn the user that the module may * not be functional. */ - if (sfp->id.ext.diagmon & SFP_DIAGMON_ADDRMODE && power_mW > 1000) { + if (sfp->id.ext.diagmon & SFP_DIAGMON_ADDRMODE) { dev_warn(sfp->dev, "Address Change Sequence not supported but module requires %u.%uW, module may not be functional\n", power_mW / 1000, (power_mW / 100) % 10);