Received: by 2002:a05:6358:e9c4:b0:b2:91dc:71ab with SMTP id hc4csp1535044rwb; Fri, 5 Aug 2022 03:52:43 -0700 (PDT) X-Google-Smtp-Source: AA6agR70fUB/3FFyEXvyMivxfJcm6+03THpDtEVpZ1CXzgMsWZ/UbaYo0bCySlXeeVAg9Q4E3uy/ X-Received: by 2002:a17:907:28c9:b0:731:e57:bf27 with SMTP id en9-20020a17090728c900b007310e57bf27mr483474ejc.451.1659696763165; Fri, 05 Aug 2022 03:52:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659696763; cv=none; d=google.com; s=arc-20160816; b=QURsTik55M3xwtMcMI8pwrJb4lopN+smxY/rJN/CPI68+JZvuQqBc+SYUljQN6rg/h Z2vDqiQr3g5iMjojq6xJqn+OvQE8qdhunUWeL80ybEFGl6DdyAu8i4frrfl3uRzHT/eY r8jwNjDMlSdY0+cMnp9o1ys0fnEcrmm17Br61OySt2EF1wRGmx/ZJ95OKNyQDAbWMkyK FWpDbJ9r831XHbneJYH5ld6gtWO7wDqk43eMTBpYbAdUU2lua3ipQTsLTJ5ZKJIPFD73 KnH2vNw9zgNtDTxG8Ufr/QUoI9kL0HRarnb6Ir5BONn34bBKR6KwX4ubKtedj7+cCrQM APsg== 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:subject:user-agent:mime-version:date:message-id; bh=Of0aZg1ldtYUazd0kkTKjaog4AVub6JfNTvHCOucMug=; b=dlIgE0CtpfGMfjINDuv6qUwfZCMXKS+GMt4Jm0Baap+odnp4QAHoUr9vHxes62VZOh 4tRNeDKop0jQUGHgUKVTLju14lpk1FOP3mil7BkpRKgdPWPMPLx/WhsWLXcT/pm9ZeVl FK6A7STZ7Oootyy5kVRG5J83fmDztOPu2+NC7xHuFoNBn41pygD8SwIDdAgfqK8uOpks nRAV8LQCK434WLwyTCSnIu0rKySRCupzppi2RtyDdvrzDZP/tIvGkb+qxtZt7+fCK7cB 2QFhVX+EYtUa5jOw77BxFOacqMv53Ha/s29CDiv1aQXJLWFy9dTqxo7MZ4q9+QaB7Et7 Gnvg== 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id pv28-20020a170907209c00b0072ed4f5cec2si3174238ejb.281.2022.08.05.03.52.16; Fri, 05 Aug 2022 03:52:43 -0700 (PDT) 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237757AbiHEKeX (ORCPT + 99 others); Fri, 5 Aug 2022 06:34:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48388 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232901AbiHEKeW (ORCPT ); Fri, 5 Aug 2022 06:34:22 -0400 Received: from frasgout.his.huawei.com (frasgout.his.huawei.com [185.176.79.56]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 831441F62E; Fri, 5 Aug 2022 03:34:19 -0700 (PDT) Received: from fraeml740-chm.china.huawei.com (unknown [172.18.147.226]) by frasgout.his.huawei.com (SkyGuard) with ESMTP id 4LzhfT4Z2xz67ZDL; Fri, 5 Aug 2022 18:29:21 +0800 (CST) Received: from lhrpeml500003.china.huawei.com (7.191.162.67) by fraeml740-chm.china.huawei.com (10.206.15.221) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Fri, 5 Aug 2022 12:34:17 +0200 Received: from [10.126.170.142] (10.126.170.142) by lhrpeml500003.china.huawei.com (7.191.162.67) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256) id 15.1.2375.24; Fri, 5 Aug 2022 11:34:15 +0100 Message-ID: <74e839ed-0733-d2db-7744-75921705ac5d@huawei.com> Date: Fri, 5 Aug 2022 11:34:18 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.6.1 Subject: Re: [PATCH v4 04/17] perf jevent: Add an 'all' architecture argument To: Ian Rogers , Will Deacon , "James Clark" , Mike Leach , Leo Yan , Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Mark Rutland , Alexander Shishkin , Jiri Olsa , "Namhyung Kim" , Andi Kleen , Zhengjun Xing , Ravi Bangoria , "Kan Liang" , Adrian Hunter , , , CC: Stephane Eranian References: <20220804221816.1802790-1-irogers@google.com> <20220804221816.1802790-5-irogers@google.com> From: John Garry In-Reply-To: <20220804221816.1802790-5-irogers@google.com> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.126.170.142] X-ClientProxiedBy: lhreml704-chm.china.huawei.com (10.201.108.53) To lhrpeml500003.china.huawei.com (7.191.162.67) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.1 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE,URIBL_SBL_A 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 04/08/2022 23:18, Ian Rogers wrote: > When 'all' is passed as the architecture generate a mapping table for > all architectures. This simplifies testing. To identify the table for an > architecture add an arch variable to the pmu_events_map. so could this 'all' arg ever passed for perf test? I thought maybe we could use to verify tables for all architectures - I didn't think that we did it today. Thanks, John > > Signed-off-by: Ian Rogers > --- > tools/perf/pmu-events/empty-pmu-events.c | 2 + > tools/perf/pmu-events/jevents.py | 70 +++++++++++++++--------- > tools/perf/pmu-events/pmu-events.h | 1 + > tools/perf/tests/pmu-events.c | 3 +- > 4 files changed, 47 insertions(+), 29 deletions(-) > > diff --git a/tools/perf/pmu-events/empty-pmu-events.c b/tools/perf/pmu-events/empty-pmu-events.c > index 77e655c6f116..d8cf9283e486 100644 > --- a/tools/perf/pmu-events/empty-pmu-events.c > +++ b/tools/perf/pmu-events/empty-pmu-events.c > @@ -110,12 +110,14 @@ static const struct pmu_event pme_test_soc_cpu[] = { > > const struct pmu_events_map pmu_events_map[] = { > { > + .arch = "testarch", > .cpuid = "testcpu", > .version = "v1", > .type = "core", > .table = pme_test_soc_cpu, > }, > { > + .arch = 0, > .cpuid = 0, > .version = 0, > .type = 0, > diff --git a/tools/perf/pmu-events/jevents.py b/tools/perf/pmu-events/jevents.py > index cdfa4e0e7557..e6e6c42c3f8a 100755 > --- a/tools/perf/pmu-events/jevents.py > +++ b/tools/perf/pmu-events/jevents.py > @@ -304,38 +304,45 @@ def process_one_file(parents: Sequence[str], item: os.DirEntry) -> None: > print_events_table_entries(item, get_topic(item.name)) > > > -def print_mapping_table() -> None: > +def print_mapping_table(archs: Sequence[str]) -> None: > """Read the mapfile and generate the struct from cpuid string to event table.""" > - with open(f'{_args.starting_dir}/{_args.arch}/mapfile.csv') as csvfile: > - table = csv.reader(csvfile) > - _args.output_file.write( > - 'const struct pmu_events_map pmu_events_map[] = {\n') > - first = True > - for row in table: > - # Skip the first row or any row beginning with #. > - if not first and len(row) > 0 and not row[0].startswith('#'): > - tblname = file_name_to_table_name([], row[2].replace('/', '_')) > - _args.output_file.write("""{ > -\t.cpuid = \"%s\", > -\t.version = \"%s\", > -\t.type = \"%s\", > -\t.table = %s > -}, > -""" % (row[0].replace('\\', '\\\\'), row[1], row[3], tblname)) > - first = False > - > - _args.output_file.write("""{ > + _args.output_file.write('const struct pmu_events_map pmu_events_map[] = {\n') > + for arch in archs: > + if arch == 'test': > + _args.output_file.write("""{ > +\t.arch = "testarch", > \t.cpuid = "testcpu", > \t.version = "v1", > \t.type = "core", > \t.table = pme_test_soc_cpu, > }, > -{ > +""") > + else: > + with open(f'{_args.starting_dir}/{arch}/mapfile.csv') as csvfile: > + table = csv.reader(csvfile) > + first = True > + for row in table: > + # Skip the first row or any row beginning with #. > + if not first and len(row) > 0 and not row[0].startswith('#'): > + tblname = file_name_to_table_name([], row[2].replace('/', '_')) > + cpuid = row[0].replace('\\', '\\\\') > + _args.output_file.write(f"""{{ > +\t.arch = "{arch}", > +\t.cpuid = "{cpuid}", > +\t.version = "{row[1]}", > +\t.type = "{row[3]}", > +\t.table = {tblname} > +}}, > +""") > + first = False > + > + _args.output_file.write("""{ > +\t.arch = 0, > \t.cpuid = 0, > \t.version = 0, > \t.type = 0, > \t.table = 0, > -}, > +} > }; > """) > > @@ -386,15 +393,24 @@ def main() -> None: > _args = ap.parse_args() > > _args.output_file.write("#include \"pmu-events/pmu-events.h\"\n") > - for path in [_args.arch, 'test']: > - arch_path = f'{_args.starting_dir}/{path}' > - if not os.path.isdir(arch_path): > - raise IOError(f'Missing architecture directory in \'{arch_path}\'') > + archs = [] > + for item in os.scandir(_args.starting_dir): > + if not item.is_dir(): > + continue > + if item.name == _args.arch or _args.arch == 'all' or item.name == 'test': > + archs.append(item.name) > + > + if len(archs) < 2: > + raise IOError(f'Missing architecture directory \'{_args.arch}\'') > + > + archs.sort() > + for arch in archs: > + arch_path = f'{_args.starting_dir}/{arch}' > preprocess_arch_std_files(arch_path) > ftw(arch_path, [], process_one_file) > print_events_table_suffix() > > - print_mapping_table() > + print_mapping_table(archs) > print_system_mapping_table() > > > diff --git a/tools/perf/pmu-events/pmu-events.h b/tools/perf/pmu-events/pmu-events.h > index 6efe73976440..7a360792635f 100644 > --- a/tools/perf/pmu-events/pmu-events.h > +++ b/tools/perf/pmu-events/pmu-events.h > @@ -38,6 +38,7 @@ struct pmu_event { > * The cpuid can contain any character other than the comma. > */ > struct pmu_events_map { > + const char *arch; > const char *cpuid; > const char *version; > const char *type; /* core, uncore etc */ > diff --git a/tools/perf/tests/pmu-events.c b/tools/perf/tests/pmu-events.c > index 263cbb67c861..82192f1a7bf7 100644 > --- a/tools/perf/tests/pmu-events.c > +++ b/tools/perf/tests/pmu-events.c > @@ -864,8 +864,7 @@ static void expr_failure(const char *msg, > const struct pmu_events_map *map, > const struct pmu_event *pe) > { > - pr_debug("%s for map %s %s %s\n", > - msg, map->cpuid, map->version, map->type); > + pr_debug("%s for map %s %s\n", msg, map->arch, map->cpuid); > pr_debug("On metric %s\n", pe->metric_name); > pr_debug("On expression %s\n", pe->metric_expr); > }