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

你可能感兴趣的:(linux)