Page MenuHomeFreeBSD

bridge: Call member interface ioctl() without NET_EPOCH
ClosedPublic

Authored by kp on Sep 12 2020, 10:06 PM.
Tags
None
Referenced Files
F133209600: D26418.id76959.diff
Fri, Oct 24, 12:06 AM
F133209586: D26418.id77954.diff
Fri, Oct 24, 12:06 AM
F133209583: D26418.id77815.diff
Fri, Oct 24, 12:06 AM
F133171141: D26418.id.diff
Thu, Oct 23, 3:32 PM
F133136345: D26418.diff
Thu, Oct 23, 6:53 AM
F133113861: D26418.id77954.diff
Thu, Oct 23, 2:23 AM
Unknown Object (File)
Sat, Oct 18, 9:20 PM
Unknown Object (File)
Fri, Oct 10, 5:08 PM

Details

Summary

We're not allowed to hold NET_EPOCH while sleeping, so when we call
ioctl() handlers for member interfaces we cannot be in NET_EPOCH.
We still need some protection of our CK_LISTs, so hold BRIDGE_LOCK
instead.
That requires changing BRIDGE_LOCK into a sleepable lock, and separating
the BRIDGE_RT_LOCK, to protect bridge_rtnode lists. That lock is taken
in the data path (while in NET_EPOCH), so it cannot be a sleepable lock.

While here document the locking stategy.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

kp requested review of this revision.Sep 12 2020, 10:06 PM

bridge: Call member interface ioctl() without NET_EPOCH

We're not allowed to hold NET_EPOCH while sleeping, so when we call
ioctl() handlers for member interfaces we cannot be in NET_EPOCH.
We still need some protection of our CK_LISTs, so hold BRIDGE_LOCK
instead.
That requires changing BRIDGE_LOCK into a sleepable lock, and separating
the BRIDGE_RT_LOCK, to protect bridge_rtnode lists. That lock is taken
in the data path (while in NET_EPOCH), so it cannot be a sleepable lock.

While here document the locking stategy.

kp retitled this revision from bridge: Do not enter NET_EPOCH in bridge_ioctl() to bridge: Call member interface ioctl() without NET_EPOCH.Oct 3 2020, 3:42 PM
kp edited the summary of this revision. (Show Details)
This revision was not accepted when it landed; it landed in state Needs Review.Oct 6 2020, 7:20 PM
This revision was automatically updated to reflect the committed changes.