blob: 0aec7704e39540b51a449cdf395b6a16ab682fba [file] [log] [blame]
Masami Hiramatsu4ea42b12009-10-08 17:17:38 -04001#ifndef _PROBE_FINDER_H
2#define _PROBE_FINDER_H
3
Masami Hiramatsu804b3602010-02-25 08:35:42 -05004#include <stdbool.h>
Arnaldo Carvalho de Melo4a58e612009-12-27 21:37:00 -02005#include "util.h"
Masami Hiramatsu5a622572014-02-06 05:32:09 +00006#include "intlist.h"
Masami Hiramatsu4235b042010-03-16 18:06:12 -04007#include "probe-event.h"
Arnaldo Carvalho de Melo4a58e612009-12-27 21:37:00 -02008
Masami Hiramatsu27f3b242009-12-16 17:16:19 -05009#define MAX_PROBE_BUFFER 1024
10#define MAX_PROBES 128
Masami Hiramatsu7969ec72013-10-11 16:10:23 +090011#define MAX_PROBE_ARGS 128
Masami Hiramatsu4ea42b12009-10-08 17:17:38 -040012
Masami Hiramatsuf8bffbf2015-05-06 21:46:53 +090013#define PROBE_ARG_VARS "$vars"
14#define PROBE_ARG_PARAMS "$params"
15
Masami Hiramatsu4ea42b12009-10-08 17:17:38 -040016static inline int is_c_varname(const char *name)
17{
18 /* TODO */
19 return isalpha(name[0]) || name[0] == '_';
20}
21
Ingo Molnar89fe8082013-09-30 12:07:11 +020022#ifdef HAVE_DWARF_SUPPORT
Masami Hiramatsuff741782011-06-27 16:27:39 +090023
24#include "dwarf-aux.h"
25
26/* TODO: export debuginfo data structure even if no dwarf support */
27
28/* debug information structure */
29struct debuginfo {
30 Dwarf *dbg;
Masami Hiramatsu576b5232013-09-25 22:16:16 +090031 Dwfl_Module *mod;
Masami Hiramatsuff741782011-06-27 16:27:39 +090032 Dwfl *dwfl;
33 Dwarf_Addr bias;
34};
35
Masami Hiramatsua15ad2f2014-02-06 05:32:27 +000036/* This also tries to open distro debuginfo */
Masami Hiramatsuff741782011-06-27 16:27:39 +090037extern struct debuginfo *debuginfo__new(const char *path);
Arnaldo Carvalho de Melo316c7132013-11-05 15:32:36 -030038extern void debuginfo__delete(struct debuginfo *dbg);
Masami Hiramatsuff741782011-06-27 16:27:39 +090039
Srikar Dronamraju0e608362010-07-29 19:43:51 +053040/* Find probe_trace_events specified by perf_probe_event from debuginfo */
Arnaldo Carvalho de Melo316c7132013-11-05 15:32:36 -030041extern int debuginfo__find_trace_events(struct debuginfo *dbg,
Masami Hiramatsuff741782011-06-27 16:27:39 +090042 struct perf_probe_event *pev,
Masami Hiramatsuddb2f582015-05-08 10:03:31 +090043 struct probe_trace_event **tevs);
Masami Hiramatsu4235b042010-03-16 18:06:12 -040044
Masami Hiramatsufb1587d2010-03-16 18:06:19 -040045/* Find a perf_probe_point from debuginfo */
Arnaldo Carvalho de Melo316c7132013-11-05 15:32:36 -030046extern int debuginfo__find_probe_point(struct debuginfo *dbg,
Masami Hiramatsuff741782011-06-27 16:27:39 +090047 unsigned long addr,
48 struct perf_probe_point *ppt);
Masami Hiramatsufb1587d2010-03-16 18:06:19 -040049
Masami Hiramatsucf6eb482010-10-21 19:13:23 +090050/* Find a line range */
Arnaldo Carvalho de Melo316c7132013-11-05 15:32:36 -030051extern int debuginfo__find_line_range(struct debuginfo *dbg,
Masami Hiramatsuff741782011-06-27 16:27:39 +090052 struct line_range *lr);
Masami Hiramatsu4ea42b12009-10-08 17:17:38 -040053
Masami Hiramatsucf6eb482010-10-21 19:13:23 +090054/* Find available variables */
Arnaldo Carvalho de Melo316c7132013-11-05 15:32:36 -030055extern int debuginfo__find_available_vars_at(struct debuginfo *dbg,
Masami Hiramatsuff741782011-06-27 16:27:39 +090056 struct perf_probe_event *pev,
Masami Hiramatsuddb2f582015-05-08 10:03:31 +090057 struct variable_list **vls);
Masami Hiramatsu4ea42b12009-10-08 17:17:38 -040058
Naohiro Aota09ed8972015-03-13 14:18:40 +090059/* Find a src file from a DWARF tag path */
60int get_real_path(const char *raw_path, const char *comp_dir,
61 char **new_path);
62
Masami Hiramatsu4ea42b12009-10-08 17:17:38 -040063struct probe_finder {
Masami Hiramatsu4235b042010-03-16 18:06:12 -040064 struct perf_probe_event *pev; /* Target probe event */
Masami Hiramatsucf6eb482010-10-21 19:13:23 +090065
66 /* Callback when a probe point is found */
Masami Hiramatsu221d0612011-08-11 20:02:59 +090067 int (*callback)(Dwarf_Die *sc_die, struct probe_finder *pf);
Masami Hiramatsu4ea42b12009-10-08 17:17:38 -040068
69 /* For function searching */
Arnaldo Carvalho de Meloeed05fe2010-04-05 12:53:45 -030070 int lno; /* Line number */
Masami Hiramatsu804b3602010-02-25 08:35:42 -050071 Dwarf_Addr addr; /* Address */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040072 const char *fname; /* Real file name */
Masami Hiramatsu804b3602010-02-25 08:35:42 -050073 Dwarf_Die cu_die; /* Current CU */
Lin Mingcd25f8b2011-03-25 16:27:48 +080074 Dwarf_Die sp_die;
Masami Hiramatsu5a622572014-02-06 05:32:09 +000075 struct intlist *lcache; /* Line cache for lazy match */
Masami Hiramatsu4ea42b12009-10-08 17:17:38 -040076
77 /* For variable searching */
Masami Hiramatsu7752f1b2010-05-10 13:12:07 -040078#if _ELFUTILS_PREREQ(0, 142)
Hemant Kumar270bde12016-02-02 20:56:46 +053079 /* Call Frame Information from .eh_frame */
80 Dwarf_CFI *cfi_eh;
81 /* Call Frame Information from .debug_frame */
82 Dwarf_CFI *cfi_dbg;
Masami Hiramatsu7752f1b2010-05-10 13:12:07 -040083#endif
Masami Hiramatsu804b3602010-02-25 08:35:42 -050084 Dwarf_Op *fb_ops; /* Frame base attribute */
Masami Hiramatsu4235b042010-03-16 18:06:12 -040085 struct perf_probe_arg *pvar; /* Current target variable */
Srikar Dronamraju0e608362010-07-29 19:43:51 +053086 struct probe_trace_arg *tvar; /* Current result variable */
Masami Hiramatsu4ea42b12009-10-08 17:17:38 -040087};
Masami Hiramatsu631c9de2010-01-06 09:45:34 -050088
Masami Hiramatsucf6eb482010-10-21 19:13:23 +090089struct trace_event_finder {
90 struct probe_finder pf;
Masami Hiramatsu576b5232013-09-25 22:16:16 +090091 Dwfl_Module *mod; /* For solving symbols */
Masami Hiramatsucf6eb482010-10-21 19:13:23 +090092 struct probe_trace_event *tevs; /* Found trace events */
93 int ntevs; /* Number of trace events */
94 int max_tevs; /* Max number of trace events */
95};
96
97struct available_var_finder {
98 struct probe_finder pf;
Masami Hiramatsu576b5232013-09-25 22:16:16 +090099 Dwfl_Module *mod; /* For solving symbols */
Masami Hiramatsucf6eb482010-10-21 19:13:23 +0900100 struct variable_list *vls; /* Found variable lists */
101 int nvls; /* Number of variable lists */
102 int max_vls; /* Max no. of variable lists */
Masami Hiramatsufb8c5a52010-10-21 19:13:35 +0900103 bool child; /* Search child scopes */
Masami Hiramatsucf6eb482010-10-21 19:13:23 +0900104};
105
Masami Hiramatsu631c9de2010-01-06 09:45:34 -0500106struct line_finder {
Masami Hiramatsu804b3602010-02-25 08:35:42 -0500107 struct line_range *lr; /* Target line range */
Masami Hiramatsu631c9de2010-01-06 09:45:34 -0500108
Masami Hiramatsu804b3602010-02-25 08:35:42 -0500109 const char *fname; /* File name */
110 int lno_s; /* Start line number */
111 int lno_e; /* End line number */
Masami Hiramatsu804b3602010-02-25 08:35:42 -0500112 Dwarf_Die cu_die; /* Current CU */
Lin Mingcd25f8b2011-03-25 16:27:48 +0800113 Dwarf_Die sp_die;
Masami Hiramatsu631c9de2010-01-06 09:45:34 -0500114 int found;
115};
116
Ingo Molnar89fe8082013-09-30 12:07:11 +0200117#endif /* HAVE_DWARF_SUPPORT */
Masami Hiramatsu4ea42b12009-10-08 17:17:38 -0400118
119#endif /*_PROBE_FINDER_H */