Received: by 2002:a05:6358:a55:b0:ec:fcf4:3ecf with SMTP id 21csp3052208rwb; Fri, 20 Jan 2023 10:31:30 -0800 (PST) X-Google-Smtp-Source: AMrXdXuPNtWWDeZCXaWpzzWVt8IpcQZv8cbJ1JjMRQW4OLKXYz54lYk3aWLse3kfgHNU2Q/uEcrk X-Received: by 2002:a17:903:2481:b0:194:b105:5cb4 with SMTP id p1-20020a170903248100b00194b1055cb4mr12826534plw.25.1674239490577; Fri, 20 Jan 2023 10:31:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1674239490; cv=none; d=google.com; s=arc-20160816; b=AZiRFeuK3fEvCT4bltrXcGpLKu4MUcoXY9yqfR/keZ1XFqL3j2R8E1r00BcIS+Pnc5 UBN177t56xRjZBWtlH0Jtw3w0dme1K6SDWPzNIeLu5gBPYO3cnLTKD6DSB5plm+IhfWO aG4bL+/h2MsDC8ggtvkucPBbXvG4Wv0oByJi3Vlyrnw/tslHtmUDl8mGZF7F0IPcJJSE uQGcdJ9+yqOfZ22zKNwoSEZYNIOc9pAvpniCewHtHgfN1maN7mmIKkKvs4NY9SvS2DAP qZvoRnbt+Cm55bakFAPYxrq9ll/9IqKG/BySsR3tCl+i8WErq/pcodoCwAoZ1yk4jc+F e7MQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=Gq4qQSMkAwMCossnIbg6Z0ycgM4TevR6SI2lGXBZt3o=; b=NrqBps6MvOio4dISNIyUydRKtDN7fgqgB7Fyu9UNukdn5kNnaf1uN93u8KFgPQskpK ge2z2pwVdE0RfKf6taaBQPLs5GCbPOor41DYbL5Vks8ZHcTYEP4aKEHSb1OGHaYvYngP NXZ19wjLvM1TYg+Hh6NyH+9ES8JzyncbsffwNwLvnEiWQlEi27NwkCMFjAEfmtogs6/3 ZOVesgmKW4KH7IOQlR6S9dfN58Dsonpe3xYseSIbOJmpCIkthy9N/fC0Q6qAHwfI+dwG laHoY19g96rgRxaIwcU6Mc9A/OSyPH5g334F2VqAggi5rVUYERg8+FxJLAvbrzuoxLO2 NbNw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=guQYVHqw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id s9-20020a17090302c900b001928d16bf5csi41306742plk.21.2023.01.20.10.31.12; Fri, 20 Jan 2023 10:31:30 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=guQYVHqw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229645AbjATRnw (ORCPT + 50 others); Fri, 20 Jan 2023 12:43:52 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60840 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229518AbjATRnv (ORCPT ); Fri, 20 Jan 2023 12:43:51 -0500 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E53BD45F50; Fri, 20 Jan 2023 09:43:49 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 74BFE62019; Fri, 20 Jan 2023 17:43:49 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 80657C433EF; Fri, 20 Jan 2023 17:43:48 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1674236628; bh=eQ8Ti0BGT1cK+eneWTl/IMTZV9chY9vkpdu4/jCchwE=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=guQYVHqwYCvg9Lt54u5WqKSoHbg9GRY+Xad47vicy2VVPiNaWEUbtgMyZgvdg/bbo lsn0NgH+L8EiEHBtbJx1sfQa9Drx/tO2cBvrqQ5IouKBwsS8VDQy9M96wg5dllj/1G rs/hWtOi/PpgqNQIWatgY7WscslFEWeM33hgbK9bf2nuvZdjgXwb//1XwBj2IN5c9J aYnh9qmT6DuCzubU9lOpFMX50jsnzKwWlXuYHT2o7Pkm3MT9w3klE2lhwdJVBR7cGE tCVN1kuHDV7FF6eowJjickSZwSBMcs3C9bZOIO40/C+kneyQ0sl/oH8ajifUD2z3lJ GrLG9l/apyk5g== Received: by quaco.ghostprotocols.net (Postfix, from userid 1000) id D58CA405BE; Fri, 20 Jan 2023 14:43:44 -0300 (-03) Date: Fri, 20 Jan 2023 14:43:44 -0300 From: Arnaldo Carvalho de Melo To: James Clark Cc: linux-perf-users@vger.kernel.org, tanmay@marvell.com, leo.yan@linaro.org, mike.leach@linaro.org, sgoutham@marvell.com, gcherian@marvell.com, lcherian@marvell.com, bbhushan2@marvell.com, Mathieu Poirier , Suzuki K Poulose , John Garry , Will Deacon , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , coresight@lists.linaro.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v5 2/8] perf: Use perf_pmu__open_file() and perf_pmu__scan_file() Message-ID: References: <20230120143702.4035046-1-james.clark@arm.com> <20230120143702.4035046-3-james.clark@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Url: http://acmel.wordpress.com X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Em Fri, Jan 20, 2023 at 02:32:30PM -0300, Arnaldo Carvalho de Melo escreveu: > Em Fri, Jan 20, 2023 at 02:21:56PM -0300, Arnaldo Carvalho de Melo escreveu: > > Em Fri, Jan 20, 2023 at 02:36:55PM +0000, James Clark escreveu: > > > Remove some code that duplicates existing methods. Copy strings where > > > const strings are required. > > > > > > No functional changes. > > > > > > Have you used 'perf test'? > > > > [acme@quaco perf]$ perf test -v python > > Couldn't bump rlimit(MEMLOCK), failures may take place when creating BPF maps, etc > > 19: 'import perf' in python : > > --- start --- > > test child forked, pid 232379 > > python usage test: "echo "import sys ; sys.path.append('/tmp/build/perf/python'); import perf" | '/usr/bin/python3' " > > Traceback (most recent call last): > > File "", line 1, in > > ImportError: /tmp/build/perf/python/perf.cpython-310-x86_64-linux-gnu.so: undefined symbol: perf_pmu__scan_file > > test child finished with -1 > > ---- end ---- > > 'import perf' in python: FAILED! > > [acme@quaco perf]$ > > I added this to this cset, now it passes. So, what I have is now at my tmp.perf/core branch, pending container testing, later today probably will move to perf/core, so that it gets exposure on linux-next for v6.3. For your convenience: https://git.kernel.org/pub/scm/linux/kernel/git/acme/linux.git/log/?h=tmp.perf/core Thanks, - Arnaldo > diff --git a/tools/perf/util/python.c b/tools/perf/util/python.c > index d948455e5ed43656..9e5d881b098767a3 100644 > --- a/tools/perf/util/python.c > +++ b/tools/perf/util/python.c > @@ -20,6 +20,7 @@ > #include "stat.h" > #include "metricgroup.h" > #include "util/env.h" > +#include "util/pmu.h" > #include > #include "util.h" > > @@ -83,7 +84,7 @@ void perf_stat__collect_metric_expr(struct evlist *evsel_list) > } > > /* > - * This one is needed not to drag the PMU bandwagon, jevents generated > + * These ones are needed not to drag the PMU bandwagon, jevents generated > * pmu_sys_event_tables, etc and evsel__find_pmu() is used so far just for > * doing per PMU perf_event_attr.exclude_guest handling, not really needed, so > * far, for the perf python binding known usecases, revisit if this become > @@ -94,6 +95,11 @@ struct perf_pmu *evsel__find_pmu(struct evsel *evsel __maybe_unused) > return NULL; > } > > +int perf_pmu__scan_file(struct perf_pmu *pmu, const char *name, const char *fmt, ...) > +{ > + return EOF; > +} > + > /* > * Add this one here not to drag util/metricgroup.c > */ > > > > Reviewed-by: Leo Yan > > > Signed-off-by: James Clark > > > --- > > > tools/perf/util/cputopo.c | 9 +------- > > > tools/perf/util/pmu-hybrid.c | 27 +++++------------------- > > > tools/perf/util/pmu.c | 40 +++++++++++------------------------- > > > tools/perf/util/pmu.h | 3 ++- > > > 4 files changed, 20 insertions(+), 59 deletions(-) > > > > > > diff --git a/tools/perf/util/cputopo.c b/tools/perf/util/cputopo.c > > > index 1a3ff6449158..e08797c3cdbc 100644 > > > --- a/tools/perf/util/cputopo.c > > > +++ b/tools/perf/util/cputopo.c > > > @@ -422,8 +422,6 @@ void numa_topology__delete(struct numa_topology *tp) > > > static int load_hybrid_node(struct hybrid_topology_node *node, > > > struct perf_pmu *pmu) > > > { > > > - const char *sysfs; > > > - char path[PATH_MAX]; > > > char *buf = NULL, *p; > > > FILE *fp; > > > size_t len = 0; > > > @@ -432,12 +430,7 @@ static int load_hybrid_node(struct hybrid_topology_node *node, > > > if (!node->pmu_name) > > > return -1; > > > > > > - sysfs = sysfs__mountpoint(); > > > - if (!sysfs) > > > - goto err; > > > - > > > - snprintf(path, PATH_MAX, CPUS_TEMPLATE_CPU, sysfs, pmu->name); > > > - fp = fopen(path, "r"); > > > + fp = perf_pmu__open_file(pmu, "cpus"); > > > if (!fp) > > > goto err; > > > > > > diff --git a/tools/perf/util/pmu-hybrid.c b/tools/perf/util/pmu-hybrid.c > > > index f51ccaac60ee..38628805a952 100644 > > > --- a/tools/perf/util/pmu-hybrid.c > > > +++ b/tools/perf/util/pmu-hybrid.c > > > @@ -20,32 +20,15 @@ LIST_HEAD(perf_pmu__hybrid_pmus); > > > > > > bool perf_pmu__hybrid_mounted(const char *name) > > > { > > > - char path[PATH_MAX]; > > > - const char *sysfs; > > > - FILE *file; > > > - int n, cpu; > > > + int cpu; > > > + char pmu_name[PATH_MAX]; > > > + struct perf_pmu pmu = {.name = pmu_name}; > > > > > > if (strncmp(name, "cpu_", 4)) > > > return false; > > > > > > - sysfs = sysfs__mountpoint(); > > > - if (!sysfs) > > > - return false; > > > - > > > - snprintf(path, PATH_MAX, CPUS_TEMPLATE_CPU, sysfs, name); > > > - if (!file_available(path)) > > > - return false; > > > - > > > - file = fopen(path, "r"); > > > - if (!file) > > > - return false; > > > - > > > - n = fscanf(file, "%u", &cpu); > > > - fclose(file); > > > - if (n <= 0) > > > - return false; > > > - > > > - return true; > > > + strlcpy(pmu_name, name, sizeof(pmu_name)); > > > + return perf_pmu__scan_file(&pmu, "cpus", "%u", &cpu) > 0; > > > } > > > > > > struct perf_pmu *perf_pmu__find_hybrid_pmu(const char *name) > > > diff --git a/tools/perf/util/pmu.c b/tools/perf/util/pmu.c > > > index 1edbb714ff32..a771a5972fc5 100644 > > > --- a/tools/perf/util/pmu.c > > > +++ b/tools/perf/util/pmu.c > > > @@ -571,45 +571,31 @@ static void pmu_read_sysfs(void) > > > closedir(dir); > > > } > > > > > > -static struct perf_cpu_map *__pmu_cpumask(const char *path) > > > -{ > > > - FILE *file; > > > - struct perf_cpu_map *cpus; > > > - > > > - file = fopen(path, "r"); > > > - if (!file) > > > - return NULL; > > > - > > > - cpus = perf_cpu_map__read(file); > > > - fclose(file); > > > - return cpus; > > > -} > > > - > > > /* > > > * Uncore PMUs have a "cpumask" file under sysfs. CPU PMUs (e.g. on arm/arm64) > > > * may have a "cpus" file. > > > */ > > > #define SYS_TEMPLATE_ID "./bus/event_source/devices/%s/identifier" > > > -#define CPUS_TEMPLATE_UNCORE "%s/bus/event_source/devices/%s/cpumask" > > > > > > static struct perf_cpu_map *pmu_cpumask(const char *name) > > > { > > > - char path[PATH_MAX]; > > > struct perf_cpu_map *cpus; > > > - const char *sysfs = sysfs__mountpoint(); > > > const char *templates[] = { > > > - CPUS_TEMPLATE_UNCORE, > > > - CPUS_TEMPLATE_CPU, > > > + "cpumask", > > > + "cpus", > > > NULL > > > }; > > > const char **template; > > > + char pmu_name[PATH_MAX]; > > > + struct perf_pmu pmu = {.name = pmu_name}; > > > + FILE *file; > > > > > > - if (!sysfs) > > > - return NULL; > > > - > > > + strlcpy(pmu_name, name, sizeof(pmu_name)); > > > for (template = templates; *template; template++) { > > > - snprintf(path, PATH_MAX, *template, sysfs, name); > > > - cpus = __pmu_cpumask(path); > > > + file = perf_pmu__open_file(&pmu, *template); > > > + if (!file) > > > + continue; > > > + cpus = perf_cpu_map__read(file); > > > if (cpus) > > > return cpus; > > > } > > > @@ -620,13 +606,11 @@ static struct perf_cpu_map *pmu_cpumask(const char *name) > > > static bool pmu_is_uncore(const char *name) > > > { > > > char path[PATH_MAX]; > > > - const char *sysfs; > > > > > > if (perf_pmu__hybrid_mounted(name)) > > > return false; > > > > > > - sysfs = sysfs__mountpoint(); > > > - snprintf(path, PATH_MAX, CPUS_TEMPLATE_UNCORE, sysfs, name); > > > + perf_pmu__pathname_scnprintf(path, sizeof(path), name, "cpumask"); > > > return file_available(path); > > > } > > > > > > @@ -1737,7 +1721,7 @@ bool pmu_have_event(const char *pname, const char *name) > > > return false; > > > } > > > > > > -static FILE *perf_pmu__open_file(struct perf_pmu *pmu, const char *name) > > > +FILE *perf_pmu__open_file(struct perf_pmu *pmu, const char *name) > > > { > > > char path[PATH_MAX]; > > > > > > diff --git a/tools/perf/util/pmu.h b/tools/perf/util/pmu.h > > > index 96d030c8b3b3..742d4db319a0 100644 > > > --- a/tools/perf/util/pmu.h > > > +++ b/tools/perf/util/pmu.h > > > @@ -7,6 +7,7 @@ > > > #include > > > #include > > > #include > > > +#include > > > #include "parse-events.h" > > > #include "pmu-events/pmu-events.h" > > > > > > @@ -22,7 +23,6 @@ enum { > > > }; > > > > > > #define PERF_PMU_FORMAT_BITS 64 > > > -#define CPUS_TEMPLATE_CPU "%s/bus/event_source/devices/%s/cpus" > > > #define MAX_PMU_NAME_LEN 128 > > > > > > struct perf_event_attr; > > > @@ -262,5 +262,6 @@ double perf_pmu__cpu_slots_per_cycle(void); > > > int perf_pmu__event_source_devices_scnprintf(char *pathname, size_t size); > > > int perf_pmu__pathname_scnprintf(char *buf, size_t size, > > > const char *pmu_name, const char *filename); > > > +FILE *perf_pmu__open_file(struct perf_pmu *pmu, const char *name); > > > > > > #endif /* __PMU_H */ > > > -- > > > 2.25.1 > > > > > > > -- > > > > - Arnaldo > > -- > > - Arnaldo -- - Arnaldo