kernel_thread

kernel thread可以用kernel_thread创建,但是在执行函数里面必须用daemonize释放资源并挂到init下,还需要用completion等待这一过程的完成。 
kthread_create是比较正牌的创建函数,这个不必要调用daemonize,用这个创建的kernel thread都挂在了kthread线程下。
从表面上来看,这两个函数非常的类似,但是实现却是相差甚远。
kthread_create是通过work_queue来实现的,kernel_thread是通过do_fork来实现的。
kthread_create:
DECLARE_WORK(work, keventd_create_kthread, &create);
调用keventd_create_kthread,keventd_create_kthread中调用kernel_thread:
    pid = kernel_thread(kthread, create, CLONE_FS | CLONE_FILES | SIGCHLD);
参考:
http://www.scs.ch/~frey/linux/kernelthreads.html
http://kernelnewbies.org/Simple_UDP_Server
http://mail.nl.linux.org/kernelnewbies/2006-07/msg00373.html
http://linux.sheup.com/linux/linux7553.htm
kernel_thread 的使用
作者:Penna 日期:2009-04-20
字体大小: 小 中 大
 
转载文章,版权归原作者所有。
可以在非内核线程中调用kernel_thread, 但这样创建的线程必须在自己调用daemonize(...)来释放资源, 成为真正的内核线程。
#include <linux/kernel.h> 
#include <linux/module.h>
static int noop(void *dummy) 

int i = 0; 
daemonize("mythread"); 
while(i++ < 5) { 
printk("current->mm = %p/n", current->mm); 
printk("current->active_mm = %p/n", current->active_mm); 
set_current_state(TASK_INTERRUPTIBLE); 
schedule_timeout(10 * HZ); 

return 0; 
}
static int test_init(void) 

kernel_thread(noop, NULL, CLONE_KERNEL | SIGCHLD); 
return 0; 
}
static void test_exit(void) {} 
module_init(test_init); 
module_exit(test_exit);
”mythread“就是给这个内核线程取的名字, 可以用ps -A来查看。 
schedule()用于进程调度, 可以理解为放弃CPU的使用权.
kernel thread可以用kernel_thread创建,但是在执行函数里面必须用daemonize释放资源并挂到init下,还需要用completion等待这一过程的完成。 
kthread_create是比较正牌的创建函数,这个不必要调用daemonize,用这个创建的kernel thread都挂在了kthread线程下。

本文来自CSDN博客,转载请标明出处: http://blog.csdn.net/unbutun/archive/2009/09/07/4528407.aspx

 

 原文地址 http://blog.csdn.net/unbutun/archive/2009/09/07/4528407.aspx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
kthread_create和kernel_thread都是用于创建内核线程的函数。 kthread_create是一个相对正式的创建函数,它会创建一个kthread_create_info结构体,并将其挂接到kthread_create_list链表上。然后,通过调用wake_up_process(kthreadd_task)来唤醒内核线程kthreadd,使其开始运行内核线程。 而kernel_thread函数则可以用于创建内核线程,但在执行函数里面必须使用daemonize来释放资源并将线程挂到init进程下,并且还需要使用completion来等待整个过程的完成。为了简化操作,定义了kthread_create函数,它能够自动完成这些步骤。创建的线程不会立即运行,而是等待调度器将其加入运行队列。 总结来说,kthread_create是一种较为正式的创建内核线程的方式,而kernel_thread则是更底层的创建函数,需要手动处理一些资源释放和线程挂载的操作。使用kthread_create可以简化线程创建的过程,并将线程挂在kthread线程下。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [2021-04-10 Linux内核线程 kernel_thread、kthread_create、 kthread_run kthread_should_stop()](https://blog.csdn.net/qq_37858386/article/details/115573565)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [kthread_create与kernel_thread的区别](https://blog.csdn.net/conceptcon/article/details/9177339)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [基于内核线程的创建、使用和退出以及延时宏的补充说明介绍](https://download.csdn.net/download/weixin_38686041/13781487)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值