Page MenuHomeFreeBSD

ng_eiface: fix kernel panic due to the racecondition in ng_eiface shutdown
ClosedPublic

Authored by afedorov on Apr 24 2020, 1:08 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 3, 10:52 AM
Unknown Object (File)
Thu, Jan 2, 3:04 AM
Unknown Object (File)
Tue, Dec 17, 2:38 PM
Unknown Object (File)
Sun, Dec 15, 1:01 AM
Unknown Object (File)
Sat, Dec 14, 2:39 PM
Unknown Object (File)
Sat, Dec 14, 2:37 PM
Unknown Object (File)
Nov 29 2024, 10:49 AM
Unknown Object (File)
Nov 27 2024, 11:16 PM

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

Looks good to me (with the suggested change). If I understand correctly, the crash happens when ng_eiface_mediastatus (which dereferences ifm->ifm_cur) is called after ifmedia_removeall (which sets ifm->ifm_cur = NULL, but before ether_ifdetach.

sys/netgraph/ng_eiface.c
629

Move the ifmedia_removeall before if_free, because the ifmedia callbacks need to access ifp, and so in theory the callbacks may be called after if_free and before ifmedia_removeall, resulting in a crash (if lucky).
Moreover, ifdetach --> ifmedia_removeall --> if_free is the same sequence used in all the other drivers.

This revision now requires changes to proceed.Apr 24 2020, 8:32 PM
afedorov marked an inline comment as done.
This revision is now accepted and ready to land.Apr 25 2020, 12:14 PM