1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
/* SPDX-License-Identifier: Apache-2.0
* Copyright (c) 2023 Cisco Systems, Inc.
*/
#include <vnet/vnet.h>
#include <vnet/dev/dev.h>
#include <vnet/dev/counters.h>
#include <dev_iavf/iavf.h>
#include <dev_iavf/virtchnl.h>
#include <dev_iavf/virtchnl_funcs.h>
VLIB_REGISTER_LOG_CLASS (iavf_log, static) = {
.class_name = "iavf",
.subclass_name = "counters",
};
typedef enum
{
IIAVF_PORT_CTR_RX_BYTES,
IIAVF_PORT_CTR_TX_BYTES,
IIAVF_PORT_CTR_RX_PACKETS,
IIAVF_PORT_CTR_TX_PACKETS,
IIAVF_PORT_CTR_RX_DROPS,
IIAVF_PORT_CTR_TX_DROPS,
IIAVF_PORT_CTR_RX_UCAST,
IIAVF_PORT_CTR_TX_UCAST,
IIAVF_PORT_CTR_RX_MCAST,
IIAVF_PORT_CTR_TX_MCAST,
IIAVF_PORT_CTR_RX_BCAST,
IIAVF_PORT_CTR_TX_BCAST,
IIAVF_PORT_CTR_RX_UNKNOWN_PROTOCOL,
IIAVF_PORT_CTR_TX_ERRORS,
} iavf_port_counter_id_t;
vnet_dev_counter_t iavf_port_counters[] = {
VNET_DEV_CTR_RX_BYTES (IIAVF_PORT_CTR_RX_BYTES),
VNET_DEV_CTR_RX_PACKETS (IIAVF_PORT_CTR_RX_PACKETS),
VNET_DEV_CTR_RX_DROPS (IIAVF_PORT_CTR_RX_DROPS),
VNET_DEV_CTR_VENDOR (IIAVF_PORT_CTR_RX_UCAST, RX, PACKETS, "unicast"),
VNET_DEV_CTR_VENDOR (IIAVF_PORT_CTR_RX_MCAST, RX, PACKETS, "multicast"),
VNET_DEV_CTR_VENDOR (IIAVF_PORT_CTR_RX_BCAST, RX, PACKETS, "broadcast"),
VNET_DEV_CTR_VENDOR (IIAVF_PORT_CTR_RX_UNKNOWN_PROTOCOL, RX, PACKETS,
"unknown protocol"),
VNET_DEV_CTR_TX_BYTES (IIAVF_PORT_CTR_TX_BYTES),
VNET_DEV_CTR_TX_PACKETS (IIAVF_PORT_CTR_TX_PACKETS),
VNET_DEV_CTR_TX_DROPS (IIAVF_PORT_CTR_TX_DROPS),
VNET_DEV_CTR_VENDOR (IIAVF_PORT_CTR_TX_UCAST, TX, PACKETS, "unicast"),
VNET_DEV_CTR_VENDOR (IIAVF_PORT_CTR_TX_MCAST, TX, PACKETS, "multicast"),
VNET_DEV_CTR_VENDOR (IIAVF_PORT_CTR_TX_BCAST, TX, PACKETS, "broadcast"),
VNET_DEV_CTR_VENDOR (IIAVF_PORT_CTR_TX_ERRORS, TX, PACKETS, "errors"),
};
void
iavf_port_add_counters (vlib_main_t *vm, vnet_dev_port_t *port)
{
vnet_dev_port_add_counters (vm, port, iavf_port_counters,
ARRAY_LEN (iavf_port_counters));
}
void
iavf_port_poll_stats (vlib_main_t *vm, vnet_dev_port_t *port)
{
vnet_dev_rv_t rv;
vnet_dev_t *dev = port->dev;
virtchnl_eth_stats_t stats;
iavf_port_t *ap = vnet_dev_get_port_data (port);
virtchnl_queue_select_t qs = { .vsi_id = ap->vsi_id };
rv = iavf_vc_op_get_stats (vm, dev, &qs, &stats);
if (rv != VNET_DEV_OK)
return;
foreach_vnet_dev_counter (c, port->counter_main)
{
switch (c->user_data)
{
case IIAVF_PORT_CTR_RX_BYTES:
vnet_dev_counter_value_update (vm, c, stats.rx_bytes);
break;
case IIAVF_PORT_CTR_TX_BYTES:
vnet_dev_counter_value_update (vm, c, stats.tx_bytes);
break;
case IIAVF_PORT_CTR_RX_PACKETS:
vnet_dev_counter_value_update (
vm, c, stats.rx_unicast + stats.rx_broadcast + stats.rx_multicast);
break;
case IIAVF_PORT_CTR_TX_PACKETS:
vnet_dev_counter_value_update (
vm, c, stats.tx_unicast + stats.tx_broadcast + stats.tx_multicast);
break;
case IIAVF_PORT_CTR_RX_DROPS:
vnet_dev_counter_value_update (vm, c, stats.rx_discards);
break;
case IIAVF_PORT_CTR_TX_DROPS:
vnet_dev_counter_value_update (vm, c, stats.tx_discards);
break;
case IIAVF_PORT_CTR_RX_UCAST:
vnet_dev_counter_value_update (vm, c, stats.rx_unicast);
break;
case IIAVF_PORT_CTR_TX_UCAST:
vnet_dev_counter_value_update (vm, c, stats.tx_unicast);
break;
case IIAVF_PORT_CTR_RX_MCAST:
vnet_dev_counter_value_update (vm, c, stats.rx_multicast);
break;
case IIAVF_PORT_CTR_TX_MCAST:
vnet_dev_counter_value_update (vm, c, stats.tx_multicast);
break;
case IIAVF_PORT_CTR_RX_BCAST:
vnet_dev_counter_value_update (vm, c, stats.rx_broadcast);
break;
case IIAVF_PORT_CTR_TX_BCAST:
vnet_dev_counter_value_update (vm, c, stats.tx_broadcast);
break;
case IIAVF_PORT_CTR_RX_UNKNOWN_PROTOCOL:
vnet_dev_counter_value_update (vm, c, stats.rx_unknown_protocol);
break;
case IIAVF_PORT_CTR_TX_ERRORS:
vnet_dev_counter_value_update (vm, c, stats.tx_errors);
break;
default:
ASSERT (0);
}
}
}
|