Skip to content

Commit 1718732

Browse files
author
Fox Snowpatch
committed
1 parent 182544a commit 1718732

1 file changed

Lines changed: 12 additions & 8 deletions

File tree

tools/perf/util/pmu.c

Lines changed: 12 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -2117,7 +2117,7 @@ static char *format_alias(char *buf, int len, const struct perf_pmu *pmu,
21172117
skip_duplicate_pmus);
21182118

21192119
/* Paramemterized events have the parameters shown. */
2120-
if (strstr(alias->terms, "=?")) {
2120+
if (!strstr(alias->terms, "=?")) {
21212121
/* No parameters. */
21222122
snprintf(buf, len, "%.*s/%s/", (int)pmu_name_len, pmu->name, alias->name);
21232123
return buf;
@@ -2129,15 +2129,19 @@ static char *format_alias(char *buf, int len, const struct perf_pmu *pmu,
21292129
pr_err("Failure to parse '%s' terms '%s': %d\n",
21302130
alias->name, alias->terms, ret);
21312131
parse_events_terms__exit(&terms);
2132-
snprintf(buf, len, "%.*s/%s/", (int)pmu_name_len, pmu->name, alias->name);
2132+
scnprintf(buf, len, "%.*s/%s/", (int)pmu_name_len, pmu->name, alias->name);
21332133
return buf;
21342134
}
2135-
used = snprintf(buf, len, "%.*s/%s", (int)pmu_name_len, pmu->name, alias->name);
2135+
used = scnprintf(buf, len, "%.*s/%s", (int)pmu_name_len, pmu->name, alias->name);
21362136

21372137
list_for_each_entry(term, &terms.terms, list) {
2138+
const char *name = term->config;
2139+
2140+
if (!name)
2141+
name = parse_events__term_type_str(term->type_term);
21382142
if (term->type_val == PARSE_EVENTS__TERM_TYPE_STR)
2139-
used += snprintf(buf + used, sub_non_neg(len, used),
2140-
",%s=%s", term->config,
2143+
used += scnprintf(buf + used, sub_non_neg(len, used),
2144+
",%s=%s", name,
21412145
term->val.str);
21422146
}
21432147
parse_events_terms__exit(&terms);
@@ -2237,13 +2241,13 @@ int perf_pmu__for_each_event(struct perf_pmu *pmu, bool skip_duplicate_pmus,
22372241
info.scale_unit = NULL;
22382242
if (strlen(event->unit) || event->scale != 1.0) {
22392243
info.scale_unit = buf + buf_used;
2240-
buf_used += snprintf(buf + buf_used, sizeof(buf) - buf_used,
2244+
buf_used += scnprintf(buf + buf_used, sizeof(buf) - buf_used,
22412245
"%G%s", event->scale, event->unit) + 1;
22422246
}
22432247
info.desc = event->desc;
22442248
info.long_desc = event->long_desc;
22452249
info.encoding_desc = buf + buf_used;
2246-
buf_used += snprintf(buf + buf_used, sizeof(buf) - buf_used,
2250+
buf_used += scnprintf(buf + buf_used, sizeof(buf) - buf_used,
22472251
"%.*s/%s/", (int)pmu_name_len, info.pmu_name, event->terms) + 1;
22482252
info.str = event->terms;
22492253
info.topic = event->topic;
@@ -2254,7 +2258,7 @@ int perf_pmu__for_each_event(struct perf_pmu *pmu, bool skip_duplicate_pmus,
22542258
}
22552259
if (pmu->selectable) {
22562260
info.name = buf;
2257-
snprintf(buf, sizeof(buf), "%s//", pmu->name);
2261+
scnprintf(buf, sizeof(buf), "%s//", pmu->name);
22582262
info.alias = NULL;
22592263
info.scale_unit = NULL;
22602264
info.desc = NULL;

0 commit comments

Comments
 (0)