On Tue, 2024-11-19 at 13:14 +0100, Christoph Hellwig wrote:
On Tue, Nov 19, 2024 at 11:49:09AM +0100, Roberto Sassu wrote:
From: Roberto Sassu roberto.sassu@huawei.com
Introduce ksys_finit_module() to let kernel components request a kernel module without requiring running modprobe.
That does sound more than sketchy, even more so because the commit log completely fails to explain why you'd need to do that.
With my solution, the kernel grants access to a file in user space depending on whether or not its calculated (or fsverity) digest is found in an application manifest provided by the software vendor.
However, what it happens is that in the early boot phase the parser is not loaded yet, and the kernel cannot extract the reference digests from the application manifest.
Thus, calling request_module() and consequently executing modprobe will fail, since the kernel does not have its reference digest yet.
Instead, loading the kernel module from the kernel itself works, because only the kernel module needs to be verified, and that can be done through its appended signature.
Roberto