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/* 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 "build-id.h"
8#include "probe-event.h"
9#include <linux/ctype.h>
10
11#define MAX_PROBE_BUFFER 1024
12#define MAX_PROBES 128
13#define MAX_PROBE_ARGS 128
14
15#define PROBE_ARG_VARS "$vars"
16#define PROBE_ARG_PARAMS "$params"
17
18static inline int is_c_varname(const char *name)
19{
20 /* TODO */
21 return isalpha(name[0]) || name[0] == '_';
22}
23
24#ifdef HAVE_LIBDW_SUPPORT
25
26#include "dwarf-aux.h"
27#include "debuginfo.h"
28
29/* Find probe_trace_events specified by perf_probe_event from debuginfo */
30int debuginfo__find_trace_events(struct debuginfo *dbg,
31 struct perf_probe_event *pev,
32 struct probe_trace_event **tevs);
33
34/* Find a perf_probe_point from debuginfo */
35int debuginfo__find_probe_point(struct debuginfo *dbg, u64 addr,
36 struct perf_probe_point *ppt);
37
38/* Find a line range */
39int debuginfo__find_line_range(struct debuginfo *dbg, struct line_range *lr);
40
41/* Find available variables */
42int debuginfo__find_available_vars_at(struct debuginfo *dbg,
43 struct perf_probe_event *pev,
44 struct variable_list **vls);
45
46/* Find a src file from a DWARF tag path */
47int find_source_path(const char *raw_path, const char *sbuild_id,
48 const char *comp_dir, char **new_path);
49
50struct probe_finder {
51 struct perf_probe_event *pev; /* Target probe event */
52 struct debuginfo *dbg;
53
54 /* Callback when a probe point is found */
55 int (*callback)(Dwarf_Die *sc_die, struct probe_finder *pf);
56
57 /* For function searching */
58 int lno; /* Line number */
59 Dwarf_Addr addr; /* Address */
60 const char *fname; /* Real file name */
61 Dwarf_Die cu_die; /* Current CU */
62 Dwarf_Die sp_die;
63 struct intlist *lcache; /* Line cache for lazy match */
64
65 /* For variable searching */
66 /* Call Frame Information from .eh_frame. Owned by this struct. */
67 Dwarf_CFI *cfi_eh;
68 /* Call Frame Information from .debug_frame. Not owned. */
69 Dwarf_CFI *cfi_dbg;
70 Dwarf_Op *fb_ops; /* Frame base attribute */
71 unsigned int e_machine; /* ELF target machine arch */
72 unsigned int e_flags; /* ELF target machine flags */
73 struct perf_probe_arg *pvar; /* Current target variable */
74 struct probe_trace_arg *tvar; /* Current result variable */
75 bool skip_empty_arg; /* Skip non-exist args */
76};
77
78struct trace_event_finder {
79 struct probe_finder pf;
80 Dwfl_Module *mod; /* For solving symbols */
81 struct probe_trace_event *tevs; /* Found trace events */
82 int ntevs; /* Number of trace events */
83 int max_tevs; /* Max number of trace events */
84};
85
86struct available_var_finder {
87 struct probe_finder pf;
88 Dwfl_Module *mod; /* For solving symbols */
89 struct variable_list *vls; /* Found variable lists */
90 int nvls; /* Number of variable lists */
91 int max_vls; /* Max no. of variable lists */
92 bool child; /* Search child scopes */
93};
94
95struct line_finder {
96 struct line_range *lr; /* Target line range */
97
98 const char *fname; /* File name */
99 int lno_s; /* Start line number */
100 int lno_e; /* End line number */
101 Dwarf_Die cu_die; /* Current CU */
102 Dwarf_Die sp_die;
103 int found;
104};
105
106#endif /* HAVE_LIBDW_SUPPORT */
107
108#endif /*_PROBE_FINDER_H */