Execute a program in kernel space in Linux
If I want to execute a开发者_开发技巧 user program (not a kernel module) in Linux kernel space, what options do I have?
I have looked at KML(kernel mode linux) but that is specific to IA-32 architecture. I want a solution which is cross platform and can work on embedded linux systems.
User programs don't execute in kernel space - that's what makes them user programs.
If you want to execute code in kernel space you have two options: build it in to the kernel, or load it with a kernel module.
call_usrmodehelper
You wrote in another question that you are a newcomer to kernel programming. Using KML is highly unconventional, and will be far more complicated that doing things in the standard way. That will make your learning that much more difficult. I would suggest that your best option is reevaluate why you want to run a user space app in kernel space and find way not to do it.
There may be a good reason to do such a thing, but it's not clear to me what that reason could be. One thing you should understand with kernel development is that just because something is possible, it's not necessarily something that should be done.
If you really want a cross platform solution, you'll have to write it yourself. The only architectures supported by KML are IA32 and AMD64.
Kernel programming is pretty much by definition platform specific, since kernels for different platforms are all different.
Take a look at FemtoLinux. Basically, it is a KML for embedded systems and embedded processors such as ARM and MIPS
If you want to start a user program from kernel space, take a look at run_init_process(). It's the way kernel run the init program.
You could execute it the same way the bootloader executes the operating system (remember, an operating system is just one or more programs executed on top of the kernel). Per standard operation, the bootloader transfers execution to the kernel program along with a selection of parameters, just like a CLI program, and then loads the /init
executable or whatever is specified by the rdinit
parameter as the main application of the operating system; in reality this could be any program, provided that all required concurrent processes (a.k.a. "services") for that application are running, as is demonstrated by the fact that the original /init
program was a shell script that concurrently launched those required processes.
See also:
- https://www.kernel.org/doc/html/v4.14/admin-guide/kernel-parameters.html
FYI: I'm well aware that this question is more than ten years old and thus either answered or dropped, despite that this solution was even available at that time, so "this is for posterity..."
精彩评论