Page MenuHomeFreeBSD

miibus: Use a bus_child_deleted method to free ivars for children
ClosedPublic

Authored by jhb on Oct 31 2024, 8:36 PM.
Tags
None
Referenced Files
F158912884: D47371.diff
Sun, Jun 7, 3:58 PM
Unknown Object (File)
Tue, May 19, 8:10 PM
Unknown Object (File)
Tue, May 19, 1:41 AM
Unknown Object (File)
Sun, May 17, 7:43 AM
Unknown Object (File)
Sun, May 17, 6:00 AM
Unknown Object (File)
May 5 2026, 3:22 AM
Unknown Object (File)
Apr 25 2026, 12:49 PM
Unknown Object (File)
Apr 21 2026, 6:18 PM
Subscribers
None

Details

Summary

If a device was detached (e.g. via devctl) and then re-attached, the
ivars would be freed by the previous bus_child_detached method during
detach, but device_get_ivars during the subsequent attach would return
a stale pointer resulting in a use after free.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable