Commit 6166bb0c authored by Joe Damato's avatar Joe Damato Committed by Jakub Kicinski
Browse files

net/mlx4: Track RX allocation failures in a stat



mlx4_en_alloc_frags currently returns -ENOMEM when mlx4_alloc_page
fails but does not increment a stat field when this occurs.

A new field called alloc_fail has been added to struct mlx4_en_rx_ring
which is now incremented in mlx4_en_rx_ring when -ENOMEM occurs.

Signed-off-by: default avatarJoe Damato <jdamato@fastly.com>
Tested-by: default avatarMartin Karsten <mkarsten@uwaterloo.ca>
Reviewed-by: default avatarTariq Toukan <tariqt@nvidia.com>
Reviewed-by: default avatarJacob Keller <jacob.e.keller@intel.com>
Link: https://lore.kernel.org/r/20240528181139.515070-2-jdamato@fastly.com


Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 95cd03f3
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -2073,6 +2073,7 @@ static void mlx4_en_clear_stats(struct net_device *dev)
		priv->rx_ring[i]->csum_ok = 0;
		priv->rx_ring[i]->csum_none = 0;
		priv->rx_ring[i]->csum_complete = 0;
		priv->rx_ring[i]->alloc_fail = 0;
	}
}

+3 −1
Original line number Diff line number Diff line
@@ -82,8 +82,10 @@ static int mlx4_en_alloc_frags(struct mlx4_en_priv *priv,

	for (i = 0; i < priv->num_frags; i++, frags++) {
		if (!frags->page) {
			if (mlx4_alloc_page(priv, frags, gfp))
			if (mlx4_alloc_page(priv, frags, gfp)) {
				ring->alloc_fail++;
				return -ENOMEM;
			}
			ring->rx_alloc_pages++;
		}
		rx_desc->data[i].addr = cpu_to_be64(frags->dma +
+1 −0
Original line number Diff line number Diff line
@@ -355,6 +355,7 @@ struct mlx4_en_rx_ring {
	unsigned long xdp_tx;
	unsigned long xdp_tx_full;
	unsigned long dropped;
	unsigned long alloc_fail;
	int hwtstamp_rx_filter;
	cpumask_var_t affinity_mask;
	struct xdp_rxq_info xdp_rxq;