Received: by 10.192.165.148 with SMTP id m20csp2221066imm; Sun, 6 May 2018 09:35:22 -0700 (PDT) X-Google-Smtp-Source: AB8JxZoHR1V6YKvD//5JkIDqXVqCSoiPi+8doC2g1pciSh+RR67O/vEVjAybQt03TdIFSl+zDuoh X-Received: by 2002:a63:6dc3:: with SMTP id i186-v6mr27292042pgc.403.1525624522079; Sun, 06 May 2018 09:35:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525624522; cv=none; d=google.com; s=arc-20160816; b=qoOs6X/00+nDfzbKwJj9fez8wFkMSX8H2sSAkf62e4YynxYpq7FAVQ5/SPicdq4Os+ n4Y4Z4P4j/LOVTGcanYnL7oLobZNuC6loF1vXE4FH6Phsi9f8wlSH1ojLxTin5NqrMUT rzIxSsYAsyjHWDw44chrQtGhhMp+tHxNWedC46aLp0YFQmog6zBqu101oueRfbyoNGQn 5wSg6WrawQaapl3CbQ6lKQGlcq0OUY6//SR2bE/vGwELLb14Bqxp1gqAZIEeUgctAu73 bOQpyEuHyQdDf/dvBZEepcToMQw10KC6z6E08sQ0f8kw+zsv/Kk8YkZFuBAu22jEaBpz Nevg== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=IgAsXxuwAJP1LVfsprz2o7srQAuMSSubKs0JCAK+oYs=; b=Y4Puv4Xz+7cIUrg0SAcfZWAa0J56sZPYDS/O/zDu/H2it/ntkn1YfC4tOwvmhX0nCI m8+T+0chac+AP5b24yyVaGDGpFUdvxDzo00XGVCbgA02pKLO/Zy0MnpHHuISIkCd12t3 SUUhoSLpEK3xlvH9VxI9Ab6BqVotfjQhLaDNDcUCcN93hl7g2R3EVsRj9nI8kcoCiaXX IIl6UnmiDoK5kmwYBHOhsIRJJjYpZO+q96gYNQCSqa+ssfGwasgXx4pRHHlHVlZqHDoa xU8G25S2ye9SXk/WBQE1LLKv5+tmMWHEHctHgPujpiBXA2oefeWjEYbPwvEDX8nq7++x XsEQ== ARC-Authentication-Results: i=1; mx.google.com; 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 i65si21857681pfb.343.2018.05.06.09.35.05; Sun, 06 May 2018 09:35:21 -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; 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 S1751808AbeEFQez (ORCPT + 99 others); Sun, 6 May 2018 12:34:55 -0400 Received: from mga04.intel.com ([192.55.52.120]:15264 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751711AbeEFQew (ORCPT ); Sun, 6 May 2018 12:34:52 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by fmsmga104.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 06 May 2018 09:34:52 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.49,370,1520924400"; d="scan'208";a="52858072" Received: from linux.intel.com ([10.54.29.200]) by fmsmga001.fm.intel.com with ESMTP; 06 May 2018 09:34:51 -0700 Received: from [10.252.209.27] (kliang2-mobl1.ccr.corp.intel.com [10.252.209.27]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by linux.intel.com (Postfix) with ESMTPS id C00935802C8; Sun, 6 May 2018 09:34:49 -0700 (PDT) Subject: Re: [PATCH] perf tools: Fix parser for empty pmu terms case To: Jiri Olsa , Andi Kleen , Arnaldo Carvalho de Melo , Adrian Hunter Cc: Ingo Molnar , Clark Williams , linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, Jiri Olsa , Alexander Shishkin , David Ahern , Namhyung Kim , Peter Zijlstra , Arnaldo Carvalho de Melo References: <20180425160008.3407-1-acme@kernel.org> <20180425160008.3407-6-acme@kernel.org> <448c4e21-8232-3d04-cac4-49b95c8bca3a@intel.com> <20180503103717.GA14776@krava> <0c33d3f9-4b76-c94c-7306-e93e8cd8d4aa@intel.com> <20180504160228.GA25229@krava> <87a7tdphyo.fsf@linux.intel.com> <20180506142830.GA18865@krava> From: "Liang, Kan" Message-ID: <6a9f5464-eae8-c22e-d518-215c4c30019f@linux.intel.com> Date: Sun, 6 May 2018 12:34:48 -0400 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <20180506142830.GA18865@krava> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 5/6/2018 10:28 AM, Jiri Olsa wrote: > On Sat, May 05, 2018 at 08:43:11PM -0700, Andi Kleen wrote: >> Jiri Olsa writes: >> >> Please fix this quickly, PT is currently totally non functional in Linus >> mainline. > > attached.. Kan, could you please test it wrt your latest changes? > > thanks, > jirka > > > --- > Adrian reported broken event parsing for Intel PT: > > $ perf record -e intel_pt//u uname > event syntax error: 'intel_pt//u' > \___ parser error > Run 'perf list' for a list of valid events > > It's caused by recent change in parsing grammar > (see Fixes: for commit). > > Adding special rule with empty terms config to handle > the reported case and moving the common rule code into > new parse_events_pmu function. > > Fixes: 9a4a931ce847 ("perf pmu: Fix pmu events parsing rule") > Reported-by: Adrian Hunter > Cc: Andi Kleen > Link: http://lkml.kernel.org/n/tip-uorb0azuem7b7ydace7cf6vc@git.kernel.org > Signed-off-by: Jiri Olsa The patch looks good to me. I tested my latest change and Intel PT. Both looks good. ./perf stat -e '{unc_m_cas_count.all,unc_m_clockticks}' -a -I 1000 # time counts unit events 1.001556622 95,686 unc_m_cas_count.all 1.001556622 1,900,544,149 unc_m_clockticks 2.002722048 159,598 unc_m_cas_count.all 2.002722048 2,339,028,614 unc_m_clockticks ./perf record -e intel_pt//u [ perf record: Woken up 1 times to write data ] [ perf record: Captured and wrote 0.044 MB perf.data ] Tested-by: Kan Liang > --- > tools/perf/util/parse-events.c | 46 +++++++++++++++++++++++++++++++++++++ > tools/perf/util/parse-events.h | 3 +++ > tools/perf/util/parse-events.y | 51 +++++++++++++----------------------------- > 3 files changed, 65 insertions(+), 35 deletions(-) > > diff --git a/tools/perf/util/parse-events.c b/tools/perf/util/parse-events.c > index 3576aaaa9e4c..7cf326a8effe 100644 > --- a/tools/perf/util/parse-events.c > +++ b/tools/perf/util/parse-events.c > @@ -8,6 +8,7 @@ > #include > #include > #include > +#include > #include "term.h" > #include "../perf.h" > #include "evlist.h" > @@ -1294,6 +1295,51 @@ int parse_events_add_pmu(struct parse_events_state *parse_state, > return evsel ? 0 : -ENOMEM; > } > > +int parse_events_pmu(struct parse_events_state *parse_state, > + struct list_head *list, char *name, > + struct list_head *head_config) > +{ > + struct list_head *orig_terms; > + struct perf_pmu *pmu = NULL; > + char *pattern = NULL; > + int ok = 0; > + > + if (!parse_events_add_pmu(parse_state, list, name, > + head_config, false, false)) > + return 0; > + > + if (parse_events_copy_term_list(head_config, &orig_terms)) > + return -1; > + > + if (asprintf(&pattern, "%s*", name) < 0) > + goto out; > + > + while ((pmu = perf_pmu__scan(pmu)) != NULL) { > + char *tmp = pmu->name; > + > + if (!strncmp(tmp, "uncore_", 7) && > + strncmp(name, "uncore_", 7)) > + tmp += 7; > + if (!fnmatch(pattern, tmp, 0)) { > + struct list_head *terms; > + > + if (parse_events_copy_term_list(orig_terms, &terms)) { > + ok = 0; > + goto out; > + } > + if (!parse_events_add_pmu(parse_state, list, pmu->name, > + terms, true, false)) > + ok++; > + parse_events_terms__delete(terms); > + } > + } > + > +out: > + parse_events_terms__delete(orig_terms); > + free(pattern); > + return ok ? 0 : -1; > +} > + > int parse_events_multi_pmu_add(struct parse_events_state *parse_state, > char *str, struct list_head **listp) > { > diff --git a/tools/perf/util/parse-events.h b/tools/perf/util/parse-events.h > index 4473dac27aee..553fcaf5d23e 100644 > --- a/tools/perf/util/parse-events.h > +++ b/tools/perf/util/parse-events.h > @@ -170,6 +170,9 @@ int parse_events_add_pmu(struct parse_events_state *parse_state, > struct list_head *head_config, > bool auto_merge_stats, > bool use_alias); > +int parse_events_pmu(struct parse_events_state *parse_state, > + struct list_head *list, char *name, > + struct list_head *head_config); > > int parse_events_multi_pmu_add(struct parse_events_state *parse_state, > char *str, > diff --git a/tools/perf/util/parse-events.y b/tools/perf/util/parse-events.y > index 47f6399a309a..d44599bece43 100644 > --- a/tools/perf/util/parse-events.y > +++ b/tools/perf/util/parse-events.y > @@ -8,7 +8,6 @@ > > #define YYDEBUG 1 > > -#include > #include > #include > #include > @@ -226,44 +225,26 @@ event_def: event_pmu | > event_pmu: > PE_NAME '/' event_config '/' > { > - struct list_head *list, *orig_terms, *terms; > + struct list_head *list; > + > + ALLOC_LIST(list); > > - if (parse_events_copy_term_list($3, &orig_terms)) > + if (parse_events_pmu(_parse_state, list, $1, $3)) > YYABORT; > > - ALLOC_LIST(list); > - if (parse_events_add_pmu(_parse_state, list, $1, $3, false, false)) { > - struct perf_pmu *pmu = NULL; > - int ok = 0; > - char *pattern; > - > - if (asprintf(&pattern, "%s*", $1) < 0) > - YYABORT; > - > - while ((pmu = perf_pmu__scan(pmu)) != NULL) { > - char *name = pmu->name; > - > - if (!strncmp(name, "uncore_", 7) && > - strncmp($1, "uncore_", 7)) > - name += 7; > - if (!fnmatch(pattern, name, 0)) { > - if (parse_events_copy_term_list(orig_terms, &terms)) { > - free(pattern); > - YYABORT; > - } > - if (!parse_events_add_pmu(_parse_state, list, pmu->name, terms, true, false)) > - ok++; > - parse_events_terms__delete(terms); > - } > - } > - > - free(pattern); > - > - if (!ok) > - YYABORT; > - } > parse_events_terms__delete($3); > - parse_events_terms__delete(orig_terms); > + $$ = list; > +} > +| > +PE_NAME '/' '/' > +{ > + struct list_head *list; > + > + ALLOC_LIST(list); > + > + if (parse_events_pmu(_parse_state, list, $1, NULL)) > + YYABORT; > + > $$ = list; > } > | >