From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 6ED4ACAC592 for ; Fri, 19 Sep 2025 12:26:08 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:References:In-Reply-To:From:Cc:To: Subject:MIME-Version:Date:Message-ID:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=eZtC3rmBqvUbugm/RJargSqqk6M41FNW668NJ9LZQSc=; b=QxqsuHSDOGhU7V +lpQESn9Iw18rjX8Yi6Fs2MtXHPGILfCyeKrMZBKZkETKfS66NqwJUiDCKog6M4A97nNcXDaiVvP6 5Z2X/0LTAd98vqul0j6nVYVL6Wu7sBtzXMMLtHxTEAU/BUlNasCFnmSlAtYiLEahbZihgHtBGghsB J5eKzkSIXCGB2fQAwbLrWF9by46BtHFSxrxYFScrG4c1sqcutZ2Xi4b5eWGGEJhL4MEVUpX3MI2B3 5LlEDMwPESEqO9fU+cc+nx4mkeSfBq23LBd0jhhmfun3B5ZS4+CsDJr9p2cqjEg+WxaEreoPtUruK AdZhrF7gERjKnU5GIVoQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98.2 #2 (Red Hat Linux)) id 1uzaBb-00000002p3s-36uf; Fri, 19 Sep 2025 12:25:59 +0000 Received: from mailout2.w1.samsung.com ([210.118.77.12]) by bombadil.infradead.org with esmtps (Exim 4.98.2 #2 (Red Hat Linux)) id 1uzaBX-00000002p3J-0r2a for linux-riscv@lists.infradead.org; Fri, 19 Sep 2025 12:25:58 +0000 Received: from eucas1p2.samsung.com (unknown [182.198.249.207]) by mailout2.w1.samsung.com (KnoxPortal) with ESMTP id 20250919122548euoutp0292a30b3d26f4e636a0191d6508f473df~mrqm60MYk0313803138euoutp02f for ; Fri, 19 Sep 2025 12:25:48 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 mailout2.w1.samsung.com 20250919122548euoutp0292a30b3d26f4e636a0191d6508f473df~mrqm60MYk0313803138euoutp02f DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=samsung.com; s=mail20170921; t=1758284748; bh=xSKIjPyrA9OEriZopMFlNAyxpcs3It57Viautl04tXI=; h=Date:Subject:To:Cc:From:In-Reply-To:References:From; b=F+Xk3glO2cgewx7e1iKp9JX1qLwGgul+qkbyUSnqJFUujLqQCD+JHqtjvA6C3plYu tb6XPaK8AiHnvh314NhvSLRtAY4447tqqdUgXWoNLeXPOAmqkxv+8RUKDUaNPnreiy X7XwGpQUJq2P149JjEd996iP8UKxN6e0DQeU8y+U= Received: from eusmtip2.samsung.com (unknown [203.254.199.222]) by eucas1p1.samsung.com (KnoxPortal) with ESMTPA id 20250919122548eucas1p1ef58c5c747bee71acd5f9d6476e7c29c~mrqmcuafh2548325483eucas1p1m; Fri, 19 Sep 2025 12:25:48 +0000 (GMT) Received: from [106.210.134.192] (unknown [106.210.134.192]) by eusmtip2.samsung.com (KnoxPortal) with ESMTPA id 20250919122546eusmtip2896ff33c135295219ae1f797110c7a94~mrqk2ipmP1691216912eusmtip2-; Fri, 19 Sep 2025 12:25:46 +0000 (GMT) Message-ID: <7605453a-ac62-497b-b77a-76d73e9a6741@samsung.com> Date: Fri, 19 Sep 2025 14:25:45 +0200 MIME-Version: 1.0 User-Agent: Betterbird (Windows) Subject: Re: [PATCH net-next] net: spacemit: Make stats_lock softirq-safe To: Vivian Wang , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Yixun Lan , Maxime Chevallier , Troy Mitchell , Vadim Fedorenko Cc: netdev@vger.kernel.org, linux-riscv@lists.infradead.org, spacemit@lists.linux.dev, linux-kernel@vger.kernel.org, Vivian Wang Content-Language: en-US From: Marek Szyprowski In-Reply-To: <20250919-k1-ethernet-fix-lock-v1-1-c8b700aa4954@iscas.ac.cn> X-CMS-MailID: 20250919122548eucas1p1ef58c5c747bee71acd5f9d6476e7c29c X-Msg-Generator: CA X-RootMTR: 20250919120522eucas1p224c42d0cc2a59903d85e6c80dfdfa727 X-EPHeader: CA X-CMS-RootMailID: 20250919120522eucas1p224c42d0cc2a59903d85e6c80dfdfa727 References: <20250919-k1-ethernet-fix-lock-v1-1-c8b700aa4954@iscas.ac.cn> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250919_052556_614444_A919FBA4 X-CRM114-Status: GOOD ( 24.23 ) X-BeenThere: linux-riscv@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-riscv" Errors-To: linux-riscv-bounces+linux-riscv=archiver.kernel.org@lists.infradead.org On 19.09.2025 14:04, Vivian Wang wrote: > While most of the statistics functions (emac_get_stats64() and such) are > called with softirqs enabled, emac_stats_timer() is, as its name > suggests, also called from a timer, i.e. called in softirq context. > > All of these take stats_lock. Therefore, make stats_lock softirq-safe by > changing spin_lock() into spin_lock_bh() for the functions that get > statistics. > > Also, instead of directly calling emac_stats_timer() in emac_up() and > emac_resume(), set the timer to trigger instead, so that > emac_stats_timer() is only called from the timer. It will keep using > spin_lock(). > > This fixes a lockdep warning, and potential deadlock when stats_timer is > triggered in the middle of getting statistics. > > Fixes: bfec6d7f2001 ("net: spacemit: Add K1 Ethernet MAC") > Reported-by: Marek Szyprowski > Closes: https://lore.kernel.org/all/a52c0cf5-0444-41aa-b061-a0a1d72b02fe@samsung.com/ > Signed-off-by: Vivian Wang Tested-by: Marek Szyprowski > --- > Thanks a lot for catching this, Marek! > --- > drivers/net/ethernet/spacemit/k1_emac.c | 30 +++++++++++++++--------------- > 1 file changed, 15 insertions(+), 15 deletions(-) > > diff --git a/drivers/net/ethernet/spacemit/k1_emac.c b/drivers/net/ethernet/spacemit/k1_emac.c > index 928fea02198c3754f63a7b33fc25c5dd8c2b59f9..e1c5faff3b71c7d4ceba2ea194d9c888f0e71b70 100644 > --- a/drivers/net/ethernet/spacemit/k1_emac.c > +++ b/drivers/net/ethernet/spacemit/k1_emac.c > @@ -135,7 +135,7 @@ struct emac_priv { > bool flow_control_autoneg; > u8 flow_control; > > - /* Hold while touching hardware statistics */ > + /* Softirq-safe, hold while touching hardware statistics */ > spinlock_t stats_lock; > }; > > @@ -1239,7 +1239,7 @@ static void emac_get_stats64(struct net_device *dev, > /* This is the only software counter */ > storage->tx_dropped = emac_get_stat_tx_drops(priv); > > - spin_lock(&priv->stats_lock); > + spin_lock_bh(&priv->stats_lock); > > emac_stats_update(priv); > > @@ -1261,7 +1261,7 @@ static void emac_get_stats64(struct net_device *dev, > storage->rx_missed_errors = rx_stats->stats.rx_drp_fifo_full_pkts; > storage->rx_missed_errors += rx_stats->stats.rx_truncate_fifo_full_pkts; > > - spin_unlock(&priv->stats_lock); > + spin_unlock_bh(&priv->stats_lock); > } > > static void emac_get_rmon_stats(struct net_device *dev, > @@ -1275,7 +1275,7 @@ static void emac_get_rmon_stats(struct net_device *dev, > > *ranges = emac_rmon_hist_ranges; > > - spin_lock(&priv->stats_lock); > + spin_lock_bh(&priv->stats_lock); > > emac_stats_update(priv); > > @@ -1294,7 +1294,7 @@ static void emac_get_rmon_stats(struct net_device *dev, > rmon_stats->hist[5] = rx_stats->stats.rx_1024_1518_pkts; > rmon_stats->hist[6] = rx_stats->stats.rx_1519_plus_pkts; > > - spin_unlock(&priv->stats_lock); > + spin_unlock_bh(&priv->stats_lock); > } > > static void emac_get_eth_mac_stats(struct net_device *dev, > @@ -1307,7 +1307,7 @@ static void emac_get_eth_mac_stats(struct net_device *dev, > tx_stats = &priv->tx_stats; > rx_stats = &priv->rx_stats; > > - spin_lock(&priv->stats_lock); > + spin_lock_bh(&priv->stats_lock); > > emac_stats_update(priv); > > @@ -1325,7 +1325,7 @@ static void emac_get_eth_mac_stats(struct net_device *dev, > mac_stats->FramesAbortedDueToXSColls = > tx_stats->stats.tx_excessclsn_pkts; > > - spin_unlock(&priv->stats_lock); > + spin_unlock_bh(&priv->stats_lock); > } > > static void emac_get_pause_stats(struct net_device *dev, > @@ -1338,14 +1338,14 @@ static void emac_get_pause_stats(struct net_device *dev, > tx_stats = &priv->tx_stats; > rx_stats = &priv->rx_stats; > > - spin_lock(&priv->stats_lock); > + spin_lock_bh(&priv->stats_lock); > > emac_stats_update(priv); > > pause_stats->tx_pause_frames = tx_stats->stats.tx_pause_pkts; > pause_stats->rx_pause_frames = rx_stats->stats.rx_pause_pkts; > > - spin_unlock(&priv->stats_lock); > + spin_unlock_bh(&priv->stats_lock); > } > > /* Other statistics that are not derivable from standard statistics */ > @@ -1393,14 +1393,14 @@ static void emac_get_ethtool_stats(struct net_device *dev, > u64 *rx_stats = (u64 *)&priv->rx_stats; > int i; > > - spin_lock(&priv->stats_lock); > + spin_lock_bh(&priv->stats_lock); > > emac_stats_update(priv); > > for (i = 0; i < ARRAY_SIZE(emac_ethtool_rx_stats); i++) > data[i] = rx_stats[emac_ethtool_rx_stats[i].offset]; > > - spin_unlock(&priv->stats_lock); > + spin_unlock_bh(&priv->stats_lock); > } > > static int emac_ethtool_get_regs_len(struct net_device *dev) > @@ -1769,7 +1769,7 @@ static int emac_up(struct emac_priv *priv) > > netif_start_queue(ndev); > > - emac_stats_timer(&priv->stats_timer); > + mod_timer(&priv->stats_timer, jiffies); > > return 0; > > @@ -1807,14 +1807,14 @@ static int emac_down(struct emac_priv *priv) > > /* Update and save current stats, see emac_stats_update() for usage */ > > - spin_lock(&priv->stats_lock); > + spin_lock_bh(&priv->stats_lock); > > emac_stats_update(priv); > > priv->tx_stats_off = priv->tx_stats; > priv->rx_stats_off = priv->rx_stats; > > - spin_unlock(&priv->stats_lock); > + spin_unlock_bh(&priv->stats_lock); > > pm_runtime_put_sync(&pdev->dev); > return 0; > @@ -2111,7 +2111,7 @@ static int emac_resume(struct device *dev) > > netif_device_attach(ndev); > > - emac_stats_timer(&priv->stats_timer); > + mod_timer(&priv->stats_timer, jiffies); > > return 0; > } > > --- > base-commit: 315f423be0d1ebe720d8fd4fa6bed68586b13d34 > change-id: 20250919-k1-ethernet-fix-lock-c99681a9aa5d > > Best regards, Best regards -- Marek Szyprowski, PhD Samsung R&D Institute Poland _______________________________________________ linux-riscv mailing list linux-riscv@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-riscv