Lines Matching full:term

10 #include "term.h"
159 struct parse_events_term *term; in get_config_str() local
164 list_for_each_entry(term, &head_terms->terms, list) in get_config_str()
165 if (term->type_term == type_term) in get_config_str()
166 return term->val.str; in get_config_str()
182 * fix_raw - For each raw term see if there is an event (aka alias) in pmu that
184 * event then change the term to be an event, if not then change it to
185 * be a config term. For example, "read" may be an event of the PMU or
189 * @config_terms: the list of terms that may contain a raw term.
194 struct parse_events_term *term; in fix_raw() local
196 list_for_each_entry(term, &config_terms->terms, list) { in fix_raw()
199 if (term->type_term != PARSE_EVENTS__TERM_TYPE_RAW) in fix_raw()
202 if (perf_pmu__have_event(pmu, term->val.str)) { in fix_raw()
203 zfree(&term->config); in fix_raw()
204 term->config = term->val.str; in fix_raw()
205 term->type_val = PARSE_EVENTS__TERM_TYPE_NUM; in fix_raw()
206 term->type_term = PARSE_EVENTS__TERM_TYPE_USER; in fix_raw()
207 term->val.num = 1; in fix_raw()
208 term->no_value = true; in fix_raw()
212 zfree(&term->config); in fix_raw()
213 term->config = strdup("config"); in fix_raw()
215 num = strtoull(term->val.str + 1, NULL, 16); in fix_raw()
217 free(term->val.str); in fix_raw()
218 term->type_val = PARSE_EVENTS__TERM_TYPE_NUM; in fix_raw()
219 term->type_term = PARSE_EVENTS__TERM_TYPE_CONFIG; in fix_raw()
220 term->val.num = num; in fix_raw()
221 term->no_value = false; in fix_raw()
332 struct parse_events_term *term,
335 struct parse_events_term *term,
750 static int check_type_val(struct parse_events_term *term, in check_type_val() argument
754 if (type == term->type_val) in check_type_val()
758 parse_events_error__handle(err, term->err_val, in check_type_val()
775 [PARSE_EVENTS__TERM_TYPE_USER] = "<sysfs term>", in parse_events__term_type_str()
804 return "unknown term"; in parse_events__term_type_str()
869 struct parse_events_term *term, in config_term_common() argument
874 if (check_type_val(term, err, PARSE_EVENTS__TERM_TYPE_ ## type)) \ in config_term_common()
878 switch (term->type_term) { in config_term_common()
881 attr->config = term->val.num; in config_term_common()
885 attr->config1 = term->val.num; in config_term_common()
889 attr->config2 = term->val.num; in config_term_common()
893 attr->config3 = term->val.num; in config_term_common()
903 if (strcmp(term->val.str, "no") && in config_term_common()
904 parse_branch_str(term->val.str, in config_term_common()
906 parse_events_error__handle(err, term->err_val, in config_term_common()
914 if (term->val.num > 1) { in config_term_common()
915 parse_events_error__handle(err, term->err_val, in config_term_common()
956 if ((unsigned int)term->val.num > 1) { in config_term_common()
957 parse_events_error__handle(err, term->err_val, in config_term_common()
971 if (term->val.num > UINT_MAX) { in config_term_common()
972 parse_events_error__handle(err, term->err_val, in config_term_common()
983 parse_events_error__handle(err, term->err_term, in config_term_common()
984 strdup(parse_events__term_type_str(term->type_term)), in config_term_common()
990 * Check term availability after basic checking so in config_term_common()
994 * user will see "'<sysfs term>' is not usable in 'perf stat'" in config_term_common()
995 * if an invalid config term is provided for legacy events in config_term_common()
998 if (!config_term_avail(term->type_term, err)) in config_term_common()
1005 struct parse_events_term *term, in config_term_pmu() argument
1008 if (term->type_term == PARSE_EVENTS__TERM_TYPE_LEGACY_CACHE) { in config_term_pmu()
1015 parse_events_error__handle(err, term->err_term, in config_term_pmu()
1025 !perf_pmu__have_event(pmu, term->config)) { in config_term_pmu()
1027 return parse_events__decode_legacy_cache(term->config, pmu->type, in config_term_pmu()
1030 term->type_term = PARSE_EVENTS__TERM_TYPE_USER; in config_term_pmu()
1031 term->no_value = true; in config_term_pmu()
1034 if (term->type_term == PARSE_EVENTS__TERM_TYPE_HARDWARE) { in config_term_pmu()
1041 parse_events_error__handle(err, term->err_term, in config_term_pmu()
1049 if (perf_pmu__have_event(pmu, term->config)) { in config_term_pmu()
1050 term->type_term = PARSE_EVENTS__TERM_TYPE_USER; in config_term_pmu()
1051 term->no_value = true; in config_term_pmu()
1052 term->alternate_hw_config = true; in config_term_pmu()
1055 attr->config = term->val.num; in config_term_pmu()
1061 if (term->type_term == PARSE_EVENTS__TERM_TYPE_USER || in config_term_pmu()
1062 term->type_term == PARSE_EVENTS__TERM_TYPE_DRV_CFG) { in config_term_pmu()
1069 return config_term_common(attr, term, err); in config_term_pmu()
1073 struct parse_events_term *term, in config_term_tracepoint() argument
1076 switch (term->type_term) { in config_term_tracepoint()
1088 return config_term_common(attr, term, err); in config_term_tracepoint()
1107 parse_events_error__handle(err, term->err_term, in config_term_tracepoint()
1108 strdup(parse_events__term_type_str(term->type_term)), in config_term_tracepoint()
1123 struct parse_events_term *term; in config_attr() local
1125 list_for_each_entry(term, &head->terms, list) in config_attr()
1126 if (config_term(attr, term, err)) in config_attr()
1164 struct parse_events_term *term; in get_config_terms() local
1166 list_for_each_entry(term, &head_config->terms, list) { in get_config_terms()
1167 switch (term->type_term) { in get_config_terms()
1169 ADD_CONFIG_TERM_VAL(PERIOD, period, term->val.num, term->weak); in get_config_terms()
1172 ADD_CONFIG_TERM_VAL(FREQ, freq, term->val.num, term->weak); in get_config_terms()
1175 ADD_CONFIG_TERM_VAL(TIME, time, term->val.num, term->weak); in get_config_terms()
1178 ADD_CONFIG_TERM_STR(CALLGRAPH, term->val.str, term->weak); in get_config_terms()
1181 ADD_CONFIG_TERM_STR(BRANCH, term->val.str, term->weak); in get_config_terms()
1185 term->val.num, term->weak); in get_config_terms()
1189 term->val.num ? 1 : 0, term->weak); in get_config_terms()
1193 term->val.num ? 0 : 1, term->weak); in get_config_terms()
1197 term->val.num, term->weak); in get_config_terms()
1201 term->val.num, term->weak); in get_config_terms()
1205 term->val.num ? 1 : 0, term->weak); in get_config_terms()
1209 term->val.num ? 0 : 1, term->weak); in get_config_terms()
1212 ADD_CONFIG_TERM_STR(DRV_CFG, term->val.str, term->weak); in get_config_terms()
1216 term->val.num ? true : false, term->weak); in get_config_terms()
1220 term->val.num ? 1 : 0, term->weak); in get_config_terms()
1223 ADD_CONFIG_TERM_STR(AUX_ACTION, term->val.str, term->weak); in get_config_terms()
1227 term->val.num, term->weak); in get_config_terms()
1253 struct parse_events_term *term; in get_config_chgs() local
1257 list_for_each_entry(term, &head_config->terms, list) { in get_config_chgs()
1258 switch (term->type_term) { in get_config_chgs()
1260 type = perf_pmu__format_type(pmu, term->config); in get_config_chgs()
1263 bits |= perf_pmu__format_bits(pmu, term->config); in get_config_chgs()
1399 struct evsel_config_term *term; in config_term_percore() local
1401 list_for_each_entry(term, config_terms, list) { in config_term_percore()
1402 if (term->type == EVSEL__CONFIG_TERM_PERCORE) in config_term_percore()
1403 return term->val.percore; in config_term_percore()
1544 struct parse_events_term *term; in parse_events_multi_pmu_add() local
1566 if (parse_events_term__num(&term, in parse_events_multi_pmu_add()
1573 list_add_tail(&term->list, &parsed_terms.terms); in parse_events_multi_pmu_add()
2492 int parse_events__is_hardcoded_term(struct parse_events_term *term) in parse_events__is_hardcoded_term() argument
2494 return term->type_term != PARSE_EVENTS__TERM_TYPE_USER; in parse_events__is_hardcoded_term()
2501 struct parse_events_term *term; in new_term() local
2503 term = malloc(sizeof(*term)); in new_term()
2504 if (!term) in new_term()
2507 *term = *temp; in new_term()
2508 INIT_LIST_HEAD(&term->list); in new_term()
2509 term->weak = false; in new_term()
2511 switch (term->type_val) { in new_term()
2513 term->val.num = num; in new_term()
2516 term->val.str = str; in new_term()
2519 free(term); in new_term()
2523 *_term = term; in new_term()
2527 int parse_events_term__num(struct parse_events_term **term, in parse_events_term__num() argument
2545 return new_term(term, &temp, /*str=*/NULL, num); in parse_events_term__num()
2548 int parse_events_term__str(struct parse_events_term **term, in parse_events_term__str() argument
2564 return new_term(term, &temp, str, /*num=*/0); in parse_events_term__str()
2567 int parse_events_term__term(struct parse_events_term **term, in parse_events_term__term() argument
2572 return parse_events_term__str(term, term_lhs, NULL, in parse_events_term__term()
2578 const struct parse_events_term *term) in parse_events_term__clone() argument
2581 struct parse_events_term temp = *term; in parse_events_term__clone()
2584 if (term->config) { in parse_events_term__clone()
2585 temp.config = strdup(term->config); in parse_events_term__clone()
2589 if (term->type_val == PARSE_EVENTS__TERM_TYPE_NUM) in parse_events_term__clone()
2590 return new_term(new, &temp, /*str=*/NULL, term->val.num); in parse_events_term__clone()
2592 str = strdup(term->val.str); in parse_events_term__clone()
2600 void parse_events_term__delete(struct parse_events_term *term) in parse_events_term__delete() argument
2602 if (term->type_val != PARSE_EVENTS__TERM_TYPE_NUM) in parse_events_term__delete()
2603 zfree(&term->val.str); in parse_events_term__delete()
2605 zfree(&term->config); in parse_events_term__delete()
2606 free(term); in parse_events_term__delete()
2612 struct parse_events_term *term; in parse_events_terms__copy() local
2614 list_for_each_entry (term, &src->terms, list) { in parse_events_terms__copy()
2618 ret = parse_events_term__clone(&n, term); in parse_events_terms__copy()
2634 struct parse_events_term *term, *h; in parse_events_terms__exit() local
2636 list_for_each_entry_safe(term, h, &terms->terms, list) { in parse_events_terms__exit()
2637 list_del_init(&term->list); in parse_events_terms__exit()
2638 parse_events_term__delete(term); in parse_events_terms__exit()
2652 struct parse_events_term *term; in parse_events_terms__to_strbuf() local
2658 list_for_each_entry(term, &terms->terms, list) { in parse_events_terms__to_strbuf()
2668 if (term->type_val == PARSE_EVENTS__TERM_TYPE_NUM) in parse_events_terms__to_strbuf()
2669 if (term->no_value) { in parse_events_terms__to_strbuf()
2670 assert(term->val.num == 1); in parse_events_terms__to_strbuf()
2671 ret = strbuf_addf(sb, "%s", term->config); in parse_events_terms__to_strbuf()
2673 ret = strbuf_addf(sb, "%s=%#"PRIx64, term->config, term->val.num); in parse_events_terms__to_strbuf()
2674 else if (term->type_val == PARSE_EVENTS__TERM_TYPE_STR) { in parse_events_terms__to_strbuf()
2675 if (term->config) { in parse_events_terms__to_strbuf()
2676 ret = strbuf_addf(sb, "%s=", term->config); in parse_events_terms__to_strbuf()
2679 } else if ((unsigned int)term->type_term < __PARSE_EVENTS__TERM_TYPE_NR) { in parse_events_terms__to_strbuf()
2681 parse_events__term_type_str(term->type_term)); in parse_events_terms__to_strbuf()
2685 assert(!term->no_value); in parse_events_terms__to_strbuf()
2686 ret = strbuf_addf(sb, "%s", term->val.str); in parse_events_terms__to_strbuf()