利用内核模块添加系统调用

作者:Younger Liu,本作品采用知识共享署名-非商业性使用-相同方式共享 3.0 未本地化版本许可协议进行许可。 

       操作系统的主要功能是为应用程序的运行创建良好的环境,为了达到这个目的,内核提供一系列具备预定功能的多内核函数,通过一组称为系统调用(system call)的接口呈现给用户。系统调用把应用程序的请求传给内核,调用相应的的内核函数完成所需的处理,将处理结果返回给应用程序,如果没有系统调用和内核函数,用户将不能编写大型应用程序。
Linux系统调用,包含了大部分常用系统调用和由系统调用派生出的的函数。

其步骤如下,

第一:增加系统调用号

在文件unistd_32.h或unistd_64.h(取决去您的机器是32位还是64位的)下,添加系统调用号,

比如:(最后一个系统调用号为348)

#define __NR_mysyscall  349

如果存在系统调用总数目宏,那么也需要修改系统调用号的数目(原来为349)

#define NR_syscalls 350

第二:实现int sys_yoursyscall()系统调用

新增一个系统调用就意味着要给内核增加1个函数,将新函数放入文件kernel/sys.c中(当然你也可以新增一个文件,那么就必须将新增文件添加到Makefile文件中使得随着内核一起编译)。新函数代码如下:

asmlingkage sys_testsyscall()
{
    ……
    return 0;
}

第三:内核编译及重启

(2.6.32之后标准linux内核版本编译)

make clean;

make –j (-j表示并行编译,速度较快,但也会使得您的机器无法做其他工作)

make install

reboot

第四:测试新系统调用

作者:Younger Liu,本作品采用知识共享署名-非商业性使用-相同方式共享 3.0 未本地化版本许可协议进行许可。 

原文地址:https://www.cnblogs.com/youngerchina/p/5624572.html