Page MenuHomeFreeBSD

kern linker: Do not try to unload kernel
ClosedPublic

Authored by zlei on Nov 9 2023, 3:43 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 9, 11:23 PM
Unknown Object (File)
Thu, Jan 9, 11:11 PM
Unknown Object (File)
Thu, Jan 9, 1:45 PM
Unknown Object (File)
Mon, Jan 6, 6:09 PM
Unknown Object (File)
Thu, Jan 2, 4:07 PM
Unknown Object (File)
Tue, Dec 31, 7:46 PM
Unknown Object (File)
Dec 9 2024, 3:19 AM
Unknown Object (File)
Dec 2 2024, 7:01 AM

Details

Summary

The userland or kernel shall not unload the kernel module.

MFC after: 2 weeks

Test Plan
# kldstat 
Id Refs Address                Size Name
 1    1 0xffffffff80200000  1d35008 kernel
# kldunload kernel
kldunload: can't unload file: Device busy

Diff Detail

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

Event Timeline

zlei requested review of this revision.Nov 9 2023, 3:43 PM
This revision is now accepted and ready to land.Nov 9 2023, 3:44 PM

I was about to commit this I found that prior to d9ce8a41eac9 (kern_linker: Handle module-loading failures in preloaded .ko files) the kernel can not be unloaded.

CC the author @cem for this. See also discuss at ML https://lists.freebsd.org/archives/freebsd-current/2023-November/004950.html .

So this is more a regression than a feature.

I tested FreeBSD-11.4-RELEASE-amd64-bootonly.iso which does not have d9ce8a41eac9 ,:

# kldunload kernel
kldunload: can't unload file: Device busy

There is also log kldunload: attempt to unload file that was loaded by the kernel from dmesg.

So I can conclude d9ce8a41eac9 introduced regression.

jhb added a subscriber: jhb.

Yes, this is a regression from d9ce8a41eac9 and I think this is the right way to fix it.

sys/kern/kern_linker.c
1866–1867

Blank line before comment