002bb86d8d
Impact: tracing's Api change Currently, the stat tracing depends on the events tracing. When you switch to a new tracer, the stats files of the previous tracer will disappear. But it's more scalable to separate those two engines. This way, we can keep the stat files of one or several tracers when we want, without bothering of multiple tracer stat files or tracer switching. To build/destroys its stats files, a tracer just have to call register_stat_tracer/unregister_stat_tracer everytimes it wants to. Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com> Signed-off-by: Steven Rostedt <srostedt@redhat.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
31 lines
891 B
C
31 lines
891 B
C
#ifndef __TRACE_STAT_H
|
|
#define __TRACE_STAT_H
|
|
|
|
#include <linux/seq_file.h>
|
|
|
|
/*
|
|
* If you want to provide a stat file (one-shot statistics), fill
|
|
* an iterator with stat_start/stat_next and a stat_show callbacks.
|
|
* The others callbacks are optional.
|
|
*/
|
|
struct tracer_stat {
|
|
/* The name of your stat file */
|
|
const char *name;
|
|
/* Iteration over statistic entries */
|
|
void *(*stat_start)(void);
|
|
void *(*stat_next)(void *prev, int idx);
|
|
/* Compare two entries for stats sorting */
|
|
int (*stat_cmp)(void *p1, void *p2);
|
|
/* Print a stat entry */
|
|
int (*stat_show)(struct seq_file *s, void *p);
|
|
/* Print the headers of your stat entries */
|
|
int (*stat_headers)(struct seq_file *s);
|
|
};
|
|
|
|
/*
|
|
* Destroy or create a stat file
|
|
*/
|
|
extern int register_stat_tracer(struct tracer_stat *trace);
|
|
extern void unregister_stat_tracer(struct tracer_stat *trace);
|
|
|
|
#endif /* __TRACE_STAT_H */
|