~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/tools/perf/util/probe-finder.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /tools/perf/util/probe-finder.h (Architecture m68k) and /tools/perf/util/probe-finder.h (Architecture sparc)


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

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php