一、Linux的一般执行过程
Linux系统的一般执行过程可以涉及用户态和内核态两个层次,其中用户态是用户进程的执行环境,而内核态是操作系统内核的执行环境。用户态进程的执行过程中,会通过系统调用等方式进入内核态,执行特权操作并返回用户态。
具体的执行过程可以概括为以下几个步骤:
- 用户态进程的执行:用户态进程的执行包括代码的解释和数据的读取等操作,其执行过程是在进程的用户地址空间中进行的。用户态进程可以通过系统调用等方式请求内核态执行某些特权操作,如打开文件、创建新进程等。
- 进入内核态:当用户态进程需要执行特权操作时,例如系统调用,会触发一个硬件中断或者异常,使CPU完成load cs:rip(entry of a specific ISR),即跳转到中断处理程序入口,进入内核态。在进入内核态前,CPU会利用swapgs指令保存现场。具体而言,CPU将用户态进程的上下文(如寄存器、栈指针等信息)保存到进程的内核栈中。此时,CPU会将控制权转移到内核态中断服务例程(ISR)的代码中,即中断执行路径的起点。
- 中断服务例程的执行:在完成上下文的保存后,根据中断类型的不同,开始执行具体的中断处理代码,这些代码通常是内核提供的,也可以由驱动程序等其他代码提供。中断处理代码的具体内容也取决于中断类型和硬件平台。
- 进程调度:中断处理过程中或中断返回前可能调用了schedule函数出现进程切换的情况。当一个进程被抢占或者主动放弃CPU时,内核会调用进程调度器选择另一个进程继续执行。进程调度器会根据一些策略,如优先级、时间片等,选择下一个要执行。若进行了进程切换,则需要通过switch_to进行进