blob: d5168f0be4ec5b3284a825f620886689391e0f66 [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);
Jiri Olsa97978b32013-12-03 14:09:24 +010021struct event_format*
22trace_event__tp_format(const char *sys, const char *name);
Steven Rostedt520509432009-08-17 16:18:05 +020023
Steven Rostedtaaf045f2012-04-06 00:47:56 +020024int bigendian(void);
25
Arnaldo Carvalho de Meloaa1aac12015-02-03 12:46:58 -030026void event_format__fprintf(struct event_format *event,
27 int cpu, void *data, int size, FILE *fp);
28
Arnaldo Carvalho de Melofcf65bf2012-08-07 09:58:03 -030029void event_format__print(struct event_format *event,
30 int cpu, void *data, int size);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020031
Arnaldo Carvalho de Meloda378962012-06-27 13:08:42 -030032int parse_ftrace_file(struct pevent *pevent, char *buf, unsigned long size);
33int parse_event_file(struct pevent *pevent,
34 char *buf, unsigned long size, char *sys);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020035
Steven Rostedtaaf045f2012-04-06 00:47:56 +020036unsigned long long
37raw_field_value(struct event_format *event, const char *name, void *data);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020038
Arnaldo Carvalho de Meloda378962012-06-27 13:08:42 -030039void parse_proc_kallsyms(struct pevent *pevent, char *file, unsigned int size);
40void parse_ftrace_printk(struct pevent *pevent, char *file, unsigned int size);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020041
Jiri Olsa29f5ffd2013-12-03 14:09:23 +010042ssize_t trace_report(int fd, struct trace_event *tevent, bool repipe);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020043
Arnaldo Carvalho de Meloda378962012-06-27 13:08:42 -030044struct event_format *trace_find_next_event(struct pevent *pevent,
45 struct event_format *event);
Arnaldo Carvalho de Melo97822432012-08-07 23:50:21 -030046unsigned long long read_size(struct event_format *event, void *ptr, int size);
Steven Rostedtaaf045f2012-04-06 00:47:56 +020047unsigned long long eval_flag(const char *flag);
48
Arnaldo Carvalho de Melo69aad6f2011-01-03 16:39:04 -020049int read_tracing_data(int fd, struct list_head *pattrs);
Jiri Olsa29208e52011-10-20 15:59:43 +020050
51struct tracing_data {
52 /* size is only valid if temp is 'true' */
53 ssize_t size;
54 bool temp;
55 char temp_file[50];
56};
57
58struct tracing_data *tracing_data_get(struct list_head *pattrs,
59 int fd, bool temp);
Namhyung Kim8755d5e2013-03-21 16:18:46 +090060int tracing_data_put(struct tracing_data *tdata);
Jiri Olsa29208e52011-10-20 15:59:43 +020061
Steven Rostedt520509432009-08-17 16:18:05 +020062
Feng Tang73994dc2012-08-08 17:57:52 +080063struct addr_location;
64
Jiri Olsa71ad0f52012-08-07 15:20:46 +020065struct perf_session;
66
Tom Zanussi956ffd02009-11-25 01:15:46 -060067struct scripting_ops {
68 const char *name;
Tom Zanussi586bc5c2009-12-15 02:53:35 -060069 int (*start_script) (const char *script, int argc, const char **argv);
Adrian Hunterd445dd22014-08-15 22:08:37 +030070 int (*flush_script) (void);
Tom Zanussi956ffd02009-11-25 01:15:46 -060071 int (*stop_script) (void);
David Ahernbe6d8422011-03-09 22:23:23 -070072 void (*process_event) (union perf_event *event,
73 struct perf_sample *sample,
Arnaldo Carvalho de Melo9e69c212011-03-15 15:44:01 -030074 struct perf_evsel *evsel,
Arnaldo Carvalho de Melof9d5d542015-04-01 13:29:25 -030075 struct addr_location *al);
Arnaldo Carvalho de Meloda378962012-06-27 13:08:42 -030076 int (*generate_script) (struct pevent *pevent, const char *outfile);
Tom Zanussi956ffd02009-11-25 01:15:46 -060077};
78
79int script_spec_register(const char *spec, struct scripting_ops *ops);
80
Tom Zanussi16c632d2009-11-25 01:15:48 -060081void setup_perl_scripting(void);
Tom Zanussi7e4b21b2010-01-27 02:27:57 -060082void setup_python_scripting(void);
Tom Zanussi16c632d2009-11-25 01:15:48 -060083
Tom Zanussi7397d802010-01-27 02:27:54 -060084struct scripting_context {
Arnaldo Carvalho de Meloda378962012-06-27 13:08:42 -030085 struct pevent *pevent;
Tom Zanussi7397d802010-01-27 02:27:54 -060086 void *event_data;
87};
88
89int common_pc(struct scripting_context *context);
90int common_flags(struct scripting_context *context);
91int common_lock_depth(struct scripting_context *context);
92
Steven Rostedt4ace73e2012-04-06 00:47:52 +020093#endif /* _PERF_UTIL_TRACE_EVENT_H */