Linux增加系统调用步骤和实例

添加系统调用步骤

   

         ①    编写系统调用函数 sys_file_copy(char *,char*),然后添加到 /usr/mylinux/linux-3.2.13/kernel/sys.c,也就是新内核的源程序sys.c文件末尾;

         ②    分配系统调用号:打开/usr/mylinux/linux-3.2.13/arch/x86/include /asm/unistd_32.h,添加一行#define_NR_file_copy 350;

         ③    增加新的内核函数指针:打开/usr/mylinux/linux-3.2.13/arch/x86/kernel/syscall_table_32.s,在末尾添加一行.long sys_file_copy,这里要数正确这行的序号,我的在349行;

         ④    在新内核 linux3.2.13并解压到 /usr/mylinux目录下(我在/usr/kernel中进行不了文件操作,除了查看);

         ⑤    复制目录下的文件到 /usr/mylinux/linux-3.2.13,并重命名为.config;

         ⑥    root权限进入/usr/mylinux/limux-3.2.13目录;

         ⑦    $makemrproper:清除之前编译的内容;

         ⑧    $ make:命令编译内核。如果你的计算机是4核的,可以添加–j4参数让编译程

序同时使用4核编译,这样可以节省近半的时间。如果你为linux系统分配的空间不多,可以执行 make localconfig,精简编译,并且时间也只需要几十分钟。如果编译中途意外中断,然后想重新开始编译,需要先执行下面命令清理一下编译现场然后再编译:
       $ make mrproper

         ⑨    $ makemodules_install:生成并安装模块,向/lib/modules/3.2.13添加modules;

         ⑩    $ makeinstall:安装编译好的内核映像文件,它会把编译文件夹里的“arch/x86/boot/bzImage”文件复制到“/boot”,同时还会复制config和System.map文件,最终在“/boot”会多出如下3个文件

         /boot/config-3.2.13

         /boot/System.map.3.2.13

         /boot/vmlinuz-3.2.13  ;

        ⑪      $mkinitramfs3.2.13 –o initrd.img-2.6.28:生成内核境像文件,用于初始ram磁盘文件;

        ⑫      修改开机启动项。可以执行$sudo gedit /boot/grub/grub.cfg命令打开开机启动项配置文件,自己修改增加新内核标签;也可以执行$sudo update–grub2命令,系统会自动帮你修改grub.cfg文件,但它会把之前的内核引导项去掉,如果你对你的新内核不是很有把握的话,还是别这么做。

我遇到的问题和需要注意的

       ①编译内核执行到make install时,出现如下错误,

Missing file: arch/x86/boot/bzImage

You need to run "make" before "makeinstall".

       说明我执行make命令的时候就出错了,没有生成bzImage文件。我再从头开始编译,还是有这个错误。之后我重新下载了内核压缩包并解压,这次编译成功,但是花了1个半小时的时间,真的等得挺痛苦的。

       ②在测试程序中添加系统调用时,syscall(349,argv[1],argv[2]) 中的349

sys_table_32.s中添加 .long sys_file_copy的序号,而不是unistd_32.h文件中申请的调用号#define _NR_file_copy  350;

        执行复制文件的系统调用代码:

asmlinkage int sys_file_copy(char *source_file, char *aim_file)
{
	int file1, file2, n;
	char buf[512];
	mm_segment_t fs;

	if( (file1 = sys_open(source_file,O_RDONLY,0)) == -1){
		printk("Can't open %s\n",source_file);
		sys_exit(-1);
	}
	if( (file2 = sys_open(aim_file,O_CREAT|O_WRONLY|O_TRUNC,0666)) == -1){
		printk("Can't create %s,mode %o\n",aim_file,0666);
		sys_exit(-1);
	}

	fs = get_fs(); 
	set_fs(get_ds());

	while( (n = sys_read(file1,buf,512)) > 0){
		if(sys_write(file2,buf,n) != n){
	                 printk("Write file %s error\n",aim_file);
			sys_exit(-1);
		}
	}

	set_fs(fs);
	sys_close(file1);
	sys_close(file2);
	return 0;
}




           测试系统调用代码:

#include
#include
#include
#define _NR_file_copy 349

int main(int argc, char *argv[])
{
	int i;
	if(argc != 3){
		printf("error\n");
	}
	else{
		syscall(349,argv[1],argv[2]);
		printf("OK\n");
	}
	return 0;
}


你可能感兴趣的:(linux,系统调用)