blob: fcaf7273e85a35f41ac465c2f343ec07cbd0f1a4 [file] [log] [blame]
Masami Hiramatsu50656ee2009-11-30 19:19:58 -05001#ifndef _PROBE_EVENT_H
2#define _PROBE_EVENT_H
3
Masami Hiramatsufac13fd2009-12-15 10:31:14 -05004#include <stdbool.h>
Masami Hiramatsu4de189f2009-11-30 19:20:17 -05005#include "strlist.h"
Masami Hiramatsubd09d7b2011-01-20 23:15:39 +09006#include "strfilter.h"
Masami Hiramatsu50656ee2009-11-30 19:19:58 -05007
Masami Hiramatsuf4d7da42010-03-16 18:06:05 -04008extern bool probe_event_dry_run;
9
Srikar Dronamraju225466f2012-04-16 17:39:09 +053010/* kprobe-tracer and uprobe-tracer tracing point */
Srikar Dronamraju0e608362010-07-29 19:43:51 +053011struct probe_trace_point {
Masami Hiramatsu4235b042010-03-16 18:06:12 -040012 char *symbol; /* Base symbol */
Masami Hiramatsu190b57f2011-06-27 16:27:45 +090013 char *module; /* Module name */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040014 unsigned long offset; /* Offset from symbol */
Masami Hiramatsufb7345b2013-12-26 05:41:53 +000015 unsigned long address; /* Actual address of the trace point */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040016 bool retprobe; /* Return probe flag */
17};
18
Srikar Dronamraju0e608362010-07-29 19:43:51 +053019/* probe-tracer tracing argument referencing offset */
20struct probe_trace_arg_ref {
21 struct probe_trace_arg_ref *next; /* Next reference */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040022 long offset; /* Offset value */
23};
24
Srikar Dronamraju225466f2012-04-16 17:39:09 +053025/* kprobe-tracer and uprobe-tracer tracing argument */
Srikar Dronamraju0e608362010-07-29 19:43:51 +053026struct probe_trace_arg {
Masami Hiramatsu4235b042010-03-16 18:06:12 -040027 char *name; /* Argument name */
28 char *value; /* Base value */
Masami Hiramatsu49849122010-04-12 13:17:15 -040029 char *type; /* Type name */
Srikar Dronamraju0e608362010-07-29 19:43:51 +053030 struct probe_trace_arg_ref *ref; /* Referencing offset */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040031};
32
Srikar Dronamraju225466f2012-04-16 17:39:09 +053033/* kprobe-tracer and uprobe-tracer tracing event (point + arg) */
Srikar Dronamraju0e608362010-07-29 19:43:51 +053034struct probe_trace_event {
Masami Hiramatsu4235b042010-03-16 18:06:12 -040035 char *event; /* Event name */
36 char *group; /* Group name */
Srikar Dronamraju0e608362010-07-29 19:43:51 +053037 struct probe_trace_point point; /* Trace point */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040038 int nargs; /* Number of args */
Srikar Dronamraju225466f2012-04-16 17:39:09 +053039 bool uprobes; /* uprobes only */
Srikar Dronamraju0e608362010-07-29 19:43:51 +053040 struct probe_trace_arg *args; /* Arguments */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040041};
42
43/* Perf probe probing point */
44struct perf_probe_point {
45 char *file; /* File path */
46 char *function; /* Function name */
47 int line; /* Line number */
Arnaldo Carvalho de Meloeed05fe2010-04-05 12:53:45 -030048 bool retprobe; /* Return probe flag */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040049 char *lazy_line; /* Lazy matching pattern */
50 unsigned long offset; /* Offset from function entry */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040051};
52
Masami Hiramatsu7df2f322010-03-16 18:06:26 -040053/* Perf probe probing argument field chain */
54struct perf_probe_arg_field {
55 struct perf_probe_arg_field *next; /* Next field */
56 char *name; /* Name of the field */
Masami Hiramatsub2a3c122010-05-19 15:57:42 -040057 long index; /* Array index number */
Masami Hiramatsu7df2f322010-03-16 18:06:26 -040058 bool ref; /* Referencing flag */
59};
60
Masami Hiramatsu4235b042010-03-16 18:06:12 -040061/* Perf probe probing argument */
62struct perf_probe_arg {
Masami Hiramatsu7df2f322010-03-16 18:06:26 -040063 char *name; /* Argument name */
Masami Hiramatsu48481932010-04-12 13:16:53 -040064 char *var; /* Variable name */
Masami Hiramatsu11a1ca32010-04-12 13:17:22 -040065 char *type; /* Type name */
Masami Hiramatsu7df2f322010-03-16 18:06:26 -040066 struct perf_probe_arg_field *field; /* Structure fields */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040067};
68
69/* Perf probe probing event (point + arg) */
70struct perf_probe_event {
71 char *event; /* Event name */
72 char *group; /* Group name */
73 struct perf_probe_point point; /* Probe point */
74 int nargs; /* Number of arguments */
Srikar Dronamraju225466f2012-04-16 17:39:09 +053075 bool uprobes;
Masami Hiramatsu4235b042010-03-16 18:06:12 -040076 struct perf_probe_arg *args; /* Arguments */
77};
78
79
80/* Line number container */
81struct line_node {
82 struct list_head list;
Masami Hiramatsud3b63d72010-04-14 18:39:42 -040083 int line;
Masami Hiramatsu4235b042010-03-16 18:06:12 -040084};
85
86/* Line range */
87struct line_range {
88 char *file; /* File name */
89 char *function; /* Function name */
Masami Hiramatsud3b63d72010-04-14 18:39:42 -040090 int start; /* Start line number */
91 int end; /* End line number */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040092 int offset; /* Start line offset */
93 char *path; /* Real path name */
Masami Hiramatsu6a330a32010-07-09 18:29:11 +090094 char *comp_dir; /* Compile directory */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040095 struct list_head line_list; /* Visible lines */
96};
97
Masami Hiramatsucf6eb482010-10-21 19:13:23 +090098/* List of variables */
99struct variable_list {
100 struct probe_trace_point point; /* Actual probepoint */
101 struct strlist *vars; /* Available variables */
102};
103
Masami Hiramatsu4235b042010-03-16 18:06:12 -0400104/* Command string to events */
Masami Hiramatsu146a1432010-04-12 13:17:42 -0400105extern int parse_perf_probe_command(const char *cmd,
106 struct perf_probe_event *pev);
Masami Hiramatsu4235b042010-03-16 18:06:12 -0400107
108/* Events to command string */
109extern char *synthesize_perf_probe_command(struct perf_probe_event *pev);
Srikar Dronamraju0e608362010-07-29 19:43:51 +0530110extern char *synthesize_probe_trace_command(struct probe_trace_event *tev);
Masami Hiramatsu7df2f322010-03-16 18:06:26 -0400111extern int synthesize_perf_probe_arg(struct perf_probe_arg *pa, char *buf,
112 size_t len);
Masami Hiramatsu4235b042010-03-16 18:06:12 -0400113
114/* Check the perf_probe_event needs debuginfo */
115extern bool perf_probe_event_need_dwarf(struct perf_probe_event *pev);
116
Masami Hiramatsu4235b042010-03-16 18:06:12 -0400117/* Release event contents */
118extern void clear_perf_probe_event(struct perf_probe_event *pev);
Masami Hiramatsu4235b042010-03-16 18:06:12 -0400119
120/* Command string to line-range */
Masami Hiramatsu146a1432010-04-12 13:17:42 -0400121extern int parse_line_range_desc(const char *cmd, struct line_range *lr);
Masami Hiramatsu4235b042010-03-16 18:06:12 -0400122
Masami Hiramatsue53b00d2014-01-16 09:39:47 +0000123/* Release line range members */
124extern void line_range__clear(struct line_range *lr);
125
126/* Initialize line range */
127extern void line_range__init(struct line_range *lr);
128
Masami Hiramatsu469b9b82010-10-21 19:13:41 +0900129/* Internal use: Return kernel/module path */
130extern const char *kernel_get_module_path(const char *module);
Masami Hiramatsu4235b042010-03-16 18:06:12 -0400131
Masami Hiramatsuef4a3562010-04-21 15:56:40 -0400132extern int add_perf_probe_events(struct perf_probe_event *pevs, int npevs,
Masami Hiramatsu469b9b82010-10-21 19:13:41 +0900133 int max_probe_points, const char *module,
134 bool force_add);
Masami Hiramatsu146a1432010-04-12 13:17:42 -0400135extern int del_perf_probe_events(struct strlist *dellist);
136extern int show_perf_probe_events(void);
Masami Hiramatsu469b9b82010-10-21 19:13:41 +0900137extern int show_line_range(struct line_range *lr, const char *module);
Masami Hiramatsucf6eb482010-10-21 19:13:23 +0900138extern int show_available_vars(struct perf_probe_event *pevs, int npevs,
Masami Hiramatsu469b9b82010-10-21 19:13:41 +0900139 int max_probe_points, const char *module,
Masami Hiramatsubd09d7b2011-01-20 23:15:39 +0900140 struct strfilter *filter, bool externs);
Srikar Dronamraju225466f2012-04-16 17:39:09 +0530141extern int show_available_funcs(const char *module, struct strfilter *filter,
142 bool user);
Masami Hiramatsu4235b042010-03-16 18:06:12 -0400143
Masami Hiramatsub498ce12009-11-30 19:20:25 -0500144/* Maximum index number of event-name postfix */
145#define MAX_EVENT_INDEX 1024
146
Masami Hiramatsu50656ee2009-11-30 19:19:58 -0500147#endif /*_PROBE_EVENT_H */