Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp10422594ybi; Wed, 24 Jul 2019 22:57:26 -0700 (PDT) X-Google-Smtp-Source: APXvYqz6P9QX9mO8ajWeCoVw1oZZcnT6ecs8JmaeMEAZ0koLKj1rEqbMEF3tHYy4YPv6jDClaT4J X-Received: by 2002:a17:902:4283:: with SMTP id h3mr86841931pld.15.1564034246282; Wed, 24 Jul 2019 22:57:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564034246; cv=none; d=google.com; s=arc-20160816; b=S7DFiLmU/F98KpbtVs+BBPq0gxvHtcMDlYmV97LAmY+W+P7JgD+PI6dFBu3n7uzqU8 gem9agCgfRaU5UImhMnl59W9bZMAdlabGyjd9/L2j7YMJfzD+0WcS6JjpndBoCXkQ7ZE 6y1eew1IVQWQtJJqt0hnOrimoWN34s7CdayXM3Vuj8HViy7tv7cNRZas+jFs+80r+J40 yzqfPAboNY2tmgOtMWfbxKu+4aScowSIp/F2tiSww1zwUJkC6Upb108+SWQqJ6jgeCjd ny20/YnKjQsLXJhqX5yRLXIKK5WzrMpW2+w5DY7Y/Pfa2B3cdqmnk44rDpQDLLlFwKl3 cbpw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=mH/uVzVPEg5vnH4HDH3LAtHxtWeFRwUZGILSL8TbgXE=; b=UPFrFNsoDkbUZP7StRhgpzc8FX9hJ0ukTAieuGRAmlNLxi7QhzFH4pbcRb/rUPeWd4 sLZ8+AVRe0/G+z0Wvn6IlE0S4s55XjIz+YdtX4ab1+dfpovtqWbvu/6pBnK0uCEAavre e5+IgfATOPJG5DtRGeLcJv6hxZWk80CpRKKIy7a9V29aeHfqqiPIXp7ZBRsePpLVce9F 9vHeDD7+q9IP6JqOJ9pYaihVQ5TKTHcjw0lsRLbXDHfB4vXMksexo1pvj6Gt/HAkomUd fVAg8FxMp6W3V0TRftOvjZ8gFwUlO5/EN2pgLPOpzZj3n+zmo4hY1jpQ1XbzJSj1W92N r+gA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=wzNTgW0N; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w18si14033322pll.132.2019.07.24.22.57.11; Wed, 24 Jul 2019 22:57:26 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=wzNTgW0N; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2404405AbfGYFke (ORCPT + 99 others); Thu, 25 Jul 2019 01:40:34 -0400 Received: from mail.kernel.org ([198.145.29.99]:55054 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2404379AbfGYFk2 (ORCPT ); Thu, 25 Jul 2019 01:40:28 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 0EEDD22BEB; Thu, 25 Jul 2019 05:40:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1564033227; bh=SL3gkF6IMjPvNC21urBdTFMCD0Q+cniEyq5TPNMr3Jc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=wzNTgW0NNMEf1O4/kQCmGqSrHSIiqi5crmrqy/Hqa8UcVZwxJ1cX6wCoTfkGbRvsX 7GzDdZ3gxZ+TAOiGxn4Asz3Skd17Xy7sCPk+01yDtRIUU5RltG/pEFTsPd+JcEXlhn aXn01/WZ2dapX2yqF7A6lvVdD/TTvfLsU8hZrm1E= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Andi Kleen , Jiri Olsa , Kan Liang , Arnaldo Carvalho de Melo , Sasha Levin Subject: [PATCH 4.19 137/271] perf stat: Fix group lookup for metric group Date: Wed, 24 Jul 2019 21:20:06 +0200 Message-Id: <20190724191706.953768702@linuxfoundation.org> X-Mailer: git-send-email 2.22.0 In-Reply-To: <20190724191655.268628197@linuxfoundation.org> References: <20190724191655.268628197@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org [ Upstream commit 2f87f33f4226523df9c9cc28f9874ea02fcc3d3f ] The metric group code tries to find a group it added earlier in the evlist. Fix the lookup to handle groups with partially overlaps correctly. When a sub string match fails and we reset the match, we have to compare the first element again. I also renamed the find_evsel function to find_evsel_group to make its purpose clearer. With the earlier changes this fixes: Before: % perf stat -M UPI,IPC sleep 1 ... 1,032,922 uops_retired.retire_slots # 1.1 UPI 1,896,096 inst_retired.any 1,896,096 inst_retired.any 1,177,254 cpu_clk_unhalted.thread After: % perf stat -M UPI,IPC sleep 1 ... 1,013,193 uops_retired.retire_slots # 1.1 UPI 932,033 inst_retired.any 932,033 inst_retired.any # 0.9 IPC 1,091,245 cpu_clk_unhalted.thread Signed-off-by: Andi Kleen Acked-by: Jiri Olsa Cc: Kan Liang Fixes: b18f3e365019 ("perf stat: Support JSON metrics in perf stat") Link: http://lkml.kernel.org/r/20190624193711.35241-4-andi@firstfloor.org Signed-off-by: Arnaldo Carvalho de Melo Signed-off-by: Sasha Levin --- tools/perf/util/metricgroup.c | 47 ++++++++++++++++++++++++++--------- 1 file changed, 35 insertions(+), 12 deletions(-) diff --git a/tools/perf/util/metricgroup.c b/tools/perf/util/metricgroup.c index a28f9b5cc4ff..8b3dafe3fac3 100644 --- a/tools/perf/util/metricgroup.c +++ b/tools/perf/util/metricgroup.c @@ -94,26 +94,49 @@ struct egroup { const char *metric_expr; }; -static struct perf_evsel *find_evsel(struct perf_evlist *perf_evlist, - const char **ids, - int idnum, - struct perf_evsel **metric_events) +static bool record_evsel(int *ind, struct perf_evsel **start, + int idnum, + struct perf_evsel **metric_events, + struct perf_evsel *ev) +{ + metric_events[*ind] = ev; + if (*ind == 0) + *start = ev; + if (++*ind == idnum) { + metric_events[*ind] = NULL; + return true; + } + return false; +} + +static struct perf_evsel *find_evsel_group(struct perf_evlist *perf_evlist, + const char **ids, + int idnum, + struct perf_evsel **metric_events) { struct perf_evsel *ev, *start = NULL; int ind = 0; evlist__for_each_entry (perf_evlist, ev) { + if (ev->collect_stat) + continue; if (!strcmp(ev->name, ids[ind])) { - metric_events[ind] = ev; - if (ind == 0) - start = ev; - if (++ind == idnum) { - metric_events[ind] = NULL; + if (record_evsel(&ind, &start, idnum, + metric_events, ev)) return start; - } } else { + /* + * We saw some other event that is not + * in our list of events. Discard + * the whole match and start again. + */ ind = 0; start = NULL; + if (!strcmp(ev->name, ids[ind])) { + if (record_evsel(&ind, &start, idnum, + metric_events, ev)) + return start; + } } } /* @@ -143,8 +166,8 @@ static int metricgroup__setup_events(struct list_head *groups, ret = -ENOMEM; break; } - evsel = find_evsel(perf_evlist, eg->ids, eg->idnum, - metric_events); + evsel = find_evsel_group(perf_evlist, eg->ids, eg->idnum, + metric_events); if (!evsel) { pr_debug("Cannot resolve %s: %s\n", eg->metric_name, eg->metric_expr); -- 2.20.1