K 10 svn:author V 6 emaste K 8 svn:date V 27 2021-01-29T01:06:03.187166Z K 7 svn:log V 744 MFC r368237: if: Fix panic when destroying vnet and epair simultaneously When destroying a vnet and an epair (with one end in the vnet) we often panicked. This was the result of the destruction of the epair, which destroys both ends simultaneously, happening while vnet_if_return() was moving the struct ifnet to its home vnet. This can result in a freed ifnet being re-added to the home vnet V_ifnet list. That in turn panics the next time the ifnet is used. Prevent this race by ensuring that vnet_if_return() cannot run at the same time as if_detach() or epair_clone_destroy(). PR: 238870, 234985, 244703, 250870 Sponsored by: Modirum MDPay Approved by: so Git Hash: e0c15f45abd4bd5165e11b557a8c90d0faf5cfeb Git Author: kp@FreeBSD.org END