2022-05-18 16:43:46 -07:00
Networking
==========
2017-05-12 09:14:02 -03:00
2022-03-29 21:25:05 -07:00
Refer to :ref: `netdev-FAQ` for a guide on netdev development process specifics.
2017-05-12 09:14:02 -03:00
Contents:
.. toctree ::
:maxdepth: 2
2018-05-02 13:01:36 +02:00
af_xdp
2020-02-24 10:57:50 +05:30
bareudp
2017-07-12 13:14:48 +02:00
batman-adv
2018-01-24 11:19:11 +01:00
can
2018-04-11 18:06:42 +02:00
can_ucan_protocol
2019-05-21 18:57:12 -07:00
device_drivers/index
2019-04-12 14:55:18 +03:00
dsa/index
2020-01-09 14:46:10 -08:00
devlink/index
2020-04-28 00:01:16 +02:00
caif/index
2019-12-27 15:55:18 +01:00
ethtool-netlink
2019-02-27 20:59:13 +01:00
ieee802154
2018-10-08 11:48:36 +02:00
j1939
2017-05-12 09:14:02 -03:00
kapi
2018-01-08 08:50:17 +02:00
msg_zerocopy
2018-07-12 07:42:49 +10:00
failover
2020-04-09 14:21:58 -07:00
net_dim
2018-07-12 07:42:49 +10:00
net_failover
2020-05-01 16:44:58 +02:00
page_pool
2019-01-26 11:25:37 +01:00
phy
2019-02-22 11:31:46 +00:00
sfp-phylink
2018-07-18 13:27:35 +10:00
alias
2018-07-18 13:27:36 +10:00
bridge
2018-11-10 13:38:12 -08:00
snmp_counter
2019-01-06 00:29:41 +01:00
checksum-offloads
segmentation-offloads
2019-01-18 21:38:32 +01:00
scaling
2019-05-21 18:57:13 -07:00
tls
2019-05-21 18:57:14 -07:00
tls-offload
2023-04-17 10:32:33 -04:00
tls-handshake
2019-11-22 08:43:06 +01:00
nfc
2020-02-06 16:17:22 +01:00
6lowpan
2020-04-28 00:01:17 +02:00
6pack
2020-04-28 00:01:19 +02:00
arcnet-hardware
2020-04-28 00:01:20 +02:00
arcnet
2020-04-28 00:01:21 +02:00
atm
2020-04-28 00:01:22 +02:00
ax25
2020-04-28 00:01:24 +02:00
bonding
2020-04-28 00:01:25 +02:00
cdc_mbim
2020-04-28 00:01:28 +02:00
dccp
2020-04-28 00:01:29 +02:00
dctcp
2020-04-28 00:01:32 +02:00
dns_resolver
2020-04-28 00:01:33 +02:00
driver
2020-04-28 00:01:34 +02:00
eql
2020-04-28 00:01:35 +02:00
fib_trie
2020-04-28 00:01:36 +02:00
filter
2020-04-28 00:01:39 +02:00
generic-hdlc
2020-04-28 00:01:40 +02:00
generic_netlink
2020-04-28 00:01:41 +02:00
gen_stats
2020-04-28 00:01:42 +02:00
gtp
2020-04-28 00:01:44 +02:00
ila
2021-07-28 23:59:12 +08:00
ioam6-sysctl
2020-04-28 00:01:46 +02:00
ip_dynaddr
2020-04-28 00:01:48 +02:00
ipsec
2020-04-28 00:01:49 +02:00
ip-sysctl
2020-04-28 00:01:50 +02:00
ipv6
2020-04-28 00:01:51 +02:00
ipvlan
2020-04-28 00:01:52 +02:00
ipvs-sysctl
2020-04-28 00:01:53 +02:00
kcm
2020-04-30 18:03:56 +02:00
l2tp
2020-04-30 18:03:57 +02:00
lapb-module
2020-04-30 18:03:59 +02:00
mac80211-injection
2021-07-29 10:20:53 +08:00
mctp
2020-04-30 18:04:00 +02:00
mpls-sysctl
2020-11-03 11:05:08 -08:00
mptcp-sysctl
2020-04-30 18:04:01 +02:00
multiqueue
2023-03-21 22:38:48 -07:00
napi
2020-04-30 18:04:02 +02:00
netconsole
2020-04-30 18:04:03 +02:00
netdev-features
2020-04-30 18:04:04 +02:00
netdevices
2020-04-30 18:04:05 +02:00
netfilter-sysctl
2020-04-30 18:04:06 +02:00
netif-msg
2021-03-29 17:57:31 +02:00
nexthop-group-resilient
2020-04-30 18:04:07 +02:00
nf_conntrack-sysctl
2020-04-30 18:04:08 +02:00
nf_flowtable
2020-04-30 18:04:09 +02:00
openvswitch
2020-04-30 18:04:10 +02:00
operstates
2020-04-30 18:04:11 +02:00
packet_mmap
2020-04-30 18:04:12 +02:00
phonet
2020-04-30 18:04:13 +02:00
pktgen
2020-04-30 18:04:14 +02:00
plip
2020-04-30 18:04:15 +02:00
ppp_generic
2020-04-30 18:04:16 +02:00
proc_net_tcp
2020-04-30 18:04:17 +02:00
radiotap-headers
2020-04-30 18:04:19 +02:00
rds
2020-04-30 18:04:20 +02:00
regulatory
2022-09-05 14:55:57 +01:00
representors
2020-04-30 18:04:21 +02:00
rxrpc
2020-04-30 18:04:22 +02:00
sctp
2020-04-30 18:04:23 +02:00
secid
2020-04-30 18:04:24 +02:00
seg6-sysctl
2022-05-09 09:04:55 -07:00
skbuff
2022-03-03 19:35:27 +08:00
smc-sysctl
net: tighten the definition of interface statistics
This patch is born out of an investigation into which IEEE statistics
correspond to which struct rtnl_link_stats64 members. Turns out that
there seems to be reasonable consensus on the matter, among many drivers.
To save others the time (and it took more time than I'm comfortable
admitting) I'm adding comments referring to IEEE attributes to
struct rtnl_link_stats64.
Up until now we had two forms of documentation for stats - in
Documentation/ABI/testing/sysfs-class-net-statistics and the comments
on struct rtnl_link_stats64 itself. While the former is very cautious
in defining the expected behavior, the latter feel quite dated and
may not be easy to understand for modern day driver author
(e.g. rx_over_errors). At the same time modern systems are far more
complex and once obvious definitions lost their clarity. For example
- does rx_packet count at the MAC layer (aFramesReceivedOK)?
packets processed correctly by hardware? received by the driver?
or maybe received by the stack?
I tried to clarify the expectations, further clarifications from
others are very welcome.
The part hardest to untangle is rx_over_errors vs rx_fifo_errors
vs rx_missed_errors. After much deliberation I concluded that for
modern HW only two of the counters will make sense. The distinction
between internal FIFO overflow and packets dropped due to back-pressure
from the host is likely too implementation (driver and device) specific
to expose in the standard stats.
Now - which two of those counters we select to use is anyone's pick:
sysfs documentation suggests rx_over_errors counts packets which
did not fit into buffers due to MTU being too small, which I reused.
There don't seem to be many modern drivers using it (well, CAN drivers
seem to love this statistic).
Of the remaining two I picked rx_missed_errors to report device drops.
bnxt reports it and it's folded into "drop"s in procfs (while
rx_fifo_errors is an error, and modern devices usually receive the frame
OK, they just can't admit it into the pipeline).
Of the drivers I looked at only AMD Lance-like and NS8390-like use all
three of these counters. rx_missed_errors counts missed frames,
rx_over_errors counts overflow events, and rx_fifo_errors counts frames
which were truncated because they didn't fit into buffers. This suggests
that rx_fifo_errors may be the correct stat for truncated packets, but
I'd think a FIFO stat counting truncated packets would be very confusing
to a modern reader.
v2:
- add driver developer notes about ethtool stat count and reset
- replace Ethernet with IEEE 802.3 to better indicate source of attrs
- mention byte counters don't count FCS
- clarify RX counter is from device to host
- drop "sightly" from sysfs paragraph
- add examples of ethtool stats
- s/incoming/received/ s/incoming/transmitted/
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
2020-09-03 16:14:31 -07:00
statistics
2020-04-30 18:04:26 +02:00
strparser
2020-04-30 18:04:27 +02:00
switchdev
2020-10-09 00:01:28 -07:00
sysfs-tagging
2020-04-30 18:04:28 +02:00
tc-actions-env-rules
2022-10-21 00:58:50 -07:00
tc-queue-filters
2023-10-23 20:22:15 +01:00
tcp_ao
2020-04-30 18:04:29 +02:00
tcp-thin
2020-04-30 18:04:30 +02:00
team
2020-04-30 18:04:31 +02:00
timestamping
2020-11-29 10:32:51 -08:00
tipc
2020-04-30 18:04:32 +02:00
tproxy
2020-05-01 16:44:23 +02:00
tuntap
2020-05-01 16:44:24 +02:00
udplite
2020-05-01 16:44:25 +02:00
vrf
2020-05-01 16:44:26 +02:00
vxlan
2020-05-01 16:44:28 +02:00
x25
2023-05-09 19:29:14 -07:00
x25-iface
2020-05-01 16:44:29 +02:00
xfrm_device
2020-05-01 16:44:30 +02:00
xfrm_proc
2020-05-01 16:44:31 +02:00
xfrm_sync
2020-05-01 16:44:32 +02:00
xfrm_sysctl
2023-01-19 14:15:20 -08:00
xdp-rx-metadata
2017-05-12 09:14:02 -03:00
2019-07-26 09:51:29 -03:00
.. only :: subproject and html
2017-05-12 09:14:02 -03:00
Indices
=======
* :ref: `genindex`