Merge branch 'for-next/errata' into for-next/core
* for-next/errata: arm64: errata: Workaround possible Cortex-A715 [ESR|FAR]_ELx corruption arm64: Add Cortex-715 CPU part definition
This commit is contained in:
commit
f455fb65b4
9 changed files with 88 additions and 0 deletions
|
@ -120,6 +120,8 @@ stable kernels.
|
||||||
+----------------+-----------------+-----------------+-----------------------------+
|
+----------------+-----------------+-----------------+-----------------------------+
|
||||||
| ARM | Cortex-A710 | #2224489 | ARM64_ERRATUM_2224489 |
|
| ARM | Cortex-A710 | #2224489 | ARM64_ERRATUM_2224489 |
|
||||||
+----------------+-----------------+-----------------+-----------------------------+
|
+----------------+-----------------+-----------------+-----------------------------+
|
||||||
|
| ARM | Cortex-A715 | #2645198 | ARM64_ERRATUM_2645198 |
|
||||||
|
+----------------+-----------------+-----------------+-----------------------------+
|
||||||
| ARM | Cortex-X2 | #2119858 | ARM64_ERRATUM_2119858 |
|
| ARM | Cortex-X2 | #2119858 | ARM64_ERRATUM_2119858 |
|
||||||
+----------------+-----------------+-----------------+-----------------------------+
|
+----------------+-----------------+-----------------+-----------------------------+
|
||||||
| ARM | Cortex-X2 | #2224489 | ARM64_ERRATUM_2224489 |
|
| ARM | Cortex-X2 | #2224489 | ARM64_ERRATUM_2224489 |
|
||||||
|
|
|
@ -968,6 +968,22 @@ config ARM64_ERRATUM_2457168
|
||||||
|
|
||||||
If unsure, say Y.
|
If unsure, say Y.
|
||||||
|
|
||||||
|
config ARM64_ERRATUM_2645198
|
||||||
|
bool "Cortex-A715: 2645198: Workaround possible [ESR|FAR]_ELx corruption"
|
||||||
|
default y
|
||||||
|
help
|
||||||
|
This option adds the workaround for ARM Cortex-A715 erratum 2645198.
|
||||||
|
|
||||||
|
If a Cortex-A715 cpu sees a page mapping permissions change from executable
|
||||||
|
to non-executable, it may corrupt the ESR_ELx and FAR_ELx registers on the
|
||||||
|
next instruction abort caused by permission fault.
|
||||||
|
|
||||||
|
Only user-space does executable to non-executable permission transition via
|
||||||
|
mprotect() system call. Workaround the problem by doing a break-before-make
|
||||||
|
TLB invalidation, for all changes to executable user space mappings.
|
||||||
|
|
||||||
|
If unsure, say Y.
|
||||||
|
|
||||||
config CAVIUM_ERRATUM_22375
|
config CAVIUM_ERRATUM_22375
|
||||||
bool "Cavium erratum 22375, 24313"
|
bool "Cavium erratum 22375, 24313"
|
||||||
default y
|
default y
|
||||||
|
|
|
@ -80,6 +80,7 @@
|
||||||
#define ARM_CPU_PART_CORTEX_X1 0xD44
|
#define ARM_CPU_PART_CORTEX_X1 0xD44
|
||||||
#define ARM_CPU_PART_CORTEX_A510 0xD46
|
#define ARM_CPU_PART_CORTEX_A510 0xD46
|
||||||
#define ARM_CPU_PART_CORTEX_A710 0xD47
|
#define ARM_CPU_PART_CORTEX_A710 0xD47
|
||||||
|
#define ARM_CPU_PART_CORTEX_A715 0xD4D
|
||||||
#define ARM_CPU_PART_CORTEX_X2 0xD48
|
#define ARM_CPU_PART_CORTEX_X2 0xD48
|
||||||
#define ARM_CPU_PART_NEOVERSE_N2 0xD49
|
#define ARM_CPU_PART_NEOVERSE_N2 0xD49
|
||||||
#define ARM_CPU_PART_CORTEX_A78C 0xD4B
|
#define ARM_CPU_PART_CORTEX_A78C 0xD4B
|
||||||
|
@ -142,6 +143,7 @@
|
||||||
#define MIDR_CORTEX_X1 MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_CORTEX_X1)
|
#define MIDR_CORTEX_X1 MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_CORTEX_X1)
|
||||||
#define MIDR_CORTEX_A510 MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_CORTEX_A510)
|
#define MIDR_CORTEX_A510 MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_CORTEX_A510)
|
||||||
#define MIDR_CORTEX_A710 MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_CORTEX_A710)
|
#define MIDR_CORTEX_A710 MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_CORTEX_A710)
|
||||||
|
#define MIDR_CORTEX_A715 MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_CORTEX_A715)
|
||||||
#define MIDR_CORTEX_X2 MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_CORTEX_X2)
|
#define MIDR_CORTEX_X2 MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_CORTEX_X2)
|
||||||
#define MIDR_NEOVERSE_N2 MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_NEOVERSE_N2)
|
#define MIDR_NEOVERSE_N2 MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_NEOVERSE_N2)
|
||||||
#define MIDR_CORTEX_A78C MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_CORTEX_A78C)
|
#define MIDR_CORTEX_A78C MIDR_CPU_MODEL(ARM_CPU_IMP_ARM, ARM_CPU_PART_CORTEX_A78C)
|
||||||
|
|
|
@ -49,6 +49,15 @@ extern pte_t huge_ptep_get(pte_t *ptep);
|
||||||
|
|
||||||
void __init arm64_hugetlb_cma_reserve(void);
|
void __init arm64_hugetlb_cma_reserve(void);
|
||||||
|
|
||||||
|
#define huge_ptep_modify_prot_start huge_ptep_modify_prot_start
|
||||||
|
extern pte_t huge_ptep_modify_prot_start(struct vm_area_struct *vma,
|
||||||
|
unsigned long addr, pte_t *ptep);
|
||||||
|
|
||||||
|
#define huge_ptep_modify_prot_commit huge_ptep_modify_prot_commit
|
||||||
|
extern void huge_ptep_modify_prot_commit(struct vm_area_struct *vma,
|
||||||
|
unsigned long addr, pte_t *ptep,
|
||||||
|
pte_t old_pte, pte_t new_pte);
|
||||||
|
|
||||||
#include <asm-generic/hugetlb.h>
|
#include <asm-generic/hugetlb.h>
|
||||||
|
|
||||||
#endif /* __ASM_HUGETLB_H */
|
#endif /* __ASM_HUGETLB_H */
|
||||||
|
|
|
@ -1096,6 +1096,15 @@ static inline bool pud_sect_supported(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#define __HAVE_ARCH_PTEP_MODIFY_PROT_TRANSACTION
|
||||||
|
#define ptep_modify_prot_start ptep_modify_prot_start
|
||||||
|
extern pte_t ptep_modify_prot_start(struct vm_area_struct *vma,
|
||||||
|
unsigned long addr, pte_t *ptep);
|
||||||
|
|
||||||
|
#define ptep_modify_prot_commit ptep_modify_prot_commit
|
||||||
|
extern void ptep_modify_prot_commit(struct vm_area_struct *vma,
|
||||||
|
unsigned long addr, pte_t *ptep,
|
||||||
|
pte_t old_pte, pte_t new_pte);
|
||||||
#endif /* !__ASSEMBLY__ */
|
#endif /* !__ASSEMBLY__ */
|
||||||
|
|
||||||
#endif /* __ASM_PGTABLE_H */
|
#endif /* __ASM_PGTABLE_H */
|
||||||
|
|
|
@ -661,6 +661,13 @@ const struct arm64_cpu_capabilities arm64_errata[] = {
|
||||||
CAP_MIDR_RANGE_LIST(trbe_write_out_of_range_cpus),
|
CAP_MIDR_RANGE_LIST(trbe_write_out_of_range_cpus),
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef CONFIG_ARM64_ERRATUM_2645198
|
||||||
|
{
|
||||||
|
.desc = "ARM erratum 2645198",
|
||||||
|
.capability = ARM64_WORKAROUND_2645198,
|
||||||
|
ERRATA_MIDR_ALL_VERSIONS(MIDR_CORTEX_A715)
|
||||||
|
},
|
||||||
|
#endif
|
||||||
#ifdef CONFIG_ARM64_ERRATUM_2077057
|
#ifdef CONFIG_ARM64_ERRATUM_2077057
|
||||||
{
|
{
|
||||||
.desc = "ARM erratum 2077057",
|
.desc = "ARM erratum 2077057",
|
||||||
|
|
|
@ -559,3 +559,24 @@ bool __init arch_hugetlb_valid_size(unsigned long size)
|
||||||
{
|
{
|
||||||
return __hugetlb_valid_size(size);
|
return __hugetlb_valid_size(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pte_t huge_ptep_modify_prot_start(struct vm_area_struct *vma, unsigned long addr, pte_t *ptep)
|
||||||
|
{
|
||||||
|
if (IS_ENABLED(CONFIG_ARM64_WORKAROUND_2645198) &&
|
||||||
|
cpus_have_const_cap(ARM64_WORKAROUND_2645198)) {
|
||||||
|
/*
|
||||||
|
* Break-before-make (BBM) is required for all user space mappings
|
||||||
|
* when the permission changes from executable to non-executable
|
||||||
|
* in cases where cpu is affected with errata #2645198.
|
||||||
|
*/
|
||||||
|
if (pte_user_exec(READ_ONCE(*ptep)))
|
||||||
|
return huge_ptep_clear_flush(vma, addr, ptep);
|
||||||
|
}
|
||||||
|
return huge_ptep_get_and_clear(vma->vm_mm, addr, ptep);
|
||||||
|
}
|
||||||
|
|
||||||
|
void huge_ptep_modify_prot_commit(struct vm_area_struct *vma, unsigned long addr, pte_t *ptep,
|
||||||
|
pte_t old_pte, pte_t pte)
|
||||||
|
{
|
||||||
|
set_huge_pte_at(vma->vm_mm, addr, ptep, pte);
|
||||||
|
}
|
||||||
|
|
|
@ -1702,3 +1702,24 @@ static int __init prevent_bootmem_remove_init(void)
|
||||||
}
|
}
|
||||||
early_initcall(prevent_bootmem_remove_init);
|
early_initcall(prevent_bootmem_remove_init);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
pte_t ptep_modify_prot_start(struct vm_area_struct *vma, unsigned long addr, pte_t *ptep)
|
||||||
|
{
|
||||||
|
if (IS_ENABLED(CONFIG_ARM64_WORKAROUND_2645198) &&
|
||||||
|
cpus_have_const_cap(ARM64_WORKAROUND_2645198)) {
|
||||||
|
/*
|
||||||
|
* Break-before-make (BBM) is required for all user space mappings
|
||||||
|
* when the permission changes from executable to non-executable
|
||||||
|
* in cases where cpu is affected with errata #2645198.
|
||||||
|
*/
|
||||||
|
if (pte_user_exec(READ_ONCE(*ptep)))
|
||||||
|
return ptep_clear_flush(vma, addr, ptep);
|
||||||
|
}
|
||||||
|
return ptep_get_and_clear(vma->vm_mm, addr, ptep);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ptep_modify_prot_commit(struct vm_area_struct *vma, unsigned long addr, pte_t *ptep,
|
||||||
|
pte_t old_pte, pte_t pte)
|
||||||
|
{
|
||||||
|
set_pte_at(vma->vm_mm, addr, ptep, pte);
|
||||||
|
}
|
||||||
|
|
|
@ -71,6 +71,7 @@ WORKAROUND_2038923
|
||||||
WORKAROUND_2064142
|
WORKAROUND_2064142
|
||||||
WORKAROUND_2077057
|
WORKAROUND_2077057
|
||||||
WORKAROUND_2457168
|
WORKAROUND_2457168
|
||||||
|
WORKAROUND_2645198
|
||||||
WORKAROUND_2658417
|
WORKAROUND_2658417
|
||||||
WORKAROUND_TRBE_OVERWRITE_FILL_MODE
|
WORKAROUND_TRBE_OVERWRITE_FILL_MODE
|
||||||
WORKAROUND_TSB_FLUSH_FAILURE
|
WORKAROUND_TSB_FLUSH_FAILURE
|
||||||
|
|
Loading…
Add table
Reference in a new issue