diff options
Diffstat (limited to 'kernel/trace/trace_irqsoff.c')
-rw-r--r-- | kernel/trace/trace_irqsoff.c | 32 |
1 files changed, 12 insertions, 20 deletions
diff --git a/kernel/trace/trace_irqsoff.c b/kernel/trace/trace_irqsoff.c index 14183b8f79c5..2dfebb67fdfb 100644 --- a/kernel/trace/trace_irqsoff.c +++ b/kernel/trace/trace_irqsoff.c | |||
@@ -144,7 +144,7 @@ check_critical_timing(struct trace_array *tr, | |||
144 | if (!report_latency(delta)) | 144 | if (!report_latency(delta)) |
145 | goto out; | 145 | goto out; |
146 | 146 | ||
147 | spin_lock(&max_trace_lock); | 147 | spin_lock_irqsave(&max_trace_lock, flags); |
148 | 148 | ||
149 | /* check if we are still the max latency */ | 149 | /* check if we are still the max latency */ |
150 | if (!report_latency(delta)) | 150 | if (!report_latency(delta)) |
@@ -165,32 +165,24 @@ check_critical_timing(struct trace_array *tr, | |||
165 | 165 | ||
166 | update_max_tr_single(tr, current, cpu); | 166 | update_max_tr_single(tr, current, cpu); |
167 | 167 | ||
168 | if (tracing_thresh) | 168 | if (tracing_thresh) { |
169 | printk(KERN_INFO "(%16s-%-5d|#%d): %lu us critical section " | 169 | printk(KERN_INFO "(%16s-%-5d|#%d):" |
170 | "violates %lu us threshold.\n" | 170 | " %lu us critical section violates %lu us threshold.\n", |
171 | " => started at timestamp %lu: ", | ||
172 | current->comm, current->pid, | 171 | current->comm, current->pid, |
173 | raw_smp_processor_id(), | 172 | raw_smp_processor_id(), |
174 | latency, nsecs_to_usecs(tracing_thresh), t0); | 173 | latency, nsecs_to_usecs(tracing_thresh)); |
175 | else | 174 | } else { |
176 | printk(KERN_INFO "(%16s-%-5d|#%d):" | 175 | printk(KERN_INFO "(%16s-%-5d|#%d):" |
177 | " new %lu us maximum-latency " | 176 | " new %lu us maximum-latency critical section.\n", |
178 | "critical section.\n => started at timestamp %lu: ", | ||
179 | current->comm, current->pid, | 177 | current->comm, current->pid, |
180 | raw_smp_processor_id(), | 178 | raw_smp_processor_id(), |
181 | latency, t0); | 179 | latency); |
182 | 180 | } | |
183 | print_symbol(KERN_CONT "<%s>\n", data->critical_start); | ||
184 | printk(KERN_CONT " => ended at timestamp %lu: ", t1); | ||
185 | print_symbol(KERN_CONT "<%s>\n", data->critical_end); | ||
186 | dump_stack(); | ||
187 | t1 = nsecs_to_usecs(now(cpu)); | ||
188 | printk(KERN_CONT " => dump-end timestamp %lu\n\n", t1); | ||
189 | 181 | ||
190 | max_sequence++; | 182 | max_sequence++; |
191 | 183 | ||
192 | out_unlock: | 184 | out_unlock: |
193 | spin_unlock(&max_trace_lock); | 185 | spin_unlock_irqrestore(&max_trace_lock, flags); |
194 | 186 | ||
195 | out: | 187 | out: |
196 | data->critical_sequence = max_sequence; | 188 | data->critical_sequence = max_sequence; |
@@ -216,7 +208,7 @@ start_critical_timing(unsigned long ip, unsigned long parent_ip) | |||
216 | cpu = raw_smp_processor_id(); | 208 | cpu = raw_smp_processor_id(); |
217 | data = tr->data[cpu]; | 209 | data = tr->data[cpu]; |
218 | 210 | ||
219 | if (unlikely(!data) || unlikely(!data->trace) || | 211 | if (unlikely(!data) || unlikely(!head_page(data)) || |
220 | atomic_read(&data->disabled)) | 212 | atomic_read(&data->disabled)) |
221 | return; | 213 | return; |
222 | 214 | ||
@@ -256,7 +248,7 @@ stop_critical_timing(unsigned long ip, unsigned long parent_ip) | |||
256 | cpu = raw_smp_processor_id(); | 248 | cpu = raw_smp_processor_id(); |
257 | data = tr->data[cpu]; | 249 | data = tr->data[cpu]; |
258 | 250 | ||
259 | if (unlikely(!data) || unlikely(!data->trace) || | 251 | if (unlikely(!data) || unlikely(!head_page(data)) || |
260 | !data->critical_start || atomic_read(&data->disabled)) | 252 | !data->critical_start || atomic_read(&data->disabled)) |
261 | return; | 253 | return; |
262 | 254 | ||