Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp12123552rwl; Tue, 3 Jan 2023 09:18:27 -0800 (PST) X-Google-Smtp-Source: AMrXdXtgNec0BsQnp8zH9INC4Dge0+nMOPVMC4j4RmsL5PiV8Jjw1En5JLt3yvuwcNSlk5zctEii X-Received: by 2002:aa7:91d9:0:b0:575:2337:17bf with SMTP id z25-20020aa791d9000000b00575233717bfmr54278946pfa.12.1672766307747; Tue, 03 Jan 2023 09:18:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1672766307; cv=none; d=google.com; s=arc-20160816; b=zfOhE5WohCr4T/IzqmTRAxzP4NZcKtY9T4wiLF9zRz3Cm89zrgXVbGqxcfmT7vadIx O2W6log2wlJMEQ2l0EhGZTKjzOz8zzVd2q59c/wfEU391KoWK51olGoEDrSQOPecC5Oj WNmzSZbvaJGMbHykliD0M/2q8fNURXWHO2wHm/JFzJj+6cTX3dEW9DdDBgwgQAM7gl8+ CJOYMeL+u1LitfRLTuDccYLIaEznHuxVfjI3psSiZXZCttTAKv+sLqyxbKRNZb6C0x6Q lBj3YStXwyT0Ui+xJRKKDxPzfSFcWRqnn0j3QB2r9hzuyV7JkLyHddeHbzjmfbSGI4Hc TEzw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=MSzpbmbSklGfNv86SkaSTduajgZgbZiNIS++WuGQ+cI=; b=FAKLZI5iVno8bWMmcnGCMu25hAZUO7AkbI6F8pYJXCK05wi6yPXfVbU9w3FmF+Y2vx pFamMrlgGMtbEz1G+0KKW85M0Bra1fdZjsLOXQtB98XKi2nP1BFmVjbueTM35Nw7dn7H V0e3PhJIFqFXdzgL2MImM+POSjXDhsHgtuz/o8W7Fk+Cry/TFIWAjl4I7I7049x20vKA SRt8ln2xYFkWfx9KnwzUoOI4oqMG4QTF4QEoNQZUX3Y4Ex810yIWq0GenHwDMwmXtC3G +pSfWOGW1pVE+fXckiwXBYyipBP3ikw1aKjQwzlavnYtR302NejHgwU6TFB/vxbxD/Am np5Q== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id l13-20020a056a00140d00b005807fa620a0si33685824pfu.326.2023.01.03.09.18.20; Tue, 03 Jan 2023 09:18:27 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238160AbjACQXT (ORCPT + 60 others); Tue, 3 Jan 2023 11:23:19 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46762 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238144AbjACQWW (ORCPT ); Tue, 3 Jan 2023 11:22:22 -0500 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id A3FEA6244; Tue, 3 Jan 2023 08:21:47 -0800 (PST) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 18EE21570; Tue, 3 Jan 2023 08:22:29 -0800 (PST) Received: from [10.32.36.24] (e121896.Emea.Arm.com [10.32.36.24]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 8F57E3F882; Tue, 3 Jan 2023 08:21:43 -0800 (PST) Message-ID: <800a1f42-319c-9098-ef1a-cb1e57159d13@arm.com> Date: Tue, 3 Jan 2023 16:21:41 +0000 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.4.2 Subject: Re: [PATCH v2 2/7] perf: Use perf_pmu__open_file() and perf_pmu__scan_file() Content-Language: en-US To: Leo Yan Cc: linux-perf-users@vger.kernel.org, tanmay@marvell.com, sgoutham@marvell.com, gcherian@marvell.com, lcherian@marvell.com, bbhushan2@marvell.com, Mathieu Poirier , Suzuki K Poulose , Mike Leach , John Garry , Will Deacon , Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , coresight@lists.linaro.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org References: <20221222160328.3639989-1-james.clark@arm.com> <20221222160328.3639989-3-james.clark@arm.com> From: James Clark In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-7.3 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_NONE 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 On 23/12/2022 03:45, Leo Yan wrote: > On Thu, Dec 22, 2022 at 04:03:22PM +0000, James Clark wrote: >> Remove some code that duplicates existing methods. This requires that >> some consts are removed because one of the existing helper methods takes >> a struct perf_pmu instead of a name which has a non const name field. >> But except for the tests, the strings were already non const. >> >> No functional changes. >> >> Signed-off-by: James Clark >> --- >> tools/perf/tests/evsel-roundtrip-name.c | 3 +- >> tools/perf/tests/parse-events.c | 3 +- >> tools/perf/util/cputopo.c | 9 +----- >> tools/perf/util/pmu-hybrid.c | 27 +++------------- >> tools/perf/util/pmu-hybrid.h | 2 +- >> tools/perf/util/pmu.c | 42 +++++++------------------ >> tools/perf/util/pmu.h | 3 +- >> 7 files changed, 24 insertions(+), 65 deletions(-) >> >> diff --git a/tools/perf/tests/evsel-roundtrip-name.c b/tools/perf/tests/evsel-roundtrip-name.c >> index e94fed901992..9bccf177f481 100644 >> --- a/tools/perf/tests/evsel-roundtrip-name.c >> +++ b/tools/perf/tests/evsel-roundtrip-name.c >> @@ -103,8 +103,9 @@ static int test__perf_evsel__roundtrip_name_test(struct test_suite *test __maybe >> int subtest __maybe_unused) >> { >> int err = 0, ret = 0; >> + char cpu_atom[] = "cpu_atom"; >> >> - if (perf_pmu__has_hybrid() && perf_pmu__hybrid_mounted("cpu_atom")) >> + if (perf_pmu__has_hybrid() && perf_pmu__hybrid_mounted(cpu_atom)) > > After change the parameter 'name' to non const type in function > perf_pmu__hybrid_mounted(), at here we still can pass string "cpu_atom" > without warning, right? If so, we don't need to define a local > variable 'cpu_atom'. > > [...] > >> -bool perf_pmu__hybrid_mounted(const char *name) >> +bool perf_pmu__hybrid_mounted(char *name) >> { >> - char path[PATH_MAX]; >> - const char *sysfs; >> - FILE *file; >> - int n, cpu; >> + int cpu; >> + struct perf_pmu pmu = {.name = 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; >> + return perf_pmu__scan_file(&pmu, "cpus", "%u", &cpu) > 0; > > It's not necessarily to change the parameter 'name' to non const type, > we can handle this case in two different ways. > > The first option is to refine the code with using the function > perf_pmu__pathname_scnprintf() which is introduced in patch 01, thus > we can keep using fopen() and fscanf() to read out value from 'cpus' > entry. > > Another option is to define a local array 'pmu_name[PATH_MAX]' and > then copy the input string to this array, something like: > > bool perf_pmu__hybrid_mounted(const char *name) > { > char pmu_name[PATH_MAX]; > struct perf_pmu pmu; > int cpu; > > strncpy(pmu_name, name, sizeof(pmu_name)); > pmu.name = pmu_name; > > return perf_pmu__scan_file(&pmu, "cpus", "%u", &cpu) > 0; > } > > We even can consider to dynamically allocate buffer and copy string from > 'name' to the allocated buffer. > I went with the string copy way and put the consts back in V3. One minor difference is that I had to use strlcpy() instead of strncpy() to avoid a compiler warning about the destination buffer being the same size. James [...] >> -static struct perf_cpu_map *pmu_cpumask(const char *name) >> +static struct perf_cpu_map *pmu_cpumask(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; >> - >> - if (!sysfs) >> - return NULL; >> + struct perf_pmu pmu = {.name = name}; > > Here we also can define a local array and copy string from 'name' to > the local array. This can allow us to provide a friendly function and > caller doesn't need to explictly pass non const string. > Done