1.首先,作为一个Ubuntu系统,需要下载一套内核源码,网址是www.kernel.org. 下载了一个版本后解压到自己想要的位置。
我是解压到的/usr/src这个文件夹下面。
2.进入 linux-版本号/arch/x86/syscalls这个文件夹,打开这个文件,在文件的最末尾写上一行.
格式大概是这样子
545(相当于标识符) 64(表示64位系统) myservice(自己命名) sys_myservice(函数名字)
3.
前面的编写相当于一个声明,但是我们还需要对头文件声明一下
进入linux-版本号/include/linux 打开,在#endif后面加上asmlinkage int sys_myservice(void);
4.
之前声明完了很多东西,现在开始写函数的内容
进入linux-版本号/kernel,建立一个myservice.c的文件
5.
还是这个文件夹
这里要创建一个Kconfig file(我也不知道是什么,但是应该是和这个c文件相关的)
命名为Kconfig.myservice
6.
继续在这个文件夹下(如果不是创建一个新的文件,就不需要这步骤了)
编辑一个叫做Makefile的文件,这里应该是包含了我们写的函数的描述之类的东西
7.
回到上级文件夹,编辑它里面的Makefile文件,需要改变的就一行,这个就是和你编译出来的内核名字相关了(随意写)
8.
所有的基础工作已经完成了,现在开始编译我们的内核
a).
首先需要建立一个.config文件,可以通过make menuconfig指令来执行,但是需要设置大量的参数,所以我们可以利用/boot 里面的文件
把它复制到linux-版本号这个文件夹下面,然后运行make menuconfig指令,
看到这样的界面,运行<Load>,输入的名字
,然后save,命名为.config,然后看看有没有出现这个文件(这个文件默认是隐藏的,所以需要Ctrl+H)
b).
既然已经配置好了,我们就可以开始编译安装了。
因为我是Ubuntu系统,所以很方便
配置完内核之后,接下来要执行真正的编译过程。通常我们可以这样下命令:
make-kpkg --initrd --revision wwang.001 --append-to-version -20110107 kernel_image
|
1、--initrd选项会让make-kpkg自动帮我们生成initramfs;
2、--revision会给生成的deb文件加上一个版本信息。这个参数只是影响到文件名,如果不指定,默认会是“10.00.Custom”;
3、--append-to-version也是一种版本信息,它不仅出现在deb安装包的文件名里,也会影响到kernel的名称,比如本例中,内核更新完成之后,用“uname -r”察看会得到“2.6.36-20110107”;
4、kernel_image表示生成内核和默认模块的安装包,另外您也可以加上kernel_headers,这样make-kpkg会再生成一个内核头文件的安装包。
如果我们用普通用户来执行make-kpkg,需要加上fakeroot运行。
fakeroot make-kpkg --initrd --revision wwang.001 --append-to-version -20110107 kernel_image
|
编译过程执行完毕之后,会在上层目录里生成一个deb安装包,本例中生成的安装包的文件名是“linux-image-2.6.36-20110107_wwang.001_i386.deb”。
上面这一段是百度到的,需要下载一个包,然后就可以用make-kpkg指令了。(编译时间很长)
End.
重启之后选择Ubuntu高级选项,可以看到我们的内核
进来之后grep myservice /proc/kallsyms ,可以判断我们的系统调用增加成功了没有。
接着我们就可以来写个测试程序来调用我们的[系统调用]了。
- #include <linux/unistd.h>
- #include <sys/syscall.h>
- int main()
- {
- syscall(545); //还记得一开始增加的这个数字吗?
- printf("成功!");
-
- }
相关资料:http://www.franksthinktank.com/howto/addsyscall/
http://blog.csdn.net/rk2900/article/details/8281335
http://www.cnblogs.com/wwang/archive/2011/01/07/1929486.html