mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-14 08:34:02 +08:00
arm64: cpu: Move errata and feature enable callbacks closer to callers
The cpu errata and feature enable callbacks are only called via their respective arm64_cpu_capabilities structure and therefore shouldn't exist in the global namespace. Move the PAN, RAS and cache maintenance emulation enable callbacks into the same files as their corresponding arm64_cpu_capabilities structures, making them static in the process. Signed-off-by: Will Deacon <will.deacon@arm.com> Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
This commit is contained in:
parent
7c36447ae5
commit
b8925ee2e1
@ -251,10 +251,6 @@ static inline void spin_lock_prefetch(const void *ptr)
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void cpu_enable_pan(const struct arm64_cpu_capabilities *__unused);
|
|
||||||
void cpu_enable_cache_maint_trap(const struct arm64_cpu_capabilities *__unused);
|
|
||||||
void cpu_clear_disr(const struct arm64_cpu_capabilities *__unused);
|
|
||||||
|
|
||||||
extern unsigned long __ro_after_init signal_minsigstksz; /* sigframe size */
|
extern unsigned long __ro_after_init signal_minsigstksz; /* sigframe size */
|
||||||
extern void __init minsigstksz_setup(void);
|
extern void __init minsigstksz_setup(void);
|
||||||
|
|
||||||
|
@ -433,6 +433,12 @@ out_printmsg:
|
|||||||
}
|
}
|
||||||
#endif /* CONFIG_ARM64_SSBD */
|
#endif /* CONFIG_ARM64_SSBD */
|
||||||
|
|
||||||
|
static void __maybe_unused
|
||||||
|
cpu_enable_cache_maint_trap(const struct arm64_cpu_capabilities *__unused)
|
||||||
|
{
|
||||||
|
sysreg_clear_set(sctlr_el1, SCTLR_EL1_UCI, 0);
|
||||||
|
}
|
||||||
|
|
||||||
#define CAP_MIDR_RANGE(model, v_min, r_min, v_max, r_max) \
|
#define CAP_MIDR_RANGE(model, v_min, r_min, v_max, r_max) \
|
||||||
.matches = is_affected_midr_range, \
|
.matches = is_affected_midr_range, \
|
||||||
.midr_range = MIDR_RANGE(model, v_min, r_min, v_max, r_max)
|
.midr_range = MIDR_RANGE(model, v_min, r_min, v_max, r_max)
|
||||||
|
@ -1081,6 +1081,28 @@ static void cpu_enable_ssbs(const struct arm64_cpu_capabilities *__unused)
|
|||||||
}
|
}
|
||||||
#endif /* CONFIG_ARM64_SSBD */
|
#endif /* CONFIG_ARM64_SSBD */
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARM64_PAN
|
||||||
|
static void cpu_enable_pan(const struct arm64_cpu_capabilities *__unused)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* We modify PSTATE. This won't work from irq context as the PSTATE
|
||||||
|
* is discarded once we return from the exception.
|
||||||
|
*/
|
||||||
|
WARN_ON_ONCE(in_interrupt());
|
||||||
|
|
||||||
|
sysreg_clear_set(sctlr_el1, SCTLR_EL1_SPAN, 0);
|
||||||
|
asm(SET_PSTATE_PAN(1));
|
||||||
|
}
|
||||||
|
#endif /* CONFIG_ARM64_PAN */
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARM64_RAS_EXTN
|
||||||
|
static void cpu_clear_disr(const struct arm64_cpu_capabilities *__unused)
|
||||||
|
{
|
||||||
|
/* Firmware may have left a deferred SError in this register. */
|
||||||
|
write_sysreg_s(0, SYS_DISR_EL1);
|
||||||
|
}
|
||||||
|
#endif /* CONFIG_ARM64_RAS_EXTN */
|
||||||
|
|
||||||
static const struct arm64_cpu_capabilities arm64_features[] = {
|
static const struct arm64_cpu_capabilities arm64_features[] = {
|
||||||
{
|
{
|
||||||
.desc = "GIC system register CPU interface",
|
.desc = "GIC system register CPU interface",
|
||||||
@ -1824,9 +1846,3 @@ static int __init enable_mrs_emulation(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
core_initcall(enable_mrs_emulation);
|
core_initcall(enable_mrs_emulation);
|
||||||
|
|
||||||
void cpu_clear_disr(const struct arm64_cpu_capabilities *__unused)
|
|
||||||
{
|
|
||||||
/* Firmware may have left a deferred SError in this register. */
|
|
||||||
write_sysreg_s(0, SYS_DISR_EL1);
|
|
||||||
}
|
|
||||||
|
@ -412,11 +412,6 @@ asmlinkage void __exception do_undefinstr(struct pt_regs *regs)
|
|||||||
BUG_ON(!user_mode(regs));
|
BUG_ON(!user_mode(regs));
|
||||||
}
|
}
|
||||||
|
|
||||||
void cpu_enable_cache_maint_trap(const struct arm64_cpu_capabilities *__unused)
|
|
||||||
{
|
|
||||||
sysreg_clear_set(sctlr_el1, SCTLR_EL1_UCI, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
#define __user_cache_maint(insn, address, res) \
|
#define __user_cache_maint(insn, address, res) \
|
||||||
if (address >= user_addr_max()) { \
|
if (address >= user_addr_max()) { \
|
||||||
res = -EFAULT; \
|
res = -EFAULT; \
|
||||||
|
@ -864,17 +864,3 @@ asmlinkage int __exception do_debug_exception(unsigned long addr,
|
|||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
NOKPROBE_SYMBOL(do_debug_exception);
|
NOKPROBE_SYMBOL(do_debug_exception);
|
||||||
|
|
||||||
#ifdef CONFIG_ARM64_PAN
|
|
||||||
void cpu_enable_pan(const struct arm64_cpu_capabilities *__unused)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* We modify PSTATE. This won't work from irq context as the PSTATE
|
|
||||||
* is discarded once we return from the exception.
|
|
||||||
*/
|
|
||||||
WARN_ON_ONCE(in_interrupt());
|
|
||||||
|
|
||||||
sysreg_clear_set(sctlr_el1, SCTLR_EL1_SPAN, 0);
|
|
||||||
asm(SET_PSTATE_PAN(1));
|
|
||||||
}
|
|
||||||
#endif /* CONFIG_ARM64_PAN */
|
|
||||||
|
Loading…
Reference in New Issue
Block a user