在kthread_create的定义中,任务被唤醒,是否有人知道这个任务在做什么?
struct task_struct *kthread_create
{
struct kthread_create_info create;
create.threadfn = threadfn;
create.data = data;
init_completion(&create.done);
spin_lock(&kthread_create_lock);
list_add_tail(&create.list, &kthread_create_list);
spin_unlock(&kthread_create_lock);
**wake_up_process(kthreadd_task);**
wait_for_completion(&create.done);
if (!IS_ERR(create.result)) {
struct sched_param param = { .sched_priority = 0 };
va_list args;
va_start(args, namefmt);
vsnprintf(create.result->comm, sizeof(create.result->comm),
namefmt, args);
va_end(args);
/*
* root may have changed our (kthreadd's) priority or CPU mask.
* The kernel thread should not inherit these properties.
*/
sched_setscheduler_nocheck(create.result, SCHED_NORMAL, ¶m);
set_cpus_allowed_ptr(create.result, cpu_all_mask);
}
return create.result;
}
Run Code Online (Sandbox Code Playgroud)
kthreadd_task是指向http://lxr.linux.no/#linux+v2.6.36/kernel/kthread.c#L231定义的task_struct内核线程 runnind 函数的指针kthreadd()
kthreadd()是守护进程的主要函数(和主循环),kthreadd它是一个内核线程守护进程,是所有其他内核线程的父级。
因此,在引用的代码中,创建了对 kthreadd 守护进程的请求。为了满足这个请求,kthreadd 将读取它并启动一个内核线程。然后它会改变标志。在代码中,您正在等待该标志。更改标志后,您的函数将检查新 kthread 创建的状态。