lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <IA3PR11MB89869955FD148E39E53182B5E5C4A@IA3PR11MB8986.namprd11.prod.outlook.com>
Date: Tue, 4 Nov 2025 07:24:25 +0000
From: "Loktionov, Aleksandr" <aleksandr.loktionov@...el.com>
To: "Keller, Jacob E" <jacob.e.keller@...el.com>, "Lobakin, Aleksander"
	<aleksander.lobakin@...el.com>, "Nguyen, Anthony L"
	<anthony.l.nguyen@...el.com>, "Kitszel, Przemyslaw"
	<przemyslaw.kitszel@...el.com>
CC: "intel-wired-lan@...ts.osuosl.org" <intel-wired-lan@...ts.osuosl.org>,
	"netdev@...r.kernel.org" <netdev@...r.kernel.org>
Subject: RE: [PATCH iwl-next 6/9] ice: remove ice_q_stats struct and use
 struct_group



> -----Original Message-----
> From: Keller, Jacob E <jacob.e.keller@...el.com>
> Sent: Tuesday, November 4, 2025 2:07 AM
> To: Loktionov, Aleksandr <aleksandr.loktionov@...el.com>; Lobakin,
> Aleksander <aleksander.lobakin@...el.com>; Nguyen, Anthony L
> <anthony.l.nguyen@...el.com>; Kitszel, Przemyslaw
> <przemyslaw.kitszel@...el.com>
> Cc: intel-wired-lan@...ts.osuosl.org; netdev@...r.kernel.org; Keller,
> Jacob E <jacob.e.keller@...el.com>
> Subject: [PATCH iwl-next 6/9] ice: remove ice_q_stats struct and use
> struct_group
> 
> The ice_qp_reset_stats function resets the stats for all rings on a
> VSI. It currently behaves differently for Tx and Rx rings. For Rx
> rings, it only clears the rx_stats which do not include the pkt and
> byte counts. For Tx rings and XDP rings, it clears only the pkt and
> byte counts.
> 
> We could add extra memset calls to cover both the stats and relevant
> tx/rx stats fields. Instead, lets convert stats into a struct_group
> which contains both the pkts and bytes fields as well as the Tx or Rx
> stats, and remove the ice_q_stats structure entirely.
> 
> The only remaining user of ice_q_stats is the ice_q_stats_len function
> in ice_ethtool.c, which just counts the number of fields. Replace this
> with a simple multiplication by 2. I find this to be simpler to reason
> about than relying on knowing the layout of the ice_q_stats structure.
> 
> Now that the stats field of the ice_ring_stats covers all of the
> statistic values, the ice_qp_reset_stats function will properly zero
> out all of the fields.
> 
> Signed-off-by: Jacob Keller <jacob.e.keller@...el.com>
> ---
>  drivers/net/ethernet/intel/ice/ice_txrx.h    | 18 ++++++++----------
>  drivers/net/ethernet/intel/ice/ice_base.c    |  4 ++--
>  drivers/net/ethernet/intel/ice/ice_ethtool.c |  4 ++--
>  drivers/net/ethernet/intel/ice/ice_lib.c     |  7 ++++---
>  4 files changed, 16 insertions(+), 17 deletions(-)
> 
> diff --git a/drivers/net/ethernet/intel/ice/ice_txrx.h
> b/drivers/net/ethernet/intel/ice/ice_txrx.h
> index f1fe1775baed..8586d5bebac7 100644
> --- a/drivers/net/ethernet/intel/ice/ice_txrx.h
> +++ b/drivers/net/ethernet/intel/ice/ice_txrx.h
> @@ -129,11 +129,6 @@ struct ice_tx_offload_params {
>  	u8 header_len;
>  };
> 
> -struct ice_q_stats {
> -	u64 pkts;
> -	u64 bytes;
> -};
> -
>  struct ice_txq_stats {
>  	u64 restart_q;
>  	u64 tx_busy;
> @@ -148,12 +143,15 @@ struct ice_rxq_stats {
> 
>  struct ice_ring_stats {
>  	struct rcu_head rcu;	/* to avoid race on free */
> -	struct ice_q_stats stats;
>  	struct u64_stats_sync syncp;
> -	union {
> -		struct ice_txq_stats tx_stats;
> -		struct ice_rxq_stats rx_stats;
> -	};
> +	struct_group(stats,
> +		u64 pkts;
> +		u64 bytes;
> +		union {
> +			struct ice_txq_stats tx_stats;
> +			struct ice_rxq_stats rx_stats;
> +		};
> +	);
>  };
> 
>  enum ice_ring_state_t {
> diff --git a/drivers/net/ethernet/intel/ice/ice_base.c
> b/drivers/net/ethernet/intel/ice/ice_base.c
> index eadb1e3d12b3..afbff8aa9ceb 100644
> --- a/drivers/net/ethernet/intel/ice/ice_base.c
> +++ b/drivers/net/ethernet/intel/ice/ice_base.c
> @@ -1414,8 +1414,8 @@ static void ice_qp_reset_stats(struct ice_vsi
> *vsi, u16 q_idx)
>  	if (!vsi_stat)
>  		return;
> 
> -	memset(&vsi_stat->rx_ring_stats[q_idx]->rx_stats, 0,
> -	       sizeof(vsi_stat->rx_ring_stats[q_idx]->rx_stats));
> +	memset(&vsi_stat->rx_ring_stats[q_idx]->stats, 0,
> +	       sizeof(vsi_stat->rx_ring_stats[q_idx]->stats));
>  	memset(&vsi_stat->tx_ring_stats[q_idx]->stats, 0,
>  	       sizeof(vsi_stat->tx_ring_stats[q_idx]->stats));
>  	if (vsi->xdp_rings)
> diff --git a/drivers/net/ethernet/intel/ice/ice_ethtool.c
> b/drivers/net/ethernet/intel/ice/ice_ethtool.c
> index a1d9abee97e5..0bc6f31a2b06 100644
> --- a/drivers/net/ethernet/intel/ice/ice_ethtool.c
> +++ b/drivers/net/ethernet/intel/ice/ice_ethtool.c
> @@ -33,8 +33,8 @@ static int ice_q_stats_len(struct net_device
> *netdev)  {
>  	struct ice_netdev_priv *np = netdev_priv(netdev);
> 
> -	return ((np->vsi->alloc_txq + np->vsi->alloc_rxq) *
> -		(sizeof(struct ice_q_stats) / sizeof(u64)));
> +	/* One packets and one bytes count per queue */
> +	return ((np->vsi->alloc_txq + np->vsi->alloc_rxq) * 2);
>  }
> 
>  #define ICE_PF_STATS_LEN	ARRAY_SIZE(ice_gstrings_pf_stats)
> diff --git a/drivers/net/ethernet/intel/ice/ice_lib.c
> b/drivers/net/ethernet/intel/ice/ice_lib.c
> index e7265e877703..c6dd297582c1 100644
> --- a/drivers/net/ethernet/intel/ice/ice_lib.c
> +++ b/drivers/net/ethernet/intel/ice/ice_lib.c
> @@ -3437,7 +3437,8 @@ int ice_vsi_cfg_tc(struct ice_vsi *vsi, u8
> ena_tc)
>   *
>   * This function assumes that caller has acquired a u64_stats_sync
> lock.
>   */
> -static void ice_update_ring_stats(struct ice_q_stats *stats, u64
> pkts, u64 bytes)
> +static void ice_update_ring_stats(struct ice_ring_stats *stats,
> +				  u64 pkts, u64 bytes)
>  {
>  	stats->bytes += bytes;
>  	stats->pkts += pkts;
> @@ -3452,7 +3453,7 @@ static void ice_update_ring_stats(struct
> ice_q_stats *stats, u64 pkts, u64 bytes  void
> ice_update_tx_ring_stats(struct ice_tx_ring *tx_ring, u64 pkts, u64
> bytes)  {
>  	u64_stats_update_begin(&tx_ring->ring_stats->syncp);
> -	ice_update_ring_stats(&tx_ring->ring_stats->stats, pkts,
> bytes);
> +	ice_update_ring_stats(tx_ring->ring_stats, pkts, bytes);
>  	u64_stats_update_end(&tx_ring->ring_stats->syncp);
>  }
> 
> @@ -3465,7 +3466,7 @@ void ice_update_tx_ring_stats(struct ice_tx_ring
> *tx_ring, u64 pkts, u64 bytes)  void ice_update_rx_ring_stats(struct
> ice_rx_ring *rx_ring, u64 pkts, u64 bytes)  {
>  	u64_stats_update_begin(&rx_ring->ring_stats->syncp);
> -	ice_update_ring_stats(&rx_ring->ring_stats->stats, pkts,
> bytes);
> +	ice_update_ring_stats(rx_ring->ring_stats, pkts, bytes);
>  	u64_stats_update_end(&rx_ring->ring_stats->syncp);
>  }
> 
> 
> --
> 2.51.0.rc1.197.g6d975e95c9d7

Reviewed-by: Aleksandr Loktionov <aleksandr.loktionov@...el.com>

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ