Page MenuHomeFreeBSD

kexec: Disallow kexec_load if securelevel > 0
ClosedPublic

Authored by jhibbits on Wed, Apr 22, 3:52 PM.
Tags
None
Referenced Files
F154532417: D56580.diff
Tue, Apr 28, 8:29 PM
Unknown Object (File)
Mon, Apr 27, 5:17 PM
Unknown Object (File)
Mon, Apr 27, 4:59 PM
Unknown Object (File)
Mon, Apr 27, 8:37 AM
Unknown Object (File)
Sat, Apr 25, 6:11 AM
Unknown Object (File)
Sat, Apr 25, 6:02 AM
Unknown Object (File)
Fri, Apr 24, 5:41 AM
Unknown Object (File)
Wed, Apr 22, 4:01 PM
Subscribers

Details

Summary

kexec_load() + reboot is intended to be equivalent to a system reboot.
However kexec_load() can load arbitrary data as the target kernel,
leading to execution of arbitrary code, even though it's effectively in
a new context. Rather than being equivalent to a system reboot, it's
also equivalent to kldload(), which loads arbitrary code into the
running kernel. Since kldload() is blocked at securelevel 1, also block
kexec_load().

Reported by: markj
Fixes: e02c57ff3 ("kern: Introduce kexec system feature (MI)")
MFC after: 2 weeks
Sponsored by: Hewlett Packard Enterprise

Diff Detail

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

Event Timeline

MFC after: 2 weeks

It looks like kexec was never MFCed?

This revision is now accepted and ready to land.Wed, Apr 22, 4:05 PM

MFC after: 2 weeks

It looks like kexec was never MFCed?

Oops, I thought I had gotten kexec_load in just before stable/15 branched, but guess not. No need to MFC, then.