系统调用基本概念
- 系统调用实质就是函数调用,只是调用的函数是系统函数,处于内核态而已。用户在调用系统调用时会向内核传递一个系统调用号,然后系统调用处理程序通过此号从系统调用表中找到相应的内核函数执行(系统调用服务例程),最后返回,在这个过程中涉及系统调用号、系统调用表以及系统调用处理程序等概念。
系统调用号
- Linux Linux为每一个系统调用定义了一个唯一的编号,此编号称为系统调用号。
// linux/arch/x86/ includeunistd32.h
#define __NR_restart_syscall 0
#define __NR_exit 1
#define __NR_fork 2
#define __NR_read 3
#define __NR_write 4
#define __NR_open 5
... ... ...
#define NR_syscalls 363
- 由此可见当前系统拥有363个系统调用。系统调用号的另一个目的是作为系统调用表的下标,当用户空间的进程执行一个系统调用的时候,这个系统调用号就被用来指明到底是要执行哪个系统调用。系统调用号相当关键,一且分配好就不能再有任何改变,否则编译好的应用程序就会因为调用到错误的系统调用而导致程序崩溃。
系统调用表
- 为了把系统调用号与相应的服务例程关联起来,内核利用了一个系统调用表,这个表存放在sys_call_table数组中,它是一个函数指针数组,每一个函数指针都指向其系统调用的封装例程,有NR_syscalls个表