利用内核模块添加系统调用
作者: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 未本地化版本许可协议进行许可。
posted on 2013-09-05 22:21 YoungerChina 阅读(2815) 评论(1) 编辑 收藏 举报