Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp269613ybg; Mon, 1 Jun 2020 00:26:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxeqWaoCMGdfnpvMJ0jbVyPmsbejfMZsX6u99+JeCbQEhczYBCvMlxArouZZHpwkU9LS6gm X-Received: by 2002:aa7:cd4b:: with SMTP id v11mr6145536edw.356.1590996412934; Mon, 01 Jun 2020 00:26:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590996412; cv=none; d=google.com; s=arc-20160816; b=OfURjNQHh7yikVmkKBE+ZbT6j+MJdjyhVMEi+cyzdxtAvvvsQbL+hqnthusFR116oP 6esmbdHEitb7Uy0s8SL2Y2qmc4FlmrOP6dkwjmazbjcvFSGYE3vl4DJgsj4UJZjyN8P3 XqxmBHLEoTMFyheDr12Rn5U6BmU4VO6euzH8YHmRkRo9a8Eo8KPKvxqFCBJjLzaoaiR9 ASCEkHhqQub7YFEq8uQxsUM9IdDtIyoRoiIiCqjdJvPU0P+JdDA1W+DdsICEmEkT9lAG 8UXFH39AN06tL9nTeTElwJkGt8ee2lrbmQ+r77+GBpPdYIvyRu6Ev4ZJlHct0dx2Hsa3 +6+w== 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:organization:from:references:cc:to:subject:ironport-sdr :ironport-sdr; bh=cyyJ9yZhay/r68+QmWt6LPwBeuRcBUDo9hvWe0L22vk=; b=ZEjsm7DKSqeNQw5gaQy9YkMN9J644edbv5R+/golLML40njS+c9xGSqhaFVrzEz6k4 lCGKvdnoPi8JdR4QMPDWIB+GAb41G67XGB9l5jwzQ2JHYJbkAl7pGsjUYlkg5gL+fKYg SYwYQKWWBwXH438GLJjwBR0mwKt8CPvwwOTpyAA/MZ+D3efX1M4/c6/IF2/thK+FMgdM WCTP9/27bDQJFLrsPNF9fGY2klZ5JldsrSDrwEDD+hVpvz8HqgLtkCEHnQDWosjaAqpK IZibWxQilhSIUMtCPK+VcBYHtPkvBpiR7h9bnmop3tEXRCyqJms5H0X+Qw6FhpzEs88h AAGw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k14si8728093edr.351.2020.06.01.00.26.30; Mon, 01 Jun 2020 00:26:52 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727828AbgFAHYj (ORCPT + 99 others); Mon, 1 Jun 2020 03:24:39 -0400 Received: from mga11.intel.com ([192.55.52.93]:17749 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725283AbgFAHYj (ORCPT ); Mon, 1 Jun 2020 03:24:39 -0400 IronPort-SDR: qlbn9Pj+vQ6h61MTl/hcku8t03IiIospiLnc8ehoMKaaW0OQ61B+Z31ASTvorQgZS8VWnXg13p OZT8WsyIAR/g== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga004.jf.intel.com ([10.7.209.38]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 01 Jun 2020 00:24:37 -0700 IronPort-SDR: h2vSqTd8LK0bbOXqeq0SpRO4Q/fOWr8basEmm0llG5fQ7NVLkTzyJkz7ToU0ZsFvLZFvd5G91V oC9iC0AOfZeQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.73,459,1583222400"; d="scan'208";a="415716184" Received: from ahunter-desktop.fi.intel.com (HELO [10.237.72.157]) ([10.237.72.157]) by orsmga004.jf.intel.com with ESMTP; 01 Jun 2020 00:24:32 -0700 Subject: Re: [PATCH v8 2/3] perf auxtrace: Add four itrace options To: Leo Yan , Arnaldo Carvalho de Melo , Jiri Olsa , Mark Rutland , Alexander Shishkin , Will Deacon , James Clark , Peter Zijlstra , Ingo Molnar , Namhyung Kim , Andi Kleen , Jin Yao , Ian Rogers , Thomas Gleixner , linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Al Grant , Mathieu Poirier , Mike Leach Cc: Tan Xiaojun References: <20200530122442.490-1-leo.yan@linaro.org> <20200530122442.490-3-leo.yan@linaro.org> From: Adrian Hunter Organization: Intel Finland Oy, Registered Address: PL 281, 00181 Helsinki, Business Identity Code: 0357606 - 4, Domiciled in Helsinki Message-ID: Date: Mon, 1 Jun 2020 10:24:00 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.7.0 MIME-Version: 1.0 In-Reply-To: <20200530122442.490-3-leo.yan@linaro.org> Content-Type: text/plain; charset=utf-8 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 30/05/20 3:24 pm, Leo Yan wrote: > From: Tan Xiaojun > > This patch is to add four options to synthesize events which are > described as below: > > 'f': synthesize first level cache events > 'm': synthesize last level cache events > 't': synthesize TLB events > 'a': synthesize remote access events > > This four options will be used by ARM SPE as their first consumer. > > Signed-off-by: Tan Xiaojun > Signed-off-by: James Clark > Signed-off-by: Leo Yan > Tested-by: James Clark Acked-by: Adrian Hunter > --- > tools/perf/Documentation/itrace.txt | 6 +++++- > tools/perf/util/auxtrace.c | 17 +++++++++++++++++ > tools/perf/util/auxtrace.h | 15 ++++++++++++++- > 3 files changed, 36 insertions(+), 2 deletions(-) > > diff --git a/tools/perf/Documentation/itrace.txt b/tools/perf/Documentation/itrace.txt > index 271484754fee..e817179c5027 100644 > --- a/tools/perf/Documentation/itrace.txt > +++ b/tools/perf/Documentation/itrace.txt > @@ -1,5 +1,5 @@ > i synthesize instructions events > - b synthesize branches events > + b synthesize branches events (branch misses for Arm SPE) > c synthesize branches events (calls only) > r synthesize branches events (returns only) > x synthesize transactions events > @@ -9,6 +9,10 @@ > of aux-output (refer to perf record) > e synthesize error events > d create a debug log > + f synthesize first level cache events > + m synthesize last level cache events > + t synthesize TLB events > + a synthesize remote access events > g synthesize a call chain (use with i or x) > G synthesize a call chain on existing event records > l synthesize last branch entries (use with i or x) > diff --git a/tools/perf/util/auxtrace.c b/tools/perf/util/auxtrace.c > index 8cf7d405ee67..fe76a056a179 100644 > --- a/tools/perf/util/auxtrace.c > +++ b/tools/perf/util/auxtrace.c > @@ -1331,6 +1331,11 @@ void itrace_synth_opts__set_default(struct itrace_synth_opts *synth_opts, > synth_opts->pwr_events = true; > synth_opts->other_events = true; > synth_opts->errors = true; > + synth_opts->flc = true; > + synth_opts->llc = true; > + synth_opts->tlb = true; > + synth_opts->remote_access = true; > + > if (no_sample) { > synth_opts->period_type = PERF_ITRACE_PERIOD_INSTRUCTIONS; > synth_opts->period = 1; > @@ -1491,6 +1496,18 @@ int itrace_parse_synth_opts(const struct option *opt, const char *str, > goto out_err; > p = endptr; > break; > + case 'f': > + synth_opts->flc = true; > + break; > + case 'm': > + synth_opts->llc = true; > + break; > + case 't': > + synth_opts->tlb = true; > + break; > + case 'a': > + synth_opts->remote_access = true; > + break; > case ' ': > case ',': > break; > diff --git a/tools/perf/util/auxtrace.h b/tools/perf/util/auxtrace.h > index 0220a2e86c16..142ccf7d34df 100644 > --- a/tools/perf/util/auxtrace.h > +++ b/tools/perf/util/auxtrace.h > @@ -63,6 +63,7 @@ enum itrace_period_type { > * because 'perf inject' will write it out > * @instructions: whether to synthesize 'instructions' events > * @branches: whether to synthesize 'branches' events > + * (branch misses only for Arm SPE) > * @transactions: whether to synthesize events for transactions > * @ptwrites: whether to synthesize events for ptwrites > * @pwr_events: whether to synthesize power events > @@ -78,6 +79,10 @@ enum itrace_period_type { > * @thread_stack: feed branches to the thread_stack > * @last_branch: add branch context to 'instruction' events > * @add_last_branch: add branch context to existing event records > + * @flc: whether to synthesize first level cache events > + * @llc: whether to synthesize last level cache events > + * @tlb: whether to synthesize TLB events > + * @remote_access: whether to synthesize remote access events > * @callchain_sz: maximum callchain size > * @last_branch_sz: branch context size > * @period: 'instructions' events period > @@ -107,6 +112,10 @@ struct itrace_synth_opts { > bool thread_stack; > bool last_branch; > bool add_last_branch; > + bool flc; > + bool llc; > + bool tlb; > + bool remote_access; > unsigned int callchain_sz; > unsigned int last_branch_sz; > unsigned long long period; > @@ -596,7 +605,7 @@ bool auxtrace__evsel_is_auxtrace(struct perf_session *session, > > #define ITRACE_HELP \ > " i: synthesize instructions events\n" \ > -" b: synthesize branches events\n" \ > +" b: synthesize branches events (branch misses for Arm SPE)\n" \ > " c: synthesize branches events (calls only)\n" \ > " r: synthesize branches events (returns only)\n" \ > " x: synthesize transactions events\n" \ > @@ -604,6 +613,10 @@ bool auxtrace__evsel_is_auxtrace(struct perf_session *session, > " p: synthesize power events\n" \ > " e: synthesize error events\n" \ > " d: create a debug log\n" \ > +" f: synthesize first level cache events\n" \ > +" m: synthesize last level cache events\n" \ > +" t: synthesize TLB events\n" \ > +" a: synthesize remote access events\n" \ > " g[len]: synthesize a call chain (use with i or x)\n" \ > " l[len]: synthesize last branch entries (use with i or x)\n" \ > " sNUMBER: skip initial number of events\n" \ >