xref: /linux/arch/riscv/Kconfig.errata (revision b615879dbfea6cf1236acbc3f2fb25ae84e07071)
1menu "CPU errata selection"
2
3config ERRATA_ANDES
4	bool "Andes AX45MP errata"
5	depends on RISCV_ALTERNATIVE && RISCV_SBI
6	help
7	  All Andes errata Kconfig depend on this Kconfig. Disabling
8	  this Kconfig will disable all Andes errata. Please say "Y"
9	  here if your platform uses Andes CPU cores.
10
11	  Otherwise, please say "N" here to avoid unnecessary overhead.
12
13config ERRATA_ANDES_CMO
14	bool "Apply Andes cache management errata"
15	depends on ERRATA_ANDES && ARCH_R9A07G043
16	select RISCV_DMA_NONCOHERENT
17	default y
18	help
19	  This will apply the cache management errata to handle the
20	  non-standard handling on non-coherent operations on Andes cores.
21
22	  If you don't know what to do here, say "Y".
23
24config ERRATA_MIPS
25	bool "MIPS errata"
26	depends on RISCV_ALTERNATIVE
27	help
28	  All MIPS errata Kconfig depend on this Kconfig. Disabling
29	  this Kconfig will disable all MIPS errata. Please say "Y"
30	  here if your platform uses MIPS CPU cores.
31
32	  Otherwise, please say "N" here to avoid unnecessary overhead.
33
34config ERRATA_MIPS_P8700_PAUSE_OPCODE
35	bool "Fix the PAUSE Opcode for MIPS P8700"
36	depends on ERRATA_MIPS && 64BIT
37	default n
38	help
39	   The RISCV MIPS P8700 uses a different opcode for PAUSE.
40	   It is a 'hint' encoding of the SLLI instruction,
41	   with rd=0, rs1=0 and imm=5. It will behave as a NOP
42	   instruction if no additional behavior beyond that of
43	   SLLI is implemented.
44
45	   If you are not using the P8700 processor, say n.
46
47config ERRATA_SIFIVE
48	bool "SiFive errata"
49	depends on RISCV_ALTERNATIVE
50	help
51	  All SiFive errata Kconfig depend on this Kconfig. Disabling
52	  this Kconfig will disable all SiFive errata. Please say "Y"
53	  here if your platform uses SiFive CPU cores.
54
55	  Otherwise, please say "N" here to avoid unnecessary overhead.
56
57config ERRATA_SIFIVE_CIP_453
58	bool "Apply SiFive errata CIP-453"
59	depends on ERRATA_SIFIVE && 64BIT
60	default y
61	help
62	  This will apply the SiFive CIP-453 errata to add sign extension
63	  to the $badaddr when exception type is instruction page fault
64	  and instruction access fault.
65
66	  If you don't know what to do here, say "Y".
67
68config ERRATA_SIFIVE_CIP_1200
69	bool "Apply SiFive errata CIP-1200"
70	depends on ERRATA_SIFIVE && 64BIT
71	default y
72	help
73	  This will apply the SiFive CIP-1200 errata to repalce all
74	  "sfence.vma addr" with "sfence.vma" to ensure that the addr
75	  has been flushed from TLB.
76
77	  If you don't know what to do here, say "Y".
78
79config ERRATA_STARFIVE_JH7100
80	bool "StarFive JH7100 support"
81	depends on ARCH_STARFIVE
82	depends on !DMA_DIRECT_REMAP
83	depends on NONPORTABLE
84	select DMA_GLOBAL_POOL
85	select RISCV_DMA_NONCOHERENT
86	select RISCV_NONSTANDARD_CACHE_OPS
87	select SIFIVE_CCACHE
88	default n
89	help
90	  The StarFive JH7100 was a test chip for the JH7110 and has
91	  caches that are non-coherent with respect to peripheral DMAs.
92	  It was designed before the Zicbom extension so needs non-standard
93	  cache operations through the SiFive cache controller.
94
95	  Say "Y" if you want to support the BeagleV Starlight and/or
96	  StarFive VisionFive V1 boards.
97
98config ERRATA_THEAD
99	bool "T-HEAD errata"
100	depends on RISCV_ALTERNATIVE
101	help
102	  All T-HEAD errata Kconfig depend on this Kconfig. Disabling
103	  this Kconfig will disable all T-HEAD errata. Please say "Y"
104	  here if your platform uses T-HEAD CPU cores.
105
106	  Otherwise, please say "N" here to avoid unnecessary overhead.
107
108config ERRATA_THEAD_MAE
109	bool "Apply T-Head's memory attribute extension (XTheadMae) errata"
110	depends on ERRATA_THEAD && 64BIT && MMU
111	select RISCV_ALTERNATIVE_EARLY
112	default y
113	help
114	  This will apply the memory attribute extension errata to handle the
115	  non-standard PTE utilization on T-Head SoCs (XTheadMae).
116
117	  If you don't know what to do here, say "Y".
118
119config ERRATA_THEAD_CMO
120	bool "Apply T-Head cache management errata"
121	depends on ERRATA_THEAD && MMU
122	select DMA_DIRECT_REMAP
123	select RISCV_DMA_NONCOHERENT
124	select RISCV_NONSTANDARD_CACHE_OPS
125	default y
126	help
127	  This will apply the cache management errata to handle the
128	  non-standard handling on non-coherent operations on T-Head SoCs.
129
130	  If you don't know what to do here, say "Y".
131
132config ERRATA_THEAD_PMU
133	bool "Apply T-Head PMU errata"
134	depends on ERRATA_THEAD && RISCV_PMU_SBI
135	default y
136	help
137	  The T-Head C9xx cores implement a PMU overflow extension very
138	  similar to the core SSCOFPMF extension.
139
140	  This will apply the overflow errata to handle the non-standard
141	  behaviour via the regular SBI PMU driver and interface.
142
143	  If you don't know what to do here, say "Y".
144
145config ERRATA_THEAD_GHOSTWRITE
146	bool "Apply T-Head Ghostwrite errata"
147	depends on ERRATA_THEAD && RISCV_ISA_XTHEADVECTOR
148	default y
149	help
150	  The T-Head C9xx cores have a vulnerability in the xtheadvector
151	  instruction set. When this errata is enabled, the CPUs will be probed
152	  to determine if they are vulnerable and disable xtheadvector.
153
154	  If you don't know what to do here, say "Y".
155
156endmenu # "CPU errata selection"
157