• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3  * Interface for managing mitigations for Spectre vulnerabilities.
4  *
5  * Copyright (C) 2020 Google LLC
6  * Author: Will Deacon <will@kernel.org>
7  */
8 
9 #ifndef __ASM_SPECTRE_H
10 #define __ASM_SPECTRE_H
11 
12 #include <asm/cpufeature.h>
13 
14 /* Watch out, ordering is important here. */
15 enum mitigation_state {
16 	SPECTRE_UNAFFECTED,
17 	SPECTRE_MITIGATED,
18 	SPECTRE_VULNERABLE,
19 };
20 
21 struct task_struct;
22 
23 enum mitigation_state arm64_get_spectre_v2_state(void);
24 bool has_spectre_v2(const struct arm64_cpu_capabilities *cap, int scope);
25 void spectre_v2_enable_mitigation(const struct arm64_cpu_capabilities *__unused);
26 
27 enum mitigation_state arm64_get_spectre_v4_state(void);
28 bool has_spectre_v4(const struct arm64_cpu_capabilities *cap, int scope);
29 void spectre_v4_enable_mitigation(const struct arm64_cpu_capabilities *__unused);
30 void spectre_v4_enable_task_mitigation(struct task_struct *tsk);
31 
32 enum mitigation_state arm64_get_spectre_bhb_state(void);
33 bool is_spectre_bhb_affected(const struct arm64_cpu_capabilities *entry, int scope);
34 u8 spectre_bhb_loop_affected(int scope);
35 void spectre_bhb_enable_mitigation(const struct arm64_cpu_capabilities *__unused);
36 #endif	/* __ASM_SPECTRE_H */
37