aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--kernel/trace/trace.c46
-rw-r--r--kernel/trace/trace.h15
-rw-r--r--kernel/trace/trace_mmiotrace.c42
3 files changed, 50 insertions, 53 deletions
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
index 7e6cb4fe62f2..d372bc535963 100644
--- a/kernel/trace/trace.c
+++ b/kernel/trace/trace.c
@@ -785,7 +785,7 @@ trace_next_page(struct trace_array_cpu *data, void *addr)
785 return page_address(page); 785 return page_address(page);
786} 786}
787 787
788static inline struct trace_entry * 788struct trace_entry *
789tracing_get_trace_entry(struct trace_array *tr, struct trace_array_cpu *data) 789tracing_get_trace_entry(struct trace_array *tr, struct trace_array_cpu *data)
790{ 790{
791 unsigned long idx, idx_next; 791 unsigned long idx, idx_next;
@@ -821,7 +821,7 @@ tracing_get_trace_entry(struct trace_array *tr, struct trace_array_cpu *data)
821 return entry; 821 return entry;
822} 822}
823 823
824static inline void 824void
825tracing_generic_entry_update(struct trace_entry *entry, unsigned long flags) 825tracing_generic_entry_update(struct trace_entry *entry, unsigned long flags)
826{ 826{
827 struct task_struct *tsk = current; 827 struct task_struct *tsk = current;
@@ -865,48 +865,6 @@ ftrace(struct trace_array *tr, struct trace_array_cpu *data,
865 trace_function(tr, data, ip, parent_ip, flags); 865 trace_function(tr, data, ip, parent_ip, flags);
866} 866}
867 867
868#ifdef CONFIG_MMIOTRACE
869void __trace_mmiotrace_rw(struct trace_array *tr, struct trace_array_cpu *data,
870 struct mmiotrace_rw *rw)
871{
872 struct trace_entry *entry;
873 unsigned long irq_flags;
874
875 raw_local_irq_save(irq_flags);
876 __raw_spin_lock(&data->lock);
877
878 entry = tracing_get_trace_entry(tr, data);
879 tracing_generic_entry_update(entry, 0);
880 entry->type = TRACE_MMIO_RW;
881 entry->field.mmiorw = *rw;
882
883 __raw_spin_unlock(&data->lock);
884 raw_local_irq_restore(irq_flags);
885
886 trace_wake_up();
887}
888
889void __trace_mmiotrace_map(struct trace_array *tr, struct trace_array_cpu *data,
890 struct mmiotrace_map *map)
891{
892 struct trace_entry *entry;
893 unsigned long irq_flags;
894
895 raw_local_irq_save(irq_flags);
896 __raw_spin_lock(&data->lock);
897
898 entry = tracing_get_trace_entry(tr, data);
899 tracing_generic_entry_update(entry, 0);
900 entry->type = TRACE_MMIO_MAP;
901 entry->field.mmiomap = *map;
902
903 __raw_spin_unlock(&data->lock);
904 raw_local_irq_restore(irq_flags);
905
906 trace_wake_up();
907}
908#endif
909
910void __trace_stack(struct trace_array *tr, 868void __trace_stack(struct trace_array *tr,
911 struct trace_array_cpu *data, 869 struct trace_array_cpu *data,
912 unsigned long flags, 870 unsigned long flags,
diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h
index 77c265f6a779..9d39aa00a9c6 100644
--- a/kernel/trace/trace.h
+++ b/kernel/trace/trace.h
@@ -213,11 +213,17 @@ struct trace_iterator {
213 long idx; 213 long idx;
214}; 214};
215 215
216void trace_wake_up(void);
216void tracing_reset(struct trace_array_cpu *data); 217void tracing_reset(struct trace_array_cpu *data);
217int tracing_open_generic(struct inode *inode, struct file *filp); 218int tracing_open_generic(struct inode *inode, struct file *filp);
218struct dentry *tracing_init_dentry(void); 219struct dentry *tracing_init_dentry(void);
219void init_tracer_sysprof_debugfs(struct dentry *d_tracer); 220void init_tracer_sysprof_debugfs(struct dentry *d_tracer);
220 221
222struct trace_entry *tracing_get_trace_entry(struct trace_array *tr,
223 struct trace_array_cpu *data);
224void tracing_generic_entry_update(struct trace_entry *entry,
225 unsigned long flags);
226
221void ftrace(struct trace_array *tr, 227void ftrace(struct trace_array *tr,
222 struct trace_array_cpu *data, 228 struct trace_array_cpu *data,
223 unsigned long ip, 229 unsigned long ip,
@@ -291,15 +297,6 @@ extern unsigned long ftrace_update_tot_cnt;
291extern int DYN_FTRACE_TEST_NAME(void); 297extern int DYN_FTRACE_TEST_NAME(void);
292#endif 298#endif
293 299
294#ifdef CONFIG_MMIOTRACE
295extern void __trace_mmiotrace_rw(struct trace_array *tr,
296 struct trace_array_cpu *data,
297 struct mmiotrace_rw *rw);
298extern void __trace_mmiotrace_map(struct trace_array *tr,
299 struct trace_array_cpu *data,
300 struct mmiotrace_map *map);
301#endif
302
303#ifdef CONFIG_FTRACE_STARTUP_TEST 300#ifdef CONFIG_FTRACE_STARTUP_TEST
304#ifdef CONFIG_FTRACE 301#ifdef CONFIG_FTRACE
305extern int trace_selftest_startup_function(struct tracer *trace, 302extern int trace_selftest_startup_function(struct tracer *trace,
diff --git a/kernel/trace/trace_mmiotrace.c b/kernel/trace/trace_mmiotrace.c
index 9b7a936f4b1f..ef02747b26d9 100644
--- a/kernel/trace/trace_mmiotrace.c
+++ b/kernel/trace/trace_mmiotrace.c
@@ -276,6 +276,27 @@ __init static int init_mmio_trace(void)
276} 276}
277device_initcall(init_mmio_trace); 277device_initcall(init_mmio_trace);
278 278
279static void __trace_mmiotrace_rw(struct trace_array *tr,
280 struct trace_array_cpu *data,
281 struct mmiotrace_rw *rw)
282{
283 struct trace_entry *entry;
284 unsigned long irq_flags;
285
286 raw_local_irq_save(irq_flags);
287 __raw_spin_lock(&data->lock);
288
289 entry = tracing_get_trace_entry(tr, data);
290 tracing_generic_entry_update(entry, 0);
291 entry->type = TRACE_MMIO_RW;
292 entry->field.mmiorw = *rw;
293
294 __raw_spin_unlock(&data->lock);
295 raw_local_irq_restore(irq_flags);
296
297 trace_wake_up();
298}
299
279void mmio_trace_rw(struct mmiotrace_rw *rw) 300void mmio_trace_rw(struct mmiotrace_rw *rw)
280{ 301{
281 struct trace_array *tr = mmio_trace_array; 302 struct trace_array *tr = mmio_trace_array;
@@ -283,6 +304,27 @@ void mmio_trace_rw(struct mmiotrace_rw *rw)
283 __trace_mmiotrace_rw(tr, data, rw); 304 __trace_mmiotrace_rw(tr, data, rw);
284} 305}
285 306
307static void __trace_mmiotrace_map(struct trace_array *tr,
308 struct trace_array_cpu *data,
309 struct mmiotrace_map *map)
310{
311 struct trace_entry *entry;
312 unsigned long irq_flags;
313
314 raw_local_irq_save(irq_flags);
315 __raw_spin_lock(&data->lock);
316
317 entry = tracing_get_trace_entry(tr, data);
318 tracing_generic_entry_update(entry, 0);
319 entry->type = TRACE_MMIO_MAP;
320 entry->field.mmiomap = *map;
321
322 __raw_spin_unlock(&data->lock);
323 raw_local_irq_restore(irq_flags);
324
325 trace_wake_up();
326}
327
286void mmio_trace_mapping(struct mmiotrace_map *map) 328void mmio_trace_mapping(struct mmiotrace_map *map)
287{ 329{
288 struct trace_array *tr = mmio_trace_array; 330 struct trace_array *tr = mmio_trace_array;