Linux内核学习从零单排(二)

系统调用:

在Linux中,每个系统调用都有一个系统调用号,独一无二,且一旦分配就不能改变,即使一个系统调用被删除,该系统调用号也不允许收回。sys_ni_syscall()专门填补无效的系统调用。内核记录了系统调用表中的所有已注册过的系统调用的列表,存储在sys_call_table中。

系统调用执行速度快:其一,上下文切换时间短,其二,系统调用处理程序和系统调用本身简洁。

应用程序需要执行系统调用时,通过一个软中断(引发一个异常使系统切换到内核态),该异常处理程序即为系统调用处理程序system_call()。当系统调用返回时,控制扔回到system_call()中,它会负责切换回用户空间,并让用户进程继续执行。


系统调用的实现:

编写玩一个系统调用后,把它注册成一个正式到系统调用:1)在系统调用表到最后加入一个表项,从0算起,它在表中到位置就是它到系统调用号。2)在<asm/unistd.h>钟定义该系统调用使之支持各种体系结构。3)将该系统调用编译进内核。只要把它放进kernel/目录下到一个相关文件即可,如sys.c。再启动内核即可使用该新系统调用。

你可能感兴趣的:(Linux内核学习从零单排(二))