linux_kernel_hacking / 3_RootkitTechniques /
@Motoki Miura Motoki Miura authored on 8 Dec 2023
..
3.0_hiding_lkm added further info links and missed credits 4 years ago
3.1_syscall_hooking support 5.15.0 2 years ago
3.2_kill_signalling support 5.15.0 2 years ago
3.3_set_root support 5.15.0 2 years ago
3.4_hiding_directories support 5.15.0 2 years ago
3.5_hiding_processes support 5.15.0 2 years ago
3.6_hiding_ports support 5.15.0 2 years ago
3.7_char_interfering support 5.15.0 2 years ago
3.8_privileged_container_escaping replace file_operations with proc_fops for proc_create() in kernel 5.6+ 4 years ago
3.9_hiding_logged_in_users support 5.15.0 2 years ago
Makefile add Makefile for sec3 1 year ago
README.md added further info links and missed credits 4 years ago
README.md

Linux Kernel Hacking

3: Rootkit Techniques

Updated to work with kernel 5.7+

There are two main way to hook syscalls via a kernel module. The first, old-fashioned way is to directly modify the sys_call_table structure in kernel memory. This is done by modifying the function pointer in this table corresponding to the syscall we're targetting to temporarily point to our own version. By saving the original value of this pointer we can both maintain the original functionality as well as restore the table when we're done. This is what is done in Section 3.1.

The other more modern method is to use ftrace. While it's meant to be used for debugging the kernel, we can use it to replace the arbitrary functions in memory with a hook instead. If you want to understand in detail what's going on with ftrace, then I suggest taking a look at the documentation linked.

As far as the function hooking goes, it's quite simple. We give a function declaration for the original function, then we write the function hook. Then, we define the hooks array which contains ftrace_hook structs containing the name, hook function address and original function address. Once we enter the module initialization function, we just call the fh_install_hooks() function defined in ftrace_helper.h and pass the hooks array to it. This does all the heavy lifting for us. Likewise, when module exit function gets called, we just call the fh_remove_hooks() function.

References/Further Reading