]> git.hungrycats.org Git - linux/commitdiff
arm64: Avoid Cavium TX2 erratum 219 when switching TTBR
authorMarc Zyngier <marc.zyngier@arm.com>
Tue, 9 Apr 2019 15:22:24 +0000 (16:22 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 29 Oct 2019 08:22:37 +0000 (09:22 +0100)
commit 9405447ef79bc93101373e130f72e9e6cbf17dbb upstream.

As a PRFM instruction racing against a TTBR update can have undesirable
effects on TX2, NOP-out such PRFM on cores that are affected by
the TX2-219 erratum.

Cc: <stable@vger.kernel.org>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Will Deacon <will@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/arm64/include/asm/cpucaps.h
arch/arm64/kernel/cpu_errata.c
arch/arm64/kernel/entry.S

index e81e0cbd728f82e792f1dba23748d04a18378edc..ac1dbca3d0cd3db0dc5396d05d38eb7dfb679da0 100644 (file)
@@ -53,7 +53,8 @@
 #define ARM64_HAS_DCPODP                       43
 #define ARM64_WORKAROUND_1463225               44
 #define ARM64_WORKAROUND_CAVIUM_TX2_219_TVM    45
+#define ARM64_WORKAROUND_CAVIUM_TX2_219_PRFM   46
 
-#define ARM64_NCAPS                            46
+#define ARM64_NCAPS                            47
 
 #endif /* __ASM_CPUCAPS_H */
index 1e43ba5c79b7e4faf475909c9a86c2ad98909229..a86b75782a3505900f4fd840a86a4a738d74f34a 100644 (file)
@@ -851,6 +851,11 @@ const struct arm64_cpu_capabilities arm64_errata[] = {
                .type = ARM64_CPUCAP_LOCAL_CPU_ERRATUM,
                .matches = has_cortex_a76_erratum_1463225,
        },
+       {
+               .desc = "Cavium ThunderX2 erratum 219 (PRFM removal)",
+               .capability = ARM64_WORKAROUND_CAVIUM_TX2_219_PRFM,
+               ERRATA_MIDR_RANGE_LIST(tx2_family_cpus),
+       },
 #endif
        {
        }
index 84a822748c84e58c85fc19a62d63053b97f0b2c2..109894bd319483bc9048d3bf58951de220b2646b 100644 (file)
@@ -1070,7 +1070,9 @@ alternative_insn isb, nop, ARM64_WORKAROUND_QCOM_FALKOR_E1003
 #else
        ldr     x30, =vectors
 #endif
+alternative_if_not ARM64_WORKAROUND_CAVIUM_TX2_219_PRFM
        prfm    plil1strm, [x30, #(1b - tramp_vectors)]
+alternative_else_nop_endif
        msr     vbar_el1, x30
        add     x30, x30, #(1b - tramp_vectors)
        isb