aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
Diffstat (limited to 'kernel')
-rw-r--r--kernel/trace/trace.c81
-rw-r--r--kernel/trace/trace.h2
-rw-r--r--kernel/trace/trace_events.c4
3 files changed, 51 insertions, 36 deletions
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
index 57b4220d96a9..4021a5e66412 100644
--- a/kernel/trace/trace.c
+++ b/kernel/trace/trace.c
@@ -47,7 +47,7 @@
47 * On boot up, the ring buffer is set to the minimum size, so that 47 * On boot up, the ring buffer is set to the minimum size, so that
48 * we do not waste memory on systems that are not using tracing. 48 * we do not waste memory on systems that are not using tracing.
49 */ 49 */
50int ring_buffer_expanded; 50bool ring_buffer_expanded;
51 51
52/* 52/*
53 * We need to change this state when a selftest is running. 53 * We need to change this state when a selftest is running.
@@ -121,12 +121,14 @@ static int tracing_set_tracer(const char *buf);
121static char bootup_tracer_buf[MAX_TRACER_SIZE] __initdata; 121static char bootup_tracer_buf[MAX_TRACER_SIZE] __initdata;
122static char *default_bootup_tracer; 122static char *default_bootup_tracer;
123 123
124static bool allocate_snapshot;
125
124static int __init set_cmdline_ftrace(char *str) 126static int __init set_cmdline_ftrace(char *str)
125{ 127{
126 strncpy(bootup_tracer_buf, str, MAX_TRACER_SIZE); 128 strncpy(bootup_tracer_buf, str, MAX_TRACER_SIZE);
127 default_bootup_tracer = bootup_tracer_buf; 129 default_bootup_tracer = bootup_tracer_buf;
128 /* We are using ftrace early, expand it */ 130 /* We are using ftrace early, expand it */
129 ring_buffer_expanded = 1; 131 ring_buffer_expanded = true;
130 return 1; 132 return 1;
131} 133}
132__setup("ftrace=", set_cmdline_ftrace); 134__setup("ftrace=", set_cmdline_ftrace);
@@ -147,6 +149,15 @@ static int __init set_ftrace_dump_on_oops(char *str)
147} 149}
148__setup("ftrace_dump_on_oops", set_ftrace_dump_on_oops); 150__setup("ftrace_dump_on_oops", set_ftrace_dump_on_oops);
149 151
152static int __init alloc_snapshot(char *str)
153{
154 allocate_snapshot = true;
155 /* We also need the main ring buffer expanded */
156 ring_buffer_expanded = true;
157 return 1;
158}
159__setup("alloc_snapshot", alloc_snapshot);
160
150 161
151static char trace_boot_options_buf[MAX_TRACER_SIZE] __initdata; 162static char trace_boot_options_buf[MAX_TRACER_SIZE] __initdata;
152static char *trace_boot_options __initdata; 163static char *trace_boot_options __initdata;
@@ -951,7 +962,7 @@ int register_tracer(struct tracer *type)
951 tracing_set_tracer(type->name); 962 tracing_set_tracer(type->name);
952 default_bootup_tracer = NULL; 963 default_bootup_tracer = NULL;
953 /* disable other selftests, since this will break it. */ 964 /* disable other selftests, since this will break it. */
954 tracing_selftest_disabled = 1; 965 tracing_selftest_disabled = true;
955#ifdef CONFIG_FTRACE_STARTUP_TEST 966#ifdef CONFIG_FTRACE_STARTUP_TEST
956 printk(KERN_INFO "Disabling FTRACE selftests due to running tracer '%s'\n", 967 printk(KERN_INFO "Disabling FTRACE selftests due to running tracer '%s'\n",
957 type->name); 968 type->name);
@@ -3318,7 +3329,7 @@ static int __tracing_resize_ring_buffer(struct trace_array *tr,
3318 * we use the size that was given, and we can forget about 3329 * we use the size that was given, and we can forget about
3319 * expanding it later. 3330 * expanding it later.
3320 */ 3331 */
3321 ring_buffer_expanded = 1; 3332 ring_buffer_expanded = true;
3322 3333
3323 /* May be called before buffers are initialized */ 3334 /* May be called before buffers are initialized */
3324 if (!tr->trace_buffer.buffer) 3335 if (!tr->trace_buffer.buffer)
@@ -5396,53 +5407,57 @@ static void init_trace_buffers(struct trace_array *tr, struct trace_buffer *buf)
5396 } 5407 }
5397} 5408}
5398 5409
5399static int allocate_trace_buffers(struct trace_array *tr, int size) 5410static int
5411allocate_trace_buffer(struct trace_array *tr, struct trace_buffer *buf, int size)
5400{ 5412{
5401 enum ring_buffer_flags rb_flags; 5413 enum ring_buffer_flags rb_flags;
5402 5414
5403 rb_flags = trace_flags & TRACE_ITER_OVERWRITE ? RB_FL_OVERWRITE : 0; 5415 rb_flags = trace_flags & TRACE_ITER_OVERWRITE ? RB_FL_OVERWRITE : 0;
5404 5416
5405 tr->trace_buffer.buffer = ring_buffer_alloc(size, rb_flags); 5417 buf->buffer = ring_buffer_alloc(size, rb_flags);
5406 if (!tr->trace_buffer.buffer) 5418 if (!buf->buffer)
5407 goto out_free; 5419 return -ENOMEM;
5408 5420
5409 tr->trace_buffer.data = alloc_percpu(struct trace_array_cpu); 5421 buf->data = alloc_percpu(struct trace_array_cpu);
5410 if (!tr->trace_buffer.data) 5422 if (!buf->data) {
5411 goto out_free; 5423 ring_buffer_free(buf->buffer);
5424 return -ENOMEM;
5425 }
5412 5426
5413 init_trace_buffers(tr, &tr->trace_buffer); 5427 init_trace_buffers(tr, buf);
5414 5428
5415 /* Allocate the first page for all buffers */ 5429 /* Allocate the first page for all buffers */
5416 set_buffer_entries(&tr->trace_buffer, 5430 set_buffer_entries(&tr->trace_buffer,
5417 ring_buffer_size(tr->trace_buffer.buffer, 0)); 5431 ring_buffer_size(tr->trace_buffer.buffer, 0));
5418 5432
5419#ifdef CONFIG_TRACER_MAX_TRACE 5433 return 0;
5420 5434}
5421 tr->max_buffer.buffer = ring_buffer_alloc(1, rb_flags);
5422 if (!tr->max_buffer.buffer)
5423 goto out_free;
5424
5425 tr->max_buffer.data = alloc_percpu(struct trace_array_cpu);
5426 if (!tr->max_buffer.data)
5427 goto out_free;
5428 5435
5429 init_trace_buffers(tr, &tr->max_buffer); 5436static int allocate_trace_buffers(struct trace_array *tr, int size)
5437{
5438 int ret;
5430 5439
5431 set_buffer_entries(&tr->max_buffer, 1); 5440 ret = allocate_trace_buffer(tr, &tr->trace_buffer, size);
5432#endif 5441 if (ret)
5433 return 0; 5442 return ret;
5434 5443
5435 out_free: 5444#ifdef CONFIG_TRACER_MAX_TRACE
5436 if (tr->trace_buffer.buffer) 5445 ret = allocate_trace_buffer(tr, &tr->max_buffer,
5446 allocate_snapshot ? size : 1);
5447 if (WARN_ON(ret)) {
5437 ring_buffer_free(tr->trace_buffer.buffer); 5448 ring_buffer_free(tr->trace_buffer.buffer);
5438 free_percpu(tr->trace_buffer.data); 5449 free_percpu(tr->trace_buffer.data);
5450 return -ENOMEM;
5451 }
5452 tr->allocated_snapshot = allocate_snapshot;
5439 5453
5440#ifdef CONFIG_TRACER_MAX_TRACE 5454 /*
5441 if (tr->max_buffer.buffer) 5455 * Only the top level trace array gets its snapshot allocated
5442 ring_buffer_free(tr->max_buffer.buffer); 5456 * from the kernel command line.
5443 free_percpu(tr->max_buffer.data); 5457 */
5458 allocate_snapshot = false;
5444#endif 5459#endif
5445 return -ENOMEM; 5460 return 0;
5446} 5461}
5447 5462
5448static int new_instance_create(const char *name) 5463static int new_instance_create(const char *name)
diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h
index f4931821a966..26bc71834041 100644
--- a/kernel/trace/trace.h
+++ b/kernel/trace/trace.h
@@ -660,7 +660,7 @@ extern int DYN_FTRACE_TEST_NAME(void);
660#define DYN_FTRACE_TEST_NAME2 trace_selftest_dynamic_test_func2 660#define DYN_FTRACE_TEST_NAME2 trace_selftest_dynamic_test_func2
661extern int DYN_FTRACE_TEST_NAME2(void); 661extern int DYN_FTRACE_TEST_NAME2(void);
662 662
663extern int ring_buffer_expanded; 663extern bool ring_buffer_expanded;
664extern bool tracing_selftest_disabled; 664extern bool tracing_selftest_disabled;
665DECLARE_PER_CPU(int, ftrace_cpu_disabled); 665DECLARE_PER_CPU(int, ftrace_cpu_disabled);
666 666
diff --git a/kernel/trace/trace_events.c b/kernel/trace/trace_events.c
index a376ab5eec5c..38b54c5edeb9 100644
--- a/kernel/trace/trace_events.c
+++ b/kernel/trace/trace_events.c
@@ -1844,8 +1844,8 @@ static char bootup_event_buf[COMMAND_LINE_SIZE] __initdata;
1844static __init int setup_trace_event(char *str) 1844static __init int setup_trace_event(char *str)
1845{ 1845{
1846 strlcpy(bootup_event_buf, str, COMMAND_LINE_SIZE); 1846 strlcpy(bootup_event_buf, str, COMMAND_LINE_SIZE);
1847 ring_buffer_expanded = 1; 1847 ring_buffer_expanded = true;
1848 tracing_selftest_disabled = 1; 1848 tracing_selftest_disabled = true;
1849 1849
1850 return 1; 1850 return 1;
1851} 1851}