OPERATING SYSTEMS -LINUX SYSTEM CALLS 1 龚玲 lgong@sjtu.edu.cn
OPERATING SYSTEMS -LINUX SYSTEM CALLS 龚玲 lgong@sjtu.edu.cn 1
什么是系统调用? o Linux内核中设置了一组用于实现各种系统功能的子程序 称为系统调用。用户可以通过系统调用命令在自己的 应用程序中调用它们。从某种角度来看,系统调用和普 通的函数调用非常相似。区别仅仅在于,系统调用由操 作系统核心提供,运行于核心态;而普通的函数调用由 函数库或用户自己提供,运行于用户态。 0 随Linux核心还提供了一些C语言函数库,这些库对系统 调用进行了一些包装和扩展,因为这些库函数与系统调 用的关系非常紧密,所以习惯上把这些函数也称为系统 调用
什么是系统调用? Linux内核中设置了一组用于实现各种系统功能的子程序 ,称为系统调用。用户可以通过系统调用命令在自己的 应用程序中调用它们。从某种角度来看,系统调用和普 通的函数调用非常相似。区别仅仅在于,系统调用由操 作系统核心提供,运行于核心态;而普通的函数调用由 函数库或用户自己提供,运行于用户态。 随Linux核心还提供了一些C语言函数库,这些库对系统 调用进行了一些包装和扩展,因为这些库函数与系统调 用的关系非常紧密,所以习惯上把这些函数也称为系统 调用
为什么要用系统调用? 实际上,很多已经被我们习以为常的C语言标准函数,在 Linux平台上的实现都是靠系统调用完成的,所以如果想对 系统底层的原理作深入的了解,掌握各种系统调用是初步的 要求。进一步,若想成为一名Linux下编程高手,也就是我 们常说的Hacker,其标志之一也是能对各种系统调用有透彻 的了解
为什么要用系统调用? 实际上,很多已经被我们习以为常的C语言标准函数,在 Linux平台上的实现都是靠系统调用完成的,所以如果想对 系统底层的原理作深入的了解,掌握各种系统调用是初步的 要求。进一步,若想成为一名Linux下编程高手,也就是我 们常说的Hacker,其标志之一也是能对各种系统调用有透彻 的了解
系统调用是怎么工作的? 一 般的,进程是不能访问内核的。它不能访问内核所 占内存空间也不能调用内核函数。CPU硬件决定了 这些(这就是为什么它被称作"保护模式")。系统调 用是这些规则的一个例外。其原理是进程先用适当的 值填充寄存器,然后调用一个特殊的指令,这个指令 会跳到一个事先定义的内核中的一个位置(当然,这 个位置是用户进程可读但是不可写的)。在Intel CPU中,这个由中断0x80实现。硬件知道一旦你跳 到这个位置,你就不是在限制模式下运行的用户,而 是作为操作系统的内核-所以你就可以为所欲为
系统调用是怎么工作的? 一般的,进程是不能访问内核的。它不能访问内核所 占内存空间也不能调用内核函数。CPU硬件决定了 这些(这就是为什么它被称作"保护模式")。系统调 用是这些规则的一个例外。其原理是进程先用适当的 值填充寄存器,然后调用一个特殊的指令,这个指令 会跳到一个事先定义的内核中的一个位置(当然,这 个位置是用户进程可读但是不可写的)。在Intel CPU中,这个由中断0x80实现。硬件知道一旦你跳 到这个位置,你就不是在限制模式下运行的用户,而 是作为操作系统的内核--所以你就可以为所欲为
系统调用是怎么工作的? 0 进程可以跳转到的内核位置叫做sysem_call。这个过 程检查系统调用号,这个号码告诉内核进程请求哪种 服务。然后,它查看系统调用表(sys_call_table)找 到所调用的内核函数入口地址。接着,就调用函数, 等返回后,做一些系统检查,最后返回到进程(或到 其他进程,如果这个进程时间用尽)。 如果你希望读 这段代码,它在<内核源码目录>kernel/entry.S, Entry(system_call)的下一行
系统调用是怎么工作的? 进程可以跳转到的内核位置叫做sysem_call。这个过 程检查系统调用号,这个号码告诉内核进程请求哪种 服务。然后,它查看系统调用表(sys_call_table)找 到所调用的内核函数入口地址。接着,就调用函数, 等返回后,做一些系统检查,最后返回到进程(或到 其他进程,如果这个进程时间用尽)。如果你希望读 这段代码,它在<内核源码目录>/kernel/entry.S, Entry(system_call)的下一行