aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/trace/trace.c
diff options
context:
space:
mode:
authorIngo Molnar <mingo@elte.hu>2008-05-12 15:20:52 -0400
committerThomas Gleixner <tglx@linutronix.de>2008-05-23 15:04:44 -0400
commit4e65551905fb0300ae7e667cbaa41ee2e3f29a13 (patch)
tree0e642c311e31043eecf86c218128c40e1ddac782 /kernel/trace/trace.c
parent4c1f4d4f0175129934d5dbc19a39296430937a05 (diff)
ftrace: sched tracer, trace full rbtree
Signed-off-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'kernel/trace/trace.c')
-rw-r--r--kernel/trace/trace.c55
1 files changed, 23 insertions, 32 deletions
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
index 0e4b7119e263..65173b14b914 100644
--- a/kernel/trace/trace.c
+++ b/kernel/trace/trace.c
@@ -66,7 +66,18 @@ static struct tracer *current_trace __read_mostly;
66static int max_tracer_type_len; 66static int max_tracer_type_len;
67 67
68static DEFINE_MUTEX(trace_types_lock); 68static DEFINE_MUTEX(trace_types_lock);
69static DECLARE_WAIT_QUEUE_HEAD (trace_wait); 69static DECLARE_WAIT_QUEUE_HEAD(trace_wait);
70
71unsigned long trace_flags = TRACE_ITER_PRINT_PARENT;
72
73/*
74 * FIXME: where should this be called?
75 */
76void trace_wake_up(void)
77{
78 if (!(trace_flags & TRACE_ITER_BLOCK))
79 wake_up(&trace_wait);
80}
70 81
71#define ENTRIES_PER_PAGE (PAGE_SIZE / sizeof(struct trace_entry)) 82#define ENTRIES_PER_PAGE (PAGE_SIZE / sizeof(struct trace_entry))
72 83
@@ -103,18 +114,6 @@ enum trace_flag_type {
103 TRACE_FLAG_SOFTIRQ = 0x08, 114 TRACE_FLAG_SOFTIRQ = 0x08,
104}; 115};
105 116
106enum trace_iterator_flags {
107 TRACE_ITER_PRINT_PARENT = 0x01,
108 TRACE_ITER_SYM_OFFSET = 0x02,
109 TRACE_ITER_SYM_ADDR = 0x04,
110 TRACE_ITER_VERBOSE = 0x08,
111 TRACE_ITER_RAW = 0x10,
112 TRACE_ITER_HEX = 0x20,
113 TRACE_ITER_BIN = 0x40,
114 TRACE_ITER_BLOCK = 0x80,
115 TRACE_ITER_STACKTRACE = 0x100,
116};
117
118#define TRACE_ITER_SYM_MASK \ 117#define TRACE_ITER_SYM_MASK \
119 (TRACE_ITER_PRINT_PARENT|TRACE_ITER_SYM_OFFSET|TRACE_ITER_SYM_ADDR) 118 (TRACE_ITER_PRINT_PARENT|TRACE_ITER_SYM_OFFSET|TRACE_ITER_SYM_ADDR)
120 119
@@ -132,8 +131,6 @@ static const char *trace_options[] = {
132 NULL 131 NULL
133}; 132};
134 133
135static unsigned trace_flags = TRACE_ITER_PRINT_PARENT;
136
137static DEFINE_SPINLOCK(ftrace_max_lock); 134static DEFINE_SPINLOCK(ftrace_max_lock);
138 135
139/* 136/*
@@ -660,9 +657,6 @@ trace_function(struct trace_array *tr, struct trace_array_cpu *data,
660 entry->fn.ip = ip; 657 entry->fn.ip = ip;
661 entry->fn.parent_ip = parent_ip; 658 entry->fn.parent_ip = parent_ip;
662 spin_unlock_irqrestore(&data->lock, irq_flags); 659 spin_unlock_irqrestore(&data->lock, irq_flags);
663
664 if (!(trace_flags & TRACE_ITER_BLOCK))
665 wake_up(&trace_wait);
666} 660}
667 661
668void 662void
@@ -673,10 +667,14 @@ ftrace(struct trace_array *tr, struct trace_array_cpu *data,
673 trace_function(tr, data, ip, parent_ip, flags); 667 trace_function(tr, data, ip, parent_ip, flags);
674} 668}
675 669
670#ifdef CONFIG_CONTEXT_SWITCH_TRACER
671
676void 672void
677trace_special(struct trace_array *tr, struct trace_array_cpu *data, 673__trace_special(void *__tr, void *__data,
678 unsigned long arg1, unsigned long arg2, unsigned long arg3) 674 unsigned long arg1, unsigned long arg2, unsigned long arg3)
679{ 675{
676 struct trace_array_cpu *data = __data;
677 struct trace_array *tr = __tr;
680 struct trace_entry *entry; 678 struct trace_entry *entry;
681 unsigned long irq_flags; 679 unsigned long irq_flags;
682 680
@@ -688,11 +686,10 @@ trace_special(struct trace_array *tr, struct trace_array_cpu *data,
688 entry->special.arg2 = arg2; 686 entry->special.arg2 = arg2;
689 entry->special.arg3 = arg3; 687 entry->special.arg3 = arg3;
690 spin_unlock_irqrestore(&data->lock, irq_flags); 688 spin_unlock_irqrestore(&data->lock, irq_flags);
691
692 if (!(trace_flags & TRACE_ITER_BLOCK))
693 wake_up(&trace_wait);
694} 689}
695 690
691#endif
692
696void __trace_stack(struct trace_array *tr, 693void __trace_stack(struct trace_array *tr,
697 struct trace_array_cpu *data, 694 struct trace_array_cpu *data,
698 unsigned long flags, 695 unsigned long flags,
@@ -739,9 +736,6 @@ tracing_sched_switch_trace(struct trace_array *tr,
739 entry->ctx.next_prio = next->prio; 736 entry->ctx.next_prio = next->prio;
740 __trace_stack(tr, data, flags, 4); 737 __trace_stack(tr, data, flags, 4);
741 spin_unlock_irqrestore(&data->lock, irq_flags); 738 spin_unlock_irqrestore(&data->lock, irq_flags);
742
743 if (!(trace_flags & TRACE_ITER_BLOCK))
744 wake_up(&trace_wait);
745} 739}
746 740
747void 741void
@@ -765,9 +759,6 @@ tracing_sched_wakeup_trace(struct trace_array *tr,
765 entry->ctx.next_prio = wakee->prio; 759 entry->ctx.next_prio = wakee->prio;
766 __trace_stack(tr, data, flags, 5); 760 __trace_stack(tr, data, flags, 5);
767 spin_unlock_irqrestore(&data->lock, irq_flags); 761 spin_unlock_irqrestore(&data->lock, irq_flags);
768
769 if (!(trace_flags & TRACE_ITER_BLOCK))
770 wake_up(&trace_wait);
771} 762}
772 763
773#ifdef CONFIG_FTRACE 764#ifdef CONFIG_FTRACE
@@ -1258,7 +1249,7 @@ print_lat_fmt(struct trace_iterator *iter, unsigned int trace_idx, int cpu)
1258 comm); 1249 comm);
1259 break; 1250 break;
1260 case TRACE_SPECIAL: 1251 case TRACE_SPECIAL:
1261 trace_seq_printf(s, " %lx %lx %lx\n", 1252 trace_seq_printf(s, " %ld %ld %ld\n",
1262 entry->special.arg1, 1253 entry->special.arg1,
1263 entry->special.arg2, 1254 entry->special.arg2,
1264 entry->special.arg3); 1255 entry->special.arg3);
@@ -1344,7 +1335,7 @@ static int print_trace_fmt(struct trace_iterator *iter)
1344 return 0; 1335 return 0;
1345 break; 1336 break;
1346 case TRACE_SPECIAL: 1337 case TRACE_SPECIAL:
1347 ret = trace_seq_printf(s, " %lx %lx %lx\n", 1338 ret = trace_seq_printf(s, " %ld %ld %ld\n",
1348 entry->special.arg1, 1339 entry->special.arg1,
1349 entry->special.arg2, 1340 entry->special.arg2,
1350 entry->special.arg3); 1341 entry->special.arg3);
@@ -1409,7 +1400,7 @@ static int print_raw_fmt(struct trace_iterator *iter)
1409 break; 1400 break;
1410 case TRACE_SPECIAL: 1401 case TRACE_SPECIAL:
1411 case TRACE_STACK: 1402 case TRACE_STACK:
1412 ret = trace_seq_printf(s, " %lx %lx %lx\n", 1403 ret = trace_seq_printf(s, " %ld %ld %ld\n",
1413 entry->special.arg1, 1404 entry->special.arg1,
1414 entry->special.arg2, 1405 entry->special.arg2,
1415 entry->special.arg3); 1406 entry->special.arg3);