Page MenuHomeFreeBSD

iflib: Make txq mp ring stats persistent
Needs ReviewPublic

Authored by zlei on Sep 22 2024, 5:13 PM.
Tags
None
Referenced Files
F133476652: D46751.id143619.diff
Sun, Oct 26, 2:08 AM
Unknown Object (File)
Tue, Oct 21, 1:19 AM
Unknown Object (File)
Mon, Oct 20, 3:03 AM
Unknown Object (File)
Mon, Oct 20, 3:03 AM
Unknown Object (File)
Sun, Oct 19, 12:29 PM
Unknown Object (File)
Wed, Oct 1, 10:11 AM
Unknown Object (File)
Sep 3 2025, 9:43 AM
Unknown Object (File)
Aug 28 2025, 2:25 AM

Details

Reviewers
jhb
erj
shurd
Group Reviewers
iflib
Summary

Those stats get reset on every iflib_stop(), e.g., ifconfig em0 -tso.
However it is harmless if they persist. Currenty they are retrived only
via sysctl. A upcoming fix will make use of drops to correctly report
output dropped packets of an interface. With this change we will not
have to save the drops stat on every iflib_stop(), then the code will
be simpler.

MFC after: 2 weeks

Test Plan

Verify the txq mp ring stats persist after changing interface flags.

# sysctl dev.igc.0 | grep txq | grep enqueues
dev.igc.0.iflib.txq3.r_enqueues: 0
dev.igc.0.iflib.txq2.r_enqueues: 0
dev.igc.0.iflib.txq1.r_enqueues: 0
dev.igc.0.iflib.txq0.r_enqueues: 4

# ifconfig igc0 -tso
# sysctl dev.igc.0 | grep txq | grep enqueues
dev.igc.0.iflib.txq3.r_enqueues: 0
dev.igc.0.iflib.txq2.r_enqueues: 0
dev.igc.0.iflib.txq1.r_enqueues: 0
dev.igc.0.iflib.txq0.r_enqueues: 4

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

zlei requested review of this revision.Sep 22 2024, 5:13 PM

For what it's worth I think the TSO reset is due to ifnet, iflib, and individual drivers only making various decisions during attach that would better be done in helper functions that are called during init and SIOCSIFCAP and not some real limitation of the network stack or hardware. It would be cool to not need that reset. I left a more relevant comment in https://reviews.freebsd.org/D46186#inline-280367