From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id B04F623D7E3 for ; Thu, 5 Mar 2026 11:26:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=170.10.129.124 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772709981; cv=none; b=Xjb9aBljvyAYEj6nBMK9p81Dwn6oLZXfxipitI3tBe55GB40+JiG7GXxCBq0I2gFFmm/eHI5IpIE6cCatRtX0BvUAgEZ68a+9tbsBRMv5kcDXabBEIowHhKCE2FG0KgfbGZkU95mkFCmCViJYPL302iVyAur4dTHFKRq0VtntHY= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772709981; c=relaxed/simple; bh=YZF2+qbA9NLMDI3/4YuPpkKbozBNwPhHAlMxMzTX1vQ=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=Mk0nb6FI+zGTlE6mM7s9UNOEYY2kQM31Olve6e9o79VMqh5Sj0gshmyYwXduSjZhYO0/OrXE0AI4BKrqlPEMWNCH6yOvGFSaszeXe7/yqIB0n1aU0MPPtkamTO5LWzaWP555X28wXlmMu2g2kPMFW7wYVGBnu63RUUH//1Qfa3c= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=redhat.com; spf=pass smtp.mailfrom=redhat.com; dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b=NurZ0woV; dkim=pass (2048-bit key) header.d=redhat.com header.i=@redhat.com header.b=R0nBvH0v; arc=none smtp.client-ip=170.10.129.124 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=redhat.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=redhat.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b="NurZ0woV"; dkim=pass (2048-bit key) header.d=redhat.com header.i=@redhat.com header.b="R0nBvH0v" DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1772709978; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=/PDdJdydDAqY2r+QCid29LNFFApkwhWkx5ohf3cC8Sw=; b=NurZ0woVECpXwpvbQ69lV1CW7qOwRCSRwSn8vGtLRi8DhgII6kgr5lLv2k7qXpYC8HVlPD LvJmNBbfGv6VK1fcQaABoMzMy/ife/Bsqvsidf58RWzBS+BFkrFR+kDqnYvrvRHEOx5PUc bvb+qUDLbnELjvrylIXndbV3lZZwZKk= Received: from mail-wm1-f72.google.com (mail-wm1-f72.google.com [209.85.128.72]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-591-gedcwN_gOoOzvPVLeh9vSg-1; Thu, 05 Mar 2026 06:26:17 -0500 X-MC-Unique: gedcwN_gOoOzvPVLeh9vSg-1 X-Mimecast-MFC-AGG-ID: gedcwN_gOoOzvPVLeh9vSg_1772709977 Received: by mail-wm1-f72.google.com with SMTP id 5b1f17b1804b1-48071615686so62389725e9.1 for ; Thu, 05 Mar 2026 03:26:17 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=google; t=1772709976; x=1773314776; darn=vger.kernel.org; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=/PDdJdydDAqY2r+QCid29LNFFApkwhWkx5ohf3cC8Sw=; b=R0nBvH0vfPoKjFStHsWmrF7ByCS8PIlSpNc/EBNc+slFn6qstCth5x4TKFQ/LrCPD8 +nrcBe2j6facHyAMqm8o+RVkuEuqKtT1QdGqCI/l0aLROfv82OU7ZjfviQn2+T7Ooirh 2kSgh3pz92aVr5GWR2lgjCsH+SN1u4pj+eMV04uzLtKfMx51i5JiIRfIl7wVt8hz8JBQ A+DQM+htL8dVz0ZGj5eOf3InlTmRlPSJB6AVVRlruptvixsXGv5Acy5arB26nqIaOnWJ bZl7C6mZ379mlKAS/aLKQ8mXaEfZeqlzotf5HDwPhvHF2x2r40v082NrScZCLHNiL/mA KT2Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1772709976; x=1773314776; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :x-gm-gg:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=/PDdJdydDAqY2r+QCid29LNFFApkwhWkx5ohf3cC8Sw=; b=SjK4p3mvKBo9II42Cks3FuONFaudBH4puk2hT4ZpA3kOscrzb4LvmX7cSfPBYRbTFa n4oTS0hPbCHK7cYi9Uo98/AU+QWer6/uzwAP5/lNfCMuw1taHLOPkqa7CgroJEQxv9te 41jV9iEugW2dN6Em47K6sW6hiOcZTFllkkJ2/KgBtIEhJ4SW1bNPkhIhkLvnKCGa9wK6 HsI7SEZHSiUNTXhk9Sygll89HIApAiGDGLAxhX/e7WUDGWeUimh02hgy35l4hcb/kQUi xLsulg5vSeazi7T6VIMvhhCEPLcr3EUEqXvSPVJ2wYtCFarTRJMzokC9/kasfPXLc1Xn 6/Vg== X-Gm-Message-State: AOJu0YzqHu+SEiWr7QVSXGT+DTCRCZ01MskPgtoJlsusCQjwXXzJ9Bct v6hpBUipj1j1A3UtRIHGdfffqi/aX/DJtO0/2Gjo7cJmV+8KOTK2zv3KGXMrNjNoXGq0FMWy8fK Q/JZaRkUARmvmsW99AgB2tdHNGNwZnX/LdMBs73wlJXQhh9JunortHYhZLdOaqwP/L3CGDbDnTb Q7yk00qWdfk1xd5l4QGD9TuZ9ZwD7bjFEo7xq1Z20= X-Gm-Gg: ATEYQzybDQV0YZy9ILweZCWa95srywRl7sXaWwNEQGS2wibgwh2CfrLarQUIDwHk2VT ZWYgGKk7B1It8gaHhDTNi4AC5/8jbj3ZSGNPIiEJ66D4JCTpA+JmGL7K57Xw07a2m5Xk1L2SZZ/ HtfkxszBLa/oQnyJ+bFxceoKYk0G637EGieiAafmlabBPlx+ikhU7s1X9IXelDdVe0NKZVi8Lil 8wMI+aSqpxbuQlNMT3Srx6VIJDLu7CkvXEWRwuvdmEIdfNSN0ffp/oek2MsYxpnrK80ButrsgcD oIPmZnkI2mP0cRFNPOWELyEbPum/v3r/fAHPxLJjBS88JhZIOLaNb2b6A0mIlAJGgqbZ3NRA1R0 TuCJvbK/AuLdY+8MdDvfamvTv1g== X-Received: by 2002:a05:600c:6305:b0:483:b505:9db7 with SMTP id 5b1f17b1804b1-485198c1d1fmr86121445e9.32.1772709976274; Thu, 05 Mar 2026 03:26:16 -0800 (PST) X-Received: by 2002:a05:600c:6305:b0:483:b505:9db7 with SMTP id 5b1f17b1804b1-485198c1d1fmr86120825e9.32.1772709975788; Thu, 05 Mar 2026 03:26:15 -0800 (PST) Received: from [192.168.88.32] ([212.105.149.216]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-4851d8ecb09sm38337535e9.2.2026.03.05.03.26.13 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 05 Mar 2026 03:26:15 -0800 (PST) Message-ID: Date: Thu, 5 Mar 2026 12:26:13 +0100 Precedence: bulk X-Mailing-List: netdev@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [net-next V4 5/5] eth: mlx5: Move pause storm errors to pause stats To: netdev@vger.kernel.org, tariqt@nvidia.com, saeedm@nvidia.com, mbloch@nvidia.com, gal@nvidia.com, leon@kernel.org, idosch@nvidia.com Cc: alexanderduyck@fb.com, alok.a.tiwari@oracle.com, andrew+netdev@lunn.ch, andrew@lunn.ch, davem@davemloft.net, dg573847474@gmail.com, donald.hunter@gmail.com, edumazet@google.com, horms@kernel.org, jacob.e.keller@intel.com, kernel-team@meta.com, kory.maincent@bootlin.com, kuba@kernel.org, lee@trager.us, linux-kernel@vger.kernel.org, linux-rdma@vger.kernel.org, linux@armlinux.org.uk, mike.marciniszyn@gmail.com, o.rempel@pengutronix.de, vadim.fedorenko@linux.dev, Mohsin Bashir References: <20260302230149.1580195-1-mohsin.bashr@gmail.com> <20260302230149.1580195-6-mohsin.bashr@gmail.com> Content-Language: en-US From: Paolo Abeni In-Reply-To: <20260302230149.1580195-6-mohsin.bashr@gmail.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit On 3/3/26 12:01 AM, Mohsin Bashir wrote: > Report device_stall_critical_watermark_cnt as tx_pause_storm_events in > the ethtool_pause_stats struct. This counter tracks pause storm error > events which indicate the NIC has been sending pause frames for an > extended period due to a stall. > > The ethtool_pause_stats struct reports these stalls as a single value, > whereas the device supports tracking them per priority. Aggregate the > counter across all priority classes to capture stalls on all priorities. > Note that the stats are fetched from the device for each priority via > mlx5_core_access_reg(). > > Signed-off-by: Jakub Kicinski > Signed-off-by: Mohsin Bashir > --- > .../ethernet/mellanox/mlx5/core/en_stats.c | 30 +++++++++++++++++++ > 1 file changed, 30 insertions(+) > > diff --git a/drivers/net/ethernet/mellanox/mlx5/core/en_stats.c b/drivers/net/ethernet/mellanox/mlx5/core/en_stats.c > index a8af84fc9763..1a3ecf073913 100644 > --- a/drivers/net/ethernet/mellanox/mlx5/core/en_stats.c > +++ b/drivers/net/ethernet/mellanox/mlx5/core/en_stats.c > @@ -916,11 +916,30 @@ static int mlx5e_stats_get_ieee(struct mlx5_core_dev *mdev, > sz, MLX5_REG_PPCNT, 0, 0); > } > > +static int mlx5e_stats_get_per_prio(struct mlx5_core_dev *mdev, > + u32 *ppcnt_per_prio, int prio) > +{ > + u32 in[MLX5_ST_SZ_DW(ppcnt_reg)] = {}; > + int sz = MLX5_ST_SZ_BYTES(ppcnt_reg); > + > + if (!(MLX5_CAP_PCAM_FEATURE(mdev, pfcc_mask) && > + MLX5_CAP_DEBUG(mdev, stall_detect))) > + return -EOPNOTSUPP; > + > + MLX5_SET(ppcnt_reg, in, local_port, 1); > + MLX5_SET(ppcnt_reg, in, grp, MLX5_PER_PRIORITY_COUNTERS_GROUP); > + MLX5_SET(ppcnt_reg, in, prio_tc, prio); > + return mlx5_core_access_reg(mdev, in, sz, ppcnt_per_prio, sz, > + MLX5_REG_PPCNT, 0, 0); > +} > + > void mlx5e_stats_pause_get(struct mlx5e_priv *priv, > struct ethtool_pause_stats *pause_stats) > { > u32 ppcnt_ieee_802_3[MLX5_ST_SZ_DW(ppcnt_reg)]; > struct mlx5_core_dev *mdev = priv->mdev; > + u64 ps_stats = 0; > + int prio; > > if (mlx5e_stats_get_ieee(mdev, ppcnt_ieee_802_3)) > return; > @@ -933,6 +952,17 @@ void mlx5e_stats_pause_get(struct mlx5e_priv *priv, > MLX5E_READ_CTR64_BE_F(ppcnt_ieee_802_3, > eth_802_3_cntrs_grp_data_layout, > a_pause_mac_ctrl_frames_received); > + > + for (prio = 0; prio < NUM_PPORT_PRIO; prio++) { > + if (mlx5e_stats_get_per_prio(mdev, ppcnt_ieee_802_3, prio)) > + return; > + > + ps_stats += MLX5E_READ_CTR64_BE_F(ppcnt_ieee_802_3, > + eth_per_prio_grp_data_layout, > + device_stall_critical_watermark_cnt); > + } > + > + pause_stats->tx_pause_storm_events = ps_stats; > } > > void mlx5e_stats_eth_phy_get(struct mlx5e_priv *priv, It would be nice if someone at nVidia could have a look at the mlx bits here. Waiting a little longer for that. Thanks, Paolo