Received: by 2002:a05:7412:bb8d:b0:d7:7d3a:4fe2 with SMTP id js13csp2748133rdb; Fri, 18 Aug 2023 09:19:45 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFcQko4/aHNy49MWuj5oi21IkbgtHN4nI/le4wh6UBahuL1pnDG7GNqFEgE9APSz2EEqMjx X-Received: by 2002:ac2:465a:0:b0:4fd:d9e0:4d79 with SMTP id s26-20020ac2465a000000b004fdd9e04d79mr2030984lfo.6.1692375585311; Fri, 18 Aug 2023 09:19:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1692375585; cv=none; d=google.com; s=arc-20160816; b=yfKpCCMUVkwhgyNWCLPWvrXwIfaH95SX2TBQuauFHLbBvt4e/D30Jx9QIveygbBjWJ Z0AHS8zNcIkJQ4vaPi3UzluINYiDT52lfR1/YYklhGv+noYAUb16M5N+P0xB9Zj5MSJo xejSOvKerjceZwSoe/nro1aDdP85il7Bcqy+dJwQRSn85NDwejbnsoAiBnEFrUDJznZj sHt2lqTEcwTYRCsXRrRAYx9suBKHTnBSEszyRX9hege3ule9IAuMEdrL0TYwZmM2G1zc coUANzClLEj72rJzQ0PnXZDzUiPfY/pl3Ad1EcfI+QDytIwFNGol6K5QyqbDBprlv1VR EU+A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=ypVJuYDxJ2auRHPqKAzhSRIDcfDW2Fnh8IE6awn6aDE=; fh=fL1dFgcA6D8i42osqQ5MYbnK5+jg2r/TNc7j8+7zDKM=; b=XdUT68JP19pyFS3EySwVdM5XRdUFGaGdg9ccZioL8Af2vpnkdFl6BgknOIrxMCpKZJ O9NARou9ZKs62WJLL29Pz/YDotir/0Fv1rtaCbHarxK9nEhO2otxDgVLxhxgEiFF4YrQ 0Kdh100S8PtUHJOXxcAXuwMTX6DZ90KxMaWDGXA/uCw5ETGRGLXafdly1kT7/Mm2bhOy JATDKsyL4RFvp7NqekiNUQoMBk1bztjSp1w5YwhS/7ZQXdQxq2qIjvAfgb+sepoerP0z nKgnohjDw4V7ab2epccnAJZIDC9RJXnWl6tnEo5/lpQwT/SlUnjxd132jDO9y1y+jXvg 0r9Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id u1-20020aa7d981000000b005256d74f242si1597238eds.13.2023.08.18.09.19.19; Fri, 18 Aug 2023 09:19:45 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S1359364AbjHRKqZ (ORCPT + 99 others); Fri, 18 Aug 2023 06:46:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46122 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1376442AbjHRKqF (ORCPT ); Fri, 18 Aug 2023 06:46:05 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 8F73D2D4A; Fri, 18 Aug 2023 03:46:01 -0700 (PDT) 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 8F357D75; Fri, 18 Aug 2023 03:46:41 -0700 (PDT) Received: from [10.163.55.189] (unknown [10.163.55.189]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 924723F762; Fri, 18 Aug 2023 03:45:57 -0700 (PDT) Message-ID: <666d2938-a058-ac63-4222-39efa84e38d7@arm.com> Date: Fri, 18 Aug 2023 16:15:53 +0530 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.13.0 Subject: Re: [PATCH V3 1/3] coresight: etm: Override TRCIDR3.CCITMIN on errata affected cpus Content-Language: en-US To: Suzuki K Poulose , Mike Leach Cc: linux-arm-kernel@lists.infradead.org, Catalin Marinas , Will Deacon , James Clark , Leo Yan , Jonathan Corbet , linux-doc@vger.kernel.org, coresight@lists.linaro.org, linux-kernel@vger.kernel.org References: <20230811034600.944386-1-anshuman.khandual@arm.com> <20230811034600.944386-2-anshuman.khandual@arm.com> <9b9d8928-ab4a-990e-9391-41657f5a54ae@arm.com> <99811457-740c-69a0-7662-dbe24fa2a1c1@arm.com> From: Anshuman Khandual In-Reply-To: <99811457-740c-69a0-7662-dbe24fa2a1c1@arm.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-5.4 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 8/18/23 14:20, Suzuki K Poulose wrote: > On 18/08/2023 09:45, Anshuman Khandual wrote: >> >> >> On 8/11/23 14:33, Mike Leach wrote: >>> Hi Anshuman, >>> >>> A few minor points. >>> >>> On Fri, 11 Aug 2023 at 04:46, Anshuman Khandual >>> wrote: >>>> >>>> This work arounds errata 1490853 on Cortex-A76, and Neoverse-N1, errata >>>> 1491015 on Cortex-A77, errata 1502854 on Cortex-X1, and errata 1619801 on >>>> Neoverse-V1, based affected cpus, where software read for TRCIDR3.CCITMIN >>>> field in ETM gets an wrong value. >>>> >>>> If software uses the value returned by the TRCIDR3.CCITMIN register field, >>>> then it will limit the range which could be used for programming the ETM. >>>> In reality, the ETM could be programmed with a much smaller value than what >>>> is indicated by the TRCIDR3.CCITMIN field and still function correctly. >>>> >>>> If software reads the TRCIDR3.CCITMIN register field, corresponding to the >>>> instruction trace counting minimum threshold, observe the value 0x100 or a >>>> minimum cycle count threshold of 256. The correct value should be 0x4 or a >>>> minimum cycle count threshold of 4. >>>> >>>> This work arounds the problem via storing 4 in drvdata->ccitmin on affected >>>> systems where the TRCIDR3.CCITMIN has been 256, thus preserving cycle count >>>> threshold granularity. >>>> >>>> These errata information has been updated in arch/arm64/silicon-errata.rst, >>>> but without their corresponding configs because these have been implemented >>>> directly in the driver. >>>> >>>> Cc: Catalin Marinas >>>> Cc: Will Deacon >>>> Cc: Suzuki K Poulose >>>> Cc: Mike Leach >>>> Cc: James Clark >>>> Cc: Jonathan Corbet >>>> Cc: linux-doc@vger.kernel.org >>>> Cc: coresight@lists.linaro.org >>>> Cc: linux-arm-kernel@lists.infradead.org >>>> Cc: linux-kernel@vger.kernel.org >>>> Signed-off-by: Anshuman Khandual >>>> --- >>>>   Documentation/arch/arm64/silicon-errata.rst   | 10 +++++ >>>>   .../coresight/coresight-etm4x-core.c          | 37 +++++++++++++++++++ >>>>   2 files changed, 47 insertions(+) >>>> >>>> diff --git a/Documentation/arch/arm64/silicon-errata.rst b/Documentation/arch/arm64/silicon-errata.rst >>>> index bedd3a1d7b42..b08f33eda5f1 100644 >>>> --- a/Documentation/arch/arm64/silicon-errata.rst >>>> +++ b/Documentation/arch/arm64/silicon-errata.rst >>>> @@ -107,6 +107,10 @@ stable kernels. >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | Cortex-A76      | #1463225        | ARM64_ERRATUM_1463225       | >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>> +| ARM            | Cortex-A76      | #1490853        | N/A                         | >>>> ++----------------+-----------------+-----------------+-----------------------------+ >>>> +| ARM            | Cortex-A77      | #1491015        | N/A                         | >>>> ++----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | Cortex-A77      | #1508412        | ARM64_ERRATUM_1508412       | >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | Cortex-A510     | #2051678        | ARM64_ERRATUM_2051678       | >>>> @@ -125,6 +129,8 @@ stable kernels. >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | Cortex-A715     | #2645198        | ARM64_ERRATUM_2645198       | >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>> +| ARM            | Cortex-X1       | #1502854        | N/A                         | >>>> ++----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | Cortex-X2       | #2119858        | ARM64_ERRATUM_2119858       | >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | Cortex-X2       | #2224489        | ARM64_ERRATUM_2224489       | >>>> @@ -133,6 +139,8 @@ stable kernels. >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | Neoverse-N1     | #1349291        | N/A                         | >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>> +| ARM            | Neoverse-N1     | #1490853        | N/A                         | >>>> ++----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | Neoverse-N1     | #1542419        | ARM64_ERRATUM_1542419       | >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | Neoverse-N2     | #2139208        | ARM64_ERRATUM_2139208       | >>>> @@ -141,6 +149,8 @@ stable kernels. >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | Neoverse-N2     | #2253138        | ARM64_ERRATUM_2253138       | >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>> +| ARM            | Neoverse-V1     | #1619801        | N/A                         | >>>> ++----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | MMU-500         | #841119,826419  | N/A                         | >>>>   +----------------+-----------------+-----------------+-----------------------------+ >>>>   | ARM            | MMU-600         | #1076982,1209401| N/A                         | >>> >>> Could these doc changes not go in patch 3? >> >> As Suzuki had explained earlier, will keep this errata documentation here in this patch. >> >>> >>>> diff --git a/drivers/hwtracing/coresight/coresight-etm4x-core.c b/drivers/hwtracing/coresight/coresight-etm4x-core.c >>>> index 703b6fcbb6a5..1f3d29a639ff 100644 >>>> --- a/drivers/hwtracing/coresight/coresight-etm4x-core.c >>>> +++ b/drivers/hwtracing/coresight/coresight-etm4x-core.c >>>> @@ -1150,6 +1150,31 @@ static void cpu_detect_trace_filtering(struct etmv4_drvdata *drvdata) >>>>          drvdata->trfcr = trfcr; >>>>   } >>>> >>>> +/* >>>> + * The following errata on applicable cpu rangess affect the CCITMIN filed >>> >>> s/rangess/ranges >> >> Fixed. >> >>> >>>> + * in TCRIDR3 register. Software read for the field returns 0x100 limiting >>>> + * the cycle threshold granularity, where as the right value should have >>>> + * been 0x4, which is well supported in the hardware. >>>> + */ >>>> +static struct midr_range etm_wrong_ccitmin_cpus[] = { >>>> +       /* Erratum #1490853 - Cortex-A76 */ >>>> +       MIDR_RANGE(MIDR_CORTEX_A76, 0, 0, 4, 0), >>>> +       /* Erratum #1490853 - Neoverse-N1 */ >>>> +       MIDR_RANGE(MIDR_NEOVERSE_N1, 0, 0, 4, 0), >>>> +       /* Erratum #1491015 - Cortex-A77 */ >>>> +       MIDR_RANGE(MIDR_CORTEX_A77, 0, 0, 1, 0), >>>> +       /* Erratum #1502854 - Cortex-X1 */ >>>> +       MIDR_REV(MIDR_CORTEX_X1, 0, 0), >>>> +       /* Erratum #1619801 - Neoverse-V1 */ >>>> +       MIDR_REV(MIDR_NEOVERSE_V1, 0, 0), >>>> +       {}, >>>> +}; >>>> + >>>> +static bool etm4_work_around_wrong_ccitmin(void) >>> >>> This is not the actual work around - perhaps this should be >>> etm4_core_reads_wrong_ccitmin()? >> >> Sounds better, will rename the function. > > Or even move the drvdata->ccitmin == 256 check to this function, > pass in the drvdata as an argument. That way, the function > completes its meaning. i.e., it reads wrong value only if the value > is 256. Something like the following ? --- a/drivers/hwtracing/coresight/coresight-etm4x-core.c +++ b/drivers/hwtracing/coresight/coresight-etm4x-core.c @@ -1159,9 +1159,20 @@ static struct midr_range etm_wrong_ccitmin_cpus[] = { {}, }; -static bool etm4_core_reads_wrong_ccitmin(void) +static bool etm4_core_reads_wrong_ccitmin(struct etmv4_drvdata *drvdata) { - return is_midr_in_range_list(read_cpuid_id(), etm_wrong_ccitmin_cpus); + if (is_midr_in_range_list(read_cpuid_id(), etm_wrong_ccitmin_cpus)) { + /* + * Erratum affected cpus will read 256 as the minimum + * instruction trace cycle counting threshold where as + * the correct value should be 4 instead. Override the + * recorded value for 'drvdata->ccitmin' to workaround + * this problem. + */ + if (drvdata->ccitmin == 256) + return true; + } + return false; } static void etm4_init_arch_data(void *info) @@ -1228,17 +1239,8 @@ static void etm4_init_arch_data(void *info) etmidr3 = etm4x_relaxed_read32(csa, TRCIDR3); /* CCITMIN, bits[11:0] minimum threshold value that can be programmed */ drvdata->ccitmin = FIELD_GET(TRCIDR3_CCITMIN_MASK, etmidr3); - if (etm4_core_reads_wrong_ccitmin()) { - /* - * Erratum affected cpus will read 256 as the minimum - * instruction trace cycle counting threshold where as - * the correct value should be 4 instead. Override the - * recorded value for 'drvdata->ccitmin' to workaround - * this problem. - */ - if (drvdata->ccitmin == 256) - drvdata->ccitmin = 4; - } + if (etm4_core_reads_wrong_ccitmin(drvdata)) + drvdata->ccitmin = 4; /* EXLEVEL_S, bits[19:16] Secure state instruction tracing */ drvdata->s_ex_level = FIELD_GET(TRCIDR3_EXLEVEL_S_MASK, etmidr3);