| #include <linux/module.h> | 
 | #include <linux/kthread.h> | 
 |  | 
 | /* | 
 |  * Any file that uses trace points, must include the header. | 
 |  * But only one file, must include the header by defining | 
 |  * CREATE_TRACE_POINTS first.  This will make the C code that | 
 |  * creates the handles for the trace points. | 
 |  */ | 
 | #define CREATE_TRACE_POINTS | 
 | #include "trace-events-sample.h" | 
 |  | 
 |  | 
 | static void simple_thread_func(int cnt) | 
 | { | 
 | 	set_current_state(TASK_INTERRUPTIBLE); | 
 | 	schedule_timeout(HZ); | 
 | 	trace_foo_bar("hello", cnt); | 
 | } | 
 |  | 
 | static int simple_thread(void *arg) | 
 | { | 
 | 	int cnt = 0; | 
 |  | 
 | 	while (!kthread_should_stop()) | 
 | 		simple_thread_func(cnt++); | 
 |  | 
 | 	return 0; | 
 | } | 
 |  | 
 | static struct task_struct *simple_tsk; | 
 |  | 
 | static int __init trace_event_init(void) | 
 | { | 
 | 	simple_tsk = kthread_run(simple_thread, NULL, "event-sample"); | 
 | 	if (IS_ERR(simple_tsk)) | 
 | 		return -1; | 
 |  | 
 | 	return 0; | 
 | } | 
 |  | 
 | static void __exit trace_event_exit(void) | 
 | { | 
 | 	kthread_stop(simple_tsk); | 
 | } | 
 |  | 
 | module_init(trace_event_init); | 
 | module_exit(trace_event_exit); | 
 |  | 
 | MODULE_AUTHOR("Steven Rostedt"); | 
 | MODULE_DESCRIPTION("trace-events-sample"); | 
 | MODULE_LICENSE("GPL"); |