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, |
Arnaldo Carvalho de Melo | 2fda5ad | 2018-10-19 15:47:34 -0300 | [diff] [blame] | 74 | PARSE_EVENTS__TERM_TYPE_MAX_EVENTS, |
Wang Nan | 626a6b7 | 2016-07-14 08:34:45 +0000 | [diff] [blame] | 75 | PARSE_EVENTS__TERM_TYPE_NOOVERWRITE, |
| 76 | PARSE_EVENTS__TERM_TYPE_OVERWRITE, |
Mathieu Poirier | dd60fba | 2016-09-06 10:37:15 -0600 | [diff] [blame] | 77 | PARSE_EVENTS__TERM_TYPE_DRV_CFG, |
Jin Yao | 064b4e8 | 2019-04-12 21:59:47 +0800 | [diff] [blame] | 78 | PARSE_EVENTS__TERM_TYPE_PERCORE, |
Wang Nan | 17cb5f8 | 2016-02-19 11:43:57 +0000 | [diff] [blame] | 79 | __PARSE_EVENTS__TERM_TYPE_NR, |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 80 | }; |
| 81 | |
Wang Nan | 2d055bf | 2016-02-22 09:10:34 +0000 | [diff] [blame] | 82 | struct parse_events_array { |
| 83 | size_t nr_ranges; |
| 84 | struct { |
| 85 | unsigned int start; |
| 86 | size_t length; |
| 87 | } *ranges; |
| 88 | }; |
| 89 | |
Arnaldo Carvalho de Melo | 6cee6cd | 2013-01-18 16:29:49 -0300 | [diff] [blame] | 90 | struct parse_events_term { |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 91 | char *config; |
Wang Nan | 2d055bf | 2016-02-22 09:10:34 +0000 | [diff] [blame] | 92 | struct parse_events_array array; |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 93 | union { |
| 94 | char *str; |
Robert Richter | b527bab | 2012-08-07 19:43:13 +0200 | [diff] [blame] | 95 | u64 num; |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 96 | } val; |
Jiri Olsa | 16fa7e8 | 2012-04-25 18:24:57 +0200 | [diff] [blame] | 97 | int type_val; |
| 98 | int type_term; |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 99 | struct list_head list; |
Cody P Schafer | 688d4df | 2015-01-07 17:13:50 -0800 | [diff] [blame] | 100 | bool used; |
Jiri Olsa | 99e7138 | 2017-02-17 15:00:56 +0100 | [diff] [blame] | 101 | bool no_value; |
Jiri Olsa | cecf3a2e | 2015-04-22 21:10:20 +0200 | [diff] [blame] | 102 | |
| 103 | /* error string indexes for within parsed string */ |
| 104 | int err_term; |
| 105 | int err_val; |
Andi Kleen | 59622fd | 2017-10-20 13:27:55 -0700 | [diff] [blame] | 106 | |
| 107 | /* Coming from implicit alias */ |
| 108 | bool weak; |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 109 | }; |
| 110 | |
Jiri Olsa | b39b839 | 2015-04-22 21:10:16 +0200 | [diff] [blame] | 111 | struct parse_events_error { |
| 112 | int idx; /* index in the parsed string */ |
| 113 | char *str; /* string to display at the index */ |
| 114 | char *help; /* optional help string */ |
| 115 | }; |
| 116 | |
Arnaldo Carvalho de Melo | 5d369a7 | 2017-08-17 14:13:25 -0300 | [diff] [blame] | 117 | struct parse_events_state { |
Jiri Olsa | b39b839 | 2015-04-22 21:10:16 +0200 | [diff] [blame] | 118 | struct list_head list; |
| 119 | int idx; |
| 120 | int nr_groups; |
| 121 | struct parse_events_error *error; |
Wang Nan | 7630b3e | 2016-02-22 09:10:33 +0000 | [diff] [blame] | 122 | struct perf_evlist *evlist; |
Arnaldo Carvalho de Melo | d17d087 | 2017-08-17 14:22:50 -0300 | [diff] [blame] | 123 | struct list_head *terms; |
Jiri Olsa | 90e2b22 | 2012-06-15 14:31:40 +0800 | [diff] [blame] | 124 | }; |
| 125 | |
Wang Nan | 1669e50 | 2016-02-19 11:43:58 +0000 | [diff] [blame] | 126 | void parse_events__shrink_config_terms(void); |
Arnaldo Carvalho de Melo | 6cee6cd | 2013-01-18 16:29:49 -0300 | [diff] [blame] | 127 | int parse_events__is_hardcoded_term(struct parse_events_term *term); |
Adrian Hunter | bb78ce7 | 2015-05-19 16:05:42 +0300 | [diff] [blame] | 128 | int parse_events_term__num(struct parse_events_term **term, |
| 129 | int type_term, char *config, u64 num, |
Jiri Olsa | 99e7138 | 2017-02-17 15:00:56 +0100 | [diff] [blame] | 130 | bool novalue, |
Adrian Hunter | bb78ce7 | 2015-05-19 16:05:42 +0300 | [diff] [blame] | 131 | void *loc_term, void *loc_val); |
| 132 | int parse_events_term__str(struct parse_events_term **term, |
| 133 | int type_term, char *config, char *str, |
| 134 | void *loc_term, void *loc_val); |
Arnaldo Carvalho de Melo | 6cee6cd | 2013-01-18 16:29:49 -0300 | [diff] [blame] | 135 | int parse_events_term__sym_hw(struct parse_events_term **term, |
Jiri Olsa | 1d33d6d | 2012-10-10 14:53:17 +0200 | [diff] [blame] | 136 | char *config, unsigned idx); |
Arnaldo Carvalho de Melo | 6cee6cd | 2013-01-18 16:29:49 -0300 | [diff] [blame] | 137 | int parse_events_term__clone(struct parse_events_term **new, |
| 138 | struct parse_events_term *term); |
Arnaldo Carvalho de Melo | 2146afc | 2016-02-12 17:09:17 -0300 | [diff] [blame] | 139 | void parse_events_terms__delete(struct list_head *terms); |
Arnaldo Carvalho de Melo | fc0a2c1 | 2016-02-12 16:43:02 -0300 | [diff] [blame] | 140 | void parse_events_terms__purge(struct list_head *terms); |
Wang Nan | 2d055bf | 2016-02-22 09:10:34 +0000 | [diff] [blame] | 141 | void parse_events__clear_array(struct parse_events_array *a); |
Jiri Olsa | f5b1135 | 2012-08-08 12:21:54 +0200 | [diff] [blame] | 142 | 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] | 143 | int parse_events__modifier_group(struct list_head *list, char *event_mod); |
Robert Richter | ac2ba9f | 2012-08-16 21:10:21 +0200 | [diff] [blame] | 144 | int parse_events_name(struct list_head *list, char *name); |
David Ahern | c5cd8ac | 2013-07-02 13:27:25 -0600 | [diff] [blame] | 145 | int parse_events_add_tracepoint(struct list_head *list, int *idx, |
Wang Nan | 8c619d6 | 2016-07-13 10:44:03 +0000 | [diff] [blame] | 146 | const char *sys, const char *event, |
He Kuang | e637d17 | 2015-09-28 03:52:16 +0000 | [diff] [blame] | 147 | struct parse_events_error *error, |
| 148 | struct list_head *head_config); |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 149 | int parse_events_load_bpf(struct parse_events_state *parse_state, |
Wang Nan | 84c86ca | 2015-10-14 12:41:14 +0000 | [diff] [blame] | 150 | struct list_head *list, |
Wang Nan | d509db0 | 2015-10-14 12:41:20 +0000 | [diff] [blame] | 151 | char *bpf_file_name, |
Wang Nan | a34f3be | 2016-02-22 09:10:31 +0000 | [diff] [blame] | 152 | bool source, |
| 153 | struct list_head *head_config); |
Wang Nan | 84c86ca | 2015-10-14 12:41:14 +0000 | [diff] [blame] | 154 | /* Provide this function for perf test */ |
| 155 | struct bpf_object; |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 156 | int parse_events_load_bpf_obj(struct parse_events_state *parse_state, |
Wang Nan | 84c86ca | 2015-10-14 12:41:14 +0000 | [diff] [blame] | 157 | struct list_head *list, |
Wang Nan | 95088a5 | 2016-02-22 09:10:36 +0000 | [diff] [blame] | 158 | struct bpf_object *obj, |
| 159 | struct list_head *head_config); |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 160 | int parse_events_add_numeric(struct parse_events_state *parse_state, |
Jiri Olsa | 87d650b | 2015-04-22 21:10:24 +0200 | [diff] [blame] | 161 | struct list_head *list, |
Robert Richter | b527bab | 2012-08-07 19:43:13 +0200 | [diff] [blame] | 162 | u32 type, u64 config, |
Jiri Olsa | 8f707d8 | 2012-03-15 20:09:16 +0100 | [diff] [blame] | 163 | struct list_head *head_config); |
Andi Kleen | f0fbb11 | 2019-03-26 15:18:21 -0700 | [diff] [blame] | 164 | enum perf_tool_event; |
| 165 | int parse_events_add_tool(struct parse_events_state *parse_state, |
| 166 | struct list_head *list, |
| 167 | enum perf_tool_event tool_event); |
David Ahern | c5cd8ac | 2013-07-02 13:27:25 -0600 | [diff] [blame] | 168 | int parse_events_add_cache(struct list_head *list, int *idx, |
Wang Nan | 43d0b97 | 2016-02-19 11:44:01 +0000 | [diff] [blame] | 169 | char *type, char *op_result1, char *op_result2, |
| 170 | struct parse_events_error *error, |
| 171 | struct list_head *head_config); |
David Ahern | c5cd8ac | 2013-07-02 13:27:25 -0600 | [diff] [blame] | 172 | int parse_events_add_breakpoint(struct list_head *list, int *idx, |
Jacob Shin | 3741eb9 | 2014-05-29 17:26:51 +0200 | [diff] [blame] | 173 | void *ptr, char *type, u64 len); |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 174 | int parse_events_add_pmu(struct parse_events_state *parse_state, |
Jiri Olsa | 36adec8 | 2015-04-22 21:10:19 +0200 | [diff] [blame] | 175 | struct list_head *list, char *name, |
Kan Liang | 369b230 | 2018-05-07 14:13:43 -0700 | [diff] [blame] | 176 | struct list_head *head_config, |
| 177 | bool auto_merge_stats, |
| 178 | bool use_alias); |
Andi Kleen | 2073ad3 | 2017-03-20 13:17:02 -0700 | [diff] [blame] | 179 | |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 180 | int parse_events_multi_pmu_add(struct parse_events_state *parse_state, |
Andi Kleen | 2073ad3 | 2017-03-20 13:17:02 -0700 | [diff] [blame] | 181 | char *str, |
| 182 | struct list_head **listp); |
| 183 | |
Andi Kleen | 8255718 | 2017-03-20 13:17:03 -0700 | [diff] [blame] | 184 | int parse_events_copy_term_list(struct list_head *old, |
| 185 | struct list_head **new); |
| 186 | |
Kan Liang | dcb4e10 | 2014-10-07 11:08:50 -0400 | [diff] [blame] | 187 | enum perf_pmu_event_symbol_type |
| 188 | perf_pmu__parse_check(const char *name); |
Kan Liang | 369b230 | 2018-05-07 14:13:43 -0700 | [diff] [blame] | 189 | void parse_events__set_leader(char *name, struct list_head *list, |
| 190 | struct parse_events_state *parse_state); |
Jiri Olsa | 5d7be90 | 2012-03-20 19:15:40 +0100 | [diff] [blame] | 191 | void parse_events_update_lists(struct list_head *list_event, |
| 192 | struct list_head *list_all); |
Arnaldo Carvalho de Melo | 5d9cdc1 | 2017-08-17 16:13:34 -0300 | [diff] [blame] | 193 | void parse_events_evlist_error(struct parse_events_state *parse_state, |
Jiri Olsa | b39b839 | 2015-04-22 21:10:16 +0200 | [diff] [blame] | 194 | int idx, const char *str); |
Jiri Olsa | 89812fc | 2012-03-15 20:09:15 +0100 | [diff] [blame] | 195 | |
Sukadev Bhattiprolu | c8d6828 | 2016-09-15 15:24:48 -0700 | [diff] [blame] | 196 | void print_events(const char *event_glob, bool name_only, bool quiet, |
Andi Kleen | bf874fc | 2017-03-20 13:17:11 -0700 | [diff] [blame] | 197 | bool long_desc, bool details_flag); |
Yunlong Song | 705750f | 2015-02-27 18:21:27 +0800 | [diff] [blame] | 198 | |
| 199 | struct event_symbol { |
| 200 | const char *symbol; |
| 201 | const char *alias; |
| 202 | }; |
| 203 | extern struct event_symbol event_symbols_hw[]; |
| 204 | extern struct event_symbol event_symbols_sw[]; |
| 205 | void print_symbol_events(const char *event_glob, unsigned type, |
| 206 | struct event_symbol *syms, unsigned max, |
| 207 | bool name_only); |
Andi Kleen | 5e0861b | 2019-03-26 15:18:23 -0700 | [diff] [blame] | 208 | void print_tool_events(const char *event_glob, bool name_only); |
Frederic Weisbecker | a3277d2 | 2012-08-09 16:31:52 +0200 | [diff] [blame] | 209 | void print_tracepoint_events(const char *subsys_glob, const char *event_glob, |
| 210 | bool name_only); |
| 211 | int print_hwcache_events(const char *event_glob, bool name_only); |
Masami Hiramatsu | 40218da | 2016-06-24 18:06:46 +0900 | [diff] [blame] | 212 | void print_sdt_events(const char *subsys_glob, const char *event_glob, |
| 213 | bool name_only); |
Arnaldo Carvalho de Melo | 3938bad | 2016-03-23 15:06:35 -0300 | [diff] [blame] | 214 | int is_valid_tracepoint(const char *event_string); |
Ingo Molnar | 8ad8db3 | 2009-05-26 11:10:09 +0200 | [diff] [blame] | 215 | |
Steven Rostedt (Red Hat) | 23773ca | 2015-02-02 14:35:07 -0500 | [diff] [blame] | 216 | int valid_event_mount(const char *eventfs); |
He Kuang | ffeb883 | 2015-09-28 03:52:14 +0000 | [diff] [blame] | 217 | char *parse_events_formats_error_string(char *additional_terms); |
Jason Baron | 5beeded | 2009-07-21 14:16:29 -0400 | [diff] [blame] | 218 | |
Andi Kleen | 333b566 | 2017-09-13 14:50:06 -0700 | [diff] [blame] | 219 | void parse_events_print_error(struct parse_events_error *err, |
| 220 | const char *event); |
| 221 | |
Ravi Bangoria | af9100a | 2017-03-14 20:36:52 +0530 | [diff] [blame] | 222 | #ifdef HAVE_LIBELF_SUPPORT |
| 223 | /* |
| 224 | * If the probe point starts with '%', |
| 225 | * or starts with "sdt_" and has a ':' but no '=', |
| 226 | * then it should be a SDT/cached probe point. |
| 227 | */ |
| 228 | static inline bool is_sdt_event(char *str) |
| 229 | { |
| 230 | return (str[0] == '%' || |
| 231 | (!strncmp(str, "sdt_", 4) && |
| 232 | !!strchr(str, ':') && !strchr(str, '='))); |
| 233 | } |
| 234 | #else |
| 235 | static inline bool is_sdt_event(char *str __maybe_unused) |
| 236 | { |
| 237 | return false; |
| 238 | } |
| 239 | #endif /* HAVE_LIBELF_SUPPORT */ |
| 240 | |
John Kacur | 8b40f52 | 2009-09-24 18:02:18 +0200 | [diff] [blame] | 241 | #endif /* __PERF_PARSE_EVENTS_H */ |