linux 内核分析-- kthread

kernel thread 是如何产生出来?
今天我们来分析这个问题。

内核存在一个服务线程(kthreadd)来完成我们对内核线程的创建请求。
所以当我们call kthread_create的时候。就产生了一个请求。然后等待 服务线程(kthreadd)的服务 。
服务线程简单的从请求队列里拿出请求产生新的线程 ,

先上图。下图是完整的过程 图
R0cHM6Ly9ibG9nLmNzZG4ubmV0L3N0YW5kYmFjaw==,size_16,color_FFFFFF,t_70)

  1. 从kthread_create开始
    [kernel/kthread.c]
    [include/linux/kthread.h]
    kthread_create 做了两件事
    a. 打包请求, 把要产生的新线程的function,以及参数打包成kthread_create_info,然后把他挂在请求队列里面
    然后唤醒kthreadd做事。

    struct kthread_create_info
    {
    int (*threadfn)(void *data);
    void *data;
    int node;
    struct task_struct *result;
    struct completion *done;
    struct list_head list;
    };

    b. 等待 khtreadd 完成线程 的产生
    c.在新线程 产生后。设定线程 的。名字, cpu mask…

  2. kthreadd
    kthread 是一个kernel thread.他在系统 init的时候 就产生了
    (可以参考/init/main.c @rest_init)
    他在一个for loop里不停的查看请求队列。当发现非空时就开始处理新的请求
    里面只是简单的call了 __do_fork,产生一个新的线程。
    这里新的线程 并不是直接 以,用户请求的function为入口的。

    pid = kernel_thread(kthread, create, CLONE_FS | CLONE_FILES |
    SIGCHLD);

    而是以一个kthread的内核函数为入口的。。用户请求被包在了里面。后面我们会看到。

  3. threadfn, 新的开始
    新的线程kthread .被 创建后就开始运行
    他会告诉 请求线程,新线程已经建立起来。
    然后新线程就进入parked 状态。
    等待wake_up_process被call.后。新线程才开始运行

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值