Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp866003pxu; Fri, 23 Oct 2020 15:36:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyIjBZ0Suh8Uj082dL+/MDmQTAWpnEZSmALaGVSPnBIuKwUnOVB5RvJASdksFrLQfLkpjh4 X-Received: by 2002:a17:906:7247:: with SMTP id n7mr4180768ejk.174.1603492590801; Fri, 23 Oct 2020 15:36:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603492590; cv=none; d=google.com; s=arc-20160816; b=lkagd4GZOXWYc9EBBawE4/xqqcEdGpgGyfQjyAPsqrUhHDYGWzse1CvGRgIwtZG71i 4B0QVHh69YH1gNlpgtegDv7DhWh1aO0J3OwiIfdc6nYfjrLtoHPG30wF7zs2kr5qRf7T 8z606j9W8uHi8gjiAdidmhvZYrn4OdQqDMD33OnT9O8rp9QSds3PmddRSM+lRdmup2yt IcA+vywA35xWizwlny6zjgrDC7t0FoLyAz4NEegKaHZLc030VBsdVeawUiOiIYQ7TuHu YzMTcE75clVLDkQq4vR5uBAmFYOaa8o5nf/y8gqJWHigGsJtb/eFvnb8OiE/F4wUAkH/ 6trQ== 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=gdN+MrO8E6CI4fmAtAnGCwC0gi1gEdJfXf7Jv9DBvSo=; b=rxTVmUsJAEX7lFFLCCCTSAz022mekZqcx1kKNsPNWB6gDokFeswmU7emOhO0Frq1ae XAdTQNU+KpPCD3u4qtWo3N0LijbqruZeODB3ZiJrhPwuT3alQGLwLp1mtCPRCAkjr47G h8+zDgonHgl+1Euihd9BQiKRJ2UiP8JiZ1M1vScDyNZsig3Ez8OxI+agwkcIqzsW2kVp DIEeELos7J9NGIpGwWZp86h9t34JqZKUFR2xk+hp85KNFAjisBvcpqDzYWKnUhNC1RJ0 wew3npMZTd357fC3NuTNLwB5U56fpPAEgwP9t5lqSrJlpf5jMOQkhxKby6A9m6BxRKpt masQ== 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 q3si1755743edv.144.2020.10.23.15.36.09; Fri, 23 Oct 2020 15:36: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; 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 S1753131AbgJWRLe (ORCPT + 99 others); Fri, 23 Oct 2020 13:11:34 -0400 Received: from foss.arm.com ([217.140.110.172]:57010 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753127AbgJWRLd (ORCPT ); Fri, 23 Oct 2020 13:11:33 -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 C70411FB; Fri, 23 Oct 2020 10:11:32 -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 22F4E3F719; Fri, 23 Oct 2020 10:11:31 -0700 (PDT) Subject: Re: [PATCH v3 15/20] perf arm-spe: Remove size condition checking for events 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-16-leo.yan@linaro.org> From: =?UTF-8?Q?Andr=c3=a9_Przywara?= Organization: ARM Ltd. Message-ID: Date: Fri, 23 Oct 2020 18:10:39 +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-16-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: > In the Armv8 ARM (ARM DDI 0487F.c), chapter "D10.2.6 Events packet", it > describes the event bit is valid with specific payload requirement. For > example, the Last Level cache access event, the bit is defined as: > > E[8], byte 1 bit [0], when SZ == 0b01 , when SZ == 0b10 , > or when SZ == 0b11 > > It requires the payload size is at least 2 bytes, when byte 1 (start > counting from 0) is valid, E[8] (bit 0 in byte 1) can be used for LLC > access event type. For safety, the code checks the condition for > payload size firstly, if meet the requirement for payload size, then > continue to parse event type. > > If review function arm_spe_get_payload(), it has used cast, so any bytes > beyond the valid size have been set to zeros. > > For this reason, we don't need to check payload size anymore afterwards > when parse events, thus this patch removes payload size conditions. > > Suggested-by: Andre Przywara > Signed-off-by: Leo Yan Thanks, that looks better now! Reviewed-by: Andre Przywara Cheers, Andre > --- > .../util/arm-spe-decoder/arm-spe-decoder.c | 9 ++---- > .../arm-spe-decoder/arm-spe-pkt-decoder.c | 30 +++++++++---------- > 2 files changed, 17 insertions(+), 22 deletions(-) > > diff --git a/tools/perf/util/arm-spe-decoder/arm-spe-decoder.c b/tools/perf/util/arm-spe-decoder/arm-spe-decoder.c > index 776b3e6628bb..a5d7509d5daa 100644 > --- a/tools/perf/util/arm-spe-decoder/arm-spe-decoder.c > +++ b/tools/perf/util/arm-spe-decoder/arm-spe-decoder.c > @@ -178,16 +178,13 @@ static int arm_spe_read_record(struct arm_spe_decoder *decoder) > if (payload & BIT(EV_TLB_ACCESS)) > decoder->record.type |= ARM_SPE_TLB_ACCESS; > > - if ((idx == 2 || idx == 4 || idx == 8) && > - (payload & BIT(EV_LLC_MISS))) > + if (payload & BIT(EV_LLC_MISS)) > decoder->record.type |= ARM_SPE_LLC_MISS; > > - if ((idx == 2 || idx == 4 || idx == 8) && > - (payload & BIT(EV_LLC_ACCESS))) > + if (payload & BIT(EV_LLC_ACCESS)) > decoder->record.type |= ARM_SPE_LLC_ACCESS; > > - if ((idx == 2 || idx == 4 || idx == 8) && > - (payload & BIT(EV_REMOTE_ACCESS))) > + if (payload & BIT(EV_REMOTE_ACCESS)) > decoder->record.type |= ARM_SPE_REMOTE_ACCESS; > > if (payload & BIT(EV_MISPRED)) > 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 58a1390b7a43..2cb019999016 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 > @@ -317,22 +317,20 @@ static int arm_spe_pkt_desc_event(const struct arm_spe_pkt *packet, > if (ret < 0) > return ret; > } > - if (packet->index > 1) { > - if (payload & BIT(EV_LLC_ACCESS)) { > - ret = arm_spe_pkt_snprintf(&buf, &blen, " LLC-ACCESS"); > - if (ret < 0) > - return ret; > - } > - if (payload & BIT(EV_LLC_MISS)) { > - ret = arm_spe_pkt_snprintf(&buf, &blen, " LLC-REFILL"); > - if (ret < 0) > - return ret; > - } > - if (payload & BIT(EV_REMOTE_ACCESS)) { > - ret = arm_spe_pkt_snprintf(&buf, &blen, " REMOTE-ACCESS"); > - if (ret < 0) > - return ret; > - } > + if (payload & BIT(EV_LLC_ACCESS)) { > + ret = arm_spe_pkt_snprintf(&buf, &blen, " LLC-ACCESS"); > + if (ret < 0) > + return ret; > + } > + if (payload & BIT(EV_LLC_MISS)) { > + ret = arm_spe_pkt_snprintf(&buf, &blen, " LLC-REFILL"); > + if (ret < 0) > + return ret; > + } > + if (payload & BIT(EV_REMOTE_ACCESS)) { > + ret = arm_spe_pkt_snprintf(&buf, &blen, " REMOTE-ACCESS"); > + if (ret < 0) > + return ret; > } > > return buf_len - blen; >