From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-15.5 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,INCLUDES_CR_TRAILER,INCLUDES_PATCH,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 708DAC4338F for ; Thu, 22 Jul 2021 21:03:54 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 285ED60EB0 for ; Thu, 22 Jul 2021 21:03:54 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 mail.kernel.org 285ED60EB0 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=kernel.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:References: Message-ID:Subject:Cc:To:From:Date:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=1MhJpX8OrksotZZSFaT1VWUGm3BdBlDGLwWwGs0t5qE=; b=Cj9hosLmh5BGt+ lNYAj9DrkIdwxKfAxZXWvN9VKkMGuGAQs1NKfRqtFJkvT7s7K0UDAE2pojdbn7PJUdywkhPp39Dq8 t3quaZ0/lRi18mcNNbLGX1wEgZ2TTfCikhzhxnClTTL7l0PnmZsAgw5BnPJpP46RNLJWUN47sqKuB Xz8mEgG9uaUNNch4R88T5NM1sdQR0VDVqRbR1OQDoDYQa7C0RXgjs+c40OZHOzoUvxzy0aXTasjow zaCHi2qVZL2BkIT9RT3dlwF6zc37PgyfnB/qlGKPaHiQ0IDmnNGxqByYdn3UwQgVJwOaVLJUqK0N2 T/Xn8bvDoRpwvOa4xHDg==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1m6fpX-002lZP-5Y; Thu, 22 Jul 2021 21:02:07 +0000 Received: from casper.infradead.org ([2001:8b0:10b:1236::1]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1m6fpU-002lYn-6d for linux-arm-kernel@bombadil.infradead.org; Thu, 22 Jul 2021 21:02:04 +0000 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=5j6r4pUdhbyrpsHzUtQVh7PmvS+2wp+1tPKlwXqtgeg=; b=Q44+N7Uu03pwh3JiENHclndx+T BmgwLmaW94enYtYCKSKI2E1xp0c+WV0j6vYZvUQvdsYWDUUnlLiARlcQFh8YcqfctFpEcw86f8hK3 SYPrbVIullE6CMPtOIdkjL28AZARY0NrWw7jW0K2xhA0/VPAGLAxt2Fa4WWdcHKU1B0Q58CI2QbIO vdwiekm5+SAu8G/eGOwBRFgaUljf6g97QM7nLRguDLmXvTWXdyTDJNddJsTaBSB+F0PyUs386qzRS J4KMTCcQJ2TRd2MU2F9fbxTHby3F8KleEqAq7MHTXpVf0XhVAiskA7SzNmH0GlN6HwH9p+cJBHFn2 HGsBjsKA==; Received: from [179.97.37.151] (helo=quaco.ghostprotocols.net) by casper.infradead.org with esmtpsa (Exim 4.94.2 #2 (Red Hat Linux)) id 1m6foH-00AhKk-Ba for linux-arm-kernel@lists.infradead.org; Thu, 22 Jul 2021 21:01:15 +0000 Received: by quaco.ghostprotocols.net (Postfix, from userid 1000) id CF6F1403F2; Thu, 22 Jul 2021 18:00:44 -0300 (-03) Date: Thu, 22 Jul 2021 18:00:44 -0300 From: Arnaldo Carvalho de Melo To: Mathieu Poirier Cc: James Clark , coresight@lists.linaro.org, leo.yan@linaro.org, al.grant@arm.com, suzuki.poulose@arm.com, anshuman.khandual@arm.com, mike.leach@linaro.org, Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , John Garry , Will Deacon , linux-arm-kernel@lists.infradead.org, linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v2 6/6] perf cs-etm: Pass unformatted flag to decoder Message-ID: References: <20210721150202.32065-1-james.clark@arm.com> <20210721150202.32065-7-james.clark@arm.com> <20210721160523.GA2377909@p14s> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20210721160523.GA2377909@p14s> X-Url: http://acmel.wordpress.com X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Em Wed, Jul 21, 2021 at 10:05:23AM -0600, Mathieu Poirier escreveu: > On Wed, Jul 21, 2021 at 04:02:02PM +0100, James Clark wrote: > > The TRBE (Trace Buffer Extension) feature allows a separate trace buffer > > for each trace source, therefore the trace wouldn't need to be > > formatted. The driver was introduced in commit 3fbf7f011f24 > > ("coresight: sink: Add TRBE driver"). > > > > The formatted/unformatted mode is encoded in one of the flags of the > > AUX record. The first AUX record encountered for each event is used to > > determine the mode, and this will persist for the remaining trace that > > is either decoded or dumped. > > > > Signed-off-by: James Clark > > --- > > .../perf/util/cs-etm-decoder/cs-etm-decoder.c | 4 +- > > tools/perf/util/cs-etm.c | 53 ++++++++++++++----- > > 2 files changed, 42 insertions(+), 15 deletions(-) > > > > Reviewed-by: Mathieu Poirier > > Arnaldo, please consider adding this set to your tree. Thanks, applied to perf/core. - Arnaldo > Thanks, > Mathieu > > > diff --git a/tools/perf/util/cs-etm-decoder/cs-etm-decoder.c b/tools/perf/util/cs-etm-decoder/cs-etm-decoder.c > > index ed1f0326f859..9c9039ae6989 100644 > > --- a/tools/perf/util/cs-etm-decoder/cs-etm-decoder.c > > +++ b/tools/perf/util/cs-etm-decoder/cs-etm-decoder.c > > @@ -687,7 +687,7 @@ cs_etm_decoder__create_etm_decoder(struct cs_etm_decoder_params *d_params, > > } > > > > struct cs_etm_decoder * > > -cs_etm_decoder__new(int num_cpu, struct cs_etm_decoder_params *d_params, > > +cs_etm_decoder__new(int decoders, struct cs_etm_decoder_params *d_params, > > struct cs_etm_trace_params t_params[]) > > { > > struct cs_etm_decoder *decoder; > > @@ -732,7 +732,7 @@ cs_etm_decoder__new(int num_cpu, struct cs_etm_decoder_params *d_params, > > /* init raw frame logging if required */ > > cs_etm_decoder__init_raw_frame_logging(d_params, decoder); > > > > - for (i = 0; i < num_cpu; i++) { > > + for (i = 0; i < decoders; i++) { > > ret = cs_etm_decoder__create_etm_decoder(d_params, > > &t_params[i], > > decoder); > > diff --git a/tools/perf/util/cs-etm.c b/tools/perf/util/cs-etm.c > > index 760050ea936d..f4b2bff533f3 100644 > > --- a/tools/perf/util/cs-etm.c > > +++ b/tools/perf/util/cs-etm.c > > @@ -461,13 +461,14 @@ static void cs_etm__set_trace_param_etmv4(struct cs_etm_trace_params *t_params, > > } > > > > static int cs_etm__init_trace_params(struct cs_etm_trace_params *t_params, > > - struct cs_etm_auxtrace *etm) > > + struct cs_etm_auxtrace *etm, > > + int decoders) > > { > > int i; > > u32 etmidr; > > u64 architecture; > > > > - for (i = 0; i < etm->num_cpu; i++) { > > + for (i = 0; i < decoders; i++) { > > architecture = etm->metadata[i][CS_ETM_MAGIC]; > > > > switch (architecture) { > > @@ -488,7 +489,8 @@ static int cs_etm__init_trace_params(struct cs_etm_trace_params *t_params, > > > > static int cs_etm__init_decoder_params(struct cs_etm_decoder_params *d_params, > > struct cs_etm_queue *etmq, > > - enum cs_etm_decoder_operation mode) > > + enum cs_etm_decoder_operation mode, > > + bool formatted) > > { > > int ret = -EINVAL; > > > > @@ -498,7 +500,7 @@ static int cs_etm__init_decoder_params(struct cs_etm_decoder_params *d_params, > > d_params->packet_printer = cs_etm__packet_dump; > > d_params->operation = mode; > > d_params->data = etmq; > > - d_params->formatted = true; > > + d_params->formatted = formatted; > > d_params->fsyncs = false; > > d_params->hsyncs = false; > > d_params->frame_aligned = true; > > @@ -720,11 +722,17 @@ static u32 cs_etm__mem_access(struct cs_etm_queue *etmq, u8 trace_chan_id, > > return len; > > } > > > > -static struct cs_etm_queue *cs_etm__alloc_queue(struct cs_etm_auxtrace *etm) > > +static struct cs_etm_queue *cs_etm__alloc_queue(struct cs_etm_auxtrace *etm, > > + bool formatted) > > { > > struct cs_etm_decoder_params d_params; > > struct cs_etm_trace_params *t_params = NULL; > > struct cs_etm_queue *etmq; > > + /* > > + * Each queue can only contain data from one CPU when unformatted, so only one decoder is > > + * needed. > > + */ > > + int decoders = formatted ? etm->num_cpu : 1; > > > > etmq = zalloc(sizeof(*etmq)); > > if (!etmq) > > @@ -735,21 +743,23 @@ static struct cs_etm_queue *cs_etm__alloc_queue(struct cs_etm_auxtrace *etm) > > goto out_free; > > > > /* Use metadata to fill in trace parameters for trace decoder */ > > - t_params = zalloc(sizeof(*t_params) * etm->num_cpu); > > + t_params = zalloc(sizeof(*t_params) * decoders); > > > > if (!t_params) > > goto out_free; > > > > - if (cs_etm__init_trace_params(t_params, etm)) > > + if (cs_etm__init_trace_params(t_params, etm, decoders)) > > goto out_free; > > > > /* Set decoder parameters to decode trace packets */ > > if (cs_etm__init_decoder_params(&d_params, etmq, > > dump_trace ? CS_ETM_OPERATION_PRINT : > > - CS_ETM_OPERATION_DECODE)) > > + CS_ETM_OPERATION_DECODE, > > + formatted)) > > goto out_free; > > > > - etmq->decoder = cs_etm_decoder__new(etm->num_cpu, &d_params, t_params); > > + etmq->decoder = cs_etm_decoder__new(decoders, &d_params, > > + t_params); > > > > if (!etmq->decoder) > > goto out_free; > > @@ -777,14 +787,15 @@ static struct cs_etm_queue *cs_etm__alloc_queue(struct cs_etm_auxtrace *etm) > > > > static int cs_etm__setup_queue(struct cs_etm_auxtrace *etm, > > struct auxtrace_queue *queue, > > - unsigned int queue_nr) > > + unsigned int queue_nr, > > + bool formatted) > > { > > struct cs_etm_queue *etmq = queue->priv; > > > > if (list_empty(&queue->head) || etmq) > > return 0; > > > > - etmq = cs_etm__alloc_queue(etm); > > + etmq = cs_etm__alloc_queue(etm, formatted); > > > > if (!etmq) > > return -ENOMEM; > > @@ -2430,8 +2441,14 @@ static int cs_etm__process_auxtrace_event(struct perf_session *session, > > if (err) > > return err; > > > > + /* > > + * Knowing if the trace is formatted or not requires a lookup of > > + * the aux record so only works in non-piped mode where data is > > + * queued in cs_etm__queue_aux_records(). Always assume > > + * formatted in piped mode (true). > > + */ > > err = cs_etm__setup_queue(etm, &etm->queues.queue_array[idx], > > - idx); > > + idx, true); > > if (err) > > return err; > > > > @@ -2678,6 +2695,7 @@ static int cs_etm__queue_aux_fragment(struct perf_session *session, off_t file_o > > union perf_event auxtrace_fragment; > > __u64 aux_offset, aux_size; > > __u32 idx; > > + bool formatted; > > > > struct cs_etm_auxtrace *etm = container_of(session->auxtrace, > > struct cs_etm_auxtrace, > > @@ -2745,7 +2763,9 @@ static int cs_etm__queue_aux_fragment(struct perf_session *session, off_t file_o > > return err; > > > > idx = auxtrace_event->idx; > > - return cs_etm__setup_queue(etm, &etm->queues.queue_array[idx], idx); > > + formatted = !(aux_event->flags & PERF_AUX_FLAG_CORESIGHT_FORMAT_RAW); > > + return cs_etm__setup_queue(etm, &etm->queues.queue_array[idx], > > + idx, formatted); > > } > > > > /* Wasn't inside this buffer, but there were no parse errors. 1 == 'not found' */ > > @@ -3034,6 +3054,13 @@ int cs_etm__process_auxtrace_info(union perf_event *event, > > goto err_delete_thread; > > > > etm->data_queued = etm->queues.populated; > > + /* > > + * Print warning in pipe mode, see cs_etm__process_auxtrace_event() and > > + * cs_etm__queue_aux_fragment() for details relating to limitations. > > + */ > > + if (!etm->data_queued) > > + pr_warning("CS ETM warning: Coresight decode and TRBE support requires random file access.\n" > > + "Continuing with best effort decoding in piped mode.\n\n"); > > > > return 0; > > > > -- > > 2.28.0 > > -- - Arnaldo _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel