Re: [PATCH net-next 3/3] net/mlx4: support per-queue statistics via netlink
From: Jakub Kicinski
Date: Tue Apr 23 2024 - 20:57:29 EST
On Tue, 23 Apr 2024 12:42:13 -1000 Joe Damato wrote:
> I realized in this case, I'll need to set the fields initialized to 0xff
> above to 0 before doing the increments below.
I don't know mlx4 very well, but glancing at the code - are you sure we
need to loop over the queues is the "base" callbacks?
The base callbacks are for getting "historical" data, i.e. info which
was associated with queues which are no longer present. You seem to
sweep all queues, so I'd have expected "base" to just set the values
to 0. And the real values to come from the per-queue callbacks.
The init to 0xff looks quite sus.
Also what does this:
> if (!priv->port_up || mlx4_is_master(priv->mdev->dev))
do? 🤔️ what's a "master" in this context?
> Sorry about that; just realized that now and will fix that in the v2 (along
> with any other feedback I get), probably something:
>
> if (priv->rx_ring_num) {
> rx->packets = 0;
> rx->bytes = 0;
> rx->alloc_fail = 0;
> }
>
> Here for the RX side and see below for the TX side.
FWIW I added a simple test for making sure queue stats match interface
stats, it's tools/testing/selftests/drivers/net/stats.py
You have to export NETIF=$name to make it run on a real interface.
To copy the tests to a remote machine I do:
make -C tools/testing/selftests/ TARGETS="net drivers/net drivers/net/hw" install INSTALL_PATH=/tmp/ksft-net-drv
rsync -ra --delete /tmp/ksft-net-drv root@${machine}:/root/
HTH