我试着写一个系统调用。我遵循了以下步骤:
linux/arch/x86/kernel/syscall_table_32.S ->。长sys mycall
linux/include/linux/syscalls.h -> asmlinkage int sys mycall (int i,int j );
linux/arch/x86/include/asm/unistd_32.h ->#定义NR mycall 333
我将linux/Makefile更改为+= -y+=内核/ 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秒。我认为在这里,可能会有问题)
发布于 2009-11-12 00:09:47
重新编译内核并重新启动。或者它是一个内核模块?
https://stackoverflow.com/questions/1716200
复制相似问题