`
kjkhi
  • 浏览: 181700 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

Linux系统调用

阅读更多
系统调用可以简单说是用户程序使用系统资源的接口,但是用户程序一般都不是直接调用系统调用,而是通过系统API、C库等间接调用,执行内陷命令,进入核心态执行。

在Linux系统中,每个系统调用被赋予一个系统调用号。这样,通过这个独一无二的编号就可以关联一个系统调用。用户空间程序需要调用系统调用时,只需要给出其对应的系统调用号就可以。内存记录了系统调用表中所有已经注册过的系统调用的列表,存储在sys_call_table中。

用户程序通过软中断实现内陷操作。通过引发一个异常来促使系统切换到内核态去执行异常处理程序。在x86上,内陷之前,需要通过eax寄存器把系统调用号传递到内核。sys_call()函数通过给定的系统调用号与NR_syscalls做比较来检查其有效性。如果它大于或者等于NS_syscalls,该函数就返回-ENOSYS。否则执行相应的系统调用。一般情况下,系统调用都需要传递参数,在x86下,通过ebx,ecx,edx,esi和edi传递依次为1到5的参数。

系统调用必须检查它们所有的参数是否合法。(因为这是要在内核态运行的)。Linux系统一般提供两个方法来完成必须的检查和内核空间与用户空间的数据的来回拷贝。copy_to_user()/copy_from_user(),这俩个方法都需要三个参数,(src,dst,length)。

绑定一个自定义的系统调用,如:
asmlinkage long sys_getPID(){return current->tgid}

首先我们需要把sys_getPID加入系统调用表中,见entry.s文件。依次得到系统调用号,把系统调用号加入asm/unistd.h文件中。最后我们要实现这个系统调用,可以把它放进kernel/sys.c或者kernel/sched.c文件中。
0
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics