1

我尝试编写一个系统调用。我按照以下步骤操作:

linux/arch/x86/kernel/syscall_table_32.S ----> 。长系统 mycall

linux/include/linux/syscalls.h --------> asmlinkage int sys mycall (int i , int j );

linux/arch/x86/include/asm/unistd_32.h ----> #define NR mycall 333

我将 linux/Makefile 更改为 core-y += kernel/ mm/ fs/ ipc/ security/ crypto/ block/ mycall/

我创建了一个名为 mycall 的目录。---->linux/mycall

在该文件中,我放置了 mycall.c :

#include <linux/kernel.h>
asmlinkageintsysmcall(int i,int j )
{
return i + j ;
}

6)我创建Makefile。---> linux/mycall/Makefile。

obj−y := mycall.o

然后当我尝试这个系统调用时,它总是返回-1。这些行是我在 Desktop 中的测试代码。testmycall.c

#include <stdio.h>
#include <sys/syscall.h>
#define __NR_mycall 333

int main(void)
{
int x1=10, x2=20, y ;
y = syscall (__NR_mycall, x1, x2 );
printf (”%d\n”,y );
return 0 ;
}

然后我重新编译内核。如果我编译代码,没有任何问题。当我运行这个程序时,它不会将两个值相加。它总是返回-1。我的系统调用有什么问题?(当我重新编译内核时,系统没有浪费超过3秒的时间。我认为这里可能有问题)

4

1 回答 1

2

重新编译内核并重新启动。或者它是一个内核模块?

于 2009-11-11T16:09:46.953 回答