Page MenuHomeFreeBSD

Protect global ifnet list and short lived ifaddr references with epoch
ClosedPublic

Authored by mmacy on May 13 2018, 1:34 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 5:20 PM
Unknown Object (File)
Dec 9 2024, 7:51 PM
Unknown Object (File)
Nov 26 2024, 1:10 AM
Unknown Object (File)
Nov 22 2024, 3:34 AM
Unknown Object (File)
Nov 14 2024, 9:46 AM
Unknown Object (File)
Oct 7 2024, 1:29 AM
Unknown Object (File)
Oct 2 2024, 8:33 AM
Unknown Object (File)
Oct 1 2024, 10:23 AM

Details

Summary

My weekend project has been improving UDP transmit performance:
https://github.com/ScaleBSD/scalebsd.github.io/blob/master/_drafts/2018-05-12-UDP-On-FreeBSD-is-anyone-using-this-at-scale.md

  • To address the contention on ifnet_rwlock seen in the second flame graph I replaced rlock calls with epoch_{enter, exit} and made the necessary changes to ensure a grace period elapsed on deletion of ifnet and other things whose liveness is protected by said lock.
  • To address the contention on the ifaddr reference that that in turn revealed I ensured that all short term references to an ifaddr were instead protected by epoch. Refcount updates are now only needed for persistent references on the heap.
Test Plan

pho and canary at Limelight Networks

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 16683

Event Timeline

mmacy edited the test plan for this revision. (Show Details)
  • update to today's HEAD
  • merge with D15410: replace AF_DATA rlock path with epoch

I think a week is a sufficient comment period for a straightforward change. I'll be committing this on Monday if there are no issues seen by pho or LLNW.

This revision is now accepted and ready to land.May 18 2018, 11:15 PM