aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLi Zefan <lizf@cn.fujitsu.com>2009-03-19 21:48:26 -0400
committerIngo Molnar <mingo@elte.hu>2009-03-21 11:16:25 -0400
commit3c289ba7c320560ee74979a8895141c829046a2d (patch)
tree293c9d1d931c06acf06998a6ea052193c0a8cf4e
parent5006ea73f38caef6065d1136808413813271633f (diff)
blktrace: remove blk_probe_mutex
blk_register_tracepoints() always returns 0, so make it return void, thus we don't need to use blk_probe_mutex to protect blk_probes_ref. Signed-off-by: Li Zefan <lizf@cn.fujitsu.com> Acked-by: Frederic Weisbecker <fweisbec@gmail.com> Acked-by: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Jens Axboe <jens.axboe@oracle.com> Cc: Steven Rostedt <rostedt@goodmis.org> LKML-Reference: <49C2F5EA.8060606@cn.fujitsu.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r--kernel/trace/blktrace.c27
1 files changed, 5 insertions, 22 deletions
diff --git a/kernel/trace/blktrace.c b/kernel/trace/blktrace.c
index 73845b7968bb..223b92e77b3f 100644
--- a/kernel/trace/blktrace.c
+++ b/kernel/trace/blktrace.c
@@ -47,10 +47,9 @@ static struct tracer_flags blk_tracer_flags = {
47}; 47};
48 48
49/* Global reference count of probes */ 49/* Global reference count of probes */
50static DEFINE_MUTEX(blk_probe_mutex);
51static atomic_t blk_probes_ref = ATOMIC_INIT(0); 50static atomic_t blk_probes_ref = ATOMIC_INIT(0);
52 51
53static int blk_register_tracepoints(void); 52static void blk_register_tracepoints(void);
54static void blk_unregister_tracepoints(void); 53static void blk_unregister_tracepoints(void);
55 54
56/* 55/*
@@ -256,10 +255,8 @@ static void blk_trace_cleanup(struct blk_trace *bt)
256 free_percpu(bt->sequence); 255 free_percpu(bt->sequence);
257 free_percpu(bt->msg_data); 256 free_percpu(bt->msg_data);
258 kfree(bt); 257 kfree(bt);
259 mutex_lock(&blk_probe_mutex);
260 if (atomic_dec_and_test(&blk_probes_ref)) 258 if (atomic_dec_and_test(&blk_probes_ref))
261 blk_unregister_tracepoints(); 259 blk_unregister_tracepoints();
262 mutex_unlock(&blk_probe_mutex);
263} 260}
264 261
265int blk_trace_remove(struct request_queue *q) 262int blk_trace_remove(struct request_queue *q)
@@ -471,13 +468,8 @@ int do_blk_trace_setup(struct request_queue *q, char *name, dev_t dev,
471 bt->pid = buts->pid; 468 bt->pid = buts->pid;
472 bt->trace_state = Blktrace_setup; 469 bt->trace_state = Blktrace_setup;
473 470
474 mutex_lock(&blk_probe_mutex); 471 if (atomic_add_return(1, &blk_probes_ref) == 1)
475 if (atomic_add_return(1, &blk_probes_ref) == 1) { 472 blk_register_tracepoints();
476 ret = blk_register_tracepoints();
477 if (ret)
478 goto probe_err;
479 }
480 mutex_unlock(&blk_probe_mutex);
481 473
482 ret = -EBUSY; 474 ret = -EBUSY;
483 old_bt = xchg(&q->blk_trace, bt); 475 old_bt = xchg(&q->blk_trace, bt);
@@ -487,9 +479,6 @@ int do_blk_trace_setup(struct request_queue *q, char *name, dev_t dev,
487 } 479 }
488 480
489 return 0; 481 return 0;
490probe_err:
491 atomic_dec(&blk_probes_ref);
492 mutex_unlock(&blk_probe_mutex);
493err: 482err:
494 if (bt) { 483 if (bt) {
495 if (bt->msg_file) 484 if (bt->msg_file)
@@ -863,7 +852,7 @@ void blk_add_driver_data(struct request_queue *q,
863} 852}
864EXPORT_SYMBOL_GPL(blk_add_driver_data); 853EXPORT_SYMBOL_GPL(blk_add_driver_data);
865 854
866static int blk_register_tracepoints(void) 855static void blk_register_tracepoints(void)
867{ 856{
868 int ret; 857 int ret;
869 858
@@ -901,7 +890,6 @@ static int blk_register_tracepoints(void)
901 WARN_ON(ret); 890 WARN_ON(ret);
902 ret = register_trace_block_remap(blk_add_trace_remap); 891 ret = register_trace_block_remap(blk_add_trace_remap);
903 WARN_ON(ret); 892 WARN_ON(ret);
904 return 0;
905} 893}
906 894
907static void blk_unregister_tracepoints(void) 895static void blk_unregister_tracepoints(void)
@@ -1099,11 +1087,8 @@ static void blk_tracer_print_header(struct seq_file *m)
1099 1087
1100static void blk_tracer_start(struct trace_array *tr) 1088static void blk_tracer_start(struct trace_array *tr)
1101{ 1089{
1102 mutex_lock(&blk_probe_mutex);
1103 if (atomic_add_return(1, &blk_probes_ref) == 1) 1090 if (atomic_add_return(1, &blk_probes_ref) == 1)
1104 if (blk_register_tracepoints()) 1091 blk_register_tracepoints();
1105 atomic_dec(&blk_probes_ref);
1106 mutex_unlock(&blk_probe_mutex);
1107 trace_flags &= ~TRACE_ITER_CONTEXT_INFO; 1092 trace_flags &= ~TRACE_ITER_CONTEXT_INFO;
1108} 1093}
1109 1094
@@ -1118,10 +1103,8 @@ static int blk_tracer_init(struct trace_array *tr)
1118static void blk_tracer_stop(struct trace_array *tr) 1103static void blk_tracer_stop(struct trace_array *tr)
1119{ 1104{
1120 trace_flags |= TRACE_ITER_CONTEXT_INFO; 1105 trace_flags |= TRACE_ITER_CONTEXT_INFO;
1121 mutex_lock(&blk_probe_mutex);
1122 if (atomic_dec_and_test(&blk_probes_ref)) 1106 if (atomic_dec_and_test(&blk_probes_ref))
1123 blk_unregister_tracepoints(); 1107 blk_unregister_tracepoints();
1124 mutex_unlock(&blk_probe_mutex);
1125} 1108}
1126 1109
1127static void blk_tracer_reset(struct trace_array *tr) 1110static void blk_tracer_reset(struct trace_array *tr)