[PATCH v2 net-next 12/26] veth: don't mix XDP_DROP counter with Rx XDP errors

From: Alexander Lobakin
Date: Tue Nov 23 2021 - 11:42:53 EST


Similarly to mlx5, count XDP_ABORTED and other Rx XDP errors
separately from XDP_DROP to better align with generic XDP stats.

Signed-off-by: Alexander Lobakin <alexandr.lobakin@xxxxxxxxx>
Reviewed-by: Jesse Brandeburg <jesse.brandeburg@xxxxxxxxx>
---
drivers/net/veth.c | 11 ++++++++---
1 file changed, 8 insertions(+), 3 deletions(-)

diff --git a/drivers/net/veth.c b/drivers/net/veth.c
index 5ca0a899101d..0e6c030576f4 100644
--- a/drivers/net/veth.c
+++ b/drivers/net/veth.c
@@ -43,6 +43,7 @@ struct veth_stats {
u64 xdp_packets;
u64 xdp_bytes;
u64 xdp_redirect;
+ u64 xdp_errors;
u64 xdp_drops;
u64 xdp_tx;
u64 xdp_tx_err;
@@ -96,6 +97,7 @@ static const struct veth_q_stat_desc veth_rq_stats_desc[] = {
{ "xdp_bytes", VETH_RQ_STAT(xdp_bytes) },
{ "drops", VETH_RQ_STAT(rx_drops) },
{ "xdp_redirect", VETH_RQ_STAT(xdp_redirect) },
+ { "xdp_errors", VETH_RQ_STAT(xdp_errors) },
{ "xdp_drops", VETH_RQ_STAT(xdp_drops) },
{ "xdp_tx", VETH_RQ_STAT(xdp_tx) },
{ "xdp_tx_errors", VETH_RQ_STAT(xdp_tx_err) },
@@ -655,16 +657,18 @@ static struct xdp_frame *veth_xdp_rcv_one(struct veth_rq *rq,
fallthrough;
case XDP_ABORTED:
trace_xdp_exception(rq->dev, xdp_prog, act);
- fallthrough;
+ goto err_xdp;
case XDP_DROP:
stats->xdp_drops++;
- goto err_xdp;
+ goto xdp_drop;
}
}
rcu_read_unlock();

return frame;
err_xdp:
+ stats->xdp_errors++;
+xdp_drop:
rcu_read_unlock();
xdp_return_frame(frame);
xdp_xmit:
@@ -805,7 +809,8 @@ static struct sk_buff *veth_xdp_rcv_skb(struct veth_rq *rq,
fallthrough;
case XDP_ABORTED:
trace_xdp_exception(rq->dev, xdp_prog, act);
- fallthrough;
+ stats->xdp_errors++;
+ goto xdp_drop;
case XDP_DROP:
stats->xdp_drops++;
goto xdp_drop;
--
2.33.1