Linux内核简介
一、Linux体系结构
从上图得知,Linux由用户空间和内核空间两部分组成。
为什么Linux系统会被划分为用户空间与内核空间?
现代CPU通常实现了不同的工作模式,以ARM为例,实现了7种工作模式:用户模式(usr)、快速中断(fiq)、外部中断(irq)、管理模式(svc)、数据访问中止(abt)、系统模式(sys)、未定义指令异常(und)
X86也实现了4个不同的级别:Ring0—Ring3。Ring0下,可以执行特权指令,可以访问IO设备等,在Ring3则有很多限制。
Linux系统利用了CPU的这一特性,使用了其中的两级来分别运行Linux内核与应用程序,这样使操作系统本身得到充分的保护。例如:如果使用X86,用户代码运行在Ring3,内核代码运行在Ring0。
内核空间与用户空间是程序执行的两种不同状态,通过系统调用和硬件中断能够完成从用户空间到内核空间的转移。
二、Linux内核架构
1. 系统调用接口
SCI 层为用户空间提供了一套标准的系统调用函数来访问Linux内核,搭起了用户空间到内核空间的桥梁。
2. 进程管理
进程管理的重点是创建进程(fork、exec),停止进程(kill、exit),并控制它们之间的通信(signal 或者 POSIX 机制)。进程管理还包括控制活动进程如何共享CPU,即进程调度。
3. 内存管理
内存管理的主要作用是控制多个进程安全地共享内存区域。
4. 网络协议栈
内核协议栈为Linux提供了丰富的网络协议实现。
5. 虚拟文件系统(VFS)
VFS隐藏各种文件系统的具体细节,为文件操作提供统一的接口。
6. 设备驱动
Linux 内核中有大量代码都在设备驱动程序中,它们控制特定的硬件设备。
7. 体系结构相关代码Architecture-depended code
与CPU密切相关的代码,如ARM、x86,是不同的微处理器可以使用同一套代码。