一、结合虚拟化技术分析Linux系统的一般执行过程
(一)Linux系统的一般执行过程分析
正在运行的用户态进程X切换到运行用户态进程Y的过程
(1)正在运行的用户态进程X
(2)发生中断——save cs:eip/esp/eflags(current) to kernel stack
then load cs:eip(entry of a specific ISR) and ss:esp(point to kernel stack).
(3)SAVE_ALL
(4)调用schedule(),switch_to做了关键的进程上下文切换
(5)标号1之后开始运行用户态进程Y(这里Y曾经通过以上步骤被切换出去过因此可以从标号1继续执行)
(6)restore_all //恢复现场
(7)iret - pop cs:eip/ss:esp/eflags from kernel stack
(8)继续运行用户态进程Y
(二)Linux执行过程中的几种特殊情况
(1)通过中断处理过程中的调度时机,用户态进程与内核线程之间互相切换和内核线程之间互相切换,与最一般的情况非常类似,只是内核线程运行过程中发生中断的时候没有进程用户态和内核态的转换,cs不会变化;
(2)内核线程主动调用schedule(),只有进程上下文的切换,没有发生中断上下文的切换,与最一般的情况略简略;
(3)创建子进程的系统调用在子进程中的执行起点(如ret_from_fork,上文中也已经提到过)及返回用户态;
(4)加载一个新的可执行程序后返回到用户态的情况,如execve;
二、Linux操作系统分析课程中的收获
本门课程让我深入了解了Linux内核的原理和机制,课程从Linux操作系统的结构、内核和管理,了解不同操作系统的特点各个方面讲解了linux系统,着重讲解了系统调用、进程切换的过程,并以此分析了Linux内核的运行过程。
通过本门课程,我学习到了Linux操作系统进程管理、内存管理、文件系统的基本概念,以及实践了编译内核,构建根文件系统,qemu模拟环境启动内核的过程,使用vccode调试,从关键函数分析一个程序运行时的过程,对于进程切换有了全新的的理解。为学习linux内核的学习指明了方向。为今后的计算机软硬件系统平台上的开发设计打下坚实的基础