mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-15 09:03:59 +08:00
425480081e
Currently, if a trace_stat user wants a handle to some private data, the trace_stat infrastructure does not supply a way to do that. This patch passes the trace_stat structure to the start function of the trace_stat code. Signed-off-by: Steven Rostedt <srostedt@redhat.com>
32 lines
912 B
C
32 lines
912 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)(struct tracer_stat *trace);
|
|
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 */
|