diff options
Diffstat (limited to 'kernel/trace/trace_selftest.c')
-rw-r--r-- | kernel/trace/trace_selftest.c | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/kernel/trace/trace_selftest.c b/kernel/trace/trace_selftest.c index ef4d3cc009f5..c01874c3b1f9 100644 --- a/kernel/trace/trace_selftest.c +++ b/kernel/trace/trace_selftest.c | |||
@@ -1,6 +1,7 @@ | |||
1 | /* Include in trace.c */ | 1 | /* Include in trace.c */ |
2 | 2 | ||
3 | #include <linux/kthread.h> | 3 | #include <linux/kthread.h> |
4 | #include <linux/delay.h> | ||
4 | 5 | ||
5 | static inline int trace_valid_entry(struct trace_entry *entry) | 6 | static inline int trace_valid_entry(struct trace_entry *entry) |
6 | { | 7 | { |
@@ -15,28 +16,29 @@ static inline int trace_valid_entry(struct trace_entry *entry) | |||
15 | static int | 16 | static int |
16 | trace_test_buffer_cpu(struct trace_array *tr, struct trace_array_cpu *data) | 17 | trace_test_buffer_cpu(struct trace_array *tr, struct trace_array_cpu *data) |
17 | { | 18 | { |
18 | struct page *page; | ||
19 | struct trace_entry *entries; | 19 | struct trace_entry *entries; |
20 | struct page *page; | ||
20 | int idx = 0; | 21 | int idx = 0; |
21 | int i; | 22 | int i; |
22 | 23 | ||
24 | BUG_ON(list_empty(&data->trace_pages)); | ||
23 | page = list_entry(data->trace_pages.next, struct page, lru); | 25 | page = list_entry(data->trace_pages.next, struct page, lru); |
24 | entries = page_address(page); | 26 | entries = page_address(page); |
25 | 27 | ||
26 | if (data->trace != entries) | 28 | if (head_page(data) != entries) |
27 | goto failed; | 29 | goto failed; |
28 | 30 | ||
29 | /* | 31 | /* |
30 | * The starting trace buffer always has valid elements, | 32 | * The starting trace buffer always has valid elements, |
31 | * if any element exits. | 33 | * if any element exists. |
32 | */ | 34 | */ |
33 | entries = data->trace; | 35 | entries = head_page(data); |
34 | 36 | ||
35 | for (i = 0; i < tr->entries; i++) { | 37 | for (i = 0; i < tr->entries; i++) { |
36 | 38 | ||
37 | if (i < data->trace_idx && | 39 | if (i < data->trace_idx && !trace_valid_entry(&entries[idx])) { |
38 | !trace_valid_entry(&entries[idx])) { | 40 | printk(KERN_CONT ".. invalid entry %d ", |
39 | printk(KERN_CONT ".. invalid entry %d ", entries[idx].type); | 41 | entries[idx].type); |
40 | goto failed; | 42 | goto failed; |
41 | } | 43 | } |
42 | 44 | ||
@@ -80,11 +82,10 @@ static int trace_test_buffer(struct trace_array *tr, unsigned long *count) | |||
80 | int ret = 0; | 82 | int ret = 0; |
81 | 83 | ||
82 | for_each_possible_cpu(cpu) { | 84 | for_each_possible_cpu(cpu) { |
83 | if (!tr->data[cpu]->trace) | 85 | if (!head_page(tr->data[cpu])) |
84 | continue; | 86 | continue; |
85 | 87 | ||
86 | cnt += tr->data[cpu]->trace_idx; | 88 | cnt += tr->data[cpu]->trace_idx; |
87 | printk("%d: count = %ld\n", cpu, cnt); | ||
88 | 89 | ||
89 | ret = trace_test_buffer_cpu(tr, tr->data[cpu]); | 90 | ret = trace_test_buffer_cpu(tr, tr->data[cpu]); |
90 | if (ret) | 91 | if (ret) |
@@ -117,6 +118,8 @@ trace_selftest_startup_function(struct tracer *trace, struct trace_array *tr) | |||
117 | } | 118 | } |
118 | 119 | ||
119 | /* start the tracing */ | 120 | /* start the tracing */ |
121 | ftrace_enabled = 1; | ||
122 | |||
120 | tr->ctrl = 1; | 123 | tr->ctrl = 1; |
121 | trace->init(tr); | 124 | trace->init(tr); |
122 | /* Sleep for a 1/10 of a second */ | 125 | /* Sleep for a 1/10 of a second */ |
@@ -124,6 +127,8 @@ trace_selftest_startup_function(struct tracer *trace, struct trace_array *tr) | |||
124 | /* stop the tracing. */ | 127 | /* stop the tracing. */ |
125 | tr->ctrl = 0; | 128 | tr->ctrl = 0; |
126 | trace->ctrl_update(tr); | 129 | trace->ctrl_update(tr); |
130 | ftrace_enabled = 0; | ||
131 | |||
127 | /* check the trace buffer */ | 132 | /* check the trace buffer */ |
128 | ret = trace_test_buffer(tr, &count); | 133 | ret = trace_test_buffer(tr, &count); |
129 | trace->reset(tr); | 134 | trace->reset(tr); |
@@ -328,7 +333,7 @@ trace_selftest_startup_wakeup(struct tracer *trace, struct trace_array *tr) | |||
328 | 333 | ||
329 | /* create a high prio thread */ | 334 | /* create a high prio thread */ |
330 | p = kthread_run(trace_wakeup_test_thread, &isrt, "ftrace-test"); | 335 | p = kthread_run(trace_wakeup_test_thread, &isrt, "ftrace-test"); |
331 | if (!IS_ERR(p)) { | 336 | if (IS_ERR(p)) { |
332 | printk(KERN_CONT "Failed to create ftrace wakeup test thread "); | 337 | printk(KERN_CONT "Failed to create ftrace wakeup test thread "); |
333 | return -1; | 338 | return -1; |
334 | } | 339 | } |