Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3979330pxv; Mon, 19 Jul 2021 13:29:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJykHe3xDYQqz8SvKad10vMpSnO2uXUsy6DSXTgJbcHAmYA2CJXD/Yk0iQOyCWzQ302PBUTg X-Received: by 2002:a17:906:edd2:: with SMTP id sb18mr14238485ejb.82.1626726570588; Mon, 19 Jul 2021 13:29:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626726570; cv=none; d=google.com; s=arc-20160816; b=y75fzibhhwBX08WEhL1waby65bBRMWAmW5hRBk44RH11TDu3HqfzozvAdeN7bgCfgv ZnPUZFJSDeyVfw1ivt3NtnnnwG7ud+muoLjG0PlCgl8yqqxpIe3oL+kQL+Cv2+RM4K/h 4SD2R2NqeSWTLzbIjVWoPSvXeMisffjKX+tU5KHS2XBfo21lX6GxRjjE+ucADz6dYetF I/+ZvKArQmetb2y0GfUtNV/Nh92dSyfdxr+U4NSWIR3sxsY46av4bDm+o/CxqTJ2u4yd Bcxrx5rLEaz7ffpV1t0WyEwFbiqChVOG4Nz3C9Zj108wZURj4+q5n5sSSM7NWKFiMYZG X4Sg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=kcNZ/XE6xPDuF3u3ajPrSNsiNkSWt/dpU0wB6i8pSgg=; b=akFcgXrQgJTuE1nGhueZg9tgeNLFrU2W7SuAX5z13S+NW1e08ul946EV86iD/QJxG8 EtvlcLwLZmhamnJchnILHpbMTraGGD4cYZtt09zILjpR3lUs7NOirC45AZ2orIOSnrjk 8Zul6PK3K0BhpWkPXORuJIHZ26BOOhZ3/Lj1VIPu1fGNE34REAcVO71nMmgFH4HQDdzX kTCqgMaYzaqTod4/crzOVlFMy44QREwa6t2tPn7P9oJsWFocdC3S5XG/xeSbMs8Hnp0o hJpPGX4Nzua+bSTAlBEoSxGr8O+LKiRgqrwIW/pBpH7A+r9iNoD3W3JYKX/NWlBxBWkc jJig== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=H+YZ2LRH; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id qa18si21898289ejc.491.2021.07.19.13.29.06; Mon, 19 Jul 2021 13:29:30 -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; dkim=pass header.i=@linaro.org header.s=google header.b=H+YZ2LRH; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1386464AbhGSTea (ORCPT + 99 others); Mon, 19 Jul 2021 15:34:30 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42864 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1385467AbhGSTAs (ORCPT ); Mon, 19 Jul 2021 15:00:48 -0400 Received: from mail-pg1-x533.google.com (mail-pg1-x533.google.com [IPv6:2607:f8b0:4864:20::533]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 70B5AC06178C for ; Mon, 19 Jul 2021 12:32:12 -0700 (PDT) Received: by mail-pg1-x533.google.com with SMTP id y4so20112269pgl.10 for ; Mon, 19 Jul 2021 12:39:57 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=kcNZ/XE6xPDuF3u3ajPrSNsiNkSWt/dpU0wB6i8pSgg=; b=H+YZ2LRHc1EK4Ihx0pQXR5M6TMgWaov1OLiHhzilMHFZYQGzGrid+x3koK2RhDXBge fd8U6o/kZ8jiqEev4sfgKTwwxg0945l29NryEXTF4qwtjCKw1MuTRIRA9G08DJCWjOGu PZWLYdpC/CHPZUun7TyBF9l+NtoImwhpqhcZX07mz138q/3fhgTg+KyUDLXDLP35jKSX b2SZRT1QpaEQrtlrnLPMJZ9YsWQxYItXIYfJf67JuDTG/uILAQz3JroU31wDSabviwdh eGyrxQx6k5gKFtaJ/3WCl6z/8aJqva/VMeC+yE2J8pqFkPO38VVvOYCe5qHyZOpbD5Ao uGMA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=kcNZ/XE6xPDuF3u3ajPrSNsiNkSWt/dpU0wB6i8pSgg=; b=XJpPtfC6lKtETzxWIoDrEiXm8KyUP5wlmJYKx32aVGxHtlIEwtjDFdDktBkv/z/gqL QMXls7azqbM9SWJFgIV5UuqL6RbHptWpMYfeLm0AtnJbqQg1tFxJ5pYVEa9MsdPpe5dC mKn8uspyrDKmXFQu+BJT5iIO6DFhrca3kwJvzLI3Ud0+nAPjOzW8LDN3QajP/f7txuVE qGffLnzLY3ZBoK+susCnxZXHsdMCs24cZkY6fHDauKoD2vvqk6TZceAOBYPnXiVdMtyZ 9DGlX8H1oIvj3bIU2b8r+7DEf+1rERxT3CLkvAezdI1dy9OrTyH6TAMNelVwwRce2eA1 iMyA== X-Gm-Message-State: AOAM5303JQuEAGCTjhH8Ncdvo8w/Pe2R3fiU8aIjCkSGYiowT4v7s3Op lbgwaKd47hMxW6JlgeQIRShjBA== X-Received: by 2002:a62:6101:0:b029:326:3166:8b0b with SMTP id v1-20020a6261010000b029032631668b0bmr28065521pfb.4.1626723596644; Mon, 19 Jul 2021 12:39:56 -0700 (PDT) Received: from p14s (S0106889e681aac74.cg.shawcable.net. [68.147.0.187]) by smtp.gmail.com with ESMTPSA id y8sm21635325pfe.162.2021.07.19.12.39.54 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 19 Jul 2021 12:39:54 -0700 (PDT) Date: Mon, 19 Jul 2021 13:39:52 -0600 From: Mathieu Poirier To: James Clark Cc: acme@kernel.org, coresight@lists.linaro.org, leo.yan@linaro.org, al.grant@arm.com, branislav.rankov@arm.com, suzuki.poulose@arm.com, anshuman.khandual@arm.com, Mike Leach , 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 5/6] perf cs-etm: Use existing decoder instead of resetting it Message-ID: <20210719193952.GF2255168@p14s> References: <20210713154008.29656-1-james.clark@arm.com> <20210713154008.29656-6-james.clark@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210713154008.29656-6-james.clark@arm.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jul 13, 2021 at 04:40:07PM +0100, James Clark wrote: > When dumping trace, the decoder is continually deleted and recreated to > decode each buffer. To support both formatted and unformatted trace in > a later commit, the decoder will be configured in advance. > > This commit removes the deletion of the decoder and allows the > formatted/unformatted setting to persist. > > Signed-off-by: James Clark > --- Reviewed-by: Mathieu Poirier > tools/perf/util/cs-etm.c | 37 +++++++------------------------------ > 1 file changed, 7 insertions(+), 30 deletions(-) > > diff --git a/tools/perf/util/cs-etm.c b/tools/perf/util/cs-etm.c > index 2d07e52ffd3c..760050ea936d 100644 > --- a/tools/perf/util/cs-etm.c > +++ b/tools/perf/util/cs-etm.c > @@ -508,14 +508,11 @@ static int cs_etm__init_decoder_params(struct cs_etm_decoder_params *d_params, > return ret; > } > > -static void cs_etm__dump_event(struct cs_etm_auxtrace *etm, > +static void cs_etm__dump_event(struct cs_etm_queue *etmq, > struct auxtrace_buffer *buffer) > { > int ret; > const char *color = PERF_COLOR_BLUE; > - struct cs_etm_decoder_params d_params; > - struct cs_etm_trace_params *t_params; > - struct cs_etm_decoder *decoder; > size_t buffer_used = 0; > > fprintf(stdout, "\n"); > @@ -523,29 +520,11 @@ static void cs_etm__dump_event(struct cs_etm_auxtrace *etm, > ". ... CoreSight ETM Trace data: size %zu bytes\n", > buffer->size); > > - /* Use metadata to fill in trace parameters for trace decoder */ > - t_params = zalloc(sizeof(*t_params) * etm->num_cpu); > - > - if (!t_params) > - return; > - > - if (cs_etm__init_trace_params(t_params, etm)) > - goto out_free; > - > - /* Set decoder parameters to simply print the trace packets */ > - if (cs_etm__init_decoder_params(&d_params, NULL, > - CS_ETM_OPERATION_PRINT)) > - goto out_free; > - > - decoder = cs_etm_decoder__new(etm->num_cpu, &d_params, t_params); > - > - if (!decoder) > - goto out_free; > do { > size_t consumed; > > ret = cs_etm_decoder__process_data_block( > - decoder, buffer->offset, > + etmq->decoder, buffer->offset, > &((u8 *)buffer->data)[buffer_used], > buffer->size - buffer_used, &consumed); > if (ret) > @@ -554,10 +533,7 @@ static void cs_etm__dump_event(struct cs_etm_auxtrace *etm, > buffer_used += consumed; > } while (buffer_used < buffer->size); > > - cs_etm_decoder__free(decoder); > - > -out_free: > - zfree(&t_params); > + cs_etm_decoder__reset(etmq->decoder); > } > > static int cs_etm__flush_events(struct perf_session *session, > @@ -769,7 +745,8 @@ static struct cs_etm_queue *cs_etm__alloc_queue(struct cs_etm_auxtrace *etm) > > /* Set decoder parameters to decode trace packets */ > if (cs_etm__init_decoder_params(&d_params, etmq, > - CS_ETM_OPERATION_DECODE)) > + dump_trace ? CS_ETM_OPERATION_PRINT : > + CS_ETM_OPERATION_DECODE)) > goto out_free; > > etmq->decoder = cs_etm_decoder__new(etm->num_cpu, &d_params, t_params); > @@ -2422,7 +2399,7 @@ static void dump_queued_data(struct cs_etm_auxtrace *etm, > for (i = 0; i < etm->queues.nr_queues; ++i) > list_for_each_entry(buf, &etm->queues.queue_array[i].head, list) > if (buf->reference == event->reference) > - cs_etm__dump_event(etm, buf); > + cs_etm__dump_event(etm->queues.queue_array[i].priv, buf); > } > > static int cs_etm__process_auxtrace_event(struct perf_session *session, > @@ -2460,7 +2437,7 @@ static int cs_etm__process_auxtrace_event(struct perf_session *session, > > if (dump_trace) > if (auxtrace_buffer__get_data(buffer, fd)) { > - cs_etm__dump_event(etm, buffer); > + cs_etm__dump_event(etm->queues.queue_array[idx].priv, buffer); > auxtrace_buffer__put_data(buffer); > } > } else if (dump_trace) > -- > 2.28.0 >