Received: by 10.192.165.148 with SMTP id m20csp2123612imm; Sun, 6 May 2018 07:29:11 -0700 (PDT) X-Google-Smtp-Source: AB8JxZr+Fyjd1j8nNBWCP8gQuOUr/dKp1FJAN67/aVde1v4AfE3OTcqLHtXYZks9AICpT6Z8JCRF X-Received: by 2002:a17:902:bf45:: with SMTP id u5-v6mr2367503pls.149.1525616951244; Sun, 06 May 2018 07:29:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525616951; cv=none; d=google.com; s=arc-20160816; b=USjiwQXv/VWtQwhnCOuhIXe0yxRItEpPcMoC32K1DDevfk/WjP8/bsVULD21i/r1Zn cSnV4TwofZ8PPHsHIW0TmakUiNlPj6egyTHCwWfMKtTCWrHVWJxhwX65/z3bIB4s71eF wEp49d2lXRbAzJJI9S2H9fDyqnFHvpmVTAQFKj0C1ju9Q6/hzmH0ip+qA8iYr+0lhMW6 G5viaS1j2uLXRSS9+3+ZWg4fDVPGTUHw6wdEadDNFvdbP9hEl6fjEKbtSZITjT4n4y9G 3EhdreKd3ge0WpXAzqPESfyWgzxfYbF+5xl+T0obutbhd1xdUDClIu9JLTfGhikY/DMk Ivvw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=B7g6ot9xinx8LReKVRShjVB2HprYHY1MVurSXE82Hrc=; b=uMtpVexq6zNKI7pQcSY6nNEvo4ytHFaxk0v3jqWMQ8CCI8qj8JYZWFalmdUGWJd4G2 d/qSot3zNw0UKf7LJjPdVq4sSJc2Q08CXmEx6qf+R6FaISV8atF33TWlv9sQjiToR4Bu K9x4ejkAvTf8ZCLDQ6XPl/69xT7VFabHMTnNt88cZ0ql0pMIE/anQUOIRm8kjNOcs2FG dsWdBQMHLBUx9b61ochGr22q6x1FISVL7lj7SuN+g6y+OVT+EHT7Q4KX3ebiAbwGpmKy 0Rh8MhcwLajzl124QgeWoISh+YxIu4VpB6zlgN6CC8l0xQ9dJds3lWlBQlr538R3mECu sJEA== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i12-v6si8681144plt.183.2018.05.06.07.28.45; Sun, 06 May 2018 07:29:11 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751684AbeEFO2j (ORCPT + 99 others); Sun, 6 May 2018 10:28:39 -0400 Received: from mx3-rdu2.redhat.com ([66.187.233.73]:53368 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751230AbeEFO2h (ORCPT ); Sun, 6 May 2018 10:28:37 -0400 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.rdu2.redhat.com [10.11.54.5]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id CB4197D83F; Sun, 6 May 2018 14:28:36 +0000 (UTC) Received: from krava (ovpn-204-48.brq.redhat.com [10.40.204.48]) by smtp.corp.redhat.com (Postfix) with SMTP id D2AE976F3; Sun, 6 May 2018 14:28:31 +0000 (UTC) Date: Sun, 6 May 2018 16:28:30 +0200 From: Jiri Olsa To: 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 , kan.liang@linux.intel.com Subject: [PATCH] perf tools: Fix parser for empty pmu terms case Message-ID: <20180506142830.GA18865@krava> 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> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <87a7tdphyo.fsf@linux.intel.com> User-Agent: Mutt/1.9.1 (2017-09-22) X-Scanned-By: MIMEDefang 2.79 on 10.11.54.5 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.2]); Sun, 06 May 2018 14:28:36 +0000 (UTC) X-Greylist: inspected by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.2]); Sun, 06 May 2018 14:28:36 +0000 (UTC) for IP:'10.11.54.5' DOMAIN:'int-mx05.intmail.prod.int.rdu2.redhat.com' HELO:'smtp.corp.redhat.com' FROM:'jolsa@redhat.com' RCPT:'' Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 --- 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; } | -- 2.13.6