Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp5591787rwb; Tue, 22 Nov 2022 02:04:47 -0800 (PST) X-Google-Smtp-Source: AA0mqf4DTPMElSrQp91TsFJOVG3MvR5WGhIVc34576r9Dw2iXLBYxTLhjdmarQc0uwxiKhEI4UeI X-Received: by 2002:a17:906:1187:b0:7ad:88f8:6a53 with SMTP id n7-20020a170906118700b007ad88f86a53mr19730373eja.61.1669111487682; Tue, 22 Nov 2022 02:04:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1669111487; cv=none; d=google.com; s=arc-20160816; b=ZEcdbyOzBut4XIjzDlJB8ZJerZtYwrQFmTjNmmnWcmqO7i12zi72bdmGbwTZ9BVq6P uU8NmKAmodHAGNHY8kqyHvqJcIkcJ1nXdov6F2JnwXUyCBDxTFpIL56PjrAwg+3iVhAY N7JHopsymfW/5HQSWqcKT7aAPT+S6i5XD4Lq6SUJvrp3PBnsOJUN8ccVaXsOI/+VJKaL 3AYe4p/veJo6jw/Lmi83HQzBo7z00bmikirdtMrlRohvluvF7p7HnZpBXOsoQHnPLWUw nzl2r/iNFb4lvmc6pxijRbp3MQqApjI0DSqW4GQkbkQJ35E6+tyTCimA8ufgau5VkocJ nXuQ== 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=rhY4x9esKHibUi3qdORDXg3ZRW/o69cHnJ/R68QkE7E=; b=uEtKX3Ejv2GbVGFjpqA9V3krnqVnjMOXMCpnC/8tkaU6M26t4uQL7JrjTFdYIUqXvT zFifXwhT1EK3x9kx3ojPdftgb7JiEwWcszPWoIlO9UPanHvU9gtW7d0XQu3TGlU4lHXf /pfElRELeBhPZ+7Q5JdNjM09QZrvGemKXEl+JC7/OLUolWzQx4YSqbpr9lzX2gBskQW4 tcE1gb7m3vgNsOk5S0dLmT8cDx2ajPK6j37Zmz2Ld87mcCQ/8toAs/762viauH2PFLvT Tx9K0enfRMCcbJEWpC3YQUZFhmPQflB+c4KMEq/BKpLECJxuAig28sHGTtUyWeAPNhil ELDQ== 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=alibaba.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id cz10-20020a0564021caa00b0046453c36c4csi10620277edb.513.2022.11.22.02.04.24; Tue, 22 Nov 2022 02:04:47 -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=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232786AbiKVJZK (ORCPT + 92 others); Tue, 22 Nov 2022 04:25:10 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58062 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232500AbiKVJZI (ORCPT ); Tue, 22 Nov 2022 04:25:08 -0500 Received: from out30-45.freemail.mail.aliyun.com (out30-45.freemail.mail.aliyun.com [115.124.30.45]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DB7D53FB9A; Tue, 22 Nov 2022 01:25:06 -0800 (PST) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R531e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046051;MF=renyu.zj@linux.alibaba.com;NM=1;PH=DS;RN=19;SR=0;TI=SMTPD_---0VVRfUdC_1669109100; Received: from 30.221.132.69(mailfrom:renyu.zj@linux.alibaba.com fp:SMTPD_---0VVRfUdC_1669109100) by smtp.aliyun-inc.com; Tue, 22 Nov 2022 17:25:02 +0800 Message-ID: Date: Tue, 22 Nov 2022 17:24:59 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:102.0) Gecko/20100101 Thunderbird/102.4.1 Subject: Re: [External] : [RFC PATCH v2 1/6] perf vendor events arm64: Add topdown L1 metrics for neoverse-n2 To: John Garry , linux-arm-kernel@lists.infradead.org, linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org, Will Deacon , James Clark , Mike Leach , Leo Yan , Ian Rogers Cc: Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Andrew Kilroy , Shuai Xue , Zhuo Song References: <1667214694-89839-1-git-send-email-renyu.zj@linux.alibaba.com> <1668411720-3581-2-git-send-email-renyu.zj@linux.alibaba.com> <590ff032-d271-48ee-a4d8-141cc070c335@oracle.com> <75c4f0e6-3f28-a748-e891-7be6016ca28e@oracle.com> From: Jing Zhang In-Reply-To: <75c4f0e6-3f28-a748-e891-7be6016ca28e@oracle.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-9.9 required=5.0 tests=BAYES_00, ENV_AND_HDR_SPF_MATCH,NICE_REPLY_A,RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS,UNPARSEABLE_RELAY, USER_IN_DEF_SPF_WL 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 在 2022/11/22 上午1:55, John Garry 写道: > On 21/11/2022 15:17, Jing Zhang wrote: >> I'm sorry that I misunderstood the purpose of putting metric as arch_std_event at first, >> and now it works after the modification over your suggestion. >> >> But there are also a few questions: >> >> 1. The value of the slot in the topdownL1 is various in different architectures, for example, >> the slot is 5 on neoverse-n2. If I put topdownL1 metric as arch_std_event, then I need to >> specify the slot to 5 in n2. I can specify slot values in metric like below, but is there any >> other concise way to do this? >> >> diff --git a/tools/perf/pmu-events/arch/arm64/arm/neoverse-n2/metrics.json b/tools/perf/pmu-events/arch/arm64/arm/neoverse-n2/metrics.json >> index 8ff1dfe..b473baf 100644 >> --- a/tools/perf/pmu-events/arch/arm64/arm/neoverse-n2/metrics.json >> +++ b/tools/perf/pmu-events/arch/arm64/arm/neoverse-n2/metrics.json >> @@ -1,4 +1,23 @@ >> [ >> +       { >> +               "MetricExpr": "5", >> +               "PublicDescription": "A pipeline slot represents the hardware resources needed to process one uOp", >> +               "BriefDescription": "A pipeline slot represents the hardware resources needed to process one uOp", >> +               "MetricName": "slot" > > Ehhh....I'm not sure if that is a good idea. Ian or anyone else have an opinion on this? It is possible to reuse metrics, so it should work, but... > > One problem is that "slot" would show up as a metric, which you would not want. > > Alternatively I was going to suggest that you can overwrite specific std arch event attributes. So for example of frontend_bound, you could have: > > + b/tools/perf/pmu-events/arch/arm64/arm/neoverse-n2/metrics.json > @@ -0,0 +1,30 @@ > [ >     { >     "ArchStdEvent": "FRONTEND_BOUND", >         "MetricExpr": "(stall_slot_frontend - cpu_cycles) / (5 * cpu_cycles)", >     }, > >> +       } >> +       { >> +               "ArchStdEvent": "FRONTEND_BOUND" >> +       }, >> +       { >> +               "ArchStdEvent": "BACKEND_BOUND" >> +       }, >> +       { >> +               "ArchStdEvent": "WASTED" >> +       }, >> +       { >> +               "ArchStdEvent": "RETIRING" >> +       }, >> >> >> 2. Should I add the topdownL1 metric to tools/perf/pmu-event/recommended.json, >> or create a new json file to place the general metric? > > It would not belong in recommended.json as that is specifically for arch-recommended events. It would really just depend on where the value comes from, i.e. arm arm or sbsa. > Thanks for your suggestion, I will send next patchset as you suggested.