提交 475d8788 编写于 作者: J John Garry 提交者: Zhong Jinghua

perf pmu: Fix alias matching

mainline inclusion
from mainline-v5.14-rc4
commit c07d5c92
category: feature
bugzilla: https://gitee.com/openeuler/kernel/issues/I63VF5
CVE: NA

Reference: https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?id=c07d5c9226980ca5ae21c6a2714baa95be2ce164

--------------------------------------------------------------------------

Commit c47a5599 ("perf tools: Fix pattern matching for same
substring in different PMU type"), may have fixed some alias matching,
but has broken some others.

Firstly it cannot handle the simple scenario of PMU name in form
pmu_name{digits} - it can only handle pmu_name_{digits}.

Secondly it cannot handle more complex matching in the case where we
have multiple tokens. In this scenario, the code failed to realise that
we may examine multiple substrings in the PMU name.

Fix in two ways:

- Change perf_pmu__valid_suffix() to accept a PMU name without '_' in the
  suffix

- Only pay attention to perf_pmu__valid_suffix() for the final token

Also add const qualifiers as necessary to avoid casting.

Fixes: c47a5599 ("perf tools: Fix pattern matching for same substring in different PMU type")
Signed-off-by: NJohn Garry <john.garry@huawei.com>
Tested-by: NJin Yao <yao.jin@linux.intel.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Ian Rogers <irogers@google.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Kajol Jain <kjain@linux.ibm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lore.kernel.org/lkml/1626793819-79090-1-git-send-email-john.garry@huawei.comSigned-off-by: NArnaldo Carvalho de Melo <acme@redhat.com>
Signed-off-by: NJunhao He <hejunhao3@huawei.com>
上级 288460dd
...@@ -719,9 +719,13 @@ struct pmu_events_map *perf_pmu__find_map(struct perf_pmu *pmu) ...@@ -719,9 +719,13 @@ struct pmu_events_map *perf_pmu__find_map(struct perf_pmu *pmu)
return map; return map;
} }
static bool perf_pmu__valid_suffix(char *pmu_name, char *tok) /*
* Suffix must be in form tok_{digits}, or tok{digits}, or same as pmu_name
* to be valid.
*/
static bool perf_pmu__valid_suffix(const char *pmu_name, char *tok)
{ {
char *p; const char *p;
if (strncmp(pmu_name, tok, strlen(tok))) if (strncmp(pmu_name, tok, strlen(tok)))
return false; return false;
...@@ -730,12 +734,16 @@ static bool perf_pmu__valid_suffix(char *pmu_name, char *tok) ...@@ -730,12 +734,16 @@ static bool perf_pmu__valid_suffix(char *pmu_name, char *tok)
if (*p == 0) if (*p == 0)
return true; return true;
if (*p != '_') if (*p == '_')
return false; ++p;
++p; /* Ensure we end in a number */
if (*p == 0 || !isdigit(*p)) while (1) {
return false; if (!isdigit(*p))
return false;
if (*(++p) == 0)
break;
}
return true; return true;
} }
...@@ -771,12 +779,19 @@ bool pmu_uncore_alias_match(const char *pmu_name, const char *name) ...@@ -771,12 +779,19 @@ bool pmu_uncore_alias_match(const char *pmu_name, const char *name)
* match "socket" in "socketX_pmunameY" and then "pmuname" in * match "socket" in "socketX_pmunameY" and then "pmuname" in
* "pmunameY". * "pmunameY".
*/ */
for (; tok; name += strlen(tok), tok = strtok_r(NULL, ",", &tmp)) { while (1) {
char *next_tok = strtok_r(NULL, ",", &tmp);
name = strstr(name, tok); name = strstr(name, tok);
if (!name || !perf_pmu__valid_suffix((char *)name, tok)) { if (!name ||
(!next_tok && !perf_pmu__valid_suffix(name, tok))) {
res = false; res = false;
goto out; goto out;
} }
if (!next_tok)
break;
tok = next_tok;
name += strlen(tok);
} }
res = true; res = true;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册