Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp97114pxv; Fri, 30 Jul 2021 20:05:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzOhko+RiQbR4IqckZ7jETFsbvd/Op7VAKJlhyi/+bbHVnfCjPrSByrDsn7hWulTaSMKuOb X-Received: by 2002:a02:cce6:: with SMTP id l6mr4642319jaq.114.1627700738426; Fri, 30 Jul 2021 20:05:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627700738; cv=none; d=google.com; s=arc-20160816; b=V00jpyNvvXI2fmSh+uolQRIB75QbDNPlIKyXsvmnM+vSHgi6i0oNFrSN1kdVgBliQg jfUrILSfqRWOoMkL7/zv3nZtK39SuDJn25R1fu0fhHA7lXwXPPFm+ezWg0uObe9ZVosq 7O0iYaLPpkQMQJQ0AIY6zKylO/n3SQ9EmzshwjxljJzFiM52gbt5oQTzxcm8K084Tz+E RfMGmZj7naX3an9rCEY6SvWyir75iWUstb+OUH77AND1QvT8r7Nv5nDosgOSXm43Hvya oZXmZhMGy77wHmqxlp2Ia6AO44JpG/xNQoR8uwI5RJGcSmtjhJvlkYgzawnpVslT23vi KD8Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:feedback-id:content-transfer-encoding :mime-version:message-id:date:subject:cc:to:from; bh=RKUx0DZDHl+QT82AKdB1bKLQQIc7JYc9HA0PFdH3osQ=; b=pHfVwFiA4czIYTiNRpaTTGsqiexS4PmuxOeEdNJXsKhTDBK5+vPbdqyslNFJ7NY/g8 QNrOUHVsqAB6G1EZ6TO+TGhbPrcZXgQwyvYJiExZ2MWa8V9GZdJRgckEVO5XN5i8TJiY VKF4r36NldyhxkummxS5kV377x1HEJwz+PPZORish91XMpDCQqRIhHTWfZk6uLpV1WUo XZa2PgT+W3DJ+is5SNwZNtK6sklkxs2Y/54cA6i7JgxBV6CkRVUFzgMabXmYxTnOLN/L +6XJzB+8fXOMiqQxRriO2wmoisYUMXZmlDdpUtfWDu5iuLeVflZQBxSbCOibk5R3lQQ0 TQqQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 15si4251469ilz.158.2021.07.30.20.05.26; Fri, 30 Jul 2021 20:05:38 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231453AbhGaDEw (ORCPT + 99 others); Fri, 30 Jul 2021 23:04:52 -0400 Received: from smtpbg704.qq.com ([203.205.195.105]:37614 "EHLO smtpproxy21.qq.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S231285AbhGaDEw (ORCPT ); Fri, 30 Jul 2021 23:04:52 -0400 X-QQ-mid: bizesmtp34t1627700679tx3105p6 Received: from localhost.localdomain (unknown [117.152.154.62]) by esmtp6.qq.com (ESMTP) with id ; Sat, 31 Jul 2021 11:04:37 +0800 (CST) X-QQ-SSF: 0140000000200050B000B00A0000000 X-QQ-FEAT: mrYqqQu6MtHX06+OAGTAWFBFQ7MmCD7WcfnU/eu4WLDlXI1MVsqi06CaJt8SB zUBGGK3yL/+5Wb9gyf4ITJ67gVybg809QdB6/hNs6b9iXbhmwKSSCFAAc9TGAymqhNIyezR NCAACa/c4ntdVChdwzQn48QudwrB0mp+ZvRR9hOVh5D4097e7ZirZNfkNbBdfzVV4m3hIcb FufSraCMkUkP83kqrqEDjZBofkJNwzWoLt0B+/l+fZUKJWH7ot10DxKqRP77VgCFJoTpfZy 006ZP5hWIWhvGO6v48zXSIxZNDTx1U5fCpnyRvqhoBO4Hx9LGdFHNzWToKor6W2MqEyyLFJ /LPPENJ1K7sevqcm1unEy3nzTFMdQ== X-QQ-GoodBg: 2 From: Hao Chen To: peppe.cavallaro@st.com Cc: alexandre.torgue@foss.st.com, joabreu@synopsys.com, davem@davemloft.net, kuba@kernel.org, mcoquelin.stm32@gmail.com, linux@armlinux.org.uk, netdev@vger.kernel.org, linux-stm32@st-md-mailman.stormreply.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Hao Chen Subject: [net,v7] net: stmmac: fix 'ethtool -P' return -EBUSY Date: Sat, 31 Jul 2021 11:04:36 +0800 Message-Id: <20210731030436.24666-1-chenhaoa@uniontech.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-QQ-SENDSIZE: 520 Feedback-ID: bizesmtp:uniontech.com:qybgforeign:qybgforeign7 X-QQ-Bgrelay: 1 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org I want to get permanent MAC address when the card is down. And I think it is more convenient to get statistics in the down state by 'ethtool -S'. But current all of the ethool command return -EBUSY. I don't think we should detect that the network card is up in '. Begin', which will cause that all the ethtool commands can't be used when the network card is down. If some ethtool commands can only be used in the up state, check it in the corresponding ethool OPS function is better. This is too rude and unreasonable. I have checked the '.begin' implementation of other drivers, most of which support the submission of NIC driver for the first time. They are too old to know why '.begin' is implemented. I suspect that they have not noticed the usage of '.begin'. Fixes: 47dd7a540b8a ("net: add support for STMicroelectronics Ethernet controllers.") Compile-tested on arm64. Tested on an arm64 system with an on-board STMMAC chip. Changes v6 ... v7: - fix arg type error of 'dev' to 'priv->device'. Changes v5 ... v6: - The 4.19.90 kernel not support pm_runtime, so implemente '.begin' and '.complete' again. Add return value check of pm_runtime function. Changes v4 ... v5: - test the '.begin' will return -13 error on my machine based on 4.19.90 kernel. The platform driver does not supported pm_runtime. So remove the implementation of '.begin' and '.complete'. Changes v3 ... v4: - implement '.complete' ethtool OPS. Changes v2 ... v3: - add linux/pm_runtime.h head file. Changes v1 ... v2: - fix spell error of dev. Signed-off-by: Hao Chen --- .../ethernet/stmicro/stmmac/stmmac_ethtool.c | 21 +++++++++++++------ 1 file changed, 15 insertions(+), 6 deletions(-) diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_ethtool.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_ethtool.c index d0ce608b81c3..fd5b68f6bf53 100644 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_ethtool.c +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_ethtool.c @@ -12,8 +12,9 @@ #include #include #include -#include #include +#include +#include #include #include "stmmac.h" @@ -410,11 +411,18 @@ static void stmmac_ethtool_setmsglevel(struct net_device *dev, u32 level) } -static int stmmac_check_if_running(struct net_device *dev) +static int stmmac_ethtool_begin(struct net_device *dev) { - if (!netif_running(dev)) - return -EBUSY; - return 0; + struct stmmac_priv *priv = netdev_priv(dev); + + return pm_runtime_resume_and_get(priv->device); +} + +static void stmmac_ethtool_complete(struct net_device *dev) +{ + struct stmmac_priv *priv = netdev_priv(dev); + + pm_runtime_put(priv->device); } static int stmmac_ethtool_get_regs_len(struct net_device *dev) @@ -1073,7 +1081,8 @@ static int stmmac_set_tunable(struct net_device *dev, static const struct ethtool_ops stmmac_ethtool_ops = { .supported_coalesce_params = ETHTOOL_COALESCE_USECS | ETHTOOL_COALESCE_MAX_FRAMES, - .begin = stmmac_check_if_running, + .begin = stmmac_ethtool_begin, + .complete = stmmac_ethtool_complete, .get_drvinfo = stmmac_ethtool_getdrvinfo, .get_msglevel = stmmac_ethtool_getmsglevel, .set_msglevel = stmmac_ethtool_setmsglevel, -- 2.20.1