53 lines
		
	
	
	
		
			1 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			53 lines
		
	
	
	
		
			1 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
|   | #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"); |