aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
Diffstat (limited to 'kernel')
-rw-r--r--kernel/trace/trace.c2
-rw-r--r--kernel/trace/trace.h1
-rw-r--r--kernel/trace/trace_boot.c9
-rw-r--r--kernel/trace/trace_functions.c9
-rw-r--r--kernel/trace/trace_irqsoff.c11
-rw-r--r--kernel/trace/trace_mmiotrace.c11
-rw-r--r--kernel/trace/trace_nop.c10
-rw-r--r--kernel/trace/trace_sched_switch.c10
-rw-r--r--kernel/trace/trace_sched_wakeup.c9
-rw-r--r--kernel/trace/trace_selftest.c48
-rw-r--r--kernel/trace/trace_sysprof.c10
11 files changed, 29 insertions, 101 deletions
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
index dbbdacfaaf9e..9e83188172a1 100644
--- a/kernel/trace/trace.c
+++ b/kernel/trace/trace.c
@@ -3357,8 +3357,6 @@ __init static int tracer_alloc_buffers(void)
3357 3357
3358 register_tracer(&nop_trace); 3358 register_tracer(&nop_trace);
3359#ifdef CONFIG_BOOT_TRACER 3359#ifdef CONFIG_BOOT_TRACER
3360 /* We don't want to launch sched_switch tracer yet */
3361 global_trace.ctrl = 0;
3362 register_tracer(&boot_tracer); 3360 register_tracer(&boot_tracer);
3363 current_trace = &boot_tracer; 3361 current_trace = &boot_tracer;
3364 current_trace->init(&global_trace); 3362 current_trace->init(&global_trace);
diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h
index 25abfc45f081..e481edaae1c4 100644
--- a/kernel/trace/trace.h
+++ b/kernel/trace/trace.h
@@ -244,7 +244,6 @@ struct tracer {
244 ssize_t (*read)(struct trace_iterator *iter, 244 ssize_t (*read)(struct trace_iterator *iter,
245 struct file *filp, char __user *ubuf, 245 struct file *filp, char __user *ubuf,
246 size_t cnt, loff_t *ppos); 246 size_t cnt, loff_t *ppos);
247 void (*ctrl_update)(struct trace_array *tr);
248#ifdef CONFIG_FTRACE_STARTUP_TEST 247#ifdef CONFIG_FTRACE_STARTUP_TEST
249 int (*selftest)(struct tracer *trace, 248 int (*selftest)(struct tracer *trace,
250 struct trace_array *tr); 249 struct trace_array *tr);
diff --git a/kernel/trace/trace_boot.c b/kernel/trace/trace_boot.c
index 0203c1054012..8f71915e8bb4 100644
--- a/kernel/trace/trace_boot.c
+++ b/kernel/trace/trace_boot.c
@@ -58,14 +58,6 @@ static void boot_trace_init(struct trace_array *tr)
58 tracing_sched_switch_assign_trace(tr); 58 tracing_sched_switch_assign_trace(tr);
59} 59}
60 60
61static void boot_trace_ctrl_update(struct trace_array *tr)
62{
63 if (tr->ctrl)
64 enable_boot_trace();
65 else
66 disable_boot_trace();
67}
68
69static enum print_line_t initcall_print_line(struct trace_iterator *iter) 61static enum print_line_t initcall_print_line(struct trace_iterator *iter)
70{ 62{
71 int ret; 63 int ret;
@@ -102,7 +94,6 @@ struct tracer boot_tracer __read_mostly =
102 .name = "initcall", 94 .name = "initcall",
103 .init = boot_trace_init, 95 .init = boot_trace_init,
104 .reset = reset_boot_trace, 96 .reset = reset_boot_trace,
105 .ctrl_update = boot_trace_ctrl_update,
106 .print_line = initcall_print_line, 97 .print_line = initcall_print_line,
107}; 98};
108 99
diff --git a/kernel/trace/trace_functions.c b/kernel/trace/trace_functions.c
index 9f1b0de71284..e980b872bef5 100644
--- a/kernel/trace/trace_functions.c
+++ b/kernel/trace/trace_functions.c
@@ -54,14 +54,6 @@ static void function_trace_reset(struct trace_array *tr)
54 stop_function_trace(tr); 54 stop_function_trace(tr);
55} 55}
56 56
57static void function_trace_ctrl_update(struct trace_array *tr)
58{
59 if (tr->ctrl)
60 start_function_trace(tr);
61 else
62 stop_function_trace(tr);
63}
64
65static void function_trace_start(struct trace_array *tr) 57static void function_trace_start(struct trace_array *tr)
66{ 58{
67 function_reset(tr); 59 function_reset(tr);
@@ -73,7 +65,6 @@ static struct tracer function_trace __read_mostly =
73 .init = function_trace_init, 65 .init = function_trace_init,
74 .reset = function_trace_reset, 66 .reset = function_trace_reset,
75 .start = function_trace_start, 67 .start = function_trace_start,
76 .ctrl_update = function_trace_ctrl_update,
77#ifdef CONFIG_FTRACE_SELFTEST 68#ifdef CONFIG_FTRACE_SELFTEST
78 .selftest = trace_selftest_startup_function, 69 .selftest = trace_selftest_startup_function,
79#endif 70#endif
diff --git a/kernel/trace/trace_irqsoff.c b/kernel/trace/trace_irqsoff.c
index 3509086cdc4c..ffdf592a54e3 100644
--- a/kernel/trace/trace_irqsoff.c
+++ b/kernel/trace/trace_irqsoff.c
@@ -394,14 +394,6 @@ static void irqsoff_tracer_reset(struct trace_array *tr)
394 stop_irqsoff_tracer(tr); 394 stop_irqsoff_tracer(tr);
395} 395}
396 396
397static void irqsoff_tracer_ctrl_update(struct trace_array *tr)
398{
399 if (tr->ctrl)
400 start_irqsoff_tracer(tr);
401 else
402 stop_irqsoff_tracer(tr);
403}
404
405static void irqsoff_tracer_start(struct trace_array *tr) 397static void irqsoff_tracer_start(struct trace_array *tr)
406{ 398{
407 tracer_enabled = 1; 399 tracer_enabled = 1;
@@ -442,7 +434,6 @@ static struct tracer irqsoff_tracer __read_mostly =
442 .stop = irqsoff_tracer_stop, 434 .stop = irqsoff_tracer_stop,
443 .open = irqsoff_tracer_open, 435 .open = irqsoff_tracer_open,
444 .close = irqsoff_tracer_close, 436 .close = irqsoff_tracer_close,
445 .ctrl_update = irqsoff_tracer_ctrl_update,
446 .print_max = 1, 437 .print_max = 1,
447#ifdef CONFIG_FTRACE_SELFTEST 438#ifdef CONFIG_FTRACE_SELFTEST
448 .selftest = trace_selftest_startup_irqsoff, 439 .selftest = trace_selftest_startup_irqsoff,
@@ -470,7 +461,6 @@ static struct tracer preemptoff_tracer __read_mostly =
470 .stop = irqsoff_tracer_stop, 461 .stop = irqsoff_tracer_stop,
471 .open = irqsoff_tracer_open, 462 .open = irqsoff_tracer_open,
472 .close = irqsoff_tracer_close, 463 .close = irqsoff_tracer_close,
473 .ctrl_update = irqsoff_tracer_ctrl_update,
474 .print_max = 1, 464 .print_max = 1,
475#ifdef CONFIG_FTRACE_SELFTEST 465#ifdef CONFIG_FTRACE_SELFTEST
476 .selftest = trace_selftest_startup_preemptoff, 466 .selftest = trace_selftest_startup_preemptoff,
@@ -500,7 +490,6 @@ static struct tracer preemptirqsoff_tracer __read_mostly =
500 .stop = irqsoff_tracer_stop, 490 .stop = irqsoff_tracer_stop,
501 .open = irqsoff_tracer_open, 491 .open = irqsoff_tracer_open,
502 .close = irqsoff_tracer_close, 492 .close = irqsoff_tracer_close,
503 .ctrl_update = irqsoff_tracer_ctrl_update,
504 .print_max = 1, 493 .print_max = 1,
505#ifdef CONFIG_FTRACE_SELFTEST 494#ifdef CONFIG_FTRACE_SELFTEST
506 .selftest = trace_selftest_startup_preemptirqsoff, 495 .selftest = trace_selftest_startup_preemptirqsoff,
diff --git a/kernel/trace/trace_mmiotrace.c b/kernel/trace/trace_mmiotrace.c
index f28484618ff0..fa9354e78b57 100644
--- a/kernel/trace/trace_mmiotrace.c
+++ b/kernel/trace/trace_mmiotrace.c
@@ -49,15 +49,10 @@ static void mmio_trace_reset(struct trace_array *tr)
49 mmio_trace_array = NULL; 49 mmio_trace_array = NULL;
50} 50}
51 51
52static void mmio_trace_ctrl_update(struct trace_array *tr) 52static void mmio_trace_start(struct trace_array *tr)
53{ 53{
54 pr_debug("in %s\n", __func__); 54 pr_debug("in %s\n", __func__);
55 if (tr->ctrl) { 55 mmio_reset_data(tr);
56 mmio_reset_data(tr);
57 enable_mmiotrace();
58 } else {
59 disable_mmiotrace();
60 }
61} 56}
62 57
63static int mmio_print_pcidev(struct trace_seq *s, const struct pci_dev *dev) 58static int mmio_print_pcidev(struct trace_seq *s, const struct pci_dev *dev)
@@ -298,10 +293,10 @@ static struct tracer mmio_tracer __read_mostly =
298 .name = "mmiotrace", 293 .name = "mmiotrace",
299 .init = mmio_trace_init, 294 .init = mmio_trace_init,
300 .reset = mmio_trace_reset, 295 .reset = mmio_trace_reset,
296 .start = mmio_trace_start,
301 .pipe_open = mmio_pipe_open, 297 .pipe_open = mmio_pipe_open,
302 .close = mmio_close, 298 .close = mmio_close,
303 .read = mmio_read, 299 .read = mmio_read,
304 .ctrl_update = mmio_trace_ctrl_update,
305 .print_line = mmio_print_line, 300 .print_line = mmio_print_line,
306}; 301};
307 302
diff --git a/kernel/trace/trace_nop.c b/kernel/trace/trace_nop.c
index 4592b4862515..e3c5fbfcdd36 100644
--- a/kernel/trace/trace_nop.c
+++ b/kernel/trace/trace_nop.c
@@ -42,21 +42,11 @@ static void nop_trace_reset(struct trace_array *tr)
42 stop_nop_trace(tr); 42 stop_nop_trace(tr);
43} 43}
44 44
45static void nop_trace_ctrl_update(struct trace_array *tr)
46{
47 /* When starting a new trace, reset the buffers */
48 if (tr->ctrl)
49 start_nop_trace(tr);
50 else
51 stop_nop_trace(tr);
52}
53
54struct tracer nop_trace __read_mostly = 45struct tracer nop_trace __read_mostly =
55{ 46{
56 .name = "nop", 47 .name = "nop",
57 .init = nop_trace_init, 48 .init = nop_trace_init,
58 .reset = nop_trace_reset, 49 .reset = nop_trace_reset,
59 .ctrl_update = nop_trace_ctrl_update,
60#ifdef CONFIG_FTRACE_SELFTEST 50#ifdef CONFIG_FTRACE_SELFTEST
61 .selftest = trace_selftest_startup_nop, 51 .selftest = trace_selftest_startup_nop,
62#endif 52#endif
diff --git a/kernel/trace/trace_sched_switch.c b/kernel/trace/trace_sched_switch.c
index 79410db64d6f..7b73fd11e4aa 100644
--- a/kernel/trace/trace_sched_switch.c
+++ b/kernel/trace/trace_sched_switch.c
@@ -220,15 +220,6 @@ static void sched_switch_trace_reset(struct trace_array *tr)
220 stop_sched_trace(tr); 220 stop_sched_trace(tr);
221} 221}
222 222
223static void sched_switch_trace_ctrl_update(struct trace_array *tr)
224{
225 /* When starting a new trace, reset the buffers */
226 if (tr->ctrl)
227 start_sched_trace(tr);
228 else
229 stop_sched_trace(tr);
230}
231
232static void sched_switch_trace_start(struct trace_array *tr) 223static void sched_switch_trace_start(struct trace_array *tr)
233{ 224{
234 sched_switch_reset(tr); 225 sched_switch_reset(tr);
@@ -247,7 +238,6 @@ static struct tracer sched_switch_trace __read_mostly =
247 .reset = sched_switch_trace_reset, 238 .reset = sched_switch_trace_reset,
248 .start = sched_switch_trace_start, 239 .start = sched_switch_trace_start,
249 .stop = sched_switch_trace_stop, 240 .stop = sched_switch_trace_stop,
250 .ctrl_update = sched_switch_trace_ctrl_update,
251#ifdef CONFIG_FTRACE_SELFTEST 241#ifdef CONFIG_FTRACE_SELFTEST
252 .selftest = trace_selftest_startup_sched_switch, 242 .selftest = trace_selftest_startup_sched_switch,
253#endif 243#endif
diff --git a/kernel/trace/trace_sched_wakeup.c b/kernel/trace/trace_sched_wakeup.c
index 240577bc8ba5..23e54d4e4d92 100644
--- a/kernel/trace/trace_sched_wakeup.c
+++ b/kernel/trace/trace_sched_wakeup.c
@@ -348,14 +348,6 @@ static void wakeup_tracer_reset(struct trace_array *tr)
348 } 348 }
349} 349}
350 350
351static void wakeup_tracer_ctrl_update(struct trace_array *tr)
352{
353 if (tr->ctrl)
354 start_wakeup_tracer(tr);
355 else
356 stop_wakeup_tracer(tr);
357}
358
359static void wakeup_tracer_start(struct trace_array *tr) 351static void wakeup_tracer_start(struct trace_array *tr)
360{ 352{
361 wakeup_reset(tr); 353 wakeup_reset(tr);
@@ -393,7 +385,6 @@ static struct tracer wakeup_tracer __read_mostly =
393 .stop = wakeup_tracer_stop, 385 .stop = wakeup_tracer_stop,
394 .open = wakeup_tracer_open, 386 .open = wakeup_tracer_open,
395 .close = wakeup_tracer_close, 387 .close = wakeup_tracer_close,
396 .ctrl_update = wakeup_tracer_ctrl_update,
397 .print_max = 1, 388 .print_max = 1,
398#ifdef CONFIG_FTRACE_SELFTEST 389#ifdef CONFIG_FTRACE_SELFTEST
399 .selftest = trace_selftest_startup_wakeup, 390 .selftest = trace_selftest_startup_wakeup,
diff --git a/kernel/trace/trace_selftest.c b/kernel/trace/trace_selftest.c
index 90bc752a7580..746934340474 100644
--- a/kernel/trace/trace_selftest.c
+++ b/kernel/trace/trace_selftest.c
@@ -134,13 +134,13 @@ int trace_selftest_startup_dynamic_tracing(struct tracer *trace,
134 msleep(100); 134 msleep(100);
135 135
136 /* stop the tracing. */ 136 /* stop the tracing. */
137 tr->ctrl = 0; 137 tracing_stop();
138 trace->ctrl_update(tr);
139 ftrace_enabled = 0; 138 ftrace_enabled = 0;
140 139
141 /* check the trace buffer */ 140 /* check the trace buffer */
142 ret = trace_test_buffer(tr, &count); 141 ret = trace_test_buffer(tr, &count);
143 trace->reset(tr); 142 trace->reset(tr);
143 tracing_start();
144 144
145 /* we should only have one item */ 145 /* we should only have one item */
146 if (!ret && count != 1) { 146 if (!ret && count != 1) {
@@ -148,6 +148,7 @@ int trace_selftest_startup_dynamic_tracing(struct tracer *trace,
148 ret = -1; 148 ret = -1;
149 goto out; 149 goto out;
150 } 150 }
151
151 out: 152 out:
152 ftrace_enabled = save_ftrace_enabled; 153 ftrace_enabled = save_ftrace_enabled;
153 tracer_enabled = save_tracer_enabled; 154 tracer_enabled = save_tracer_enabled;
@@ -185,13 +186,13 @@ trace_selftest_startup_function(struct tracer *trace, struct trace_array *tr)
185 /* Sleep for a 1/10 of a second */ 186 /* Sleep for a 1/10 of a second */
186 msleep(100); 187 msleep(100);
187 /* stop the tracing. */ 188 /* stop the tracing. */
188 tr->ctrl = 0; 189 tracing_stop();
189 trace->ctrl_update(tr);
190 ftrace_enabled = 0; 190 ftrace_enabled = 0;
191 191
192 /* check the trace buffer */ 192 /* check the trace buffer */
193 ret = trace_test_buffer(tr, &count); 193 ret = trace_test_buffer(tr, &count);
194 trace->reset(tr); 194 trace->reset(tr);
195 tracing_start();
195 196
196 if (!ret && !count) { 197 if (!ret && !count) {
197 printk(KERN_CONT ".. no entries found .."); 198 printk(KERN_CONT ".. no entries found ..");
@@ -232,13 +233,13 @@ trace_selftest_startup_irqsoff(struct tracer *trace, struct trace_array *tr)
232 udelay(100); 233 udelay(100);
233 local_irq_enable(); 234 local_irq_enable();
234 /* stop the tracing. */ 235 /* stop the tracing. */
235 tr->ctrl = 0; 236 tracing_stop();
236 trace->ctrl_update(tr);
237 /* check both trace buffers */ 237 /* check both trace buffers */
238 ret = trace_test_buffer(tr, NULL); 238 ret = trace_test_buffer(tr, NULL);
239 if (!ret) 239 if (!ret)
240 ret = trace_test_buffer(&max_tr, &count); 240 ret = trace_test_buffer(&max_tr, &count);
241 trace->reset(tr); 241 trace->reset(tr);
242 tracing_start();
242 243
243 if (!ret && !count) { 244 if (!ret && !count) {
244 printk(KERN_CONT ".. no entries found .."); 245 printk(KERN_CONT ".. no entries found ..");
@@ -269,13 +270,13 @@ trace_selftest_startup_preemptoff(struct tracer *trace, struct trace_array *tr)
269 udelay(100); 270 udelay(100);
270 preempt_enable(); 271 preempt_enable();
271 /* stop the tracing. */ 272 /* stop the tracing. */
272 tr->ctrl = 0; 273 tracing_stop();
273 trace->ctrl_update(tr);
274 /* check both trace buffers */ 274 /* check both trace buffers */
275 ret = trace_test_buffer(tr, NULL); 275 ret = trace_test_buffer(tr, NULL);
276 if (!ret) 276 if (!ret)
277 ret = trace_test_buffer(&max_tr, &count); 277 ret = trace_test_buffer(&max_tr, &count);
278 trace->reset(tr); 278 trace->reset(tr);
279 tracing_start();
279 280
280 if (!ret && !count) { 281 if (!ret && !count) {
281 printk(KERN_CONT ".. no entries found .."); 282 printk(KERN_CONT ".. no entries found ..");
@@ -312,27 +313,30 @@ trace_selftest_startup_preemptirqsoff(struct tracer *trace, struct trace_array *
312 local_irq_enable(); 313 local_irq_enable();
313 314
314 /* stop the tracing. */ 315 /* stop the tracing. */
315 tr->ctrl = 0; 316 tracing_stop();
316 trace->ctrl_update(tr);
317 /* check both trace buffers */ 317 /* check both trace buffers */
318 ret = trace_test_buffer(tr, NULL); 318 ret = trace_test_buffer(tr, NULL);
319 if (ret) 319 if (ret) {
320 tracing_start();
320 goto out; 321 goto out;
322 }
321 323
322 ret = trace_test_buffer(&max_tr, &count); 324 ret = trace_test_buffer(&max_tr, &count);
323 if (ret) 325 if (ret) {
326 tracing_start();
324 goto out; 327 goto out;
328 }
325 329
326 if (!ret && !count) { 330 if (!ret && !count) {
327 printk(KERN_CONT ".. no entries found .."); 331 printk(KERN_CONT ".. no entries found ..");
328 ret = -1; 332 ret = -1;
333 tracing_start();
329 goto out; 334 goto out;
330 } 335 }
331 336
332 /* do the test by disabling interrupts first this time */ 337 /* do the test by disabling interrupts first this time */
333 tracing_max_latency = 0; 338 tracing_max_latency = 0;
334 tr->ctrl = 1; 339 tracing_start();
335 trace->ctrl_update(tr);
336 preempt_disable(); 340 preempt_disable();
337 local_irq_disable(); 341 local_irq_disable();
338 udelay(100); 342 udelay(100);
@@ -341,8 +345,7 @@ trace_selftest_startup_preemptirqsoff(struct tracer *trace, struct trace_array *
341 local_irq_enable(); 345 local_irq_enable();
342 346
343 /* stop the tracing. */ 347 /* stop the tracing. */
344 tr->ctrl = 0; 348 tracing_stop();
345 trace->ctrl_update(tr);
346 /* check both trace buffers */ 349 /* check both trace buffers */
347 ret = trace_test_buffer(tr, NULL); 350 ret = trace_test_buffer(tr, NULL);
348 if (ret) 351 if (ret)
@@ -358,6 +361,7 @@ trace_selftest_startup_preemptirqsoff(struct tracer *trace, struct trace_array *
358 361
359 out: 362 out:
360 trace->reset(tr); 363 trace->reset(tr);
364 tracing_start();
361 tracing_max_latency = save_max; 365 tracing_max_latency = save_max;
362 366
363 return ret; 367 return ret;
@@ -448,8 +452,7 @@ trace_selftest_startup_wakeup(struct tracer *trace, struct trace_array *tr)
448 msleep(100); 452 msleep(100);
449 453
450 /* stop the tracing. */ 454 /* stop the tracing. */
451 tr->ctrl = 0; 455 tracing_stop();
452 trace->ctrl_update(tr);
453 /* check both trace buffers */ 456 /* check both trace buffers */
454 ret = trace_test_buffer(tr, NULL); 457 ret = trace_test_buffer(tr, NULL);
455 if (!ret) 458 if (!ret)
@@ -457,6 +460,7 @@ trace_selftest_startup_wakeup(struct tracer *trace, struct trace_array *tr)
457 460
458 461
459 trace->reset(tr); 462 trace->reset(tr);
463 tracing_start();
460 464
461 tracing_max_latency = save_max; 465 tracing_max_latency = save_max;
462 466
@@ -485,11 +489,11 @@ trace_selftest_startup_sched_switch(struct tracer *trace, struct trace_array *tr
485 /* Sleep for a 1/10 of a second */ 489 /* Sleep for a 1/10 of a second */
486 msleep(100); 490 msleep(100);
487 /* stop the tracing. */ 491 /* stop the tracing. */
488 tr->ctrl = 0; 492 tracing_stop();
489 trace->ctrl_update(tr);
490 /* check the trace buffer */ 493 /* check the trace buffer */
491 ret = trace_test_buffer(tr, &count); 494 ret = trace_test_buffer(tr, &count);
492 trace->reset(tr); 495 trace->reset(tr);
496 tracing_start();
493 497
494 if (!ret && !count) { 498 if (!ret && !count) {
495 printk(KERN_CONT ".. no entries found .."); 499 printk(KERN_CONT ".. no entries found ..");
@@ -513,11 +517,11 @@ trace_selftest_startup_sysprof(struct tracer *trace, struct trace_array *tr)
513 /* Sleep for a 1/10 of a second */ 517 /* Sleep for a 1/10 of a second */
514 msleep(100); 518 msleep(100);
515 /* stop the tracing. */ 519 /* stop the tracing. */
516 tr->ctrl = 0; 520 tracing_stop();
517 trace->ctrl_update(tr);
518 /* check the trace buffer */ 521 /* check the trace buffer */
519 ret = trace_test_buffer(tr, &count); 522 ret = trace_test_buffer(tr, &count);
520 trace->reset(tr); 523 trace->reset(tr);
524 tracing_start();
521 525
522 return ret; 526 return ret;
523} 527}
diff --git a/kernel/trace/trace_sysprof.c b/kernel/trace/trace_sysprof.c
index 9587d3bcba55..8097430edff9 100644
--- a/kernel/trace/trace_sysprof.c
+++ b/kernel/trace/trace_sysprof.c
@@ -275,21 +275,11 @@ static void stack_trace_reset(struct trace_array *tr)
275 stop_stack_trace(tr); 275 stop_stack_trace(tr);
276} 276}
277 277
278static void stack_trace_ctrl_update(struct trace_array *tr)
279{
280 /* When starting a new trace, reset the buffers */
281 if (tr->ctrl)
282 start_stack_trace(tr);
283 else
284 stop_stack_trace(tr);
285}
286
287static struct tracer stack_trace __read_mostly = 278static struct tracer stack_trace __read_mostly =
288{ 279{
289 .name = "sysprof", 280 .name = "sysprof",
290 .init = stack_trace_init, 281 .init = stack_trace_init,
291 .reset = stack_trace_reset, 282 .reset = stack_trace_reset,
292 .ctrl_update = stack_trace_ctrl_update,
293#ifdef CONFIG_FTRACE_SELFTEST 283#ifdef CONFIG_FTRACE_SELFTEST
294 .selftest = trace_selftest_startup_sysprof, 284 .selftest = trace_selftest_startup_sysprof,
295#endif 285#endif