Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Masami Hiramatsu | 4ea42b1 | 2009-10-08 17:17:38 -0400 | [diff] [blame] | 2 | #ifndef _PROBE_FINDER_H |
| 3 | #define _PROBE_FINDER_H |
| 4 | |
Masami Hiramatsu | 804b360 | 2010-02-25 08:35:42 -0500 | [diff] [blame] | 5 | #include <stdbool.h> |
Masami Hiramatsu | 5a62257 | 2014-02-06 05:32:09 +0000 | [diff] [blame] | 6 | #include "intlist.h" |
Masami Hiramatsu | 4235b04 | 2010-03-16 18:06:12 -0400 | [diff] [blame] | 7 | #include "probe-event.h" |
Arnaldo Carvalho de Melo | 3052ba5 | 2019-06-25 17:27:31 -0300 | [diff] [blame] | 8 | #include <linux/ctype.h> |
Arnaldo Carvalho de Melo | 4a58e61 | 2009-12-27 21:37:00 -0200 | [diff] [blame] | 9 | |
Masami Hiramatsu | 27f3b24 | 2009-12-16 17:16:19 -0500 | [diff] [blame] | 10 | #define MAX_PROBE_BUFFER 1024 |
| 11 | #define MAX_PROBES 128 |
Masami Hiramatsu | 7969ec7 | 2013-10-11 16:10:23 +0900 | [diff] [blame] | 12 | #define MAX_PROBE_ARGS 128 |
Masami Hiramatsu | 4ea42b1 | 2009-10-08 17:17:38 -0400 | [diff] [blame] | 13 | |
Masami Hiramatsu | f8bffbf | 2015-05-06 21:46:53 +0900 | [diff] [blame] | 14 | #define PROBE_ARG_VARS "$vars" |
| 15 | #define PROBE_ARG_PARAMS "$params" |
| 16 | |
Masami Hiramatsu | 4ea42b1 | 2009-10-08 17:17:38 -0400 | [diff] [blame] | 17 | static inline int is_c_varname(const char *name) |
| 18 | { |
| 19 | /* TODO */ |
| 20 | return isalpha(name[0]) || name[0] == '_'; |
| 21 | } |
| 22 | |
Ingo Molnar | 89fe808 | 2013-09-30 12:07:11 +0200 | [diff] [blame] | 23 | #ifdef HAVE_DWARF_SUPPORT |
Masami Hiramatsu | ff74178 | 2011-06-27 16:27:39 +0900 | [diff] [blame] | 24 | |
| 25 | #include "dwarf-aux.h" |
| 26 | |
| 27 | /* TODO: export debuginfo data structure even if no dwarf support */ |
| 28 | |
| 29 | /* debug information structure */ |
| 30 | struct debuginfo { |
| 31 | Dwarf *dbg; |
Masami Hiramatsu | 576b523 | 2013-09-25 22:16:16 +0900 | [diff] [blame] | 32 | Dwfl_Module *mod; |
Masami Hiramatsu | ff74178 | 2011-06-27 16:27:39 +0900 | [diff] [blame] | 33 | Dwfl *dwfl; |
| 34 | Dwarf_Addr bias; |
| 35 | }; |
| 36 | |
Masami Hiramatsu | a15ad2f | 2014-02-06 05:32:27 +0000 | [diff] [blame] | 37 | /* This also tries to open distro debuginfo */ |
Arnaldo Carvalho de Melo | 3938bad | 2016-03-23 15:06:35 -0300 | [diff] [blame] | 38 | struct debuginfo *debuginfo__new(const char *path); |
| 39 | void debuginfo__delete(struct debuginfo *dbg); |
Masami Hiramatsu | ff74178 | 2011-06-27 16:27:39 +0900 | [diff] [blame] | 40 | |
Srikar Dronamraju | 0e60836 | 2010-07-29 19:43:51 +0530 | [diff] [blame] | 41 | /* Find probe_trace_events specified by perf_probe_event from debuginfo */ |
Arnaldo Carvalho de Melo | 3938bad | 2016-03-23 15:06:35 -0300 | [diff] [blame] | 42 | int debuginfo__find_trace_events(struct debuginfo *dbg, |
| 43 | struct perf_probe_event *pev, |
| 44 | struct probe_trace_event **tevs); |
Masami Hiramatsu | 4235b04 | 2010-03-16 18:06:12 -0400 | [diff] [blame] | 45 | |
Masami Hiramatsu | fb1587d | 2010-03-16 18:06:19 -0400 | [diff] [blame] | 46 | /* Find a perf_probe_point from debuginfo */ |
Arnaldo Carvalho de Melo | 3938bad | 2016-03-23 15:06:35 -0300 | [diff] [blame] | 47 | int debuginfo__find_probe_point(struct debuginfo *dbg, unsigned long addr, |
| 48 | struct perf_probe_point *ppt); |
Masami Hiramatsu | fb1587d | 2010-03-16 18:06:19 -0400 | [diff] [blame] | 49 | |
Masami Hiramatsu | 613f050 | 2017-01-11 15:01:57 +0900 | [diff] [blame] | 50 | int debuginfo__get_text_offset(struct debuginfo *dbg, Dwarf_Addr *offs, |
| 51 | bool adjust_offset); |
| 52 | |
Masami Hiramatsu | cf6eb48 | 2010-10-21 19:13:23 +0900 | [diff] [blame] | 53 | /* Find a line range */ |
Arnaldo Carvalho de Melo | 3938bad | 2016-03-23 15:06:35 -0300 | [diff] [blame] | 54 | int debuginfo__find_line_range(struct debuginfo *dbg, struct line_range *lr); |
Masami Hiramatsu | 4ea42b1 | 2009-10-08 17:17:38 -0400 | [diff] [blame] | 55 | |
Masami Hiramatsu | cf6eb48 | 2010-10-21 19:13:23 +0900 | [diff] [blame] | 56 | /* Find available variables */ |
Arnaldo Carvalho de Melo | 3938bad | 2016-03-23 15:06:35 -0300 | [diff] [blame] | 57 | int debuginfo__find_available_vars_at(struct debuginfo *dbg, |
| 58 | struct perf_probe_event *pev, |
| 59 | struct variable_list **vls); |
Masami Hiramatsu | 4ea42b1 | 2009-10-08 17:17:38 -0400 | [diff] [blame] | 60 | |
Naohiro Aota | 09ed897 | 2015-03-13 14:18:40 +0900 | [diff] [blame] | 61 | /* Find a src file from a DWARF tag path */ |
| 62 | int get_real_path(const char *raw_path, const char *comp_dir, |
| 63 | char **new_path); |
| 64 | |
Masami Hiramatsu | 4ea42b1 | 2009-10-08 17:17:38 -0400 | [diff] [blame] | 65 | struct probe_finder { |
Masami Hiramatsu | 4235b04 | 2010-03-16 18:06:12 -0400 | [diff] [blame] | 66 | struct perf_probe_event *pev; /* Target probe event */ |
Masami Hiramatsu | cf6eb48 | 2010-10-21 19:13:23 +0900 | [diff] [blame] | 67 | |
| 68 | /* Callback when a probe point is found */ |
Masami Hiramatsu | 221d061 | 2011-08-11 20:02:59 +0900 | [diff] [blame] | 69 | int (*callback)(Dwarf_Die *sc_die, struct probe_finder *pf); |
Masami Hiramatsu | 4ea42b1 | 2009-10-08 17:17:38 -0400 | [diff] [blame] | 70 | |
| 71 | /* For function searching */ |
Arnaldo Carvalho de Melo | eed05fe | 2010-04-05 12:53:45 -0300 | [diff] [blame] | 72 | int lno; /* Line number */ |
Masami Hiramatsu | 804b360 | 2010-02-25 08:35:42 -0500 | [diff] [blame] | 73 | Dwarf_Addr addr; /* Address */ |
Masami Hiramatsu | 4235b04 | 2010-03-16 18:06:12 -0400 | [diff] [blame] | 74 | const char *fname; /* Real file name */ |
Masami Hiramatsu | 804b360 | 2010-02-25 08:35:42 -0500 | [diff] [blame] | 75 | Dwarf_Die cu_die; /* Current CU */ |
Lin Ming | cd25f8b | 2011-03-25 16:27:48 +0800 | [diff] [blame] | 76 | Dwarf_Die sp_die; |
Masami Hiramatsu | 5a62257 | 2014-02-06 05:32:09 +0000 | [diff] [blame] | 77 | struct intlist *lcache; /* Line cache for lazy match */ |
Masami Hiramatsu | 4ea42b1 | 2009-10-08 17:17:38 -0400 | [diff] [blame] | 78 | |
| 79 | /* For variable searching */ |
Masami Hiramatsu | 7752f1b | 2010-05-10 13:12:07 -0400 | [diff] [blame] | 80 | #if _ELFUTILS_PREREQ(0, 142) |
Hemant Kumar | 270bde1 | 2016-02-02 20:56:46 +0530 | [diff] [blame] | 81 | /* Call Frame Information from .eh_frame */ |
| 82 | Dwarf_CFI *cfi_eh; |
| 83 | /* Call Frame Information from .debug_frame */ |
| 84 | Dwarf_CFI *cfi_dbg; |
Masami Hiramatsu | 7752f1b | 2010-05-10 13:12:07 -0400 | [diff] [blame] | 85 | #endif |
Masami Hiramatsu | 804b360 | 2010-02-25 08:35:42 -0500 | [diff] [blame] | 86 | Dwarf_Op *fb_ops; /* Frame base attribute */ |
Masami Hiramatsu | 293d5b4 | 2016-08-26 01:24:57 +0900 | [diff] [blame] | 87 | unsigned int machine; /* Target machine arch */ |
Masami Hiramatsu | 4235b04 | 2010-03-16 18:06:12 -0400 | [diff] [blame] | 88 | struct perf_probe_arg *pvar; /* Current target variable */ |
Srikar Dronamraju | 0e60836 | 2010-07-29 19:43:51 +0530 | [diff] [blame] | 89 | struct probe_trace_arg *tvar; /* Current result variable */ |
Masami Hiramatsu | 4ea42b1 | 2009-10-08 17:17:38 -0400 | [diff] [blame] | 90 | }; |
Masami Hiramatsu | 631c9de | 2010-01-06 09:45:34 -0500 | [diff] [blame] | 91 | |
Masami Hiramatsu | cf6eb48 | 2010-10-21 19:13:23 +0900 | [diff] [blame] | 92 | struct trace_event_finder { |
| 93 | struct probe_finder pf; |
Masami Hiramatsu | 576b523 | 2013-09-25 22:16:16 +0900 | [diff] [blame] | 94 | Dwfl_Module *mod; /* For solving symbols */ |
Masami Hiramatsu | cf6eb48 | 2010-10-21 19:13:23 +0900 | [diff] [blame] | 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 | |
| 100 | struct available_var_finder { |
| 101 | struct probe_finder pf; |
Masami Hiramatsu | 576b523 | 2013-09-25 22:16:16 +0900 | [diff] [blame] | 102 | Dwfl_Module *mod; /* For solving symbols */ |
Masami Hiramatsu | cf6eb48 | 2010-10-21 19:13:23 +0900 | [diff] [blame] | 103 | struct variable_list *vls; /* Found variable lists */ |
| 104 | int nvls; /* Number of variable lists */ |
| 105 | int max_vls; /* Max no. of variable lists */ |
Masami Hiramatsu | fb8c5a5 | 2010-10-21 19:13:35 +0900 | [diff] [blame] | 106 | bool child; /* Search child scopes */ |
Masami Hiramatsu | cf6eb48 | 2010-10-21 19:13:23 +0900 | [diff] [blame] | 107 | }; |
| 108 | |
Masami Hiramatsu | 631c9de | 2010-01-06 09:45:34 -0500 | [diff] [blame] | 109 | struct line_finder { |
Masami Hiramatsu | 804b360 | 2010-02-25 08:35:42 -0500 | [diff] [blame] | 110 | struct line_range *lr; /* Target line range */ |
Masami Hiramatsu | 631c9de | 2010-01-06 09:45:34 -0500 | [diff] [blame] | 111 | |
Masami Hiramatsu | 804b360 | 2010-02-25 08:35:42 -0500 | [diff] [blame] | 112 | const char *fname; /* File name */ |
| 113 | int lno_s; /* Start line number */ |
| 114 | int lno_e; /* End line number */ |
Masami Hiramatsu | 804b360 | 2010-02-25 08:35:42 -0500 | [diff] [blame] | 115 | Dwarf_Die cu_die; /* Current CU */ |
Lin Ming | cd25f8b | 2011-03-25 16:27:48 +0800 | [diff] [blame] | 116 | Dwarf_Die sp_die; |
Masami Hiramatsu | 631c9de | 2010-01-06 09:45:34 -0500 | [diff] [blame] | 117 | int found; |
| 118 | }; |
| 119 | |
Ingo Molnar | 89fe808 | 2013-09-30 12:07:11 +0200 | [diff] [blame] | 120 | #endif /* HAVE_DWARF_SUPPORT */ |
Masami Hiramatsu | 4ea42b1 | 2009-10-08 17:17:38 -0400 | [diff] [blame] | 121 | |
| 122 | #endif /*_PROBE_FINDER_H */ |