Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp734870pxu; Fri, 23 Oct 2020 11:57:50 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxqZI30opAHDWRwp9fyVqQe5ylc/pAYPoZnSGhNy3kZ8gWgGSm8uFEjVz6PEyKUdu/dJLuD X-Received: by 2002:a17:907:9621:: with SMTP id gb33mr3470811ejc.158.1603479469735; Fri, 23 Oct 2020 11:57:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603479469; cv=none; d=google.com; s=arc-20160816; b=yvE+BzJbPsg6ytmCDhAcr3kvqvetGa157HI/Zc6Fz9xopE0ELY3ecjzY/uk65XfAsn y8vYGkrdQC195WDkLXj1XEtnf22T1x5iMnbzh9d1NJF77RpYk1ROEh9EP2BOg5ZDgzAY pKVviYRrHqVdPLlyJ8GMLtTl15HigDKjoisEL1Bp8/YGcsc47uJTI9m1AL9UW5wD//hG o98WkAe1Zv7D54KvuInU19n7XWh0ZD3K7sAlYL5QuIqUahwhtFAVsOPskJXW6ZO05UG/ i/3kA5sQgGj5C9+gfv/cSPBPhP1SYmPCEU4mQw5UgS1ZMZIvlP9Wl6uQIizSsgWNt2nK Qx1Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:organization :from:references:to:subject; bh=roH/+Qgg0HmnSys2luSsfMZq06z3Rk7x6DOBGiABJHo=; b=AIW61GB1jsEixObogew9DhWf4LQgNMD+hQsggCV9pekF10TGs+socmOvEuFNE64vnp GNCK2lSjbpHMU1Ia5ASsZ5p3ATzNBgO5X03zhXiBdb6kQ/CEtXfcjbMMDmblGHIBl8PM UTiPLr/cyLEL2BHMB3m6z4Yj2CXu0oSGpjy6TKlqvzVJF5KUvPzeZxC7mcS8hYpN4lOY k0HjlSIslK7ihqC1m7C7KiRAXC7ca1ZNvzN1sBOz03KX7RvIiiobFmaEQK2O4LABBRjM VxuC2fwWT+RQSvwhqVOOpaKW97F6Eg7AbbZT9PApW0zRea0nlp4C9rFKyfW824LHek+E BBcQ== 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=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j12si1396957edy.197.2020.10.23.11.57.27; Fri, 23 Oct 2020 11:57:49 -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=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753121AbgJWRLN (ORCPT + 99 others); Fri, 23 Oct 2020 13:11:13 -0400 Received: from foss.arm.com ([217.140.110.172]:56990 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753117AbgJWRLM (ORCPT ); Fri, 23 Oct 2020 13:11:12 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 430121FB; Fri, 23 Oct 2020 10:11:12 -0700 (PDT) Received: from [192.168.2.22] (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 90F803F719; Fri, 23 Oct 2020 10:11:10 -0700 (PDT) Subject: Re: [PATCH v3 11/20] perf arm-spe: Add new function arm_spe_pkt_desc_counter() To: Leo Yan , Arnaldo Carvalho de Melo , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Wei Li , James Clark , Al Grant , Dave Martin , linux-kernel@vger.kernel.org References: <20201022145816.14069-1-leo.yan@linaro.org> <20201022145816.14069-12-leo.yan@linaro.org> From: =?UTF-8?Q?Andr=c3=a9_Przywara?= Organization: ARM Ltd. Message-ID: <5845e1fb-57ed-0883-b477-7f3d4a521d31@arm.com> Date: Fri, 23 Oct 2020 18:10:18 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.12.0 MIME-Version: 1.0 In-Reply-To: <20201022145816.14069-12-leo.yan@linaro.org> Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 22/10/2020 15:58, Leo Yan wrote: > This patch moves out the counter packet parsing code from > arm_spe_pkt_desc() to the new function arm_spe_pkt_desc_counter(). > > Signed-off-by: Leo Yan Confirmed by diff'ing '-' vs. '+' to not introduce an actual change. Reviewed-by: Andre Przywara Cheers, Andre > --- > .../arm-spe-decoder/arm-spe-pkt-decoder.c | 64 +++++++++++-------- > 1 file changed, 37 insertions(+), 27 deletions(-) > > diff --git a/tools/perf/util/arm-spe-decoder/arm-spe-pkt-decoder.c b/tools/perf/util/arm-spe-decoder/arm-spe-pkt-decoder.c > index 1fc07c693640..023bcc9be3cc 100644 > --- a/tools/perf/util/arm-spe-decoder/arm-spe-pkt-decoder.c > +++ b/tools/perf/util/arm-spe-decoder/arm-spe-pkt-decoder.c > @@ -293,6 +293,42 @@ static int arm_spe_pkt_desc_addr(const struct arm_spe_pkt *packet, > } > } > > +static int arm_spe_pkt_desc_counter(const struct arm_spe_pkt *packet, > + char *buf, size_t buf_len) > +{ > + u64 payload = packet->payload; > + const char *name = arm_spe_pkt_name(packet->type); > + size_t blen = buf_len; > + int ret; > + > + ret = arm_spe_pkt_snprintf(&buf, &blen, "%s %d ", name, > + (unsigned short)payload); > + if (ret < 0) > + return ret; > + > + switch (packet->index) { > + case 0: > + ret = arm_spe_pkt_snprintf(&buf, &blen, "TOT"); > + if (ret < 0) > + return ret; > + break; > + case 1: > + ret = arm_spe_pkt_snprintf(&buf, &blen, "ISSUE"); > + if (ret < 0) > + return ret; > + break; > + case 2: > + ret = arm_spe_pkt_snprintf(&buf, &blen, "XLAT"); > + if (ret < 0) > + return ret; > + break; > + default: > + break; > + } > + > + return buf_len - blen; > +} > + > int arm_spe_pkt_desc(const struct arm_spe_pkt *packet, char *buf, > size_t buf_len) > { > @@ -435,33 +471,7 @@ int arm_spe_pkt_desc(const struct arm_spe_pkt *packet, char *buf, > return arm_spe_pkt_snprintf(&buf, &blen, "%s 0x%lx el%d", > name, (unsigned long)payload, idx + 1); > case ARM_SPE_COUNTER: > - ret = arm_spe_pkt_snprintf(&buf, &blen, "%s %d ", name, > - (unsigned short)payload); > - if (ret < 0) > - return ret; > - > - switch (idx) { > - case 0: > - ret = arm_spe_pkt_snprintf(&buf, &blen, "TOT"); > - if (ret < 0) > - return ret; > - break; > - case 1: > - ret = arm_spe_pkt_snprintf(&buf, &blen, "ISSUE"); > - if (ret < 0) > - return ret; > - break; > - case 2: > - ret = arm_spe_pkt_snprintf(&buf, &blen, "XLAT"); > - if (ret < 0) > - return ret; > - break; > - default: > - break; > - } > - > - return buf_len - blen; > - > + return arm_spe_pkt_desc_counter(packet, buf, buf_len); > default: > break; > } >