| Steven Rostedt | 9cfe06f | 2009-04-14 21:37:03 -0400 | [diff] [blame] | 1 | #include <linux/module.h> | 
|  | 2 | #include <linux/kthread.h> | 
|  | 3 |  | 
|  | 4 | /* | 
|  | 5 | * Any file that uses trace points, must include the header. | 
|  | 6 | * But only one file, must include the header by defining | 
|  | 7 | * CREATE_TRACE_POINTS first.  This will make the C code that | 
|  | 8 | * creates the handles for the trace points. | 
|  | 9 | */ | 
|  | 10 | #define CREATE_TRACE_POINTS | 
|  | 11 | #include "trace-events-sample.h" | 
|  | 12 |  | 
|  | 13 |  | 
|  | 14 | static void simple_thread_func(int cnt) | 
|  | 15 | { | 
|  | 16 | set_current_state(TASK_INTERRUPTIBLE); | 
|  | 17 | schedule_timeout(HZ); | 
|  | 18 | trace_foo_bar("hello", cnt); | 
| Steven Rostedt | 9cfe06f | 2009-04-14 21:37:03 -0400 | [diff] [blame] | 19 | } | 
|  | 20 |  | 
|  | 21 | static int simple_thread(void *arg) | 
|  | 22 | { | 
|  | 23 | int cnt = 0; | 
|  | 24 |  | 
|  | 25 | while (!kthread_should_stop()) | 
|  | 26 | simple_thread_func(cnt++); | 
|  | 27 |  | 
|  | 28 | return 0; | 
|  | 29 | } | 
|  | 30 |  | 
|  | 31 | static struct task_struct *simple_tsk; | 
|  | 32 |  | 
|  | 33 | static int __init trace_event_init(void) | 
|  | 34 | { | 
|  | 35 | simple_tsk = kthread_run(simple_thread, NULL, "event-sample"); | 
|  | 36 | if (IS_ERR(simple_tsk)) | 
|  | 37 | return -1; | 
|  | 38 |  | 
|  | 39 | return 0; | 
|  | 40 | } | 
|  | 41 |  | 
|  | 42 | static void __exit trace_event_exit(void) | 
|  | 43 | { | 
|  | 44 | kthread_stop(simple_tsk); | 
|  | 45 | } | 
|  | 46 |  | 
|  | 47 | module_init(trace_event_init); | 
|  | 48 | module_exit(trace_event_exit); | 
|  | 49 |  | 
|  | 50 | MODULE_AUTHOR("Steven Rostedt"); | 
|  | 51 | MODULE_DESCRIPTION("trace-events-sample"); | 
|  | 52 | MODULE_LICENSE("GPL"); |