Loading...
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef _PROBE_FINDER_H
3#define _PROBE_FINDER_H
4
5#include <stdbool.h>
6#include "intlist.h"
7#include "probe-event.h"
8#include <linux/ctype.h>
9
10#define MAX_PROBE_BUFFER 1024
11#define MAX_PROBES 128
12#define MAX_PROBE_ARGS 128
13
14#define PROBE_ARG_VARS "$vars"
15#define PROBE_ARG_PARAMS "$params"
16
17static inline int is_c_varname(const char *name)
18{
19 /* TODO */
20 return isalpha(name[0]) || name[0] == '_';
21}
22
23#ifdef HAVE_DWARF_SUPPORT
24
25#include "dwarf-aux.h"
26
27/* TODO: export debuginfo data structure even if no dwarf support */
28
29/* debug information structure */
30struct debuginfo {
31 Dwarf *dbg;
32 Dwfl_Module *mod;
33 Dwfl *dwfl;
34 Dwarf_Addr bias;
35};
36
37/* This also tries to open distro debuginfo */
38struct debuginfo *debuginfo__new(const char *path);
39void debuginfo__delete(struct debuginfo *dbg);
40
41/* Find probe_trace_events specified by perf_probe_event from debuginfo */
42int debuginfo__find_trace_events(struct debuginfo *dbg,
43 struct perf_probe_event *pev,
44 struct probe_trace_event **tevs);
45
46/* Find a perf_probe_point from debuginfo */
47int debuginfo__find_probe_point(struct debuginfo *dbg, unsigned long addr,
48 struct perf_probe_point *ppt);
49
50int debuginfo__get_text_offset(struct debuginfo *dbg, Dwarf_Addr *offs,
51 bool adjust_offset);
52
53/* Find a line range */
54int debuginfo__find_line_range(struct debuginfo *dbg, struct line_range *lr);
55
56/* Find available variables */
57int debuginfo__find_available_vars_at(struct debuginfo *dbg,
58 struct perf_probe_event *pev,
59 struct variable_list **vls);
60
61/* Find a src file from a DWARF tag path */
62int get_real_path(const char *raw_path, const char *comp_dir,
63 char **new_path);
64
65struct probe_finder {
66 struct perf_probe_event *pev; /* Target probe event */
67
68 /* Callback when a probe point is found */
69 int (*callback)(Dwarf_Die *sc_die, struct probe_finder *pf);
70
71 /* For function searching */
72 int lno; /* Line number */
73 Dwarf_Addr addr; /* Address */
74 const char *fname; /* Real file name */
75 Dwarf_Die cu_die; /* Current CU */
76 Dwarf_Die sp_die;
77 struct intlist *lcache; /* Line cache for lazy match */
78
79 /* For variable searching */
80#if _ELFUTILS_PREREQ(0, 142)
81 /* Call Frame Information from .eh_frame */
82 Dwarf_CFI *cfi_eh;
83 /* Call Frame Information from .debug_frame */
84 Dwarf_CFI *cfi_dbg;
85#endif
86 Dwarf_Op *fb_ops; /* Frame base attribute */
87 unsigned int machine; /* Target machine arch */
88 struct perf_probe_arg *pvar; /* Current target variable */
89 struct probe_trace_arg *tvar; /* Current result variable */
90};
91
92struct trace_event_finder {
93 struct probe_finder pf;
94 Dwfl_Module *mod; /* For solving symbols */
95 struct probe_trace_event *tevs; /* Found trace events */
96 int ntevs; /* Number of trace events */
97 int max_tevs; /* Max number of trace events */
98};
99
100struct available_var_finder {
101 struct probe_finder pf;
102 Dwfl_Module *mod; /* For solving symbols */
103 struct variable_list *vls; /* Found variable lists */
104 int nvls; /* Number of variable lists */
105 int max_vls; /* Max no. of variable lists */
106 bool child; /* Search child scopes */
107};
108
109struct line_finder {
110 struct line_range *lr; /* Target line range */
111
112 const char *fname; /* File name */
113 int lno_s; /* Start line number */
114 int lno_e; /* End line number */
115 Dwarf_Die cu_die; /* Current CU */
116 Dwarf_Die sp_die;
117 int found;
118};
119
120#endif /* HAVE_DWARF_SUPPORT */
121
122#endif /*_PROBE_FINDER_H */
1#ifndef _PROBE_FINDER_H
2#define _PROBE_FINDER_H
3
4#include <stdbool.h>
5#include "util.h"
6#include "probe-event.h"
7
8#define MAX_PROBE_BUFFER 1024
9#define MAX_PROBES 128
10
11static inline int is_c_varname(const char *name)
12{
13 /* TODO */
14 return isalpha(name[0]) || name[0] == '_';
15}
16
17#ifdef DWARF_SUPPORT
18
19#include "dwarf-aux.h"
20
21/* TODO: export debuginfo data structure even if no dwarf support */
22
23/* debug information structure */
24struct debuginfo {
25 Dwarf *dbg;
26 Dwfl *dwfl;
27 Dwarf_Addr bias;
28};
29
30extern struct debuginfo *debuginfo__new(const char *path);
31extern struct debuginfo *debuginfo__new_online_kernel(unsigned long addr);
32extern void debuginfo__delete(struct debuginfo *self);
33
34/* Find probe_trace_events specified by perf_probe_event from debuginfo */
35extern int debuginfo__find_trace_events(struct debuginfo *self,
36 struct perf_probe_event *pev,
37 struct probe_trace_event **tevs,
38 int max_tevs);
39
40/* Find a perf_probe_point from debuginfo */
41extern int debuginfo__find_probe_point(struct debuginfo *self,
42 unsigned long addr,
43 struct perf_probe_point *ppt);
44
45/* Find a line range */
46extern int debuginfo__find_line_range(struct debuginfo *self,
47 struct line_range *lr);
48
49/* Find available variables */
50extern int debuginfo__find_available_vars_at(struct debuginfo *self,
51 struct perf_probe_event *pev,
52 struct variable_list **vls,
53 int max_points, bool externs);
54
55struct probe_finder {
56 struct perf_probe_event *pev; /* Target probe event */
57
58 /* Callback when a probe point is found */
59 int (*callback)(Dwarf_Die *sc_die, struct probe_finder *pf);
60
61 /* For function searching */
62 int lno; /* Line number */
63 Dwarf_Addr addr; /* Address */
64 const char *fname; /* Real file name */
65 Dwarf_Die cu_die; /* Current CU */
66 Dwarf_Die sp_die;
67 struct list_head lcache; /* Line cache for lazy match */
68
69 /* For variable searching */
70#if _ELFUTILS_PREREQ(0, 142)
71 Dwarf_CFI *cfi; /* Call Frame Information */
72#endif
73 Dwarf_Op *fb_ops; /* Frame base attribute */
74 struct perf_probe_arg *pvar; /* Current target variable */
75 struct probe_trace_arg *tvar; /* Current result variable */
76};
77
78struct trace_event_finder {
79 struct probe_finder pf;
80 struct probe_trace_event *tevs; /* Found trace events */
81 int ntevs; /* Number of trace events */
82 int max_tevs; /* Max number of trace events */
83};
84
85struct available_var_finder {
86 struct probe_finder pf;
87 struct variable_list *vls; /* Found variable lists */
88 int nvls; /* Number of variable lists */
89 int max_vls; /* Max no. of variable lists */
90 bool externs; /* Find external vars too */
91 bool child; /* Search child scopes */
92};
93
94struct line_finder {
95 struct line_range *lr; /* Target line range */
96
97 const char *fname; /* File name */
98 int lno_s; /* Start line number */
99 int lno_e; /* End line number */
100 Dwarf_Die cu_die; /* Current CU */
101 Dwarf_Die sp_die;
102 int found;
103};
104
105#endif /* DWARF_SUPPORT */
106
107#endif /*_PROBE_FINDER_H */