diff options
author | Frederic Weisbecker <fweisbec@gmail.com> | 2009-03-06 11:21:49 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-03-06 11:59:12 -0500 |
commit | 769b0441f438c4bb4872cb8560eb6fe51bcc09ee (patch) | |
tree | 9908682dfd89e97c3097a7c3adcae35d821e1895 /kernel/trace/trace.h | |
parent | 1ba28e02a18cbdbea123836f6c98efb09cbf59ec (diff) |
tracing/core: drop the old trace_printk() implementation in favour of trace_bprintk()
Impact: faster and lighter tracing
Now that we have trace_bprintk() which is faster and consume lesser
memory than trace_printk() and has the same purpose, we can now drop
the old implementation in favour of the binary one from trace_bprintk(),
which means we move all the implementation of trace_bprintk() to
trace_printk(), so the Api doesn't change except that we must now use
trace_seq_bprintk() to print the TRACE_PRINT entries.
Some changes result of this:
- Previously, trace_bprintk depended of a single tracer and couldn't
work without. This tracer has been dropped and the whole implementation
of trace_printk() (like the module formats management) is now integrated
in the tracing core (comes with CONFIG_TRACING), though we keep the file
trace_printk (previously trace_bprintk.c) where we can find the module
management. Thus we don't overflow trace.c
- changes some parts to use trace_seq_bprintk() to print TRACE_PRINT entries.
- change a bit trace_printk/trace_vprintk macros to support non-builtin formats
constants, and fix 'const' qualifiers warnings. But this is all transparent for
developers.
- etc...
V2:
- Rebase against last changes
- Fix mispell on the changelog
V3:
- Rebase against last changes (moving trace_printk() to kernel.h)
Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
Acked-by: Steven Rostedt <rostedt@goodmis.org>
LKML-Reference: <1236356510-8381-5-git-send-email-fweisbec@gmail.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/trace/trace.h')
-rw-r--r-- | kernel/trace/trace.h | 14 |
1 files changed, 3 insertions, 11 deletions
diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h index 0f5077f8f957..6140922392c8 100644 --- a/kernel/trace/trace.h +++ b/kernel/trace/trace.h | |||
@@ -20,7 +20,6 @@ enum trace_type { | |||
20 | TRACE_WAKE, | 20 | TRACE_WAKE, |
21 | TRACE_STACK, | 21 | TRACE_STACK, |
22 | TRACE_PRINT, | 22 | TRACE_PRINT, |
23 | TRACE_BPRINTK, | ||
24 | TRACE_SPECIAL, | 23 | TRACE_SPECIAL, |
25 | TRACE_MMIO_RW, | 24 | TRACE_MMIO_RW, |
26 | TRACE_MMIO_MAP, | 25 | TRACE_MMIO_MAP, |
@@ -120,16 +119,10 @@ struct userstack_entry { | |||
120 | */ | 119 | */ |
121 | struct print_entry { | 120 | struct print_entry { |
122 | struct trace_entry ent; | 121 | struct trace_entry ent; |
123 | unsigned long ip; | 122 | unsigned long ip; |
124 | int depth; | 123 | int depth; |
125 | char buf[]; | 124 | const char *fmt; |
126 | }; | 125 | u32 buf[]; |
127 | |||
128 | struct bprintk_entry { | ||
129 | struct trace_entry ent; | ||
130 | unsigned long ip; | ||
131 | const char *fmt; | ||
132 | u32 buf[]; | ||
133 | }; | 126 | }; |
134 | #ifdef CONFIG_TRACE_BPRINTK | 127 | #ifdef CONFIG_TRACE_BPRINTK |
135 | extern int trace_bprintk_enable; | 128 | extern int trace_bprintk_enable; |
@@ -296,7 +289,6 @@ extern void __ftrace_bad_type(void); | |||
296 | IF_ASSIGN(var, ent, struct stack_entry, TRACE_STACK); \ | 289 | IF_ASSIGN(var, ent, struct stack_entry, TRACE_STACK); \ |
297 | IF_ASSIGN(var, ent, struct userstack_entry, TRACE_USER_STACK);\ | 290 | IF_ASSIGN(var, ent, struct userstack_entry, TRACE_USER_STACK);\ |
298 | IF_ASSIGN(var, ent, struct print_entry, TRACE_PRINT); \ | 291 | IF_ASSIGN(var, ent, struct print_entry, TRACE_PRINT); \ |
299 | IF_ASSIGN(var, ent, struct bprintk_entry, TRACE_BPRINTK);\ | ||
300 | IF_ASSIGN(var, ent, struct special_entry, 0); \ | 292 | IF_ASSIGN(var, ent, struct special_entry, 0); \ |
301 | IF_ASSIGN(var, ent, struct trace_mmiotrace_rw, \ | 293 | IF_ASSIGN(var, ent, struct trace_mmiotrace_rw, \ |
302 | TRACE_MMIO_RW); \ | 294 | TRACE_MMIO_RW); \ |