 fd6da10a61
			
		
	
	
	fd6da10a61
	
	
	
		
			
			The sample is useful for testing, and I'm using it. But after loading the module, it keeps saying hi every 10 seconds, this may be disturbing. Also Steven said commenting out the "hi" helped in causing races. :) [ Impact: make testing a bit easier ] Signed-off-by: Li Zefan <lizf@cn.fujitsu.com> Acked-by: Steven Rostedt <rostedt@goodmis.org> Acked-by: Frederic Weisbecker <fweisbec@gmail.com> LKML-Reference: <4A00F6AD.2070008@cn.fujitsu.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
		
			
				
	
	
		
			52 lines
		
	
	
	
		
			1 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			52 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");
 |