Received: by 10.213.65.68 with SMTP id h4csp1811769imn; Thu, 29 Mar 2018 11:29:00 -0700 (PDT) X-Google-Smtp-Source: AIpwx48dOHA+tvaAwTPMKbjxfw6BlmUJ25L6H2xloJv/33875sDhX5R+k1twpIk//6L8A97SFBYH X-Received: by 10.98.13.23 with SMTP id v23mr7294493pfi.202.1522348140633; Thu, 29 Mar 2018 11:29:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522348140; cv=none; d=google.com; s=arc-20160816; b=FdTmp5EyIirdNAJqxZMJETOSnP1t9WoJQFC6dsLiwXsLKWVDjV7FWhRL0AIxWBDDDZ oSPzumnX5WXX70v4y7ZMge/FNdzbIXwM6cp59LIkIiascfPCcESKpU0q4XU87ivbD46M 33M/B5nE93ZR8WRN+L60GIJ6PHk9G2pl5B/FiPCYDXuUMNX9TqsxoTTf1RoRDemuLzvd 4NSxJYvSFFy/N/I3YfZELbfv+EjlumrQLRqX8lc9bFD9zemn753ge0tpAmJWztmZre6T DWYwIDoUmCMEnU6A423pzly2ii6f6kczhF81icPY46jNixQ3NIKWHS/bPdqWcqNg8/eO iRZA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=XxrIJSwxkZJXDur/xuS1eKPUxbkMmjql1ESX1cgzRao=; b=BjDDFyxd+TBWcl6ZCDPBmf312rVL4X2xLU6fbrMwfdHP/AUSPI5fSVkrqT8HUgwa1r frQLWGwcAeIWcxyw84KMUzs/Qp20i3vqJxjjDKuuCFhRxrhXMwKYzXwQ6fIZrbonNgcV XoZtIDfHOuPUQUFIJXceO0hzCJ2AWVOEP2AjG6cYm2cb7xNbYYmcS568Y4BKUT7SlDsi z3B2ZuPd0i6bRpsBE+qliVBm5sPhvmw+uL8tQlqFeV/WT9bNkjpWAHkYpRcaHSWCslo9 nUx7EcgS/eK6vgviZJHAvkSAWEbSEQvUUcnqB3pG02rzzTi6Kfwz0Sxc3xMSaiZooB4q zhnQ== 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 b60-v6si6364603plc.75.2018.03.29.11.28.46; Thu, 29 Mar 2018 11:29:00 -0700 (PDT) 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 S1753419AbeC2S1p (ORCPT + 99 others); Thu, 29 Mar 2018 14:27:45 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:58886 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752961AbeC2SEq (ORCPT ); Thu, 29 Mar 2018 14:04:46 -0400 Received: from localhost (LFbn-1-12247-202.w90-92.abo.wanadoo.fr [90.92.61.202]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 2DC16C48; Thu, 29 Mar 2018 18:04:46 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Florian Fainelli , Andrew Lunn , Grygorii Strashko , "David S. Miller" Subject: [PATCH 4.14 05/43] net: phy: relax error checking when creating sysfs link netdev->phydev Date: Thu, 29 Mar 2018 20:00:00 +0200 Message-Id: <20180329175730.675306460@linuxfoundation.org> X-Mailer: git-send-email 2.16.3 In-Reply-To: <20180329175730.190353692@linuxfoundation.org> References: <20180329175730.190353692@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Grygorii Strashko [ Upstream commit 4414b3ed74be0e205e04e12cd83542a727d88255 ] Some ethernet drivers (like TI CPSW) may connect and manage >1 Net PHYs per one netdevice, as result such drivers will produce warning during system boot and fail to connect second phy to netdevice when PHYLIB framework will try to create sysfs link netdev->phydev for second PHY in phy_attach_direct(), because sysfs link with the same name has been created already for the first PHY. As result, second CPSW external port will became unusable. Fix it by relaxing error checking when PHYLIB framework is creating sysfs link netdev->phydev in phy_attach_direct(), suppressing warning by using sysfs_create_link_nowarn() and adding error message instead. After this change links (phy->netdev and netdev->phy) creation failure is not fatal any more and system can continue working, which fixes TI CPSW issue. Cc: Florian Fainelli Cc: Andrew Lunn Fixes: a3995460491d ("net: phy: Relax error checking on sysfs_create_link()") Signed-off-by: Grygorii Strashko Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/phy/phy_device.c | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) --- a/drivers/net/phy/phy_device.c +++ b/drivers/net/phy/phy_device.c @@ -999,10 +999,17 @@ int phy_attach_direct(struct net_device err = sysfs_create_link(&phydev->mdio.dev.kobj, &dev->dev.kobj, "attached_dev"); if (!err) { - err = sysfs_create_link(&dev->dev.kobj, &phydev->mdio.dev.kobj, - "phydev"); - if (err) - goto error; + err = sysfs_create_link_nowarn(&dev->dev.kobj, + &phydev->mdio.dev.kobj, + "phydev"); + if (err) { + dev_err(&dev->dev, "could not add device link to %s err %d\n", + kobject_name(&phydev->mdio.dev.kobj), + err); + /* non-fatal - some net drivers can use one netdevice + * with more then one phy + */ + } phydev->sysfs_links = true; }