1 /* SPDX-License-Identifier: GPL-2.0 */ 2 #ifndef _PERF_UTIL_TRACE_EVENT_H 3 #define _PERF_UTIL_TRACE_EVENT_H 4 5 #include <traceevent/event-parse.h> 6 #include "parse-events.h" 7 8 struct machine; 9 struct perf_sample; 10 union perf_event; 11 struct perf_tool; 12 struct thread; 13 struct tep_plugin_list; 14 15 struct trace_event { 16 struct tep_handle *pevent; 17 struct tep_plugin_list *plugin_list; 18 }; 19 20 int trace_event__init(struct trace_event *t); 21 void trace_event__cleanup(struct trace_event *t); 22 int trace_event__register_resolver(struct machine *machine, 23 tep_func_resolver_t *func); 24 struct tep_event* 25 trace_event__tp_format(const char *sys, const char *name); 26 27 struct tep_event *trace_event__tp_format_id(int id); 28 29 int bigendian(void); 30 31 void event_format__fprintf(struct tep_event *event, 32 int cpu, void *data, int size, FILE *fp); 33 34 void event_format__print(struct tep_event *event, 35 int cpu, void *data, int size); 36 37 int parse_ftrace_file(struct tep_handle *pevent, char *buf, unsigned long size); 38 int parse_event_file(struct tep_handle *pevent, 39 char *buf, unsigned long size, char *sys); 40 41 unsigned long long 42 raw_field_value(struct tep_event *event, const char *name, void *data); 43 44 void parse_proc_kallsyms(struct tep_handle *pevent, char *file, unsigned int size); 45 void parse_ftrace_printk(struct tep_handle *pevent, char *file, unsigned int size); 46 void parse_saved_cmdline(struct tep_handle *pevent, char *file, unsigned int size); 47 48 ssize_t trace_report(int fd, struct trace_event *tevent, bool repipe); 49 50 struct tep_event *trace_find_next_event(struct tep_handle *pevent, 51 struct tep_event *event); 52 unsigned long long read_size(struct tep_event *event, void *ptr, int size); 53 unsigned long long eval_flag(const char *flag); 54 55 int read_tracing_data(int fd, struct list_head *pattrs); 56 57 struct tracing_data { 58 /* size is only valid if temp is 'true' */ 59 ssize_t size; 60 bool temp; 61 char temp_file[50]; 62 }; 63 64 struct tracing_data *tracing_data_get(struct list_head *pattrs, 65 int fd, bool temp); 66 int tracing_data_put(struct tracing_data *tdata); 67 68 69 struct addr_location; 70 71 struct perf_session; 72 struct perf_stat_config; 73 74 struct scripting_ops { 75 const char *name; 76 int (*start_script) (const char *script, int argc, const char **argv); 77 int (*flush_script) (void); 78 int (*stop_script) (void); 79 void (*process_event) (union perf_event *event, 80 struct perf_sample *sample, 81 struct evsel *evsel, 82 struct addr_location *al); 83 void (*process_switch)(union perf_event *event, 84 struct perf_sample *sample, 85 struct machine *machine); 86 void (*process_stat)(struct perf_stat_config *config, 87 struct evsel *evsel, u64 tstamp); 88 void (*process_stat_interval)(u64 tstamp); 89 int (*generate_script) (struct tep_handle *pevent, const char *outfile); 90 }; 91 92 extern unsigned int scripting_max_stack; 93 94 int script_spec_register(const char *spec, struct scripting_ops *ops); 95 96 void setup_perl_scripting(void); 97 void setup_python_scripting(void); 98 99 struct scripting_context { 100 struct tep_handle *pevent; 101 void *event_data; 102 }; 103 104 int common_pc(struct scripting_context *context); 105 int common_flags(struct scripting_context *context); 106 int common_lock_depth(struct scripting_context *context); 107 108 #endif /* _PERF_UTIL_TRACE_EVENT_H */ 109