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..446beb7ac48d 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 bool 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 | ||
