Page MenuHomeFreeBSD

iflib: Remove redundant VLAN events deregistration
ClosedPublic

Authored by piotr.pietruszewski_intel.com on Sep 19 2019, 9:20 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 4, 1:28 AM
Unknown Object (File)
Wed, Dec 25, 8:03 PM
Unknown Object (File)
Tue, Dec 24, 7:56 PM
Unknown Object (File)
Dec 4 2024, 6:59 AM
Unknown Object (File)
Dec 4 2024, 6:59 AM
Unknown Object (File)
Dec 4 2024, 6:59 AM
Unknown Object (File)
Dec 4 2024, 6:35 AM
Unknown Object (File)
Nov 26 2024, 7:05 PM
Subscribers

Details

Summary

r351152 introduced iflib_deregister() function calling
EVENTHANDLER_DEREGISTER() to unregister VLAN events. This patch removes
duplicate of EVENTHANDLER_DEREGISTER() calls placed in
iflib_device_deregister() as this function is now calling
iflib_deregister(). This is to avoid deregistering same event twice.

This patch also adds check in iflib_vlan_register() to prevent
registering VLAN while being in detach.

Patch co-authored by Krzysztof Galazka <krzysztof.galazka@intel.com>,
erj <erj@FreeBSD.org> and Jacob Keller <jacob.e.keller@intel.com>.

Signed-off-by: Piotr Pietruszewski <piotr.pietruszewski@intel.com>

Test Plan

Before applying this patch, kernel panic should be observed after issuing:

for i in {1..10}; do kldunload if_ix; kldload if_ix; done

Usually, less than 10 cycles are needed to trigger the panic. After applying
the patch, panic should be gone.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 26563
Build 24951: arc lint + arc unit