| .. | |||
| Makefile | 5 years ago | ||
| README.md | 5 years ago | ||
| rootkit.c | 5 years ago | ||
Hijacking the linux syscall table, and hooking sys_mkdir.
We have to use the pt_regs struct defined in arch/x86/include/asm/ptrace.h in order to be able to access the argument passed to the syscall in our hook. Crucially, we have to define orig_mkdir via:
typedef asmlinkage long (*orig_mkdir_t)(const struct pt_regs *);
orig_mkdir_t orig_mkdir;
...
asmlinkage int hook_mkdir(const struct pt_regs *regs)
{
    ...
}
This means that we can wrap around this syscall by doing whatever we want to do in our hook, and then just pass the entire pt_regs struct over to this function pointer with orig_mkdir(regs) when we're done.
The other benefit of doing this is that we only have to extract the arguments that we are interested in and not all of them solely for the purpose of passing them along to the real syscall. Looking up sys_mkdir here, we see that *pathname is stored in the rdi register. This means that we simply dereference the string containing the new directory with (char *)regs->di.
To use:
makeinsmod rootkit.komkdir admesgrmmod rootkit