On 11/24/2022 4:59 PM, Stephen Hemminger wrote:
> On Thu, 24 Nov 2022 15:33:35 +0800
> Junfeng Guo <junfeng....@intel.com> wrote:
> 
>> +static int
>> +gve_dev_stats_get(struct rte_eth_dev *dev, struct rte_eth_stats *stats)
>> +{
>> +    uint16_t i;
>> +
>> +    for (i = 0; i < dev->data->nb_tx_queues; i++) {
>> +            struct gve_tx_queue *txq = dev->data->tx_queues[i];
>> +            if (txq == NULL)
>> +                    continue;
>> +
>> +            stats->opackets += txq->packets;
>> +            stats->obytes += txq->bytes;
>> +            stats->oerrors += txq->errors;
>> +    }
>> +
>> +    for (i = 0; i < dev->data->nb_rx_queues; i++) {
>> +            struct gve_rx_queue *rxq = dev->data->rx_queues[i];
>> +            if (rxq == NULL)
>> +                    continue;
>> +
>> +            stats->ipackets += rxq->packets;
>> +            stats->ibytes += rxq->bytes;
>> +            stats->ierrors += rxq->errors;
>> +            stats->rx_nombuf += rxq->no_mbufs;
>> +    }
>> +
>> +    return 0;
>> +}
>> +
> 
> The driver should be filling in the per-queue stats as well.
> q_ipackets, q_opackets, q_ibytes, q_obytes, q_errors


Hi Stephen,

Queue stats moved to xstats, and there is a long term goal to move all
queue stats from basic stats to xstats for all PMDs, and remove interim
'RTE_ETH_DEV_AUTOFILL_QUEUE_XSTATS' flag.

That is why request to new PMDs is to not introduce queue stats in basic
stats, but in xstats.

Reply via email to