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 @   Fredric_2013  阅读(312)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示