Linux 内核源代码分析 - 进程管理及调度
http://wenku.baidu.com/link?url=yzMjiwX-ZzlnYZgb8CKG5veDdv6_uTbweFpb0_LPDDf7xYilF4fImm4QcL5-0gsk6SNu9KrFUqvrzYdbl0wLU8RHGilVFMS_mPIL0HRSB4m
进程管理的任务
.允许进程复制自己(真正作到一个应用多进程)
.确定哪个进程能够拥有CPU
.接受中断并将中断导向相应的内核子系统
.向用户进程发送信号
.管理时钟硬件
.当一个进程结束时,释放其资源
.动态装载执行模块
进程模块与其他模块的依赖关系
.对用户进程提供了一组简单的系统调用接口
.对内核的其他模块提供了丰富的接口功能
内存管理模块,当一个进程被调度的时候,为它建立内存映射。
所有的其他模块都依赖于进程调度模块,因为当要进行硬件访问的时候它们需要CPU挂起用户进程,切换到系统态进行处理。
进程的创建(FORK, copy-on-write)
Linux中,进程的创建是通过拷贝已存在进程来实现的。
在Linux内核启动的时候,首先由start_kernel()初始化各个系统数据结构,同时生成了和系统共存亡的后台进程:init。
init进程通过拷贝自身,产生了若干内核子进程。然后这些进程就可以通过系统调用fork()生成它们的子进程,当然这些子进程的原始数据都是他们的父亲的副本。进程的终止是通过系统调用_exit()实现的。
进程的终止
.进程运行结束时要释放相应的资源,通过EXIT()调用实现(显式或隐式)
.EXIT()实现时调用了do_exit()完成以下工作
Task_struct中标志成员设为:PF_EXITING
调用__exit_mm()
调用sem__exit()
调用__exit_files(), __exit_fs(), exit__name__space, exit_sighand
退出代码替换为EXIT()提供的代码
调用Exit_notify()向父进程发信号,(标为ZOOMBIE)
调用shedule切换到其他进程
线程实现
Linux没有真正的线程。
仅仅是进程之间资源直接共享的一种机制。
内核线程:独立运行在内核的标准进程。