Page MenuHomeFreeBSD

ifnet: add if_foreach_sleep() to allow ifnet iterations with sleep.
ClosedPublic

Authored by melifaro on Mar 4 2023, 10:10 AM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Oct 15, 5:24 AM
Unknown Object (File)
Tue, Oct 14, 2:42 PM
Unknown Object (File)
Tue, Oct 14, 2:42 PM
Unknown Object (File)
Tue, Oct 14, 2:42 PM
Unknown Object (File)
Tue, Oct 14, 2:42 PM
Unknown Object (File)
Tue, Oct 14, 2:42 PM
Unknown Object (File)
Tue, Oct 14, 1:03 AM
Unknown Object (File)
Sun, Oct 12, 3:46 PM

Details

Summary

Some kernel customers exporting network interfaces may require sleep during the iteration. Netlink and linsysfs can be the examples.

This change adds the generic iteration interface, similar to if_foreach(), but allowing the callback to sleep.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 50142
Build 47034: arc lint + arc unit

Event Timeline

Update match function signature.

sys/net/if.c
4591

seems should be error = cb();

This revision was not accepted when it landed; it landed in state Needs Review.Mar 6 2023, 3:09 PM
This revision was automatically updated to reflect the committed changes.

As discussed in email, if_foreach_sleep() sounds like the loop itself inserts a delay. I suggest changing it to if_foreach_sleepable(), which more accurately conveys that it can sleep (or use callbacks that can sleep), not that that it does sleep.