blob: bce5b1dac26827735e538d737e9417555f3c3e2b [file] [log] [blame]
Steven Rostedt4ace73e2012-04-06 00:47:52 +02001#ifndef _PERF_UTIL_TRACE_EVENT_H
2#define _PERF_UTIL_TRACE_EVENT_H
Steven Rostedt520509432009-08-17 16:18:05 +02003
Robert Richter4e319022013-06-11 17:29:18 +02004#include <traceevent/event-parse.h>
Frederic Weisbecker1ef2ed12009-08-28 03:09:58 +02005#include "parse-events.h"
Arnaldo Carvalho de Melo743eb862011-11-28 07:56:39 -02006
7struct machine;
8struct perf_sample;
9union perf_event;
Arnaldo Carvalho de Meloda378962012-06-27 13:08:42 -030010struct perf_tool;
David Ahern2eaa1b42013-07-18 16:06:15 -060011struct thread;
Jiri Olsa29f5ffd2013-12-03 14:09:23 +010012struct plugin_list;
13
14struct trace_event {
15 struct pevent *pevent;
16 struct plugin_list *plugin_list;
17};
18
19int trace_event__init(struct trace_event *t);
20void trace_event__cleanup(struct trace_event *t);
Arnaldo Carvalho de Melo959c2192015-07-24 12:13:05 -030021int trace_event__register_resolver(struct machine *machine,
22 pevent_func_resolver_t *func);
Jiri Olsa97978b32013-12-03 14:09:24 +010023struct event_format*
24trace_event__tp_format(const char *sys, const char *name);
Steven Rostedt520509432009-08-17 16:18:05 +020025
Steven Rostedtaaf045f2012-04-06 00:47:56 +020026int bigendian(void);
27
Arnaldo Carvalho de Meloaa1aac12015-02-03 12:46:58 -030028void event_format__fprintf(struct event_format *event,
29 int cpu, void *data, int size, FILE *fp);
30
Arnaldo Carvalho de Melofcf65bf2012-08-07 09:58:03 -030031void event_format__print(struct event_format *event,
32 int cpu, void *data, int size);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020033
Arnaldo Carvalho de Meloda378962012-06-27 13:08:42 -030034int parse_ftrace_file(struct pevent *pevent, char *buf, unsigned long size);
35int parse_event_file(struct pevent *pevent,
36 char *buf, unsigned long size, char *sys);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020037
Steven Rostedtaaf045f2012-04-06 00:47:56 +020038unsigned long long
39raw_field_value(struct event_format *event, const char *name, void *data);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020040
Arnaldo Carvalho de Meloda378962012-06-27 13:08:42 -030041void parse_proc_kallsyms(struct pevent *pevent, char *file, unsigned int size);
42void parse_ftrace_printk(struct pevent *pevent, char *file, unsigned int size);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020043
Jiri Olsa29f5ffd2013-12-03 14:09:23 +010044ssize_t trace_report(int fd, struct trace_event *tevent, bool repipe);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020045
Arnaldo Carvalho de Meloda378962012-06-27 13:08:42 -030046struct event_format *trace_find_next_event(struct pevent *pevent,
47 struct event_format *event);
Arnaldo Carvalho de Melo97822432012-08-07 23:50:21 -030048unsigned long long read_size(struct event_format *event, void *ptr, int size);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020049unsigned long long eval_flag(const char *flag);
50
Arnaldo Carvalho de Melo69aad6f2011-01-03 16:39:04 -020051int read_tracing_data(int fd, struct list_head *pattrs);
Jiri Olsa29208e52011-10-20 15:59:43 +020052
53struct tracing_data {
54 /* size is only valid if temp is 'true' */
55 ssize_t size;
56 bool temp;
57 char temp_file[50];
58};
59
60struct tracing_data *tracing_data_get(struct list_head *pattrs,
61 int fd, bool temp);
Namhyung Kim8755d5e2013-03-21 16:18:46 +090062int tracing_data_put(struct tracing_data *tdata);
Jiri Olsa29208e52011-10-20 15:59:43 +020063
Steven Rostedt520509432009-08-17 16:18:05 +020064
Feng Tang73994dc2012-08-08 17:57:52 +080065struct addr_location;
66
Jiri Olsa71ad0f52012-08-07 15:20:46 +020067struct perf_session;
Jiri Olsa8058a302016-01-05 22:09:08 +010068struct perf_stat_config;
Jiri Olsa71ad0f52012-08-07 15:20:46 +020069
Tom Zanussi956ffd02009-11-25 01:15:46 -060070struct scripting_ops {
71 const char *name;
Tom Zanussi586bc5c2009-12-15 02:53:35 -060072 int (*start_script) (const char *script, int argc, const char **argv);
Adrian Hunterd445dd22014-08-15 22:08:37 +030073 int (*flush_script) (void);
Tom Zanussi956ffd02009-11-25 01:15:46 -060074 int (*stop_script) (void);
David Ahernbe6d8422011-03-09 22:23:23 -070075 void (*process_event) (union perf_event *event,
76 struct perf_sample *sample,
Arnaldo Carvalho de Melo9e69c212011-03-15 15:44:01 -030077 struct perf_evsel *evsel,
Arnaldo Carvalho de Melof9d5d542015-04-01 13:29:25 -030078 struct addr_location *al);
Jiri Olsa8058a302016-01-05 22:09:08 +010079 void (*process_stat)(struct perf_stat_config *config,
80 struct perf_evsel *evsel, u64 tstamp);
81 void (*process_stat_interval)(u64 tstamp);
Arnaldo Carvalho de Meloda378962012-06-27 13:08:42 -030082 int (*generate_script) (struct pevent *pevent, const char *outfile);
Tom Zanussi956ffd02009-11-25 01:15:46 -060083};
84
Adrian Hunter44cbe722015-09-25 16:15:50 +030085extern unsigned int scripting_max_stack;
86
Tom Zanussi956ffd02009-11-25 01:15:46 -060087int script_spec_register(const char *spec, struct scripting_ops *ops);
88
Tom Zanussi16c632d2009-11-25 01:15:48 -060089void setup_perl_scripting(void);
Tom Zanussi7e4b21b2010-01-27 02:27:57 -060090void setup_python_scripting(void);
Tom Zanussi16c632d2009-11-25 01:15:48 -060091
Tom Zanussi7397d802010-01-27 02:27:54 -060092struct scripting_context {
Arnaldo Carvalho de Meloda378962012-06-27 13:08:42 -030093 struct pevent *pevent;
Tom Zanussi7397d802010-01-27 02:27:54 -060094 void *event_data;
95};
96
97int common_pc(struct scripting_context *context);
98int common_flags(struct scripting_context *context);
99int common_lock_depth(struct scripting_context *context);
100
Steven Rostedt4ace73e2012-04-06 00:47:52 +0200101#endif /* _PERF_UTIL_TRACE_EVENT_H */