123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592 |
- /** @file
- * @brief Network statistics
- *
- * Network statistics data. This should only be enabled when
- * debugging as it consumes memory.
- */
- /*
- * Copyright (c) 2016 Intel Corporation
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- #ifndef ZEPHYR_INCLUDE_NET_NET_STATS_H_
- #define ZEPHYR_INCLUDE_NET_NET_STATS_H_
- #include <zephyr/types.h>
- #include <net/net_core.h>
- #include <net/net_mgmt.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- /**
- * @brief Network statistics library
- * @defgroup net_stats Network Statistics Library
- * @ingroup networking
- * @{
- */
- /**
- * @typedef net_stats_t
- * @brief Network statistics counter
- */
- typedef uint32_t net_stats_t;
- /**
- * @brief Number of bytes sent and received.
- */
- struct net_stats_bytes {
- /** Number of bytes sent */
- net_stats_t sent;
- /** Number of bytes received */
- net_stats_t received;
- };
- /**
- * @brief Number of network packets sent and received.
- */
- struct net_stats_pkts {
- /** Number of packets sent */
- net_stats_t tx;
- /** Number of packets received */
- net_stats_t rx;
- };
- /**
- * @brief IP layer statistics
- */
- struct net_stats_ip {
- /** Number of received packets at the IP layer. */
- net_stats_t recv;
- /** Number of sent packets at the IP layer. */
- net_stats_t sent;
- /** Number of forwarded packets at the IP layer. */
- net_stats_t forwarded;
- /** Number of dropped packets at the IP layer. */
- net_stats_t drop;
- };
- /**
- * @brief IP layer error statistics
- */
- struct net_stats_ip_errors {
- /** Number of packets dropped due to wrong IP version
- * or header length.
- */
- net_stats_t vhlerr;
- /** Number of packets dropped due to wrong IP length, high byte. */
- net_stats_t hblenerr;
- /** Number of packets dropped due to wrong IP length, low byte. */
- net_stats_t lblenerr;
- /** Number of packets dropped because they were IP fragments. */
- net_stats_t fragerr;
- /** Number of packets dropped due to IP checksum errors. */
- net_stats_t chkerr;
- /** Number of packets dropped because they were neither ICMP,
- * UDP nor TCP.
- */
- net_stats_t protoerr;
- };
- /**
- * @brief ICMP statistics
- */
- struct net_stats_icmp {
- /** Number of received ICMP packets. */
- net_stats_t recv;
- /** Number of sent ICMP packets. */
- net_stats_t sent;
- /** Number of dropped ICMP packets. */
- net_stats_t drop;
- /** Number of ICMP packets with a wrong type. */
- net_stats_t typeerr;
- /** Number of ICMP packets with a bad checksum. */
- net_stats_t chkerr;
- };
- /**
- * @brief TCP statistics
- */
- struct net_stats_tcp {
- /** Amount of received and sent TCP application data. */
- struct net_stats_bytes bytes;
- /** Amount of retransmitted data. */
- net_stats_t resent;
- /** Number of dropped packets at the TCP layer. */
- net_stats_t drop;
- /** Number of received TCP segments. */
- net_stats_t recv;
- /** Number of sent TCP segments. */
- net_stats_t sent;
- /** Number of dropped TCP segments. */
- net_stats_t seg_drop;
- /** Number of TCP segments with a bad checksum. */
- net_stats_t chkerr;
- /** Number of received TCP segments with a bad ACK number. */
- net_stats_t ackerr;
- /** Number of received bad TCP RST (reset) segments. */
- net_stats_t rsterr;
- /** Number of received TCP RST (reset) segments. */
- net_stats_t rst;
- /** Number of retransmitted TCP segments. */
- net_stats_t rexmit;
- /** Number of dropped connection attempts because too few connections
- * were available.
- */
- net_stats_t conndrop;
- /** Number of connection attempts for closed ports, triggering a RST. */
- net_stats_t connrst;
- };
- /**
- * @brief UDP statistics
- */
- struct net_stats_udp {
- /** Number of dropped UDP segments. */
- net_stats_t drop;
- /** Number of received UDP segments. */
- net_stats_t recv;
- /** Number of sent UDP segments. */
- net_stats_t sent;
- /** Number of UDP segments with a bad checksum. */
- net_stats_t chkerr;
- };
- /**
- * @brief IPv6 neighbor discovery statistics
- */
- struct net_stats_ipv6_nd {
- net_stats_t drop;
- net_stats_t recv;
- net_stats_t sent;
- };
- /**
- * @brief IPv6 multicast listener daemon statistics
- */
- struct net_stats_ipv6_mld {
- /** Number of received IPv6 MLD queries */
- net_stats_t recv;
- /** Number of sent IPv6 MLD reports */
- net_stats_t sent;
- /** Number of dropped IPv6 MLD packets */
- net_stats_t drop;
- };
- /**
- * @brief IPv4 IGMP daemon statistics
- */
- struct net_stats_ipv4_igmp {
- /** Number of received IPv4 IGMP queries */
- net_stats_t recv;
- /** Number of sent IPv4 IGMP reports */
- net_stats_t sent;
- /** Number of dropped IPv4 IGMP packets */
- net_stats_t drop;
- };
- /**
- * @brief Network packet transfer times for calculating average TX time
- */
- struct net_stats_tx_time {
- uint64_t sum;
- net_stats_t count;
- };
- /**
- * @brief Network packet receive times for calculating average RX time
- */
- struct net_stats_rx_time {
- uint64_t sum;
- net_stats_t count;
- };
- #if NET_TC_TX_COUNT == 0
- #define NET_TC_TX_STATS_COUNT 1
- #else
- #define NET_TC_TX_STATS_COUNT NET_TC_TX_COUNT
- #endif
- #if NET_TC_RX_COUNT == 0
- #define NET_TC_RX_STATS_COUNT 1
- #else
- #define NET_TC_RX_STATS_COUNT NET_TC_RX_COUNT
- #endif
- /**
- * @brief Traffic class statistics
- */
- struct net_stats_tc {
- struct {
- struct net_stats_tx_time tx_time;
- #if defined(CONFIG_NET_PKT_TXTIME_STATS_DETAIL)
- struct net_stats_tx_time
- tx_time_detail[NET_PKT_DETAIL_STATS_COUNT];
- #endif
- net_stats_t pkts;
- net_stats_t bytes;
- uint8_t priority;
- } sent[NET_TC_TX_STATS_COUNT];
- struct {
- struct net_stats_rx_time rx_time;
- #if defined(CONFIG_NET_PKT_RXTIME_STATS_DETAIL)
- struct net_stats_rx_time
- rx_time_detail[NET_PKT_DETAIL_STATS_COUNT];
- #endif
- net_stats_t pkts;
- net_stats_t bytes;
- uint8_t priority;
- } recv[NET_TC_RX_STATS_COUNT];
- };
- /**
- * @brief Power management statistics
- */
- struct net_stats_pm {
- uint64_t overall_suspend_time;
- net_stats_t suspend_count;
- uint32_t last_suspend_time;
- uint32_t start_time;
- };
- /**
- * @brief All network statistics in one struct.
- */
- struct net_stats {
- /** Count of malformed packets or packets we do not have handler for */
- net_stats_t processing_error;
- /**
- * This calculates amount of data transferred through all the
- * network interfaces.
- */
- struct net_stats_bytes bytes;
- /** IP layer errors */
- struct net_stats_ip_errors ip_errors;
- #if defined(CONFIG_NET_STATISTICS_IPV6)
- /** IPv6 statistics */
- struct net_stats_ip ipv6;
- #endif
- #if defined(CONFIG_NET_STATISTICS_IPV4)
- /** IPv4 statistics */
- struct net_stats_ip ipv4;
- #endif
- #if defined(CONFIG_NET_STATISTICS_ICMP)
- /** ICMP statistics */
- struct net_stats_icmp icmp;
- #endif
- #if defined(CONFIG_NET_STATISTICS_TCP)
- /** TCP statistics */
- struct net_stats_tcp tcp;
- #endif
- #if defined(CONFIG_NET_STATISTICS_UDP)
- /** UDP statistics */
- struct net_stats_udp udp;
- #endif
- #if defined(CONFIG_NET_STATISTICS_IPV6_ND)
- /** IPv6 neighbor discovery statistics */
- struct net_stats_ipv6_nd ipv6_nd;
- #endif
- #if defined(CONFIG_NET_STATISTICS_MLD)
- /** IPv6 MLD statistics */
- struct net_stats_ipv6_mld ipv6_mld;
- #endif
- #if defined(CONFIG_NET_STATISTICS_IGMP)
- /** IPv4 IGMP statistics */
- struct net_stats_ipv4_igmp ipv4_igmp;
- #endif
- #if NET_TC_COUNT > 1
- /** Traffic class statistics */
- struct net_stats_tc tc;
- #endif
- #if defined(CONFIG_NET_PKT_TXTIME_STATS)
- /** Network packet TX time statistics */
- struct net_stats_tx_time tx_time;
- #endif
- #if defined(CONFIG_NET_PKT_RXTIME_STATS)
- /** Network packet RX time statistics */
- struct net_stats_rx_time rx_time;
- #endif
- #if defined(CONFIG_NET_PKT_TXTIME_STATS_DETAIL)
- /** Network packet TX time detail statistics */
- struct net_stats_tx_time tx_time_detail[NET_PKT_DETAIL_STATS_COUNT];
- #endif
- #if defined(CONFIG_NET_PKT_RXTIME_STATS_DETAIL)
- /** Network packet RX time detail statistics */
- struct net_stats_rx_time rx_time_detail[NET_PKT_DETAIL_STATS_COUNT];
- #endif
- #if defined(CONFIG_NET_STATISTICS_POWER_MANAGEMENT)
- struct net_stats_pm pm;
- #endif
- };
- /**
- * @brief Ethernet error statistics
- */
- struct net_stats_eth_errors {
- net_stats_t rx_length_errors;
- net_stats_t rx_over_errors;
- net_stats_t rx_crc_errors;
- net_stats_t rx_frame_errors;
- net_stats_t rx_no_buffer_count;
- net_stats_t rx_missed_errors;
- net_stats_t rx_long_length_errors;
- net_stats_t rx_short_length_errors;
- net_stats_t rx_align_errors;
- net_stats_t rx_dma_failed;
- net_stats_t rx_buf_alloc_failed;
- net_stats_t tx_aborted_errors;
- net_stats_t tx_carrier_errors;
- net_stats_t tx_fifo_errors;
- net_stats_t tx_heartbeat_errors;
- net_stats_t tx_window_errors;
- net_stats_t tx_dma_failed;
- net_stats_t uncorr_ecc_errors;
- net_stats_t corr_ecc_errors;
- };
- /**
- * @brief Ethernet flow control statistics
- */
- struct net_stats_eth_flow {
- net_stats_t rx_flow_control_xon;
- net_stats_t rx_flow_control_xoff;
- net_stats_t tx_flow_control_xon;
- net_stats_t tx_flow_control_xoff;
- };
- /**
- * @brief Ethernet checksum statistics
- */
- struct net_stats_eth_csum {
- net_stats_t rx_csum_offload_good;
- net_stats_t rx_csum_offload_errors;
- };
- /**
- * @brief Ethernet hardware timestamp statistics
- */
- struct net_stats_eth_hw_timestamp {
- net_stats_t rx_hwtstamp_cleared;
- net_stats_t tx_hwtstamp_timeouts;
- net_stats_t tx_hwtstamp_skipped;
- };
- #ifdef CONFIG_NET_STATISTICS_ETHERNET_VENDOR
- /**
- * @brief Ethernet vendor specific statistics
- */
- struct net_stats_eth_vendor {
- const char * const key;
- uint32_t value;
- };
- #endif
- /**
- * @brief All Ethernet specific statistics
- */
- struct net_stats_eth {
- struct net_stats_bytes bytes;
- struct net_stats_pkts pkts;
- struct net_stats_pkts broadcast;
- struct net_stats_pkts multicast;
- struct net_stats_pkts errors;
- struct net_stats_eth_errors error_details;
- struct net_stats_eth_flow flow_control;
- struct net_stats_eth_csum csum;
- struct net_stats_eth_hw_timestamp hw_timestamp;
- net_stats_t collisions;
- net_stats_t tx_dropped;
- net_stats_t tx_timeout_count;
- net_stats_t tx_restart_queue;
- #ifdef CONFIG_NET_STATISTICS_ETHERNET_VENDOR
- /** Array is terminated with an entry containing a NULL key */
- struct net_stats_eth_vendor *vendor;
- #endif
- };
- /**
- * @brief All PPP specific statistics
- */
- struct net_stats_ppp {
- struct net_stats_bytes bytes;
- struct net_stats_pkts pkts;
- /** Number of received and dropped PPP frames. */
- net_stats_t drop;
- /** Number of received PPP frames with a bad checksum. */
- net_stats_t chkerr;
- };
- #if defined(CONFIG_NET_STATISTICS_USER_API)
- /* Management part definitions */
- #define _NET_STATS_LAYER NET_MGMT_LAYER_L3
- #define _NET_STATS_CODE 0x101
- #define _NET_STATS_BASE (NET_MGMT_LAYER(_NET_STATS_LAYER) | \
- NET_MGMT_LAYER_CODE(_NET_STATS_CODE))
- enum net_request_stats_cmd {
- NET_REQUEST_STATS_CMD_GET_ALL = 1,
- NET_REQUEST_STATS_CMD_GET_PROCESSING_ERROR,
- NET_REQUEST_STATS_CMD_GET_BYTES,
- NET_REQUEST_STATS_CMD_GET_IP_ERRORS,
- NET_REQUEST_STATS_CMD_GET_IPV4,
- NET_REQUEST_STATS_CMD_GET_IPV6,
- NET_REQUEST_STATS_CMD_GET_IPV6_ND,
- NET_REQUEST_STATS_CMD_GET_ICMP,
- NET_REQUEST_STATS_CMD_GET_UDP,
- NET_REQUEST_STATS_CMD_GET_TCP,
- NET_REQUEST_STATS_CMD_GET_ETHERNET,
- NET_REQUEST_STATS_CMD_GET_PPP,
- NET_REQUEST_STATS_CMD_GET_PM
- };
- #define NET_REQUEST_STATS_GET_ALL \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_ALL)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_ALL);
- #define NET_REQUEST_STATS_GET_PROCESSING_ERROR \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_PROCESSING_ERROR)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_PROCESSING_ERROR);
- #define NET_REQUEST_STATS_GET_BYTES \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_BYTES)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_BYTES);
- #define NET_REQUEST_STATS_GET_IP_ERRORS \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_IP_ERRORS)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_IP_ERRORS);
- #if defined(CONFIG_NET_STATISTICS_IPV4)
- #define NET_REQUEST_STATS_GET_IPV4 \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_IPV4)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_IPV4);
- #endif /* CONFIG_NET_STATISTICS_IPV4 */
- #if defined(CONFIG_NET_STATISTICS_IPV6)
- #define NET_REQUEST_STATS_GET_IPV6 \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_IPV6)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_IPV6);
- #endif /* CONFIG_NET_STATISTICS_IPV6 */
- #if defined(CONFIG_NET_STATISTICS_IPV6_ND)
- #define NET_REQUEST_STATS_GET_IPV6_ND \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_IPV6_ND)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_IPV6_ND);
- #endif /* CONFIG_NET_STATISTICS_IPV6_ND */
- #if defined(CONFIG_NET_STATISTICS_ICMP)
- #define NET_REQUEST_STATS_GET_ICMP \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_ICMP)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_ICMP);
- #endif /* CONFIG_NET_STATISTICS_ICMP */
- #if defined(CONFIG_NET_STATISTICS_UDP)
- #define NET_REQUEST_STATS_GET_UDP \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_UDP)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_UDP);
- #endif /* CONFIG_NET_STATISTICS_UDP */
- #if defined(CONFIG_NET_STATISTICS_TCP)
- #define NET_REQUEST_STATS_GET_TCP \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_TCP)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_TCP);
- #endif /* CONFIG_NET_STATISTICS_TCP */
- #if defined(CONFIG_NET_STATISTICS_ETHERNET)
- #define NET_REQUEST_STATS_GET_ETHERNET \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_ETHERNET)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_ETHERNET);
- #endif /* CONFIG_NET_STATISTICS_ETHERNET */
- #if defined(CONFIG_NET_STATISTICS_PPP)
- #define NET_REQUEST_STATS_GET_PPP \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_PPP)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_PPP);
- #endif /* CONFIG_NET_STATISTICS_PPP */
- #endif /* CONFIG_NET_STATISTICS_USER_API */
- #if defined(CONFIG_NET_STATISTICS_POWER_MANAGEMENT)
- #define NET_REQUEST_STATS_GET_PM \
- (_NET_STATS_BASE | NET_REQUEST_STATS_CMD_GET_PM)
- NET_MGMT_DEFINE_REQUEST_HANDLER(NET_REQUEST_STATS_GET_PM);
- #endif /* CONFIG_NET_STATISTICS_POWER_MANAGEMENT */
- /**
- * @}
- */
- #ifdef __cplusplus
- }
- #endif
- #endif /* ZEPHYR_INCLUDE_NET_NET_STATS_H_ */
|