diff options
Diffstat (limited to 'samples/trace_events/trace-events-sample.c')
-rw-r--r-- | samples/trace_events/trace-events-sample.c | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/samples/trace_events/trace-events-sample.c b/samples/trace_events/trace-events-sample.c index bc7fcf010a5b..5522692100ba 100644 --- a/samples/trace_events/trace-events-sample.c +++ b/samples/trace_events/trace-events-sample.c | |||
@@ -78,29 +78,37 @@ static int simple_thread_fn(void *arg) | |||
78 | } | 78 | } |
79 | 79 | ||
80 | static DEFINE_MUTEX(thread_mutex); | 80 | static DEFINE_MUTEX(thread_mutex); |
81 | static int simple_thread_cnt; | ||
81 | 82 | ||
82 | int foo_bar_reg(void) | 83 | int foo_bar_reg(void) |
83 | { | 84 | { |
85 | mutex_lock(&thread_mutex); | ||
86 | if (simple_thread_cnt++) | ||
87 | goto out; | ||
88 | |||
84 | pr_info("Starting thread for foo_bar_fn\n"); | 89 | pr_info("Starting thread for foo_bar_fn\n"); |
85 | /* | 90 | /* |
86 | * We shouldn't be able to start a trace when the module is | 91 | * We shouldn't be able to start a trace when the module is |
87 | * unloading (there's other locks to prevent that). But | 92 | * unloading (there's other locks to prevent that). But |
88 | * for consistency sake, we still take the thread_mutex. | 93 | * for consistency sake, we still take the thread_mutex. |
89 | */ | 94 | */ |
90 | mutex_lock(&thread_mutex); | ||
91 | simple_tsk_fn = kthread_run(simple_thread_fn, NULL, "event-sample-fn"); | 95 | simple_tsk_fn = kthread_run(simple_thread_fn, NULL, "event-sample-fn"); |
96 | out: | ||
92 | mutex_unlock(&thread_mutex); | 97 | mutex_unlock(&thread_mutex); |
93 | return 0; | 98 | return 0; |
94 | } | 99 | } |
95 | 100 | ||
96 | void foo_bar_unreg(void) | 101 | void foo_bar_unreg(void) |
97 | { | 102 | { |
98 | pr_info("Killing thread for foo_bar_fn\n"); | ||
99 | /* protect against module unloading */ | ||
100 | mutex_lock(&thread_mutex); | 103 | mutex_lock(&thread_mutex); |
104 | if (--simple_thread_cnt) | ||
105 | goto out; | ||
106 | |||
107 | pr_info("Killing thread for foo_bar_fn\n"); | ||
101 | if (simple_tsk_fn) | 108 | if (simple_tsk_fn) |
102 | kthread_stop(simple_tsk_fn); | 109 | kthread_stop(simple_tsk_fn); |
103 | simple_tsk_fn = NULL; | 110 | simple_tsk_fn = NULL; |
111 | out: | ||
104 | mutex_unlock(&thread_mutex); | 112 | mutex_unlock(&thread_mutex); |
105 | } | 113 | } |
106 | 114 | ||