Linking shared library in linux kernel

2019-01-26 21:55发布

问题:

I would like to modify the linux kernel.

I would like to use functions from a shared library (an .so file) in file kernel/panic.c.

Unfortunately I don't know how to compile it.

When I put it in to the Makefile I receive the following error:

ld: attempted static link of dynamic object.

Is there a way to put the shared library file to the Linux kernel or do I need to recompile my library to gain an object file.

回答1:

It is not possible to link shared library into kernel code (ELF shared objects are a user-space thing, using ld-linux(8)...) You should consider making a kernel module (and use modprobe(8) to load it). Read Loadable Kernel Module HowTo.

kernel modules *.ko are conceptually similar to shared objects *.so but the linking mechanism is different.

BTW, you generally should avoid writing kernel code and should prefer coding application code. In other words, modifying the kernel is generally a bad idea and is frowned upon.

Also, the API available in kernel space is not the same as user space API (which extends the C standard library and POSIX functions). For example, kernel modules (and kernel code) don't have (so cannot call) fopen or fprintf or fork; the kernel is a freestanding C application. Also, kernel code cannot use any floating point operation!

Userland applications are interacting with the kernel using system calls listed in syscalls(2) (and the libc is using them, e.g. for printf or system(3)). Kernel code (including kernel modules) cannot use directly syscalls (since they are provided by the kernel, see syscalls(2)).

Read also Advanced Linux Programming (mostly about application programming) and Operating Systems: Three Easy Pieces (to get a broader view about OSes).