Steven Rostedt | 4ace73e | 2012-04-06 00:47:52 +0200 | [diff] [blame] | 1 | #ifndef _PERF_UTIL_TRACE_EVENT_H |
| 2 | #define _PERF_UTIL_TRACE_EVENT_H |
Steven Rostedt | 52050943 | 2009-08-17 16:18:05 +0200 | [diff] [blame] | 3 | |
Frederic Weisbecker | 1ef2ed1 | 2009-08-28 03:09:58 +0200 | [diff] [blame] | 4 | #include "parse-events.h" |
Steven Rostedt | aaf045f | 2012-04-06 00:47:56 +0200 | [diff] [blame^] | 5 | #include "event-parse.h" |
Steven Rostedt | 4ace73e | 2012-04-06 00:47:52 +0200 | [diff] [blame] | 6 | #include "session.h" |
Arnaldo Carvalho de Melo | 743eb86 | 2011-11-28 07:56:39 -0200 | [diff] [blame] | 7 | |
| 8 | struct machine; |
| 9 | struct perf_sample; |
| 10 | union perf_event; |
| 11 | struct thread; |
Steven Rostedt | 52050943 | 2009-08-17 16:18:05 +0200 | [diff] [blame] | 12 | |
Steven Rostedt | aaf045f | 2012-04-06 00:47:56 +0200 | [diff] [blame^] | 13 | extern int header_page_size_size; |
| 14 | extern int header_page_ts_size; |
| 15 | extern int header_page_data_offset; |
| 16 | |
| 17 | extern bool latency_format; |
| 18 | extern struct pevent *perf_pevent; |
| 19 | |
| 20 | enum { |
| 21 | RINGBUF_TYPE_PADDING = 29, |
| 22 | RINGBUF_TYPE_TIME_EXTEND = 30, |
| 23 | RINGBUF_TYPE_TIME_STAMP = 31, |
| 24 | }; |
| 25 | |
| 26 | #ifndef TS_SHIFT |
| 27 | #define TS_SHIFT 27 |
| 28 | #endif |
| 29 | |
| 30 | int bigendian(void); |
| 31 | |
| 32 | int read_trace_init(int file_bigendian, int host_bigendian); |
| 33 | void print_trace_event(int cpu, void *data, int size); |
| 34 | |
| 35 | void print_event(int cpu, void *data, int size, unsigned long long nsecs, |
| 36 | char *comm); |
| 37 | |
| 38 | int parse_ftrace_file(char *buf, unsigned long size); |
| 39 | int parse_event_file(char *buf, unsigned long size, char *sys); |
| 40 | |
| 41 | struct record *trace_peek_data(int cpu); |
| 42 | struct event_format *trace_find_event(int type); |
| 43 | |
| 44 | unsigned long long |
| 45 | raw_field_value(struct event_format *event, const char *name, void *data); |
| 46 | void *raw_field_ptr(struct event_format *event, const char *name, void *data); |
| 47 | |
| 48 | void parse_proc_kallsyms(char *file, unsigned int size __unused); |
| 49 | void parse_ftrace_printk(char *file, unsigned int size __unused); |
| 50 | |
| 51 | ssize_t trace_report(int fd, bool repipe); |
| 52 | |
| 53 | int trace_parse_common_type(void *data); |
| 54 | int trace_parse_common_pid(void *data); |
| 55 | |
| 56 | struct event_format *trace_find_next_event(struct event_format *event); |
| 57 | unsigned long long read_size(void *ptr, int size); |
| 58 | unsigned long long eval_flag(const char *flag); |
| 59 | |
| 60 | struct record *trace_read_data(int cpu); |
Arnaldo Carvalho de Melo | 69aad6f | 2011-01-03 16:39:04 -0200 | [diff] [blame] | 61 | int read_tracing_data(int fd, struct list_head *pattrs); |
Jiri Olsa | 29208e5 | 2011-10-20 15:59:43 +0200 | [diff] [blame] | 62 | |
| 63 | struct tracing_data { |
| 64 | /* size is only valid if temp is 'true' */ |
| 65 | ssize_t size; |
| 66 | bool temp; |
| 67 | char temp_file[50]; |
| 68 | }; |
| 69 | |
| 70 | struct tracing_data *tracing_data_get(struct list_head *pattrs, |
| 71 | int fd, bool temp); |
| 72 | void tracing_data_put(struct tracing_data *tdata); |
| 73 | |
Steven Rostedt | 52050943 | 2009-08-17 16:18:05 +0200 | [diff] [blame] | 74 | |
Tom Zanussi | 956ffd0 | 2009-11-25 01:15:46 -0600 | [diff] [blame] | 75 | struct scripting_ops { |
| 76 | const char *name; |
Tom Zanussi | 586bc5c | 2009-12-15 02:53:35 -0600 | [diff] [blame] | 77 | int (*start_script) (const char *script, int argc, const char **argv); |
Tom Zanussi | 956ffd0 | 2009-11-25 01:15:46 -0600 | [diff] [blame] | 78 | int (*stop_script) (void); |
David Ahern | be6d842 | 2011-03-09 22:23:23 -0700 | [diff] [blame] | 79 | void (*process_event) (union perf_event *event, |
| 80 | struct perf_sample *sample, |
Arnaldo Carvalho de Melo | 9e69c21 | 2011-03-15 15:44:01 -0300 | [diff] [blame] | 81 | struct perf_evsel *evsel, |
Arnaldo Carvalho de Melo | 743eb86 | 2011-11-28 07:56:39 -0200 | [diff] [blame] | 82 | struct machine *machine, |
David Ahern | be6d842 | 2011-03-09 22:23:23 -0700 | [diff] [blame] | 83 | struct thread *thread); |
Tom Zanussi | 956ffd0 | 2009-11-25 01:15:46 -0600 | [diff] [blame] | 84 | int (*generate_script) (const char *outfile); |
| 85 | }; |
| 86 | |
| 87 | int script_spec_register(const char *spec, struct scripting_ops *ops); |
| 88 | |
Tom Zanussi | 16c632d | 2009-11-25 01:15:48 -0600 | [diff] [blame] | 89 | void setup_perl_scripting(void); |
Tom Zanussi | 7e4b21b | 2010-01-27 02:27:57 -0600 | [diff] [blame] | 90 | void setup_python_scripting(void); |
Tom Zanussi | 16c632d | 2009-11-25 01:15:48 -0600 | [diff] [blame] | 91 | |
Tom Zanussi | 7397d80 | 2010-01-27 02:27:54 -0600 | [diff] [blame] | 92 | struct scripting_context { |
| 93 | void *event_data; |
| 94 | }; |
| 95 | |
| 96 | int common_pc(struct scripting_context *context); |
| 97 | int common_flags(struct scripting_context *context); |
| 98 | int common_lock_depth(struct scripting_context *context); |
| 99 | |
Steven Rostedt | 4ace73e | 2012-04-06 00:47:52 +0200 | [diff] [blame] | 100 | #endif /* _PERF_UTIL_TRACE_EVENT_H */ |