How to create some threads running tha same function

Parmenides mobile.parmenides at gmail.com
Thu Sep 15 10:20:03 EDT 2011


Hi,

   I will try to test how to create kernel threads and have write a
kernel module which creates a number of kernel threads running the
same function. But the results is somewhat confusing.

	#include <linux/kernel.h>
	#include <linux/kthread.h>
	#include <linux/delay.h>
	#define MAX_KTHREAD  2
	struct task_struct *ktask[MAX_KTHREAD];
	static int my_kthread(void *data)
	{
	     int nr = *(int *)data;
	     while (!kthread_should_stop()){
		  ssleep(1);
		  printk(KERN_ALERT "This is mythread[%d].\n", nr);
	     }
	     return 0;
	}
	static int kthread_init(void)
	{
	     int i;

	     for (i = 0; i < MAX_KTHREAD; i++){
		  ktask[i] = kthread_run(my_kthread, &i, "mythread[%d]", i);
	     }
	     return 0;
	}
	static void kthread_exit(void)
	{
	     int i;

	     for (i = 0; i < MAX_KTHREAD; i++){
		  if (ktask[i]){
		       kthread_stop(ktask[i]);
		       ktask[i] = NULL;
		  }
	     }
	}
	module_init(kthread_init);
	module_exit(kthread_exit);
	MODULE_LICENSE("GPL");
	MODULE_AUTHOR("Shakespeare");
	MODULE_DESCRIPTION("This is a test program of kthread.");

The messages on the screen are:

	This is mythread[-929820448].
	This is mythread[1].
	This is mythread[-929820448].
	This is mythread[1].
	This is mythread[-929820448].
	...	...	...

I wonder why the first thread's number is not zero rather than -929820448.

Furthermore, when running again with MAX_KTHREAD == 3, the messages are:

	This is mythread[1].
	This is mythread[2].
	This is mythread[1].
	This is mythread[1].
	This is mythread[2].
	This is mythread[1].
	This is mythread[1].
	This is mythread[2].
	...	...	...

There should be 3 threads running, but only two of them appear. The
first thread get lost.



More information about the Kernelnewbies mailing list