在linux2.6 下添加系统调用步骤
作者:Amit Choudhary[amit2030@]
翻译:彭博[pengbo37877@163.com]
修订历史
Revision 1.0 2006-10-27 修订者:ac
官方发布
这是篇关于在i38 架构的装有linux2. 核心的linux 操作系统的机器上如何完成添加系统调用的信
息的文档。全篇文档还包含如何使用和修改代码及对源码、Makefile 和C 测试代码的描述。
目录
1.介绍
2.系统调用
3.需要修改/创建的文件列表
4.修改内核文件
5.syscall_table_32.S
6.unistd.h
7.syscalls.h
8.Makefile
9.创建新的内核源码/ 目录
10.mycall
11.mycall.c
12.Makefile
13.创建新的用户空间源码,测试添加的系统调用
14.testmycall.h
15.testmycall.c
16._syscall N 宏
17.测试添加的系统调用
18.问题和建议
19.版权声明
20.许可声明
1.介绍
这篇文档是介绍如何在linux2. 上完成一个新的系统调用。系统调用(用户空间)是应用程序从操作
系统请求的服务。
2.系统调用
系统调用(用户空间)是应用程序从操作系统请求的服务。接下来的声明表明为什么需要系统调用。操
作系统可以直接操作硬件,但是用户程序却不能直接操作硬件。这样做是为了让内核保持系统安全免受
用户程序的恶意破坏。但是,用户程序常常需要查看硬件的信息(比如从一个摄像头获取一张照片)。
因为用户程序不能直接访问硬件,所以需要操作系统提供硬件的信息,这些请求就使用相应的系统调用
来完成。
系统调用在内核态运行,每一个系统调用都有一个号码和它对应。这个号码传到内核使内核知道哪个系
统函数被调用。当一个用户程序发出一个系统调用,它实际调用的是一个库程序。这个库程序通过执行
INT 0x80 汇编代码内陷到linux 操作系统。它同时将系统调用号通过EAX 寄存器传入内核,系统调
用的参数也可以通过寄存器(EBX,ECX,etc. )传入内核.内核执行系统函数然后通过寄存器返回结
果给用户程序。如果系统调用需要返回大量数据给用户程序,它会使用其他的机制(例如,
copy_to_user 调用)。
1 / 11
3.需要修改/创建的文件列表
假设你的linux 内核源码放在/usr/src/linux 下面
需要修还的内核代码如下:
(1)./usr/src/linux/arch/i386/kernel/syscall_table_32.S
(2)./usr/src/linux/include/asm-i386/unistd.h
(3)./usr/src/linux/include/linux/syscalls.h
(4)./usr/src/linux/Makefile
需要创建的内核文件/ 目录如下:
(1)./usr/src/linux/mycall - 目录,包含源码,头文件,Makefile
(2)./usr/src/linux/mycall/Makefile – Makefile
需要创建的用户文件如下:
(1).testmycall.c - 源码,用来测试新添加的系统调用
(2).testmycall.h – 头文件
4.修改内核文件
5.syscall_table_32.S
文件路径 - /usr/src/linux/arch/i386/kernel/syscall_table_32.S
这个文件包含系统调用的名称
(1).在文件的结尾处添加一行,先假设你添加的系统调用名称为mycall
(2).在文件结尾处添加”.long sys_mycall”
6.unistd.h
文件路径 - /usr/src/linux/include/asm-i386/unistd.h
这个文件包含系统调用号,系统调用号在系统调用发生的时候通过寄存器传入内核
(1).在列表结尾处添加”#define __NR_mycall ”
如果最后一个系统调用的定义是
“#define __NR_vmsplice316”则在列表结尾添加
“#define __NR_my