Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
John Kacur | 8b40f52 | 2009-09-24 18:02:18 +0200 | [diff] [blame] | 2 | #ifndef __PERF_PARSE_EVENTS_H |
| 3 | #define __PERF_PARSE_EVENTS_H |
Ingo Molnar | 5242519 | 2009-05-26 09:17:18 +0200 | [diff] [blame] | 4 | /* |
| 5 | * Parse symbolic events/counts passed in as options: |
| 6 | */ |
| 7 | |
Jiri Olsa | f50246e | 2012-05-21 09:12:49 +0200 | [diff] [blame] | 8 | #include <linux/list.h> |
Robert Richter | c651214 | 2012-04-05 18:26:25 +0200 | [diff] [blame] | 9 | #include <stdbool.h> |
Borislav Petkov | d944c4e | 2014-04-25 21:31:02 +0200 | [diff] [blame] | 10 | #include <linux/types.h> |
David Howells | d2709c7 | 2012-11-19 22:21:03 +0000 | [diff] [blame] | 11 | #include <linux/perf_event.h> |
Ravi Bangoria | af9100a | 2017-03-14 20:36:52 +0530 | [diff] [blame] | 12 | #include <string.h> |
Arnaldo Carvalho de Melo | 69aad6f | 2011-01-03 16:39:04 -0200 | [diff] [blame] | 13 | |
| 14 | struct list_head; |
| 15 | struct perf_evsel; |
Jiri Olsa | f120f9d | 2011-07-14 11:25:32 +0200 | [diff] [blame] | 16 | struct perf_evlist; |
Jiri Olsa | b39b839 | 2015-04-22 21:10:16 +0200 | [diff] [blame] | 17 | struct parse_events_error; |
Arnaldo Carvalho de Melo | 69aad6f | 2011-01-03 16:39:04 -0200 | [diff] [blame] | 18 | |
Jason Baron | 5beeded | 2009-07-21 14:16:29 -0400 | [diff] [blame] | 19 | struct option; |
| 20 | |
Frederic Weisbecker | 1ef2ed1 | 2009-08-28 03:09:58 +0200 | [diff] [blame] | 21 | struct tracepoint_path { |
| 22 | char *system; |
| 23 | char *name; |
| 24 | struct tracepoint_path *next; |
| 25 | }; |
| 26 | |
Arnaldo Carvalho de Melo | 3938bad | 2016-03-23 15:06:35 -0300 | [diff] [blame] | 27 | struct tracepoint_path *tracepoint_id_to_path(u64 config); |
| 28 | struct tracepoint_path *tracepoint_name_to_path(const char *name); |
| 29 | bool have_tracepoints(struct list_head *evlist); |
Frederic Weisbecker | 1ef2ed1 | 2009-08-28 03:09:58 +0200 | [diff] [blame] | 30 | |
David Ahern | 1424dc9 | 2011-03-09 22:23:28 -0700 | [diff] [blame] | 31 | const char *event_type(int type); |
Ingo Molnar | 8ad8db3 | 2009-05-26 11:10:09 +0200 | [diff] [blame] | 32 | |
Arnaldo Carvalho de Melo | 3938bad | 2016-03-23 15:06:35 -0300 | [diff] [blame] | 33 | int parse_events_option(const struct option *opt, const char *str, int unset); |
| 34 | int parse_events(struct perf_evlist *evlist, const char *str, |
| 35 | struct parse_events_error *error); |
| 36 | int parse_events_terms(struct list_head *terms, const char *str); |
| 37 | int parse_filter(const struct option *opt, const char *str, int unset); |
| 38 | int exclude_perf(const struct option *opt, const char *arg, int unset); |
Ingo Molnar | 8ad8db3 | 2009-05-26 11:10:09 +0200 | [diff] [blame] | 39 | |
| 40 | #define EVENTS_HELP_MAX (128*1024) |
| 41 | |
Kan Liang | dcb4e10 | 2014-10-07 11:08:50 -0400 | [diff] [blame] | 42 | enum perf_pmu_event_symbol_type { |
| 43 | PMU_EVENT_SYMBOL_ERR, /* not a PMU EVENT */ |
| 44 | PMU_EVENT_SYMBOL, /* normal style PMU event */ |
| 45 | PMU_EVENT_SYMBOL_PREFIX, /* prefix of pre-suf style event */ |
| 46 | PMU_EVENT_SYMBOL_SUFFIX, /* suffix of pre-suf style event */ |
| 47 | }; |
| 48 | |
| 49 | struct perf_pmu_event_symbol { |
| 50 | char *symbol; |
| 51 | enum perf_pmu_event_symbol_type type; |
| 52 | }; |
| 53 | |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 54 | enum { |
Jiri Olsa | 16fa7e8 | 2012-04-25 18:24:57 +0200 | [diff] [blame] | 55 | PARSE_EVENTS__TERM_TYPE_NUM, |
| 56 | PARSE_EVENTS__TERM_TYPE_STR, |
| 57 | }; |
| 58 | |
| 59 | enum { |
| 60 | PARSE_EVENTS__TERM_TYPE_USER, |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 61 | PARSE_EVENTS__TERM_TYPE_CONFIG, |
| 62 | PARSE_EVENTS__TERM_TYPE_CONFIG1, |
| 63 | PARSE_EVENTS__TERM_TYPE_CONFIG2, |
Jiri Olsa | 6b5fc39 | 2012-05-21 09:12:53 +0200 | [diff] [blame] | 64 | PARSE_EVENTS__TERM_TYPE_NAME, |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 65 | PARSE_EVENTS__TERM_TYPE_SAMPLE_PERIOD, |
Namhyung Kim | 09af2a5 | 2015-08-09 15:45:23 +0900 | [diff] [blame] | 66 | PARSE_EVENTS__TERM_TYPE_SAMPLE_FREQ, |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 67 | PARSE_EVENTS__TERM_TYPE_BRANCH_SAMPLE_TYPE, |
Kan Liang | 3206771 | 2015-08-04 04:30:19 -0400 | [diff] [blame] | 68 | PARSE_EVENTS__TERM_TYPE_TIME, |
Kan Liang | d457c96 | 2015-08-11 06:30:47 -0400 | [diff] [blame] | 69 | PARSE_EVENTS__TERM_TYPE_CALLGRAPH, |
| 70 | PARSE_EVENTS__TERM_TYPE_STACKSIZE, |
Wang Nan | 374ce93 | 2015-10-28 10:55:02 +0000 | [diff] [blame] | 71 | PARSE_EVENTS__TERM_TYPE_NOINHERIT, |
Wang Nan | 17cb5f8 | 2016-02-19 11:43:57 +0000 | [diff] [blame] | 72 | PARSE_EVENTS__TERM_TYPE_INHERIT, |
Arnaldo Carvalho de Melo | 792d48b | 2016-04-28 19:03:42 -0300 | [diff] [blame] | 73 | PARSE_EVENTS__TERM_TYPE_MAX_STACK, |
Wang Nan | 626a6b7 | 2016-07-14 08:34:45 +0000 | [diff] [blame] | 74 | PARSE_EVENTS__TERM_TYPE_NOOVERWRITE, |
| 75 | PARSE_EVENTS__TERM_TYPE_OVERWRITE, |
Mathieu Poirier | dd60fba | 2016-09-06 10:37:15 -0600 | [diff] [blame] | 76 | PARSE_EVENTS__TERM_TYPE_DRV_CFG, |
Wang Nan | 17cb5f8 | 2016-02-19 11:43:57 +0000 | [diff] [blame] | 77 | __PARSE_EVENTS__TERM_TYPE_NR, |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 78 | }; |
| 79 | |
Wang Nan | 2d055bf | 2016-02-22 09:10:34 +0000 | [diff] [blame] | 80 | struct parse_events_array { |
| 81 | size_t nr_ranges; |
| 82 | struct { |
| 83 | unsigned int start; |
| 84 | size_t length; |
| 85 | } *ranges; |
| 86 | }; |
| 87 | |
Arnaldo Carvalho de Melo | 6cee6cd | 2013-01-18 16:29:49 -0300 | [diff] [blame] | 88 | struct parse_events_term { |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 89 | char *config; |
Wang Nan | 2d055bf | 2016-02-22 09:10:34 +0000 | [diff] [blame] | 90 | struct parse_events_array array; |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 91 | union { |
| 92 | char *str; |
Robert Richter | b527bab | 2012-08-07 19:43:13 +0200 | [diff] [blame] | 93 | u64 num; |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 94 | } val; |
Jiri Olsa | 16fa7e8 | 2012-04-25 18:24:57 +0200 | [diff] [blame] | 95 | int type_val; |
| 96 | int type_term; |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 97 | struct list_head list; |
Cody P Schafer | 688d4df | 2015-01-07 17:13:50 -0800 | [diff] [blame] | 98 | bool used; |
Jiri Olsa | 99e7138 | 2017-02-17 15:00:56 +0100 | [diff] [blame] | 99 | bool no_value; |
Jiri Olsa | cecf3a2e | 2015-04-22 21:10:20 +0200 | [diff] [blame] | 100 | |
| 101 | /* error string indexes for within parsed string */ |
| 102 | int err_term; |
| 103 | int err_val; |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 104 | }; |
| 105 | |
Jiri Olsa | b39b839 | 2015-04-22 21:10:16 +0200 | [diff] [blame] | 106 | struct parse_events_error { |
| 107 | int idx; /* index in the parsed string */ |
| 108 | char *str; /* string to display at the index */ |
| 109 | char *help; /* optional help string */ |
| 110 | }; |
| 111 | |
Arnaldo Carvalho de Melo | 5d369a7 | 2017-08-17 14:13:25 -0300 | [diff] [blame] | 112 | struct parse_events_state { |
Jiri Olsa | b39b839 | 2015-04-22 21:10:16 +0200 | [diff] [blame] | 113 | struct list_head list; |
| 114 | int idx; |
| 115 | int nr_groups; |
| 116 | struct parse_events_error *error; |
Wang Nan | 7630b3e | 2016-02-22 09:10:33 +0000 | [diff] [blame] | 117 | struct perf_evlist *evlist; |
Arnaldo Carvalho de Melo | d17d087 | 2017-08-17 14:22:50 -0300 | [diff] [blame] | 118 | struct list_head *terms; |
Jiri Olsa | 90e2b22 | 2012-06-15 14:31:40 +0800 | [diff] [blame] | 119 | }; |
| 120 | |
Wang Nan | 1669e50 | 2016-02-19 11:43:58 +0000 | [diff] [blame] | 121 | void parse_events__shrink_config_terms(void); |
Arnaldo Carvalho de Melo | 6cee6cd | 2013-01-18 16:29:49 -0300 | [diff] [blame] | 122 | int parse_events__is_hardcoded_term(struct parse_events_term *term); |
Adrian Hunter | bb78ce7 | 2015-05-19 16:05:42 +0300 | [diff] [blame] | 123 | int parse_events_term__num(struct parse_events_term **term, |
| 124 | int type_term, char *config, u64 num, |
Jiri Olsa | 99e7138 | 2017-02-17 15:00:56 +0100 | [diff] [blame] | 125 | bool novalue, |
Adrian Hunter | bb78ce7 | 2015-05-19 16:05:42 +0300 | [diff] [blame] | 126 | void *loc_term, void *loc_val); |
| 127 | int parse_events_term__str(struct parse_events_term **term, |
| 128 | int type_term, char *config, char *str, |
| 129 | void *loc_term, void *loc_val); |
Arnaldo Carvalho de Melo | 6cee6cd | 2013-01-18 16:29:49 -0300 | [diff] [blame] | 130 | int parse_events_term__sym_hw(struct parse_events_term **term, |
Jiri Olsa | 1d33d6d | 2012-10-10 14:53:17 +0200 | [diff] [blame] | 131 | char *config, unsigned idx); |
Arnaldo Carvalho de Melo | 6cee6cd | 2013-01-18 16:29:49 -0300 | [diff] [blame] | 132 | int parse_events_term__clone(struct parse_events_term **new, |
| 133 | struct parse_events_term *term); |
Arnaldo Carvalho de Melo | 2146afc | 2016-02-12 17:09:17 -0300 | [diff] [blame] | 134 | void parse_events_terms__delete(struct list_head *terms); |
Arnaldo Carvalho de Melo | fc0a2c1 | 2016-02-12 16:43:02 -0300 | [diff] [blame] | 135 | void parse_events_terms__purge(struct list_head *terms); |
Wang Nan | 2d055bf | 2016-02-22 09:10:34 +0000 | [diff] [blame] | 136 | void parse_events__clear_array(struct parse_events_array *a); |
Jiri Olsa | f5b1135 | 2012-08-08 12:21:54 +0200 | [diff] [blame] | 137 | int parse_events__modifier_event(struct list_head *list, char *str, bool add); |
Jiri Olsa | 89efb02 | 2012-08-08 12:14:14 +0200 | [diff] [blame] | 138 | int parse_events__modifier_group(struct list_head *list, char *event_mod); |
Robert Richter | ac2ba9f | 2012-08-16 21:10:21 +0200 | [diff] [blame] | 139 | int parse_events_name(struct list_head *list, char *name); |
David Ahern | c5cd8ac | 2013-07-02 13:27:25 -0600 | [diff] [blame] | 140 | int parse_events_add_tracepoint(struct list_head *list, int *idx, |
Wang Nan | 8c619d6 | 2016-07-13 10:44:03 +0000 | [diff] [blame] | 141 | const char *sys, const char *event, |
He Kuang | e637d17 | 2015-09-28 03:52:16 +0000 | [diff] [blame] | 142 | struct parse_events_error *error, |
| 143 | struct list_head *head_config); |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 144 | int parse_events_load_bpf(struct parse_events_state *parse_state, |
Wang Nan | 84c86ca | 2015-10-14 12:41:14 +0000 | [diff] [blame] | 145 | struct list_head *list, |
Wang Nan | d509db0 | 2015-10-14 12:41:20 +0000 | [diff] [blame] | 146 | char *bpf_file_name, |
Wang Nan | a34f3be | 2016-02-22 09:10:31 +0000 | [diff] [blame] | 147 | bool source, |
| 148 | struct list_head *head_config); |
Wang Nan | 84c86ca | 2015-10-14 12:41:14 +0000 | [diff] [blame] | 149 | /* Provide this function for perf test */ |
| 150 | struct bpf_object; |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 151 | int parse_events_load_bpf_obj(struct parse_events_state *parse_state, |
Wang Nan | 84c86ca | 2015-10-14 12:41:14 +0000 | [diff] [blame] | 152 | struct list_head *list, |
Wang Nan | 95088a5 | 2016-02-22 09:10:36 +0000 | [diff] [blame] | 153 | struct bpf_object *obj, |
| 154 | struct list_head *head_config); |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 155 | int parse_events_add_numeric(struct parse_events_state *parse_state, |
Jiri Olsa | 87d650b | 2015-04-22 21:10:24 +0200 | [diff] [blame] | 156 | struct list_head *list, |
Robert Richter | b527bab | 2012-08-07 19:43:13 +0200 | [diff] [blame] | 157 | u32 type, u64 config, |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 158 | struct list_head *head_config); |
David Ahern | c5cd8ac | 2013-07-02 13:27:25 -0600 | [diff] [blame] | 159 | int parse_events_add_cache(struct list_head *list, int *idx, |
Wang Nan | 43d0b97 | 2016-02-19 11:44:01 +0000 | [diff] [blame] | 160 | char *type, char *op_result1, char *op_result2, |
| 161 | struct parse_events_error *error, |
| 162 | struct list_head *head_config); |
David Ahern | c5cd8ac | 2013-07-02 13:27:25 -0600 | [diff] [blame] | 163 | int parse_events_add_breakpoint(struct list_head *list, int *idx, |
Jacob Shin | 3741eb9 | 2014-05-29 17:26:51 +0200 | [diff] [blame] | 164 | void *ptr, char *type, u64 len); |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 165 | int parse_events_add_pmu(struct parse_events_state *parse_state, |
Jiri Olsa | 36adec8 | 2015-04-22 21:10:19 +0200 | [diff] [blame] | 166 | struct list_head *list, char *name, |
| 167 | struct list_head *head_config); |
Andi Kleen | 2073ad3 | 2017-03-20 13:17:02 -0700 | [diff] [blame] | 168 | |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 169 | int parse_events_multi_pmu_add(struct parse_events_state *parse_state, |
Andi Kleen | 2073ad3 | 2017-03-20 13:17:02 -0700 | [diff] [blame] | 170 | char *str, |
| 171 | struct list_head **listp); |
| 172 | |
Andi Kleen | 8255718 | 2017-03-20 13:17:03 -0700 | [diff] [blame] | 173 | int parse_events_copy_term_list(struct list_head *old, |
| 174 | struct list_head **new); |
| 175 | |
Kan Liang | dcb4e10 | 2014-10-07 11:08:50 -0400 | [diff] [blame] | 176 | enum perf_pmu_event_symbol_type |
| 177 | perf_pmu__parse_check(const char *name); |
Arnaldo Carvalho de Melo | 63dab22 | 2012-08-14 16:35:48 -0300 | [diff] [blame] | 178 | void parse_events__set_leader(char *name, struct list_head *list); |
Jiri Olsa | 5d7be90 | 2012-03-20 19:15:40 +0100 | [diff] [blame] | 179 | void parse_events_update_lists(struct list_head *list_event, |
| 180 | struct list_head *list_all); |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 181 | void parse_events_evlist_error(struct parse_events_state *parse_state, |
Jiri Olsa | b39b839 | 2015-04-22 21:10:16 +0200 | [diff] [blame] | 182 | int idx, const char *str); |
Jiri Olsa | 89812fc | 2012-03-15 20:09:15 +0100 | [diff] [blame] | 183 | |
Sukadev Bhattiprolu | c8d6828 | 2016-09-15 15:24:48 -0700 | [diff] [blame] | 184 | void print_events(const char *event_glob, bool name_only, bool quiet, |
Andi Kleen | bf874fc | 2017-03-20 13:17:11 -0700 | [diff] [blame] | 185 | bool long_desc, bool details_flag); |
Yunlong Song | 705750f | 2015-02-27 18:21:27 +0800 | [diff] [blame] | 186 | |
| 187 | struct event_symbol { |
| 188 | const char *symbol; |
| 189 | const char *alias; |
| 190 | }; |
| 191 | extern struct event_symbol event_symbols_hw[]; |
| 192 | extern struct event_symbol event_symbols_sw[]; |
| 193 | void print_symbol_events(const char *event_glob, unsigned type, |
| 194 | struct event_symbol *syms, unsigned max, |
| 195 | bool name_only); |
Frederic Weisbecker | a3277d2 | 2012-08-09 16:31:52 +0200 | [diff] [blame] | 196 | void print_tracepoint_events(const char *subsys_glob, const char *event_glob, |
| 197 | bool name_only); |
| 198 | int print_hwcache_events(const char *event_glob, bool name_only); |
Masami Hiramatsu | 40218da | 2016-06-24 18:06:46 +0900 | [diff] [blame] | 199 | void print_sdt_events(const char *subsys_glob, const char *event_glob, |
| 200 | bool name_only); |
Arnaldo Carvalho de Melo | 3938bad | 2016-03-23 15:06:35 -0300 | [diff] [blame] | 201 | int is_valid_tracepoint(const char *event_string); |
Ingo Molnar | 8ad8db3 | 2009-05-26 11:10:09 +0200 | [diff] [blame] | 202 | |
Steven Rostedt (Red Hat) | 23773ca | 2015-02-02 14:35:07 -0500 | [diff] [blame] | 203 | int valid_event_mount(const char *eventfs); |
He Kuang | ffeb883 | 2015-09-28 03:52:14 +0000 | [diff] [blame] | 204 | char *parse_events_formats_error_string(char *additional_terms); |
Jason Baron | 5beeded | 2009-07-21 14:16:29 -0400 | [diff] [blame] | 205 | |
Andi Kleen | 333b566 | 2017-09-13 14:50:06 -0700 | [diff] [blame] | 206 | void parse_events_print_error(struct parse_events_error *err, |
| 207 | const char *event); |
| 208 | |
Ravi Bangoria | af9100a | 2017-03-14 20:36:52 +0530 | [diff] [blame] | 209 | #ifdef HAVE_LIBELF_SUPPORT |
| 210 | /* |
| 211 | * If the probe point starts with '%', |
| 212 | * or starts with "sdt_" and has a ':' but no '=', |
| 213 | * then it should be a SDT/cached probe point. |
| 214 | */ |
| 215 | static inline bool is_sdt_event(char *str) |
| 216 | { |
| 217 | return (str[0] == '%' || |
| 218 | (!strncmp(str, "sdt_", 4) && |
| 219 | !!strchr(str, ':') && !strchr(str, '='))); |
| 220 | } |
| 221 | #else |
| 222 | static inline bool is_sdt_event(char *str __maybe_unused) |
| 223 | { |
| 224 | return false; |
| 225 | } |
| 226 | #endif /* HAVE_LIBELF_SUPPORT */ |
| 227 | |
John Kacur | 8b40f52 | 2009-09-24 18:02:18 +0200 | [diff] [blame] | 228 | #endif /* __PERF_PARSE_EVENTS_H */ |