linux 0.11 源码学习(九)
fork.c
fork.c 是创建进程的功能实现,其核心函数式copy_process,被系统函数sys_fork(定义在System_call.s中)调用。因此源码学习从sys_fork开始,代码如下:
sys_fork: call find_empty_process //是否还能够创建进程,0.11默认最大进程数为64 testl %eax,%eax js 1f push %gs pushl %esi pushl %edi pushl %ebp pushl %eax call copy_process //调用copy_process addl $20,%esp //考虑入参在堆栈的长度 1: ret
copy_process函数原型:
int copy_process(int nr,long ebp,long edi,long esi,long gs,long none, long ebx,long ecx,long edx, long fs,long es,long ds, long eip,long cs,long eflags,long esp,long ss)
主要工作如下:
- 获取一个空闲页存储任务结构:p = (struct task_struct *) get_free_page(),并根据入参初始化;
- 调用copy_mem函数,赋值p中的代码段ldt和数据段ldt;此时并没有分配正真的物理页,见memory部分源码学习;
- 设置TSS和LDT选择描述符,设置当前fork的进程状态为RUNNING;
遗留问题:类似copy_process这样的系统调用,参数是怎么传的??