Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp2931430iob; Sun, 1 May 2022 01:42:54 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxarL36/B7pmLLJsAyU6VUhzu0szXgXMKR1gcnqb5r7JxidUkWv46spQHssVL1Bw+CKyZ5R X-Received: by 2002:a05:6a00:1683:b0:4f7:e497:6a55 with SMTP id k3-20020a056a00168300b004f7e4976a55mr6171632pfc.21.1651394574131; Sun, 01 May 2022 01:42:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651394574; cv=none; d=google.com; s=arc-20160816; b=ABU3DmtoMWJUTUNRXwG1ut2yuzW9wNY6Yellzo3QCJUdWguoJAeoUe0K5gIZo0Xx3Y fjwVa+n3b1XGCw0CA9bglib3n9Y5lScZHfeWxJc1wsYdC2lUg004h/ot/RwvcLYMparA vd6fhg/d66cbAG6GBTUVabID6cqB9p4BE47W8yGJ9h/QwZkuAzOiS2OVPHyuAqjm0ZZU t0tiKRahF/FSH6s3Mi8r+cALKH7JBXPPCerIkc1pLgOrS1NteZuVLZuoDkHl2BuFWLst scbWg9DcIO9o7scoMjOdpZgJzAkeQxgaDfsHJkmdOzl5CaoSyfKkryKLtgI7qtuCA+Qp Jf6A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=/a5ljRFZhYXEjLddAM9nRcuoh3XdDUt0CimFZregVbQ=; b=oDJEtLRMiubsSk3IKkvfoKutphMAMR92KUIT7pK8vd3Q0GxBMUeV8QwjZe3/Dn9/BJ 1hzaHmxmtCVbP01DPqz8jtpPV29Fz7Xp0o9nBAThnqlfmSheBff4mjldrBij6JhdCiGX yMvPwM1q6GcFreJp+aGTBdtNyisLk38tIviws0ktoSxf6Bv4/unEdYML/hWk0cTrxGbK Qa+ztGZsiVxqlnxXoMv8cPTEN3qpsM4tmr5Yh9zX8jUrCm2m3Gp3aa7HYStyj1X6TD6o FORP5/6N71u58C7SVg3kvQxS5xhVAfYBZfXoCJZFxuAwWbrkeAETmpn1lpYJswavMMbo bWkg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=Eg0KawaX; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h1-20020a170902704100b0015a7e9bbe73si9996912plt.425.2022.05.01.01.42.39; Sun, 01 May 2022 01:42:54 -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; dkim=pass header.i=@google.com header.s=20210112 header.b=Eg0KawaX; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1381967AbiD3BNm (ORCPT + 99 others); Fri, 29 Apr 2022 21:13:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33530 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1346943AbiD3BNk (ORCPT ); Fri, 29 Apr 2022 21:13:40 -0400 Received: from mail-wr1-x432.google.com (mail-wr1-x432.google.com [IPv6:2a00:1450:4864:20::432]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8878EE0C2 for ; Fri, 29 Apr 2022 18:10:19 -0700 (PDT) Received: by mail-wr1-x432.google.com with SMTP id d5so12745090wrb.6 for ; Fri, 29 Apr 2022 18:10:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=/a5ljRFZhYXEjLddAM9nRcuoh3XdDUt0CimFZregVbQ=; b=Eg0KawaXriFIrCO0euxBXcWAwOwcYX5INInvWR+nCPeBgfDxdnqQZMBdQbC8gNNhZm 2dam+bp8L0qivRF47NoAMG9cIhiSf/f3raxshzyntse1yizBoUpyHuZirdxzNrPnw6uR y4JncESA8ac+4D2PxQnfNxVmqCnwtDMipzDTEDPJX6dYBU0rqyTcUHeeE2fyTjDAoO8R V3FS6cEs215Qw4zjr5cg52Fhr2ddSdqx7L251XuYA09kTr2OfW0QptgTxKsUZmktECBc rXOzvEBR9PW5GQUR7qrxYx3tvlDyiDuDwytQkiqqpNmxltk3wlIroF/ggtP7pFlH872D xodQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=/a5ljRFZhYXEjLddAM9nRcuoh3XdDUt0CimFZregVbQ=; b=mccqvN26uDzbd3RQXeOC7/ASmM+xevAS55y0prrF5j3AxtZw8d4hASpvaC5bo7gZHN aF9hpGVybUu8e9xgMnSFoNlS0fytpjRyszjJnBHUxokx27qUOcPYlMyP9tAEWWg7yeds IQJJnKJ+QWg0GZYUuuZKP88xMODugCcf9UxS7ioAF4gzgTFHRhYO3lBcU9ki+LMVKboQ 0T80FtpozNZXnLnTFYR/hwEqsb+XKdgN97Wwty+neLP5Q0n1+ivgoHw0vvpt2LPlXXc7 80Y2XeFYsT0e139OxXzt4bizmLjoHgzEcwjuO3mdOb3kw+qicRSKDxqTNjR6XoblW35x /Syw== X-Gm-Message-State: AOAM531g6MTIDLWmaSIVxWsVnzOFDG130LEyZDiisfPdnBW52ayX4t7m jlX+aHsKIRgigcmcs8nKk7NFpRhHRnASI+agcOG4vA== X-Received: by 2002:a5d:6241:0:b0:207:ac0e:3549 with SMTP id m1-20020a5d6241000000b00207ac0e3549mr1182184wrv.343.1651281017863; Fri, 29 Apr 2022 18:10:17 -0700 (PDT) MIME-Version: 1.0 References: <20220422162402.147958-1-adrian.hunter@intel.com> <20220422162402.147958-20-adrian.hunter@intel.com> In-Reply-To: From: Ian Rogers Date: Fri, 29 Apr 2022 18:10:05 -0700 Message-ID: Subject: Re: [PATCH RFC 19/21] perf stat: Add requires_cpu flag for uncore To: Namhyung Kim Cc: Adrian Hunter , Arnaldo Carvalho de Melo , Jiri Olsa , Alexey Bayduraev , Leo Yan , linux-kernel Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-17.6 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF, ENV_AND_HDR_SPF_MATCH,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS, USER_IN_DEF_DKIM_WL,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 On Fri, Apr 29, 2022 at 3:58 PM Namhyung Kim wrote: > > On Fri, Apr 22, 2022 at 9:25 AM Adrian Hunter wrote: > > > > Uncore events require a CPU i.e. it cannot be -1. > > > > The evsel system_wide flag is intended for events that should be on every > > CPU, which does not make sense for uncore events because uncore events do > > not map one-to-one with CPUs. > > > > These 2 requirements are not exactly the same, so introduce a new flag > > 'requires_cpu' the uncore case. > > Yeah, I like this change! I was often confused by the two different things. > > Thanks, > Namhyung > > > > > Signed-off-by: Adrian Hunter > > --- > > tools/lib/perf/evlist.c | 4 +++- > > tools/lib/perf/include/internal/evsel.h | 1 + > > tools/perf/builtin-stat.c | 5 +---- > > tools/perf/util/evsel.c | 1 + > > tools/perf/util/parse-events.c | 2 +- > > 5 files changed, 7 insertions(+), 6 deletions(-) > > > > diff --git a/tools/lib/perf/evlist.c b/tools/lib/perf/evlist.c > > index 37dfa9d936a7..9fbcca3fc836 100644 > > --- a/tools/lib/perf/evlist.c > > +++ b/tools/lib/perf/evlist.c > > @@ -42,7 +42,9 @@ static void __perf_evlist__propagate_maps(struct perf_evlist *evlist, > > if (!evsel->own_cpus || evlist->has_user_cpus) { > > perf_cpu_map__put(evsel->cpus); > > evsel->cpus = perf_cpu_map__get(evlist->user_requested_cpus); > > - } else if (!evsel->system_wide && perf_cpu_map__empty(evlist->user_requested_cpus)) { > > + } else if (!evsel->system_wide && > > + !evsel->requires_cpu && > > + perf_cpu_map__empty(evlist->user_requested_cpus)) { > > perf_cpu_map__put(evsel->cpus); > > evsel->cpus = perf_cpu_map__get(evlist->user_requested_cpus); > > } else if (evsel->cpus != evsel->own_cpus) { > > diff --git a/tools/lib/perf/include/internal/evsel.h b/tools/lib/perf/include/internal/evsel.h > > index cfc9ebd7968e..77fbb8b97e5c 100644 > > --- a/tools/lib/perf/include/internal/evsel.h > > +++ b/tools/lib/perf/include/internal/evsel.h > > @@ -50,6 +50,7 @@ struct perf_evsel { > > /* parse modifier helper */ > > int nr_members; > > bool system_wide; Nice cleanup! Could we add some comments here as to what the booleans mean/imply? Thanks, Ian > > + bool requires_cpu; > > int idx; > > }; > > > > diff --git a/tools/perf/builtin-stat.c b/tools/perf/builtin-stat.c > > index a96f106dc93a..8972ae546cfe 100644 > > --- a/tools/perf/builtin-stat.c > > +++ b/tools/perf/builtin-stat.c > > @@ -364,9 +364,6 @@ static int read_counter_cpu(struct evsel *counter, struct timespec *rs, int cpu_ > > if (!counter->supported) > > return -ENOENT; > > > > - if (counter->core.system_wide) > > - nthreads = 1; > > - > > for (thread = 0; thread < nthreads; thread++) { > > struct perf_counts_values *count; > > > > @@ -2224,7 +2221,7 @@ static void setup_system_wide(int forks) > > struct evsel *counter; > > > > evlist__for_each_entry(evsel_list, counter) { > > - if (!counter->core.system_wide && > > + if (!counter->core.requires_cpu && > > strcmp(counter->name, "duration_time")) { > > return; > > } > > diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c > > index 2a1729e7aee4..81bbddb6fbc0 100644 > > --- a/tools/perf/util/evsel.c > > +++ b/tools/perf/util/evsel.c > > @@ -382,6 +382,7 @@ struct evsel *evsel__clone(struct evsel *orig) > > evsel->core.threads = perf_thread_map__get(orig->core.threads); > > evsel->core.nr_members = orig->core.nr_members; > > evsel->core.system_wide = orig->core.system_wide; > > + evsel->core.requires_cpu = orig->core.requires_cpu; > > > > if (orig->name) { > > evsel->name = strdup(orig->name); > > diff --git a/tools/perf/util/parse-events.c b/tools/perf/util/parse-events.c > > index dd84fed698a3..783359017548 100644 > > --- a/tools/perf/util/parse-events.c > > +++ b/tools/perf/util/parse-events.c > > @@ -350,7 +350,7 @@ __add_event(struct list_head *list, int *idx, > > (*idx)++; > > evsel->core.cpus = cpus; > > evsel->core.own_cpus = perf_cpu_map__get(cpus); > > - evsel->core.system_wide = pmu ? pmu->is_uncore : false; > > + evsel->core.requires_cpu = pmu ? pmu->is_uncore : false; > > evsel->auto_merge_stats = auto_merge_stats; > > > > if (name) > > -- > > 2.25.1 > >