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这样的系统调用,参数是怎么传的??

posted @ 2013-05-04 20:01  Fredric_2013  阅读(307)  评论(0编辑  收藏  举报