Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp1252005pxu; Sat, 24 Oct 2020 05:16:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwEWhT+sERWMBOyFwXEZyhq9eGiRGldRcPT+8neLHj/8F4Nfg7pjQbYp/TfGCtx435Euco3 X-Received: by 2002:a17:906:c1d4:: with SMTP id bw20mr6476752ejb.91.1603541792308; Sat, 24 Oct 2020 05:16:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603541792; cv=none; d=google.com; s=arc-20160816; b=Kgf9qhCV/MoAAJXLR4oibS6UHtx2ANo7WGh+OQNF9Y9Q8lISK9P3TWSv1r6JOVLyE7 LAqf5Yjz2NCUC4B29HFBDOfpZ3Z3Sz7n6gGHUuD8v7r0cRglTUHIpPMq88qilCeUqIo3 JqHT0fKYsxmJE8eGNCAk7cSN1YXEXOI7m2SWt+FjZioZV5YCSnKZgc8pecjcpDrMo7Rr 9pibMXFdJ4AIfJ8+4o8d1AIE6hAyhM1AKUtCa7IiKpyGbfr9aXEMYovuLOcsTGNiL6je C1kFO4nCeuxnckbXmTmEpiZVP9s1Msf0D1b6Cd08ix457VvQM4CZuv3rWLM/tNbtmjMH eGSw== 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=v2Z95jRku8V7za7XXEIUTjbfe9awUIJINmPjgwtq0R4=; b=O5HdpmtMIrJ8LgBcmd2pF1Vrdl364oE0b8yewqJ2p4s/4IYVtVLu/0AM2nFmFPrGsV igP6E+2gY1I0HuGDJSsdoaw1GTCXEZVZSOMyYxIbGLNKm1+S8PGgZ3WbztI5EAuYb5HI BI8JfsaSvJ5uFi4nt+fVGfke+arZSvDPV2TrgT4rVM8YAyDE/wCx0SYhM/mSNCkKVzDH jA33VJE0wZZiccdgrZw/EHuZva1xfojpkvxMzVaE5ag+IJTKFU3U9+//FhoOhzjRsM5F kzYH44y4ijgqLZ3FtxzcdOMtDOURkdCwNwtWstZzJgBw4IQ1T+IF7LapSyJmZ3g9KNdv VFxQ== 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 gt24si2964917ejb.90.2020.10.24.05.15.54; Sat, 24 Oct 2020 05:16:32 -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 S1755468AbgJXAdW (ORCPT + 99 others); Fri, 23 Oct 2020 20:33:22 -0400 Received: from foss.arm.com ([217.140.110.172]:60442 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755382AbgJXAdV (ORCPT ); Fri, 23 Oct 2020 20:33:21 -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 1C867113E; Fri, 23 Oct 2020 17:33:21 -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 6F3043F719; Fri, 23 Oct 2020 17:33:19 -0700 (PDT) Subject: Re: [PATCH v3 18/20] perf arm-spe: Add more sub classes for operation packet 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-19-leo.yan@linaro.org> From: =?UTF-8?Q?Andr=c3=a9_Przywara?= Organization: ARM Ltd. Message-ID: Date: Sat, 24 Oct 2020 01:32:27 +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-19-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: Hi, > For the operation type packet payload with load/store class, it misses > to support these sub classes: > > - A load/store targeting the general-purpose registers; > - A load/store targeting unspecified registers; > - The ARMv8.4 nested virtualisation extension can redirect system > register accesses to a memory page controlled by the hypervisor. > The SPE profiling feature in newer implementations can tag those > memory accesses accordingly. > > Add the bit pattern describing load/store sub classes, so that the perf > tool can decode it properly. > > Inspired by Andre Przywara, refined the commit log and code for more > clear description. > > Co-developed-by: Andre Przywara > Signed-off-by: Leo Yan Reviewed-by: Andre Przywara Cheers, Andre > --- > .../arm-spe-decoder/arm-spe-pkt-decoder.c | 28 +++++++++++++++++-- > 1 file changed, 26 insertions(+), 2 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 59b538563d31..c1a3b0afd1de 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 > @@ -370,11 +370,35 @@ static int arm_spe_pkt_desc_op_type(const struct arm_spe_pkt *packet, > if (ret < 0) > return ret; > } > - } else if (SPE_OP_PKT_LDST_SUBCLASS_GET(payload) == > - SPE_OP_PKT_LDST_SUBCLASS_SIMD_FP) { > + } > + > + switch (SPE_OP_PKT_LDST_SUBCLASS_GET(payload)) { > + case SPE_OP_PKT_LDST_SUBCLASS_SIMD_FP: > ret = arm_spe_pkt_snprintf(&buf, &blen, " SIMD-FP"); > if (ret < 0) > return ret; > + > + break; > + case SPE_OP_PKT_LDST_SUBCLASS_GP_REG: > + ret = arm_spe_pkt_snprintf(&buf, &blen, " GP-REG"); > + if (ret < 0) > + return ret; > + > + break; > + case SPE_OP_PKT_LDST_SUBCLASS_UNSPEC_REG: > + ret = arm_spe_pkt_snprintf(&buf, &blen, " UNSPEC-REG"); > + if (ret < 0) > + return ret; > + > + break; > + case SPE_OP_PKT_LDST_SUBCLASS_NV_SYSREG: > + ret = arm_spe_pkt_snprintf(&buf, &blen, " NV-SYSREG"); > + if (ret < 0) > + return ret; > + > + break; > + default: > + break; > } > > return buf_len - blen; >