原创内容(cxsmarkchan 陈晓爽)
转载请注明出处
《Linux内核分析》MOOC课程学习笔记
为保证系统的稳定运行,CPU运行状态被分为内核态和用户态。操作系统在内核态下运行,因此拥有所有计算机资源的操作权限。而一般的应用程序则在用户态下运行,它们不能直接操作底层的硬件设备,从而保证应用软件不会破坏系统的稳定。但是,应用程序在运行时常常需要和各种资源打交道,为此,操作系统提供了“系统调用”的功能,提供一组API,由用户态程序调用。本文通过asm内联汇编,分析系统调用的全过程。
1 系统调用的概念
下图是一个典型的系统调用图示:
从该函数可以看到,系统调用分成如下过程:
1. 用户态程序调用API函数xyz
2. 在xyz
接口函数内部,通过中断号0x80
进入系统调用,此时CPU进入内核态。
3. CPU开始执行中断处理程序,根据用户传入的信息(系统调用号和相关参数),执行相应的内核态函数,并返回结果。
这里有两个问题:
1. 内核态的切换是通过中断方式进入的,而产生中断时只能传入一个中断向量(即0x80
),而系统调用有大量的API函数,系统如何知道调用