Received: by 2002:a05:6a10:c604:0:0:0:0 with SMTP id y4csp610137pxt; Thu, 12 Aug 2021 05:58:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyzkQFrjbPz/iwSSpmohTHGZwRZIc9GKy9zWCvbgRvSvFXAguskX5z+ThA/LDtrSEUqN5Em X-Received: by 2002:a17:906:4808:: with SMTP id w8mr3589915ejq.56.1628773124869; Thu, 12 Aug 2021 05:58:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628773124; cv=none; d=google.com; s=arc-20160816; b=L6aSk1xfdQNMKeb94UJPJ5rc3n83U0P/l0FVSJar3SZT4b6B9wUbNkARHv9YLdtoq9 YgEHsoXJkUuYbV0y+KJmKPooQiIvQbvAasdDPdw+JVBsRklhMWjVKpKtXrsEZO2S6mwG 2reGi3QT0mQd7/5TPqGVpxIImqvXsny+rR7aMXYA2i+bycXbgAly2JYvolFUAdULGggV 5Vr48zO16JEQSeEmkJhveV0etJjcyeA21hHFdDcXZIPIdB/ijHmQHd+hZeov19rgmysI n0/4aQX0fQA9gB/yr3d3TVRaqvmzCrvISiGggA5EubQ+uEspJcAWyHEPKE7V3U7nKAww UImA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=+HxpL1WAx55nBkT+wi0Z8Tu3w5XRSmSVnvBytfK7i9Y=; b=GUibIkhkRNjkoBj+WRK1kss4S4fTWT/QrcgOCoF66tmm9JezNCLy6rU16fGUixhk6C v6ZUR0dx5MyKJ+JVxd/v5e5Q3DCq1VSy4Qo/WYpmLLLkwR7KafWezmoy8c/gw+WJpiai XCM1IVtjm1TLlE1XvfVKnHYgu/wcMqXzJEYxw0TrFtWCdHQS0D8UElOCLZlt86afmZf7 UaKdSmWMSunmqHjhkpC5ZZT03Hl/4qlBZhIXUGtZ3IHhqC7S9ZGdovcN6xOZo8NtrPrh o5gxrtpdhASVeITqlKJU9B0j8mknXp+dSjjPtLGO0ljWOwveFhEpfNUSzyN/+KDkvM9x VKpw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b1si3132856ejb.152.2021.08.12.05.58.19; Thu, 12 Aug 2021 05:58:44 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232397AbhHLMQD (ORCPT + 99 others); Thu, 12 Aug 2021 08:16:03 -0400 Received: from frasgout.his.huawei.com ([185.176.79.56]:3643 "EHLO frasgout.his.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231384AbhHLMQC (ORCPT ); Thu, 12 Aug 2021 08:16:02 -0400 Received: from fraeml713-chm.china.huawei.com (unknown [172.18.147.201]) by frasgout.his.huawei.com (SkyGuard) with ESMTP id 4GllxY2vJLz6FFjn; Thu, 12 Aug 2021 20:14:57 +0800 (CST) Received: from lhreml724-chm.china.huawei.com (10.201.108.75) by fraeml713-chm.china.huawei.com (10.206.15.32) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.8; Thu, 12 Aug 2021 14:15:35 +0200 Received: from [10.47.80.186] (10.47.80.186) by lhreml724-chm.china.huawei.com (10.201.108.75) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256) id 15.1.2176.2; Thu, 12 Aug 2021 13:15:34 +0100 Subject: Re: [PATCH v4 1/2] perf pmu: Add PMU alias support To: Jin Yao , , , , , CC: , , , , , , Kan Liang References: <20210811024827.9483-1-yao.jin@linux.intel.com> <20210811024827.9483-2-yao.jin@linux.intel.com> From: John Garry Message-ID: <8730872e-dae1-4d95-48aa-60b15dec2fa7@huawei.com> Date: Thu, 12 Aug 2021 13:14:53 +0100 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.12.1 MIME-Version: 1.0 In-Reply-To: <20210811024827.9483-2-yao.jin@linux.intel.com> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.47.80.186] X-ClientProxiedBy: lhreml704-chm.china.huawei.com (10.201.108.53) To lhreml724-chm.china.huawei.com (10.201.108.75) X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org perf pmu: Add x86 PMU alias support > +char *pmu_find_real_name(const char *name) > +{ > + static bool cached_list; > + > + if (cached_list) > + return __pmu_find_real_name(name); > + > + setup_pmu_alias_list(); > + cached_list = true; > + > + return __pmu_find_real_name(name); > +} > + > +char *pmu_find_alias_name(const char *name) > +{ > + struct perf_pmu_alias_name *pmu; > + > + list_for_each_entry(pmu, &pmu_alias_name_list, list) { > + if (!strcmp(name, pmu->name)) > + return strdup(pmu->alias); I would not expect a function which does a "find" to duplicate the name. Same goes for all the other places which does similar. > + } > + return NULL; > +} > diff --git a/tools/perf/util/parse-events.y b/tools/perf/util/parse-events.y > index 9321bd0e2f76..d94e48e1ff9b 100644 > --- a/tools/perf/util/parse-events.y > +++ b/tools/perf/util/parse-events.y > @@ -316,7 +316,8 @@ event_pmu_name opt_pmu_config > if (!strncmp(name, "uncore_", 7) && > strncmp($1, "uncore_", 7)) > name += 7; > - if (!perf_pmu__match(pattern, name, $1)) { > + if (!perf_pmu__match(pattern, name, $1) || > + !perf_pmu__match(pattern, pmu->alias_name, $1)) { > if (parse_events_copy_term_list(orig_terms, &terms)) > CLEANUP_YYABORT; > if (!parse_events_add_pmu(_parse_state, list, pmu->name, terms, true, false)) > diff --git a/tools/perf/util/pmu.c b/tools/perf/util/pmu.c > index fc683bc41715..796a4be752f4 100644 > --- a/tools/perf/util/pmu.c > +++ b/tools/perf/util/pmu.c > @@ -946,6 +946,18 @@ perf_pmu__get_default_config(struct perf_pmu *pmu __maybe_unused) > return NULL; > } > > +char * __weak > +pmu_find_real_name(const char *name) > +{ > + return strdup(name); > +} That's not finding anything. > + > +char * __weak > +pmu_find_alias_name(const char *name __maybe_unused) > +{ > + return NULL; > +} > + > static int pmu_max_precise(const char *name) > { > char path[PATH_MAX]; > @@ -959,19 +971,25 @@ static int pmu_max_precise(const char *name) > return max_precise; > } > > -static struct perf_pmu *pmu_lookup(const char *name) > +static struct perf_pmu *pmu_lookup(const char *lookup_name) > { > - struct perf_pmu *pmu; > + struct perf_pmu *pmu = NULL; > LIST_HEAD(format); > LIST_HEAD(aliases); > __u32 type; > - bool is_hybrid = perf_pmu__hybrid_mounted(name); > + bool is_hybrid; > + char *name = pmu_find_real_name(lookup_name); > + > + if (!name) > + return NULL; > + > + is_hybrid = perf_pmu__hybrid_mounted(name); > > /* > * Check pmu name for hybrid and the pmu may be invalid in sysfs > */ > if (!strncmp(name, "cpu_", 4) && !is_hybrid) > - return NULL; > + goto out; > > /* > * The pmu data we store & need consists of the pmu > @@ -979,23 +997,24 @@ static struct perf_pmu *pmu_lookup(const char *name) > * now. > */ > if (pmu_format(name, &format)) > - return NULL; > + goto out; > > /* > * Check the type first to avoid unnecessary work. > */ > if (pmu_type(name, &type)) > - return NULL; > + goto out; > > if (pmu_aliases(name, &aliases)) > - return NULL; > + goto out; > > pmu = zalloc(sizeof(*pmu)); > if (!pmu) > - return NULL; > + goto out; > > pmu->cpus = pmu_cpumask(name); > - pmu->name = strdup(name); > + pmu->name = name; > + pmu->alias_name = pmu_find_alias_name(name); > pmu->type = type; > pmu->is_uncore = pmu_is_uncore(name); > if (pmu->is_uncore) > @@ -1017,6 +1036,10 @@ static struct perf_pmu *pmu_lookup(const char *name) > > pmu->default_config = perf_pmu__get_default_config(pmu); > > +out: > + if (!pmu) > + free(name); I don't understand this. There are lots of places this function can fail , but we don't free memories allocated previously - why just free this one? > + > return pmu; > } > > @@ -1025,7 +1048,8 @@ static struct perf_pmu *pmu_find(const char *name) > struct perf_pmu *pmu; > > list_for_each_entry(pmu, &pmus, list) > - if (!strcmp(pmu->name, name)) > + if (!strcmp(pmu->name, name) || > + (pmu->alias_name && !strcmp(pmu->alias_name, name))) > return pmu; I'd be inclined to use {} for the list_for_each_entry() call > > return NULL; > @@ -1920,6 +1944,9 @@ bool perf_pmu__has_hybrid(void) > > int perf_pmu__match(char *pattern, char *name, char *tok) > { > + if (!name) > + return -1; > + > if (fnmatch(pattern, name, 0)) > return -1; > > diff --git a/tools/perf/util/pmu.h b/tools/perf/util/pmu.h > index 926da483a141..f6ca9f6a06ef 100644 > --- a/tools/perf/util/pmu.h > +++ b/tools/perf/util/pmu.h > @@ -21,6 +21,7 @@ enum { > #define PERF_PMU_FORMAT_BITS 64 > #define EVENT_SOURCE_DEVICE_PATH "/bus/event_source/devices/" > #define CPUS_TEMPLATE_CPU "%s/bus/event_source/devices/%s/cpus" > +#define MAX_PMU_NAME_LEN 128 > > struct perf_event_attr; > > @@ -32,6 +33,7 @@ struct perf_pmu_caps { > > struct perf_pmu { > char *name; > + char *alias_name; /* PMU alias name */ useless comment > char *id; > __u32 type; > bool selectable; > @@ -135,4 +137,7 @@ void perf_pmu__warn_invalid_config(struct perf_pmu *pmu, __u64 config, > bool perf_pmu__has_hybrid(void); > int perf_pmu__match(char *pattern, char *name, char *tok); > > +char *pmu_find_real_name(const char *name); > +char *pmu_find_alias_name(const char *name); > + > #endif /* __PMU_H */ >