mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2026-04-03 12:05:13 +02:00
Cortex-X4 erratum 3194386 and Neoverse-V3 erratum 3312417 are identical, with duplicate Kconfig text and some unsightly ifdeffery. While we try to share code behind CONFIG_ARM64_WORKAROUND_SPECULATIVE_SSBS, having separate options results in a fair amount of boilerplate code, and this will only get worse as we expand the set of affected CPUs. To reduce this boilerplate, unify the two behind a common Kconfig option. This removes the duplicate text and Kconfig logic, and removes the need for the intermediate ARM64_WORKAROUND_SPECULATIVE_SSBS option. The set of affected CPUs is described as a list so that this can easily be extended. I've used ARM64_ERRATUM_3194386 (matching the Neoverse-V3 erratum ID) as the common option, matching the way we use ARM64_ERRATUM_1319367 to cover Cortex-A57 erratum 1319537 and Cortex-A72 erratum 1319367. Signed-off-by: Mark Rutland <mark.rutland@arm.com> Cc: James Morse <james.morse@arm.com> Cc: Will Deacon <wilL@kernel.org> Link: https://lore.kernel.org/r/20240603111812.1514101-5-mark.rutland@arm.com Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
70 lines
2.0 KiB
C
70 lines
2.0 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
|
|
#ifndef __ASM_CPUCAPS_H
|
|
#define __ASM_CPUCAPS_H
|
|
|
|
#include <asm/cpucap-defs.h>
|
|
|
|
#ifndef __ASSEMBLY__
|
|
#include <linux/types.h>
|
|
/*
|
|
* Check whether a cpucap is possible at compiletime.
|
|
*/
|
|
static __always_inline bool
|
|
cpucap_is_possible(const unsigned int cap)
|
|
{
|
|
compiletime_assert(__builtin_constant_p(cap),
|
|
"cap must be a constant");
|
|
compiletime_assert(cap < ARM64_NCAPS,
|
|
"cap must be < ARM64_NCAPS");
|
|
|
|
switch (cap) {
|
|
case ARM64_HAS_PAN:
|
|
return IS_ENABLED(CONFIG_ARM64_PAN);
|
|
case ARM64_HAS_EPAN:
|
|
return IS_ENABLED(CONFIG_ARM64_EPAN);
|
|
case ARM64_SVE:
|
|
return IS_ENABLED(CONFIG_ARM64_SVE);
|
|
case ARM64_SME:
|
|
case ARM64_SME2:
|
|
case ARM64_SME_FA64:
|
|
return IS_ENABLED(CONFIG_ARM64_SME);
|
|
case ARM64_HAS_CNP:
|
|
return IS_ENABLED(CONFIG_ARM64_CNP);
|
|
case ARM64_HAS_ADDRESS_AUTH:
|
|
case ARM64_HAS_GENERIC_AUTH:
|
|
return IS_ENABLED(CONFIG_ARM64_PTR_AUTH);
|
|
case ARM64_HAS_GIC_PRIO_MASKING:
|
|
return IS_ENABLED(CONFIG_ARM64_PSEUDO_NMI);
|
|
case ARM64_MTE:
|
|
return IS_ENABLED(CONFIG_ARM64_MTE);
|
|
case ARM64_BTI:
|
|
return IS_ENABLED(CONFIG_ARM64_BTI);
|
|
case ARM64_HAS_TLB_RANGE:
|
|
return IS_ENABLED(CONFIG_ARM64_TLB_RANGE);
|
|
case ARM64_UNMAP_KERNEL_AT_EL0:
|
|
return IS_ENABLED(CONFIG_UNMAP_KERNEL_AT_EL0);
|
|
case ARM64_WORKAROUND_843419:
|
|
return IS_ENABLED(CONFIG_ARM64_ERRATUM_843419);
|
|
case ARM64_WORKAROUND_1742098:
|
|
return IS_ENABLED(CONFIG_ARM64_ERRATUM_1742098);
|
|
case ARM64_WORKAROUND_2645198:
|
|
return IS_ENABLED(CONFIG_ARM64_ERRATUM_2645198);
|
|
case ARM64_WORKAROUND_2658417:
|
|
return IS_ENABLED(CONFIG_ARM64_ERRATUM_2658417);
|
|
case ARM64_WORKAROUND_CAVIUM_23154:
|
|
return IS_ENABLED(CONFIG_CAVIUM_ERRATUM_23154);
|
|
case ARM64_WORKAROUND_NVIDIA_CARMEL_CNP:
|
|
return IS_ENABLED(CONFIG_NVIDIA_CARMEL_CNP_ERRATUM);
|
|
case ARM64_WORKAROUND_REPEAT_TLBI:
|
|
return IS_ENABLED(CONFIG_ARM64_WORKAROUND_REPEAT_TLBI);
|
|
case ARM64_WORKAROUND_SPECULATIVE_SSBS:
|
|
return IS_ENABLED(CONFIG_ARM64_ERRATUM_3194386);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
#endif /* __ASSEMBLY__ */
|
|
|
|
#endif /* __ASM_CPUCAPS_H */
|