Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp2825061pxb; Mon, 1 Nov 2021 02:35:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwCYMG7dPU6To0EEkaTZM+teb891hf2TgSEu+QYtmdO1BJhOJoMgppKQ6my7X9Iy9wBqd30 X-Received: by 2002:a50:da4e:: with SMTP id a14mr39620459edk.154.1635759349002; Mon, 01 Nov 2021 02:35:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1635759348; cv=none; d=google.com; s=arc-20160816; b=widke2E958nMUNVr0Autyz92DqoFGt608Uys3QFKPUwFVg9RhHruYpX/CAx3Hma8oU gNT3ecR2NTMnbmWEoVMYBbiukp2ONm/2P2qXT26TH7d4YzTDyg8WpNty1rKKKvdXExAa oQ00RtoDAPMfoaTXvkXaryfwQu22YCQ5ClVpG02NgN0rcZyTO1Mn6pq8rPdPhyIlaDxK u8lhtW0IfZeYne9YE+DyklfIcPXN9i1DF224oAg282HnNbGgfpvOBVIScgxNa2nz7mo3 6crAwXZnrzwoxki87EriJPkeab1fAm4Igpf3YDzPCPYtjJi2jD6NBphqmGeOjWAo9vFq dn8A== 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=wQ+0YUN7szGIdmxoQ6yEmJqflgrMjq+OjtCtXF9aq1Y=; b=p9vfOjSf4O06DcPXDs/TPHGbEN37B0cyYKDBYRZGrEes//WhTbygffJ1T8FzQaT/kf 6QkfeJYoUBjsmor/IpXFf/mo2TaJlnYZ4oGljKOc1ph7clbFJU0I4UL/ILSOie7XjQov SlgUyWM6pgr5Z+fTZZNv8P2h0MdYBUMmVquKiPxvJyJwxT/CUK/uOfxfBQFxXkxaKEYL zqzPNqfuKFBqUbvgGCnaTiyhU3N49379JQ9Bwa3yEPhTK3V/MU83XQC2L4V0wMMXa4Te nhelFd0cuuB1UTeuourNaDYF9T/QV153S0PvB9Vx4d4mJB1w/s1eD0eguJlnSAIxq47r pR3Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=NsJjcEVQ; 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 qw18si25707517ejc.681.2021.11.01.02.35.25; Mon, 01 Nov 2021 02:35:48 -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=pass header.i=@linuxfoundation.org header.s=korg header.b=NsJjcEVQ; 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 S233111AbhKAJdQ (ORCPT + 99 others); Mon, 1 Nov 2021 05:33:16 -0400 Received: from mail.kernel.org ([198.145.29.99]:37008 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232632AbhKAJaN (ORCPT ); Mon, 1 Nov 2021 05:30:13 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 6BC8561245; Mon, 1 Nov 2021 09:23:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1635758620; bh=yJCJCEjavwY8aWVwv2u5XFcUQtIJpWe2RP38w1kzVsU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=NsJjcEVQqqbrkcVEDKvuOFwI8ooZQkB2MJMtSA1WQHWLNxu0vBZEmVCUINq6E9rpD oox42a83bXyQl3ILLIQd3WO13jA7svYKjFssf6i0a2k9ErLlb42qcfqqZbUhbv9Jfh NhIMkVQeZu66daFAwlTFnbkgpfkRnaUtCPNAo/6I= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Andrew Lunn , "David S. Miller" Subject: [PATCH 5.4 39/51] phy: phy_ethtool_ksettings_get: Lock the phy for consistency Date: Mon, 1 Nov 2021 10:17:43 +0100 Message-Id: <20211101082509.760959374@linuxfoundation.org> X-Mailer: git-send-email 2.33.1 In-Reply-To: <20211101082500.203657870@linuxfoundation.org> References: <20211101082500.203657870@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: Andrew Lunn commit c10a485c3de5ccbf1fff65a382cebcb2730c6b06 upstream. The PHY structure should be locked while copying information out if it, otherwise there is no guarantee of self consistency. Without the lock the PHY state machine could be updating the structure. Fixes: 2d55173e71b0 ("phy: add generic function to support ksetting support") Signed-off-by: Andrew Lunn Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/phy/phy.c | 2 ++ 1 file changed, 2 insertions(+) --- a/drivers/net/phy/phy.c +++ b/drivers/net/phy/phy.c @@ -367,6 +367,7 @@ EXPORT_SYMBOL(phy_ethtool_ksettings_set) void phy_ethtool_ksettings_get(struct phy_device *phydev, struct ethtool_link_ksettings *cmd) { + mutex_lock(&phydev->lock); linkmode_copy(cmd->link_modes.supported, phydev->supported); linkmode_copy(cmd->link_modes.advertising, phydev->advertising); linkmode_copy(cmd->link_modes.lp_advertising, phydev->lp_advertising); @@ -383,6 +384,7 @@ void phy_ethtool_ksettings_get(struct ph cmd->base.autoneg = phydev->autoneg; cmd->base.eth_tp_mdix_ctrl = phydev->mdix_ctrl; cmd->base.eth_tp_mdix = phydev->mdix; + mutex_unlock(&phydev->lock); } EXPORT_SYMBOL(phy_ethtool_ksettings_get);