xref: /linux/arch/riscv/Kconfig (revision 2e05544060b9fef5d4d0e0172944e6956c55080f)
1# SPDX-License-Identifier: GPL-2.0-only
2#
3# For a description of the syntax of this configuration file,
4# see Documentation/kbuild/kconfig-language.rst.
5#
6
7config 64BIT
8	bool
9
10config 32BIT
11	bool
12
13config RISCV
14	def_bool y
15	select ACPI_GENERIC_GSI if ACPI
16	select ACPI_MCFG if (ACPI && PCI)
17	select ACPI_PPTT if ACPI
18	select ACPI_REDUCED_HARDWARE_ONLY if ACPI
19	select ACPI_RIMT if ACPI
20	select ACPI_SPCR_TABLE if ACPI
21	select ARCH_DMA_DEFAULT_COHERENT
22	select ARCH_ENABLE_HUGEPAGE_MIGRATION if HUGETLB_PAGE && MIGRATION
23	select ARCH_ENABLE_MEMORY_HOTPLUG if SPARSEMEM_VMEMMAP
24	select ARCH_ENABLE_SPLIT_PMD_PTLOCK if PGTABLE_LEVELS > 2
25	select ARCH_ENABLE_THP_MIGRATION if TRANSPARENT_HUGEPAGE
26	select ARCH_HAS_BINFMT_FLAT
27	select ARCH_HAS_CC_CAN_LINK
28	select ARCH_HAS_CURRENT_STACK_POINTER
29	select ARCH_HAS_DEBUG_VIRTUAL if MMU
30	select ARCH_HAS_DEBUG_VM_PGTABLE
31	select ARCH_HAS_DEBUG_WX
32	select ARCH_HAS_ELF_CORE_EFLAGS if BINFMT_ELF && ELF_CORE
33	select ARCH_HAS_FAST_MULTIPLIER
34	select ARCH_HAS_FORTIFY_SOURCE
35	select ARCH_HAS_GCOV_PROFILE_ALL
36	select ARCH_HAS_GIGANTIC_PAGE
37	select ARCH_HAS_HW_PTE_YOUNG
38	select ARCH_HAS_KCOV
39	select ARCH_HAS_KERNEL_FPU_SUPPORT if 64BIT && FPU
40	select ARCH_HAS_MEMBARRIER_CALLBACKS
41	select ARCH_HAS_MEMBARRIER_SYNC_CORE
42	select ARCH_HAS_MMIOWB
43	select ARCH_HAS_NON_OVERLAPPING_ADDRESS_SPACE
44	select ARCH_HAS_PMEM_API
45	select ARCH_HAS_PREEMPT_LAZY
46	select ARCH_HAS_PREPARE_SYNC_CORE_CMD
47	select ARCH_HAS_PTDUMP if MMU
48	select ARCH_HAS_PTE_SPECIAL
49	select ARCH_HAS_SET_DIRECT_MAP if MMU
50	select ARCH_HAS_SET_MEMORY if MMU
51	select ARCH_HAS_STRICT_KERNEL_RWX if MMU
52	select ARCH_HAS_STRICT_MODULE_RWX if MMU
53	select ARCH_HAS_SYNC_CORE_BEFORE_USERMODE
54	select ARCH_HAS_SYSCALL_WRAPPER
55	select ARCH_HAS_TICK_BROADCAST if GENERIC_CLOCKEVENTS_BROADCAST
56	select ARCH_HAS_UBSAN
57	select ARCH_HAS_VDSO_ARCH_DATA if HAVE_GENERIC_VDSO
58	select ARCH_HAVE_NMI_SAFE_CMPXCHG
59	select ARCH_KEEP_MEMBLOCK if ACPI || KEXEC
60	select ARCH_MHP_MEMMAP_ON_MEMORY_ENABLE	if 64BIT && MMU
61	select ARCH_OPTIONAL_KERNEL_RWX if ARCH_HAS_STRICT_KERNEL_RWX
62	select ARCH_OPTIONAL_KERNEL_RWX_DEFAULT
63	select ARCH_STACKWALK
64	select ARCH_SUPPORTS_ATOMIC_RMW
65	select ARCH_SUPPORTS_CFI
66	select ARCH_SUPPORTS_DEBUG_PAGEALLOC if MMU
67	select ARCH_SUPPORTS_HUGE_PFNMAP if TRANSPARENT_HUGEPAGE
68	select ARCH_SUPPORTS_HUGETLBFS if MMU
69	select ARCH_SUPPORTS_LTO_CLANG if CMODEL_MEDANY
70	select ARCH_SUPPORTS_LTO_CLANG_THIN
71	select ARCH_SUPPORTS_MSEAL_SYSTEM_MAPPINGS if 64BIT && MMU
72	select ARCH_SUPPORTS_PAGE_TABLE_CHECK if MMU
73	select ARCH_SUPPORTS_PER_VMA_LOCK if MMU
74	select ARCH_SUPPORTS_RT
75	select ARCH_SUPPORTS_SHADOW_CALL_STACK if HAVE_SHADOW_CALL_STACK
76	select ARCH_SUPPORTS_SCHED_MC if SMP
77	select ARCH_USE_CMPXCHG_LOCKREF if 64BIT
78	select ARCH_USE_MEMTEST
79	select ARCH_USE_QUEUED_RWLOCKS
80	select ARCH_USE_SYM_ANNOTATIONS
81	select ARCH_USES_CFI_TRAPS if CFI
82	select ARCH_WANT_BATCHED_UNMAP_TLB_FLUSH if MMU
83	select ARCH_WANT_DEFAULT_TOPDOWN_MMAP_LAYOUT if MMU
84	select ARCH_WANT_FRAME_POINTERS
85	select ARCH_WANT_GENERAL_HUGETLB if !RISCV_ISA_SVNAPOT
86	select ARCH_WANT_HUGE_PMD_SHARE if 64BIT
87	select ARCH_WANT_LD_ORPHAN_WARN
88	select ARCH_WANT_OPTIMIZE_DAX_VMEMMAP
89	select ARCH_WANT_OPTIMIZE_HUGETLB_VMEMMAP
90	select ARCH_WANTS_NO_INSTR
91	select ARCH_WANTS_THP_SWAP if HAVE_ARCH_TRANSPARENT_HUGEPAGE
92	select ARCH_WEAK_RELEASE_ACQUIRE if ARCH_USE_QUEUED_SPINLOCKS
93	select BINFMT_FLAT_NO_DATA_START_OFFSET if !MMU
94	select BUILDTIME_TABLE_SORT if MMU
95	select CLINT_TIMER if RISCV_M_MODE
96	select CLONE_BACKWARDS
97	select COMMON_CLK
98	select CPU_NO_EFFICIENT_FFS if !RISCV_ISA_ZBB
99	select CPU_PM if CPU_IDLE || HIBERNATION || SUSPEND
100	select DYNAMIC_FTRACE if FUNCTION_TRACER
101	select EDAC_SUPPORT
102	select FRAME_POINTER if PERF_EVENTS || (FUNCTION_TRACER && !DYNAMIC_FTRACE)
103	select FTRACE_MCOUNT_USE_PATCHABLE_FUNCTION_ENTRY if DYNAMIC_FTRACE
104	select FUNCTION_ALIGNMENT_8B if DYNAMIC_FTRACE_WITH_CALL_OPS
105	select GENERIC_ARCH_TOPOLOGY
106	select GENERIC_ATOMIC64 if !64BIT
107	select GENERIC_BITREVERSE if HAVE_ARCH_BITREVERSE
108	select GENERIC_CLOCKEVENTS_BROADCAST if SMP
109	select GENERIC_CPU_DEVICES
110	select GENERIC_CPU_VULNERABILITIES
111	select GENERIC_EARLY_IOREMAP
112	select GENERIC_ENTRY
113	select GENERIC_GETTIMEOFDAY if HAVE_GENERIC_VDSO && 64BIT
114	select GENERIC_IDLE_POLL_SETUP
115	select GENERIC_IOREMAP if MMU
116	select HAVE_IOREMAP_PROT if MMU
117	select GENERIC_IRQ_IPI if SMP
118	select GENERIC_IRQ_IPI_MUX if SMP
119	select GENERIC_IRQ_MULTI_HANDLER
120	select GENERIC_IRQ_SHOW
121	select GENERIC_IRQ_SHOW_LEVEL
122	select GENERIC_LIB_DEVMEM_IS_ALLOWED
123	select GENERIC_PENDING_IRQ if SMP
124	select GENERIC_PCI_IOMAP
125	select GENERIC_SCHED_CLOCK
126	select GENERIC_SMP_IDLE_THREAD
127	select HARDIRQS_SW_RESEND
128	select HAS_IOPORT if MMU
129	select HAVE_ALIGNED_STRUCT_PAGE
130	select HAVE_ARCH_AUDITSYSCALL
131	select HAVE_ARCH_BITREVERSE if RISCV_ISA_ZBKB && BITREVERSE
132	select HAVE_ARCH_HUGE_VMALLOC if HAVE_ARCH_HUGE_VMAP
133	select HAVE_ARCH_HUGE_VMAP if MMU && 64BIT
134	select HAVE_ARCH_JUMP_LABEL
135	select HAVE_ARCH_JUMP_LABEL_RELATIVE
136	select HAVE_ARCH_KASAN if MMU && 64BIT
137	select HAVE_ARCH_KASAN_VMALLOC if MMU && 64BIT
138	select HAVE_ARCH_KFENCE if MMU && 64BIT
139	select HAVE_ARCH_KSTACK_ERASE
140	select HAVE_ARCH_KGDB
141	select HAVE_ARCH_KGDB_QXFER_PKT
142	select HAVE_ARCH_MMAP_RND_BITS if MMU
143	select HAVE_ARCH_MMAP_RND_COMPAT_BITS if COMPAT
144	select HAVE_ARCH_RANDOMIZE_KSTACK_OFFSET
145	select HAVE_ARCH_SECCOMP_FILTER
146	select HAVE_ARCH_SOFT_DIRTY if 64BIT && MMU && RISCV_ISA_SVRSW60T59B
147	select HAVE_ARCH_THREAD_STRUCT_WHITELIST
148	select HAVE_ARCH_TRACEHOOK
149	select HAVE_ARCH_TRANSPARENT_HUGEPAGE if 64BIT && MMU
150	select HAVE_ARCH_TRANSPARENT_HUGEPAGE_PUD if 64BIT && MMU
151	select HAVE_ARCH_USERFAULTFD_MINOR if 64BIT && USERFAULTFD
152	select HAVE_ARCH_USERFAULTFD_WP if 64BIT && MMU && USERFAULTFD && RISCV_ISA_SVRSW60T59B
153	select HAVE_ARCH_VMAP_STACK if MMU && 64BIT
154	select HAVE_ASM_MODVERSIONS
155	select HAVE_BUILDTIME_MCOUNT_SORT
156	select HAVE_CONTEXT_TRACKING_USER
157	select HAVE_DEBUG_KMEMLEAK
158	select HAVE_DMA_CONTIGUOUS if MMU
159	select HAVE_DYNAMIC_FTRACE if MMU && (CLANG_SUPPORTS_DYNAMIC_FTRACE || GCC_SUPPORTS_DYNAMIC_FTRACE)
160	select FUNCTION_ALIGNMENT_4B if HAVE_DYNAMIC_FTRACE && RISCV_ISA_C
161	select HAVE_DYNAMIC_FTRACE_WITH_DIRECT_CALLS if HAVE_DYNAMIC_FTRACE_WITH_CALL_OPS
162	select HAVE_DYNAMIC_FTRACE_WITH_CALL_OPS if (DYNAMIC_FTRACE_WITH_ARGS && !CFI)
163	select HAVE_DYNAMIC_FTRACE_WITH_ARGS if HAVE_DYNAMIC_FTRACE
164	select HAVE_FTRACE_GRAPH_FUNC
165	select HAVE_FUNCTION_GRAPH_TRACER if HAVE_DYNAMIC_FTRACE_WITH_ARGS
166	select HAVE_FUNCTION_GRAPH_FREGS
167	select HAVE_FUNCTION_TRACER if HAVE_DYNAMIC_FTRACE
168	select HAVE_EBPF_JIT if MMU
169	select HAVE_GENERIC_TIF_BITS
170	select HAVE_GUP_FAST if MMU
171	select HAVE_FUNCTION_ARG_ACCESS_API
172	select HAVE_FUNCTION_ERROR_INJECTION
173	select HAVE_GCC_PLUGINS
174	select HAVE_GENERIC_VDSO if MMU
175	select HAVE_IRQ_TIME_ACCOUNTING
176	select HAVE_KERNEL_BZIP2 if !EFI_ZBOOT
177	select HAVE_KERNEL_GZIP if !EFI_ZBOOT
178	select HAVE_KERNEL_LZ4 if !EFI_ZBOOT
179	select HAVE_KERNEL_LZMA if !EFI_ZBOOT
180	select HAVE_KERNEL_LZO if !EFI_ZBOOT
181	select HAVE_KERNEL_UNCOMPRESSED if !EFI_ZBOOT
182	select HAVE_KERNEL_ZSTD if !EFI_ZBOOT
183	select HAVE_KERNEL_XZ if !EFI_ZBOOT
184	select HAVE_KPROBES
185	select HAVE_KRETPROBES
186	# https://github.com/ClangBuiltLinux/linux/issues/1881
187	select HAVE_LD_DEAD_CODE_DATA_ELIMINATION if !LD_IS_LLD
188	select HAVE_MOVE_PMD
189	select HAVE_MOVE_PUD
190	select HAVE_PAGE_SIZE_4KB
191	select HAVE_PCI
192	select HAVE_PERF_EVENTS
193	select HAVE_PERF_REGS
194	select HAVE_PERF_USER_STACK_DUMP
195	select HAVE_POSIX_CPU_TIMERS_TASK_WORK
196	select HAVE_PREEMPT_DYNAMIC_KEY
197	select HAVE_REGS_AND_STACK_ACCESS_API
198	select HAVE_RETHOOK
199	select HAVE_RSEQ
200	select HAVE_RUST if RUSTC_SUPPORTS_RISCV && CC_IS_CLANG
201	select HAVE_SAMPLE_FTRACE_DIRECT
202	select HAVE_SAMPLE_FTRACE_DIRECT_MULTI
203	select HAVE_STACKPROTECTOR
204	select HAVE_SYSCALL_TRACEPOINTS
205	select HOTPLUG_PARALLEL if HOTPLUG_CPU
206	select IRQ_DOMAIN
207	select IRQ_FORCED_THREADING
208	select KASAN_VMALLOC if KASAN
209	select LOCK_MM_AND_FIND_VMA
210	select MMU_GATHER_RCU_TABLE_FREE if SMP && MMU
211	select MODULES_USE_ELF_RELA if MODULES
212	select OF
213	select OF_EARLY_FLATTREE
214	select OF_IRQ
215	select PCI_DOMAINS_GENERIC if PCI
216	select PCI_ECAM if (ACPI && PCI)
217	select PCI_MSI if PCI
218	select RELOCATABLE if !MMU && !PHYS_RAM_BASE_FIXED
219	select RISCV_ALTERNATIVE
220	select RISCV_APLIC
221	select RISCV_IMSIC
222	select RISCV_INTC
223	select RISCV_TIMER if RISCV_SBI
224	select SIFIVE_PLIC
225	select SPARSE_IRQ
226	select SYSCTL_EXCEPTION_TRACE
227	select THREAD_INFO_IN_TASK
228	select TRACE_IRQFLAGS_SUPPORT
229	select UACCESS_MEMCPY if !MMU
230	select VDSO_GETRANDOM if HAVE_GENERIC_VDSO && 64BIT
231	select USER_STACKTRACE_SUPPORT
232	select ZONE_DMA32 if 64BIT
233
234config RUSTC_SUPPORTS_RISCV
235	def_bool y
236	depends on 64BIT
237
238config CLANG_SUPPORTS_DYNAMIC_FTRACE
239	def_bool CC_IS_CLANG
240	# https://github.com/ClangBuiltLinux/linux/issues/1817
241	depends on AS_IS_GNU || (AS_IS_LLVM && (LD_IS_LLD || LD_VERSION >= 23600))
242
243config GCC_SUPPORTS_DYNAMIC_FTRACE
244	def_bool CC_IS_GCC
245	depends on $(cc-option,-fpatchable-function-entry=8)
246	depends on CC_HAS_MIN_FUNCTION_ALIGNMENT || !RISCV_ISA_C
247
248config HAVE_SHADOW_CALL_STACK
249	def_bool $(cc-option,-fsanitize=shadow-call-stack)
250	# https://github.com/riscv-non-isa/riscv-elf-psabi-doc/commit/a484e843e6eeb51f0cb7b8819e50da6d2444d769
251	depends on $(ld-option,--no-relax-gp)
252
253# https://github.com/llvm/llvm-project/commit/bbc0f99f3bc96f1db16f649fc21dd18e5b0918f6
254config ARCH_HAS_BROKEN_DWARF5
255	def_bool y
256	# https://github.com/llvm/llvm-project/commit/1df5ea29b43690b6622db2cad7b745607ca4de6a
257	depends on AS_IS_LLVM && AS_VERSION < 180000
258	# https://github.com/llvm/llvm-project/commit/7ffabb61a5569444b5ac9322e22e5471cc5e4a77
259	depends on LD_IS_LLD && LLD_VERSION < 180000
260
261config ARCH_MMAP_RND_BITS_MIN
262	default 18 if 64BIT
263	default 8
264
265config ARCH_MMAP_RND_COMPAT_BITS_MIN
266	default 8
267
268# max bits determined by the following formula:
269#  VA_BITS - PAGE_SHIFT - 3
270config ARCH_MMAP_RND_BITS_MAX
271	default 24 if 64BIT # SV39 based
272	default 17
273
274config ARCH_MMAP_RND_COMPAT_BITS_MAX
275	default 17
276
277# set if we run in machine mode, cleared if we run in supervisor mode
278config RISCV_M_MODE
279	bool "Build a kernel that runs in machine mode"
280	depends on !MMU
281	default y
282	help
283	  Select this option if you want to run the kernel in M-mode,
284	  without the assistance of any other firmware.
285
286# set if we are running in S-mode and can use SBI calls
287config RISCV_SBI
288	bool
289	depends on !RISCV_M_MODE
290	default y
291
292config MMU
293	bool "MMU-based Paged Memory Management Support"
294	default y
295	help
296	  Select if you want MMU-based virtualised addressing space
297	  support by paged memory management. If unsure, say 'Y'.
298
299config KASAN_SHADOW_OFFSET
300	hex
301	depends on KASAN_GENERIC
302	default 0xdfffffff00000000 if 64BIT
303	default 0xffffffff if 32BIT
304
305config ARCH_FLATMEM_ENABLE
306	def_bool !NUMA
307
308config ARCH_SPARSEMEM_ENABLE
309	def_bool y
310	depends on MMU
311	select SPARSEMEM_STATIC if 32BIT && SPARSEMEM
312	select SPARSEMEM_VMEMMAP_ENABLE if 64BIT
313
314config ARCH_SELECT_MEMORY_MODEL
315	def_bool ARCH_SPARSEMEM_ENABLE
316
317config ARCH_SUPPORTS_UPROBES
318	def_bool y
319
320config STACKTRACE_SUPPORT
321	def_bool y
322
323config GENERIC_BUG
324	def_bool y
325	depends on BUG
326	select GENERIC_BUG_RELATIVE_POINTERS if 64BIT
327
328config GENERIC_BUG_RELATIVE_POINTERS
329	bool
330
331config GENERIC_CALIBRATE_DELAY
332	def_bool y
333
334config GENERIC_CSUM
335	def_bool y
336
337config GENERIC_HWEIGHT
338	def_bool y
339
340config FIX_EARLYCON_MEM
341	def_bool MMU
342
343config ILLEGAL_POINTER_VALUE
344	hex
345	default 0 if 32BIT
346	default 0xdead000000000000 if 64BIT
347
348config PGTABLE_LEVELS
349	int
350	default 5 if 64BIT
351	default 2
352
353config LOCKDEP_SUPPORT
354	def_bool y
355
356config RISCV_DMA_NONCOHERENT
357	bool
358	select ARCH_HAS_DMA_PREP_COHERENT
359	select ARCH_HAS_SETUP_DMA_OPS
360	select ARCH_HAS_SYNC_DMA_FOR_CPU
361	select ARCH_HAS_SYNC_DMA_FOR_DEVICE
362	select DMA_BOUNCE_UNALIGNED_KMALLOC if SWIOTLB
363
364config RISCV_NONSTANDARD_CACHE_OPS
365	bool
366	help
367	  This enables function pointer support for non-standard noncoherent
368	  systems to handle cache management.
369
370config AS_HAS_INSN
371	def_bool $(as-instr,.insn 0x100000f)
372
373config AS_HAS_OPTION_ARCH
374	# https://github.com/llvm/llvm-project/commit/9e8ed3403c191ab9c4903e8eeb8f732ff8a43cb4
375	def_bool y
376	depends on $(as-instr, .option arch$(comma) +m)
377
378source "arch/riscv/Kconfig.socs"
379source "arch/riscv/Kconfig.errata"
380
381menu "Platform type"
382
383config NONPORTABLE
384	bool "Allow configurations that result in non-portable kernels"
385	help
386	  RISC-V kernel binaries are compatible between all known systems
387	  whenever possible, but there are some use cases that can only be
388	  satisfied by configurations that result in kernel binaries that are
389	  not portable between systems.
390
391	  Selecting N does not guarantee kernels will be portable to all known
392	  systems.  Selecting any of the options guarded by NONPORTABLE will
393	  result in kernel binaries that are unlikely to be portable between
394	  systems.
395
396	  If unsure, say N.
397
398choice
399	prompt "Base ISA"
400	default ARCH_RV64I
401	help
402	  This selects the base ISA that this kernel will target and must match
403	  the target platform.
404
405config ARCH_RV32I
406	bool "RV32I"
407	depends on NONPORTABLE
408	select 32BIT
409	select GENERIC_LIB_UCMPDI2
410
411config ARCH_RV64I
412	bool "RV64I"
413	select 64BIT
414	select ARCH_SUPPORTS_INT128 if CC_HAS_INT128
415	select SWIOTLB if MMU
416
417endchoice
418
419# We must be able to map all physical memory into the kernel, but the compiler
420# is still a bit more efficient when generating code if it's setup in a manner
421# such that it can only map 2GiB of memory.
422choice
423	prompt "Kernel Code Model"
424	default CMODEL_MEDLOW if 32BIT
425	default CMODEL_MEDANY if 64BIT
426
427	config CMODEL_MEDLOW
428		bool "medium low code model"
429	config CMODEL_MEDANY
430		bool "medium any code model"
431endchoice
432
433config MODULE_SECTIONS
434	bool
435	select HAVE_MOD_ARCH_SPECIFIC
436
437config SMP
438	bool "Symmetric Multi-Processing"
439	help
440	  This enables support for systems with more than one CPU.  If
441	  you say N here, the kernel will run on single and
442	  multiprocessor machines, but will use only one CPU of a
443	  multiprocessor machine. If you say Y here, the kernel will run
444	  on many, but not all, single processor machines. On a single
445	  processor machine, the kernel will run faster if you say N
446	  here.
447
448	  If you don't know what to do here, say N.
449
450config NR_CPUS
451	int "Maximum number of CPUs (2-512)"
452	depends on SMP
453	range 2 512 if !RISCV_SBI_V01
454	range 2 32 if RISCV_SBI_V01 && 32BIT
455	range 2 64 if RISCV_SBI_V01 && 64BIT
456	default "32" if 32BIT
457	default "64" if 64BIT
458
459config HOTPLUG_CPU
460	bool "Support for hot-pluggable CPUs"
461	depends on SMP
462	select GENERIC_IRQ_MIGRATION
463	help
464
465	  Say Y here to experiment with turning CPUs off and on.  CPUs
466	  can be controlled through /sys/devices/system/cpu.
467
468	  Say N if you want to disable CPU hotplug.
469
470choice
471	prompt "CPU Tuning"
472	default TUNE_GENERIC
473
474config TUNE_GENERIC
475	bool "generic"
476
477endchoice
478
479# Common NUMA Features
480config NUMA
481	bool "NUMA Memory Allocation and Scheduler Support"
482	depends on SMP && MMU
483	select ARCH_SUPPORTS_NUMA_BALANCING
484	select GENERIC_ARCH_NUMA
485	select HAVE_SETUP_PER_CPU_AREA
486	select NEED_PER_CPU_EMBED_FIRST_CHUNK
487	select NEED_PER_CPU_PAGE_FIRST_CHUNK
488	select OF_NUMA
489	select USE_PERCPU_NUMA_NODE_ID
490	help
491	  Enable NUMA (Non-Uniform Memory Access) support.
492
493	  The kernel will try to allocate memory used by a CPU on the
494	  local memory of the CPU and add some more NUMA awareness to the kernel.
495
496config NODES_SHIFT
497	int "Maximum NUMA Nodes (as a power of 2)"
498	range 1 10
499	default "2"
500	depends on NUMA
501	help
502	  Specify the maximum number of NUMA Nodes available on the target
503	  system.  Increases memory reserved to accommodate various tables.
504
505choice
506	prompt "RISC-V spinlock type"
507	default RISCV_COMBO_SPINLOCKS
508
509config RISCV_TICKET_SPINLOCKS
510	bool "Using ticket spinlock"
511
512config RISCV_QUEUED_SPINLOCKS
513	bool "Using queued spinlock"
514	depends on SMP && MMU && NONPORTABLE
515	select ARCH_USE_QUEUED_SPINLOCKS
516	help
517	  The queued spinlock implementation requires the forward progress
518	  guarantee of cmpxchg()/xchg() atomic operations: CAS with Zabha or
519	  LR/SC with Ziccrse provide such guarantee.
520
521	  Select this if and only if Zabha or Ziccrse is available on your
522	  platform, RISCV_QUEUED_SPINLOCKS must not be selected for platforms
523	  without one of those extensions.
524
525	  If unsure, select RISCV_COMBO_SPINLOCKS, which will use qspinlocks
526	  when supported and otherwise ticket spinlocks.
527
528config RISCV_COMBO_SPINLOCKS
529	bool "Using combo spinlock"
530	depends on SMP && MMU
531	select ARCH_USE_QUEUED_SPINLOCKS
532	help
533	  Embed both queued spinlock and ticket lock so that the spinlock
534	  implementation can be chosen at runtime.
535
536endchoice
537
538config RISCV_ALTERNATIVE
539	bool
540	help
541	  This Kconfig allows the kernel to automatically patch the
542	  erratum or cpufeature required by the execution platform at run
543	  time. The code patching overhead is minimal, as it's only done
544	  once at boot and once on each module load.
545
546config RISCV_ALTERNATIVE_EARLY
547	bool
548	depends on RISCV_ALTERNATIVE
549	help
550	  Allows early patching of the kernel for special errata
551
552config RISCV_ISA_C
553	bool "Emit compressed instructions when building Linux"
554	default y
555	help
556	  Adds "C" to the ISA subsets that the toolchain is allowed to emit
557	  when building Linux, which results in compressed instructions in the
558	  Linux binary. This option produces a kernel that will not run on
559	  systems that do not support compressed instructions.
560
561	  If you don't know what to do here, say Y.
562
563config RISCV_ISA_SUPM
564	bool "Supm extension for userspace pointer masking"
565	depends on 64BIT
566	default y
567	help
568	  Add support for pointer masking in userspace (Supm) when the
569	  underlying hardware extension (Smnpm or Ssnpm) is detected at boot.
570
571	  If this option is disabled, userspace will be unable to use
572	  the prctl(PR_{SET,GET}_TAGGED_ADDR_CTRL) API.
573
574config RISCV_ISA_SVNAPOT
575	bool "Svnapot extension support for supervisor mode NAPOT pages"
576	depends on 64BIT && MMU
577	depends on RISCV_ALTERNATIVE
578	default y
579	help
580	  Enable support for the Svnapot ISA-extension when it is detected
581	  at boot.
582
583	  The Svnapot extension is used to mark contiguous PTEs as a range
584	  of contiguous virtual-to-physical translations for a naturally
585	  aligned power-of-2 (NAPOT) granularity larger than the base 4KB page
586	  size. When HUGETLBFS is also selected this option unconditionally
587	  allocates some memory for each NAPOT page size supported by the kernel.
588	  When optimizing for low memory consumption and for platforms without
589	  the Svnapot extension, it may be better to say N here.
590
591	  If you don't know what to do here, say Y.
592
593config RISCV_ISA_SVPBMT
594	bool "Svpbmt extension support for supervisor mode page-based memory types"
595	depends on 64BIT && MMU
596	depends on RISCV_ALTERNATIVE
597	default y
598	help
599	   Add support for the Svpbmt ISA-extension (Supervisor-mode:
600	   page-based memory types) in the kernel when it is detected at boot.
601
602	   The memory type for a page contains a combination of attributes
603	   that indicate the cacheability, idempotency, and ordering
604	   properties for access to that page.
605
606	   The Svpbmt extension is only available on 64-bit cpus.
607
608	   If you don't know what to do here, say Y.
609
610config TOOLCHAIN_HAS_V
611	bool
612	default y
613	depends on !64BIT || $(cc-option,-mabi=lp64 -march=rv64imv)
614	depends on !32BIT || $(cc-option,-mabi=ilp32 -march=rv32imv)
615	depends on LD_IS_LLD || LD_VERSION >= 23800
616	depends on AS_HAS_OPTION_ARCH
617
618config RISCV_ISA_V
619	bool "Vector extension support"
620	depends on TOOLCHAIN_HAS_V
621	depends on FPU
622	select DYNAMIC_SIGFRAME
623	default y
624	help
625	  Add support for the Vector extension when it is detected at boot.
626	  When this option is disabled, neither the kernel nor userspace may
627	  use vector procedures.
628
629	  If you don't know what to do here, say Y.
630
631config RISCV_ISA_V_DEFAULT_ENABLE
632	bool "Enable userspace Vector by default"
633	depends on RISCV_ISA_V
634	default y
635	help
636	  Say Y here if you want to enable Vector in userspace by default.
637	  Otherwise, userspace has to make explicit prctl() call to enable
638	  Vector, or enable it via the sysctl interface.
639
640	  If you don't know what to do here, say Y.
641
642config RISCV_ISA_V_UCOPY_THRESHOLD
643	int "Threshold size for vectorized user copies"
644	depends on RISCV_ISA_V
645	default 768
646	help
647	  Prefer using vectorized copy_to_user()/copy_from_user() when the
648	  workload size exceeds this value.
649
650config RISCV_ISA_V_PREEMPTIVE
651	bool "Run kernel-mode Vector with kernel preemption"
652	depends on PREEMPTION
653	depends on RISCV_ISA_V
654	default y
655	help
656	  Usually, in-kernel SIMD routines are run with preemption disabled.
657	  Functions which invoke long running SIMD thus must yield the core's
658	  vector unit to prevent blocking other tasks for too long.
659
660	  This config allows the kernel to run SIMD without explicitly disabling
661	  preemption. Enabling this config will result in higher memory consumption
662	  due to the allocation of per-task's kernel Vector context.
663
664config RISCV_ISA_ZAWRS
665	bool "Zawrs extension support for more efficient busy waiting"
666	depends on RISCV_ALTERNATIVE
667	default y
668	help
669	  The Zawrs extension defines instructions to be used in polling loops
670	  which allow a hart to enter a low-power state or to trap to the
671	  hypervisor while waiting on a store to a memory location. Enable the
672	  use of these instructions in the kernel when the Zawrs extension is
673	  detected at boot.
674
675config TOOLCHAIN_HAS_ZABHA
676	bool
677	default y
678	depends on !64BIT || $(cc-option,-mabi=lp64 -march=rv64ima_zabha)
679	depends on !32BIT || $(cc-option,-mabi=ilp32 -march=rv32ima_zabha)
680	depends on AS_HAS_OPTION_ARCH
681
682config RISCV_ISA_ZABHA
683	bool "Zabha extension support for atomic byte/halfword operations"
684	depends on TOOLCHAIN_HAS_ZABHA
685	depends on RISCV_ALTERNATIVE
686	default y
687	help
688	  Enable the use of the Zabha ISA-extension to implement kernel
689	  byte/halfword atomic memory operations when it is detected at boot.
690
691	  If you don't know what to do here, say Y.
692
693config TOOLCHAIN_HAS_ZACAS
694	bool
695	default y
696	depends on !64BIT || $(cc-option,-mabi=lp64 -march=rv64ima_zacas)
697	depends on !32BIT || $(cc-option,-mabi=ilp32 -march=rv32ima_zacas)
698	depends on AS_HAS_OPTION_ARCH
699
700config RISCV_ISA_ZACAS
701	bool "Zacas extension support for atomic CAS"
702	depends on RISCV_ALTERNATIVE
703	default y
704	help
705	  Enable the use of the Zacas ISA-extension to implement kernel atomic
706	  cmpxchg operations when it is detected at boot.
707
708	  If you don't know what to do here, say Y.
709
710config TOOLCHAIN_HAS_ZBB
711	bool
712	default y
713	depends on !64BIT || $(cc-option,-mabi=lp64 -march=rv64ima_zbb)
714	depends on !32BIT || $(cc-option,-mabi=ilp32 -march=rv32ima_zbb)
715	depends on LD_IS_LLD || LD_VERSION >= 23900
716	depends on AS_HAS_OPTION_ARCH
717
718# This symbol indicates that the toolchain supports all v1.0 vector crypto
719# extensions, including Zvk*, Zvbb, and Zvbc.  LLVM added all of these at once.
720# binutils added all except Zvkb, then added Zvkb.  So we just check for Zvkb.
721config TOOLCHAIN_HAS_VECTOR_CRYPTO
722	def_bool $(as-instr, .option arch$(comma) +v$(comma) +zvkb)
723	depends on AS_HAS_OPTION_ARCH
724
725config TOOLCHAIN_HAS_ZBA
726	bool
727	default y
728	depends on !64BIT || $(cc-option,-mabi=lp64 -march=rv64ima_zba)
729	depends on !32BIT || $(cc-option,-mabi=ilp32 -march=rv32ima_zba)
730	depends on LD_IS_LLD || LD_VERSION >= 23900
731	depends on AS_HAS_OPTION_ARCH
732
733config RISCV_ISA_ZBA
734	bool "Zba extension support for bit manipulation instructions"
735	default y
736	help
737	   Add support for enabling optimisations in the kernel when the Zba
738	   extension is detected at boot.
739
740	   The Zba extension provides instructions to accelerate the generation
741	   of addresses that index into arrays of basic data types.
742
743	   If you don't know what to do here, say Y.
744
745config RISCV_ISA_ZBB
746	bool "Zbb extension support for bit manipulation instructions"
747	depends on RISCV_ALTERNATIVE
748	default y
749	help
750	   Add support for enabling optimisations in the kernel when the
751	   Zbb extension is detected at boot. Some optimisations may
752	   additionally depend on toolchain support for Zbb.
753
754	   The Zbb extension provides instructions to accelerate a number
755	   of bit-specific operations (count bit population, sign extending,
756	   bitrotation, etc).
757
758	   If you don't know what to do here, say Y.
759
760config TOOLCHAIN_HAS_ZBC
761	bool
762	default y
763	depends on !64BIT || $(cc-option,-mabi=lp64 -march=rv64ima_zbc)
764	depends on !32BIT || $(cc-option,-mabi=ilp32 -march=rv32ima_zbc)
765	depends on LD_IS_LLD || LD_VERSION >= 23900
766	depends on AS_HAS_OPTION_ARCH
767
768config RISCV_ISA_ZBC
769	bool "Zbc extension support for carry-less multiplication instructions"
770	depends on TOOLCHAIN_HAS_ZBC
771	depends on MMU
772	depends on RISCV_ALTERNATIVE
773	default y
774	help
775	   Adds support to dynamically detect the presence of the Zbc
776	   extension (carry-less multiplication) and enable its usage.
777
778	   The Zbc extension could accelerate CRC (cyclic redundancy check)
779	   calculations.
780
781	   If you don't know what to do here, say Y.
782
783config TOOLCHAIN_HAS_ZBKB
784	bool
785	default y
786	depends on !64BIT || $(cc-option,-mabi=lp64 -march=rv64ima_zbkb)
787	depends on !32BIT || $(cc-option,-mabi=ilp32 -march=rv32ima_zbkb)
788	depends on LD_IS_LLD || LD_VERSION >= 23900
789	depends on AS_HAS_OPTION_ARCH
790
791config RISCV_ISA_ZBKB
792	bool "Zbkb extension support for bit manipulation instructions"
793	depends on TOOLCHAIN_HAS_ZBKB
794	depends on RISCV_ALTERNATIVE
795	default y
796	help
797	   Adds support to dynamically detect the presence of the ZBKB
798	   extension (bit manipulation for cryptography) and enable its usage.
799
800	   The Zbkb extension provides instructions to accelerate a number
801	   of common cryptography operations (pack, zip, etc).
802
803	   If you don't know what to do here, say Y.
804
805config RISCV_ISA_ZICBOM
806	bool "Zicbom extension support for non-coherent DMA operation"
807	depends on MMU
808	depends on RISCV_ALTERNATIVE
809	default y
810	select RISCV_DMA_NONCOHERENT
811	select DMA_DIRECT_REMAP
812	help
813	   Add support for the Zicbom extension (Cache Block Management
814	   Operations) and enable its use in the kernel when it is detected
815	   at boot.
816
817	   The Zicbom extension can be used to handle for example
818	   non-coherent DMA support on devices that need it.
819
820	   If you don't know what to do here, say Y.
821
822config RISCV_ISA_ZICBOZ
823	bool "Zicboz extension support for faster zeroing of memory"
824	depends on RISCV_ALTERNATIVE
825	default y
826	help
827	   Enable the use of the Zicboz extension (cbo.zero instruction)
828	   in the kernel when it is detected at boot.
829
830	   The Zicboz extension is used for faster zeroing of memory.
831
832	   If you don't know what to do here, say Y.
833
834config RISCV_ISA_ZICBOP
835	bool "Zicbop extension support for cache block prefetch"
836	depends on MMU
837	depends on RISCV_ALTERNATIVE
838	default y
839	help
840	  Adds support to dynamically detect the presence of the ZICBOP
841	  extension (Cache Block Prefetch Operations) and enable its
842	  usage.
843
844	  The Zicbop extension can be used to prefetch cache blocks for
845	  read/write fetch.
846
847	  If you don't know what to do here, say Y.
848
849config RISCV_ISA_SVRSW60T59B
850	bool "Svrsw60t59b extension support for using PTE bits 60 and 59"
851	depends on MMU && 64BIT
852	depends on RISCV_ALTERNATIVE
853	default y
854	help
855	  Adds support to dynamically detect the presence of the Svrsw60t59b
856	  extension and enable its usage.
857
858	  The Svrsw60t59b extension allows to free the PTE reserved bits 60
859	  and 59 for software to use.
860
861	  If you don't know what to do here, say Y.
862
863config TOOLCHAIN_NEEDS_EXPLICIT_ZICSR_ZIFENCEI
864	def_bool y
865	# https://sourceware.org/git/?p=binutils-gdb.git;a=commit;h=aed44286efa8ae8717a77d94b51ac3614e2ca6dc
866	# https://gcc.gnu.org/git/?p=gcc.git;a=commit;h=98416dbb0a62579d4a7a4a76bab51b5b52fec2cd
867	depends on AS_IS_GNU && AS_VERSION >= 23600
868	help
869	  Binutils-2.38 and GCC-12.1.0 bumped the default ISA spec to the newer
870	  20191213 version, which moves some instructions from the I extension to
871	  the Zicsr and Zifencei extensions. This requires explicitly specifying
872	  Zicsr and Zifencei when binutils >= 2.38 or GCC >= 12.1.0. Zicsr
873	  and Zifencei are supported in binutils from version 2.36 onwards.
874	  To make life easier, and avoid forcing toolchains that default to a
875	  newer ISA spec to version 2.2, relax the check to binutils >= 2.36.
876	  For GCC < 11.3.0, for which this is not possible or need special
877	  treatment, this is dealt with in TOOLCHAIN_NEEDS_OLD_ISA_SPEC.
878
879config TOOLCHAIN_NEEDS_OLD_ISA_SPEC
880	def_bool y
881	depends on TOOLCHAIN_NEEDS_EXPLICIT_ZICSR_ZIFENCEI
882	# https://gcc.gnu.org/git/?p=gcc.git;a=commit;h=d29f5d6ab513c52fd872f532c492e35ae9fd6671
883	depends on CC_IS_GCC && GCC_VERSION < 110300
884	help
885	  Certain versions of GCC do not support zicsr and zifencei via -march.
886	  This option causes an older ISA spec compatible with these older
887	  versions of GCC to be passed to GAS, which has the same result
888	  as passing zicsr and zifencei to -march.
889
890config FPU
891	bool "FPU support"
892	default y
893	help
894	  Add support for floating point operations when an FPU is detected at
895	  boot. When this option is disabled, neither the kernel nor userspace
896	  may use the floating point unit.
897
898	  If you don't know what to do here, say Y.
899
900config IRQ_STACKS
901	bool "Independent irq & softirq stacks" if EXPERT
902	default y
903	select HAVE_IRQ_EXIT_ON_IRQ_STACK
904	select HAVE_SOFTIRQ_ON_OWN_STACK
905	help
906	  Add independent irq & softirq stacks for percpu to prevent kernel stack
907	  overflows. We may save some memory footprint by disabling IRQ_STACKS.
908
909config THREAD_SIZE_ORDER
910	int "Kernel stack size (in power-of-two numbers of page size)" if VMAP_STACK && EXPERT
911	range 0 4
912	default 1 if 32BIT
913	default 2
914	help
915	  Specify the Pages of thread stack size (from 4KB to 64KB), which also
916	  affects irq stack size, which is equal to thread stack size.
917
918config RISCV_MISALIGNED
919	bool
920	help
921	  Embed support for detecting and emulating misaligned
922	  scalar or vector loads and stores.
923
924config RISCV_SCALAR_MISALIGNED
925	bool
926	select RISCV_MISALIGNED
927	select SYSCTL_ARCH_UNALIGN_ALLOW
928	help
929	  Embed support for emulating misaligned loads and stores.
930
931config RISCV_VECTOR_MISALIGNED
932	bool
933	select RISCV_MISALIGNED
934	depends on RISCV_ISA_V
935	help
936	  Enable detecting support for vector misaligned loads and stores.
937
938config RISCV_SBI_FWFT_DELEGATE_MISALIGNED
939	bool "Request firmware delegation of unaligned access exceptions"
940	depends on RISCV_SBI
941	depends on NONPORTABLE
942	help
943	  Use SBI FWFT to request delegation of load address misaligned and
944	  store address misaligned exceptions, if possible, and prefer Linux
945	  kernel emulation of these accesses to firmware emulation.
946
947	  Unfortunately, Linux's emulation is still incomplete. Namely, it
948	  currently does not handle vector instructions and KVM guest accesses.
949	  On platforms where these accesses would have been handled by firmware,
950	  enabling this causes unexpected kernel oopses, userspaces crashes and
951	  KVM guest crashes. If you are sure that these are not a problem for
952	  your platform, you can say Y here, which may improve performance.
953
954	  Saying N here will not worsen emulation support for unaligned accesses
955	  even in the case where the firmware also has incomplete support. It
956	  simply keeps the firmware's emulation enabled.
957
958	  If you don't know what to do here, say N.
959
960choice
961	prompt "Unaligned Accesses Support"
962	default RISCV_PROBE_UNALIGNED_ACCESS
963	help
964	  This determines the level of support for unaligned accesses. This
965	  information is used by the kernel to perform optimizations. It is also
966	  exposed to user space via the hwprobe syscall. The hardware will be
967	  probed at boot by default.
968
969config RISCV_PROBE_UNALIGNED_ACCESS
970	bool "Probe for hardware unaligned access support"
971	select RISCV_SCALAR_MISALIGNED
972	help
973	  During boot, the kernel will run a series of tests to determine the
974	  speed of unaligned accesses. This probing will dynamically determine
975	  the speed of unaligned accesses on the underlying system. If unaligned
976	  memory accesses trap into the kernel as they are not supported by the
977	  system, the kernel will emulate the unaligned accesses to preserve the
978	  UABI.
979
980config RISCV_EMULATED_UNALIGNED_ACCESS
981	bool "Emulate unaligned access where system support is missing"
982	select RISCV_SCALAR_MISALIGNED
983	help
984	  If unaligned memory accesses trap into the kernel as they are not
985	  supported by the system, the kernel will emulate the unaligned
986	  accesses to preserve the UABI. When the underlying system does support
987	  unaligned accesses, the unaligned accesses are assumed to be slow.
988
989config RISCV_SLOW_UNALIGNED_ACCESS
990	bool "Assume the system supports slow unaligned memory accesses"
991	depends on NONPORTABLE
992	help
993	  Assume that the system supports slow unaligned memory accesses. The
994	  kernel and userspace programs may not be able to run at all on systems
995	  that do not support unaligned memory accesses.
996
997config RISCV_EFFICIENT_UNALIGNED_ACCESS
998	bool "Assume the system supports fast unaligned memory accesses"
999	depends on NONPORTABLE
1000	select DCACHE_WORD_ACCESS if MMU
1001	select HAVE_EFFICIENT_UNALIGNED_ACCESS
1002	help
1003	  Assume that the system supports fast unaligned memory accesses. When
1004	  enabled, this option improves the performance of the kernel on such
1005	  systems. However, the kernel and userspace programs will run much more
1006	  slowly, or will not be able to run at all, on systems that do not
1007	  support efficient unaligned memory accesses.
1008
1009endchoice
1010
1011choice
1012	prompt "Vector unaligned Accesses Support"
1013	depends on RISCV_ISA_V
1014	default RISCV_PROBE_VECTOR_UNALIGNED_ACCESS
1015	help
1016	  This determines the level of support for vector unaligned accesses. This
1017	  information is used by the kernel to perform optimizations. It is also
1018	  exposed to user space via the hwprobe syscall. The hardware will be
1019	  probed at boot by default.
1020
1021config RISCV_PROBE_VECTOR_UNALIGNED_ACCESS
1022	bool "Probe speed of vector unaligned accesses"
1023	select RISCV_VECTOR_MISALIGNED
1024	help
1025	  During boot, the kernel will run a series of tests to determine the
1026	  speed of vector unaligned accesses if they are supported. This probing
1027	  will dynamically determine the speed of vector unaligned accesses on
1028	  the underlying system if they are supported.
1029
1030config RISCV_SLOW_VECTOR_UNALIGNED_ACCESS
1031	bool "Assume the system supports slow vector unaligned memory accesses"
1032	depends on NONPORTABLE
1033	help
1034	  Assume that the system supports slow vector unaligned memory accesses. The
1035	  kernel and userspace programs may not be able to run at all on systems
1036	  that do not support unaligned memory accesses.
1037
1038config RISCV_EFFICIENT_VECTOR_UNALIGNED_ACCESS
1039	bool "Assume the system supports fast vector unaligned memory accesses"
1040	depends on NONPORTABLE
1041	help
1042	  Assume that the system supports fast vector unaligned memory accesses. When
1043	  enabled, this option improves the performance of the kernel on such
1044	  systems. However, the kernel and userspace programs will run much more
1045	  slowly, or will not be able to run at all, on systems that do not
1046	  support efficient unaligned memory accesses.
1047
1048endchoice
1049
1050source "arch/riscv/Kconfig.vendor"
1051
1052endmenu # "Platform type"
1053
1054menu "Kernel features"
1055
1056source "kernel/Kconfig.hz"
1057
1058config RISCV_SBI_V01
1059	bool "SBI v0.1 support"
1060	depends on RISCV_SBI
1061	help
1062	  This config allows kernel to use SBI v0.1 APIs. This will be
1063	  deprecated in future once legacy M-mode software are no longer in use.
1064
1065config RISCV_BOOT_SPINWAIT
1066	bool "Spinwait booting method"
1067	depends on SMP
1068	default y if RISCV_SBI_V01 || RISCV_M_MODE
1069	help
1070	  This enables support for booting Linux via spinwait method. In the
1071	  spinwait method, all cores randomly jump to Linux. One of the cores
1072	  gets chosen via lottery and all other keep spinning on a percpu
1073	  variable. This method cannot support CPU hotplug and sparse hartid
1074	  scheme. It should be only enabled for M-mode Linux or platforms relying
1075	  on older firmware without SBI HSM extension. All other platforms should
1076	  rely on ordered booting via SBI HSM extension which gets chosen
1077	  dynamically at runtime if the firmware supports it.
1078
1079	  Since spinwait is incompatible with sparse hart IDs, it requires
1080	  NR_CPUS be large enough to contain the physical hart ID of the first
1081	  hart to enter Linux.
1082
1083	  If unsure what to do here, say N.
1084
1085config ARCH_SUPPORTS_KEXEC
1086	def_bool y
1087
1088config ARCH_SELECTS_KEXEC
1089	def_bool y
1090	depends on KEXEC
1091	select HOTPLUG_CPU if SMP
1092
1093config ARCH_SUPPORTS_KEXEC_FILE
1094	def_bool 64BIT
1095
1096config ARCH_SELECTS_KEXEC_FILE
1097	def_bool y
1098	depends on KEXEC_FILE
1099	select HAVE_IMA_KEXEC if IMA
1100	select KEXEC_ELF
1101
1102config ARCH_SUPPORTS_KEXEC_PURGATORY
1103	def_bool ARCH_SUPPORTS_KEXEC_FILE
1104
1105config ARCH_SUPPORTS_CRASH_DUMP
1106	def_bool y
1107
1108config ARCH_DEFAULT_CRASH_DUMP
1109	def_bool y
1110
1111config ARCH_HAS_GENERIC_CRASHKERNEL_RESERVATION
1112	def_bool CRASH_RESERVE
1113
1114config COMPAT
1115	bool "Kernel support for 32-bit U-mode"
1116	default 64BIT
1117	depends on 64BIT && MMU
1118	help
1119	  This option enables support for a 32-bit U-mode running under a 64-bit
1120	  kernel at S-mode. riscv32-specific components such as system calls,
1121	  the user helper functions (vdso), signal rt_frame functions and the
1122	  ptrace interface are handled appropriately by the kernel.
1123
1124	  If you want to execute 32-bit userspace applications, say Y.
1125
1126config PARAVIRT
1127	bool "Enable paravirtualization code"
1128	depends on RISCV_SBI
1129	select HAVE_PV_STEAL_CLOCK_GEN
1130	help
1131	  This changes the kernel so it can modify itself when it is run
1132	  under a hypervisor, potentially improving performance significantly
1133	  over full virtualization.
1134
1135config PARAVIRT_TIME_ACCOUNTING
1136	bool "Paravirtual steal time accounting"
1137	depends on PARAVIRT
1138	help
1139	  Select this option to enable fine granularity task steal time
1140	  accounting. Time spent executing other tasks in parallel with
1141	  the current vCPU is discounted from the vCPU power. To account for
1142	  that, there can be a small performance impact.
1143
1144	  If in doubt, say N here.
1145
1146config RELOCATABLE
1147	bool "Build a relocatable kernel"
1148	select MODULE_SECTIONS if MODULES
1149	select ARCH_VMLINUX_NEEDS_RELOCS
1150	help
1151          This builds a kernel as a Position Independent Executable (PIE),
1152          which retains all relocation metadata required to relocate the
1153          kernel binary at runtime to a different virtual address than the
1154          address it was linked at.
1155          Since RISCV uses the RELA relocation format, this requires a
1156          relocation pass at runtime even if the kernel is loaded at the
1157          same address it was linked at.
1158
1159          If unsure, say N.
1160
1161config RANDOMIZE_BASE
1162        bool "Randomize the address of the kernel image"
1163        depends on RELOCATABLE
1164        depends on MMU && 64BIT
1165        help
1166          Randomizes the virtual address at which the kernel image is
1167          loaded, as a security feature that deters exploit attempts
1168          relying on knowledge of the location of kernel internals.
1169
1170          It is the bootloader's job to provide entropy, by passing a
1171          random u64 value in /chosen/kaslr-seed at kernel entry.
1172
1173          When booting via the UEFI stub, it will invoke the firmware's
1174          EFI_RNG_PROTOCOL implementation (if available) to supply entropy
1175          to the kernel proper. In addition, it will randomise the physical
1176          location of the kernel Image as well.
1177
1178          If unsure, say N.
1179
1180config RISCV_USER_CFI
1181	def_bool y
1182	bool "riscv userspace control flow integrity"
1183	depends on 64BIT && MMU && \
1184		$(cc-option,-mabi=lp64 -march=rv64ima_zicfiss_zicfilp -fcf-protection=full)
1185	depends on RISCV_ALTERNATIVE
1186	select RISCV_SBI
1187	select ARCH_HAS_USER_SHADOW_STACK
1188	select ARCH_USES_HIGH_VMA_FLAGS
1189	select DYNAMIC_SIGFRAME
1190	help
1191	  Provides CPU-assisted control flow integrity to userspace tasks.
1192	  Control flow integrity is provided by implementing shadow stack for
1193	  backward edge and indirect branch tracking for forward edge.
1194	  Shadow stack protection is a hardware feature that detects function
1195	  return address corruption. This helps mitigate ROP attacks.
1196	  Indirect branch tracking enforces that all indirect branches must land
1197	  on a landing pad instruction else CPU will fault. This mitigates against
1198	  JOP / COP attacks. Applications must be enabled to use it, and old userspace
1199	  does not get protection "for free".
1200	  default y.
1201
1202endmenu # "Kernel features"
1203
1204menu "Boot options"
1205
1206config CMDLINE
1207	string "Built-in kernel command line"
1208	help
1209	  For most platforms, the arguments for the kernel's command line
1210	  are provided at run-time, during boot. However, there are cases
1211	  where either no arguments are being provided or the provided
1212	  arguments are insufficient or even invalid.
1213
1214	  When that occurs, it is possible to define a built-in command
1215	  line here and choose how the kernel should use it later on.
1216
1217choice
1218	prompt "Built-in command line usage"
1219	depends on CMDLINE != ""
1220	default CMDLINE_FALLBACK
1221	help
1222	  Choose how the kernel will handle the provided built-in command
1223	  line.
1224
1225config CMDLINE_FALLBACK
1226	bool "Use bootloader kernel arguments if available"
1227	help
1228	  Use the built-in command line as fallback in case we get nothing
1229	  during boot. This is the default behaviour.
1230
1231config CMDLINE_EXTEND
1232	bool "Extend bootloader kernel arguments"
1233	help
1234	  The built-in command line will be appended to the command-
1235	  line arguments provided during boot. This is useful in
1236	  cases where the provided arguments are insufficient and
1237	  you don't want to or cannot modify them.
1238
1239config CMDLINE_FORCE
1240	bool "Always use the default kernel command string"
1241	help
1242	  Always use the built-in command line, even if we get one during
1243	  boot. This is useful in case you need to override the provided
1244	  command line on systems where you don't have or want control
1245	  over it.
1246
1247endchoice
1248
1249config EFI_STUB
1250	bool
1251
1252config EFI
1253	bool "UEFI runtime support"
1254	depends on OF
1255	depends on MMU
1256	default y
1257	select ARCH_SUPPORTS_ACPI if 64BIT
1258	select EFI_GENERIC_STUB
1259	select EFI_PARAMS_FROM_FDT
1260	select EFI_RUNTIME_WRAPPERS
1261	select EFI_STUB
1262	select LIBFDT
1263	select RISCV_ISA_C
1264	select UCS2_STRING
1265	help
1266	  This option provides support for runtime services provided
1267	  by UEFI firmware (such as non-volatile variables, realtime
1268	  clock, and platform reset). A UEFI stub is also provided to
1269	  allow the kernel to be booted as an EFI application. This
1270	  is only useful on systems that have UEFI firmware.
1271
1272config DMI
1273	bool "Enable support for SMBIOS (DMI) tables"
1274	depends on EFI
1275	default y
1276	help
1277	  This enables SMBIOS/DMI feature for systems.
1278
1279	  This option is only useful on systems that have UEFI firmware.
1280	  However, even with this option, the resultant kernel should
1281	  continue to boot on existing non-UEFI platforms.
1282
1283config CC_HAVE_STACKPROTECTOR_TLS
1284	def_bool $(cc-option,-mstack-protector-guard=tls -mstack-protector-guard-reg=tp -mstack-protector-guard-offset=0)
1285
1286config STACKPROTECTOR_PER_TASK
1287	def_bool y
1288	depends on !RANDSTRUCT
1289	depends on STACKPROTECTOR && CC_HAVE_STACKPROTECTOR_TLS
1290
1291config PHYS_RAM_BASE_FIXED
1292	bool "Explicitly specified physical RAM address"
1293	depends on NONPORTABLE
1294	default n
1295
1296config PHYS_RAM_BASE
1297	hex "Platform Physical RAM address"
1298	depends on PHYS_RAM_BASE_FIXED
1299	default "0x80000000"
1300	help
1301	  This is the physical address of RAM in the system. It has to be
1302	  explicitly specified to run early relocations of read-write data
1303	  from flash to RAM.
1304
1305config RISCV_ISA_FALLBACK
1306	bool "Permit falling back to parsing riscv,isa for extension support by default"
1307	default y
1308	help
1309	  Parsing the "riscv,isa" devicetree property has been deprecated and
1310	  replaced by a list of explicitly defined strings. For compatibility
1311	  with existing platforms, the kernel will fall back to parsing the
1312	  "riscv,isa" property if the replacements are not found.
1313
1314	  Selecting N here will result in a kernel that does not use the
1315	  fallback, unless the commandline "riscv_isa_fallback" parameter is
1316	  present.
1317
1318	  Please see the dt-binding, located at
1319	  Documentation/devicetree/bindings/riscv/extensions.yaml for details
1320	  on the replacement properties, "riscv,isa-base" and
1321	  "riscv,isa-extensions".
1322
1323config BUILTIN_DTB
1324	bool "Built-in device tree"
1325	depends on OF && NONPORTABLE
1326	select GENERIC_BUILTIN_DTB
1327	help
1328	  Build a device tree into the Linux image.
1329	  This option should be selected if no bootloader is being used.
1330	  If unsure, say N.
1331
1332
1333config BUILTIN_DTB_NAME
1334	string "Built-in device tree source"
1335	depends on BUILTIN_DTB
1336	help
1337	  DTS file path (without suffix, relative to arch/riscv/boot/dts)
1338	  for the DTS file that will be used to produce the DTB linked into the
1339	  kernel.
1340
1341endmenu # "Boot options"
1342
1343config PORTABLE
1344	bool
1345	default !NONPORTABLE
1346	select EFI
1347	select MMU
1348	select OF
1349
1350config ARCH_PROC_KCORE_TEXT
1351	def_bool y
1352
1353config ARCH_CC_CAN_LINK
1354	bool
1355	default $(cc_can_link_user,-march=rv64g -mabi=lp64d) if 64BIT && FPU
1356	default $(cc_can_link_user,-march=rv64g -mabi=lp64) if 64BIT
1357	default $(cc_can_link_user,-march=rv32g -mabi=ilp32d) if FPU
1358	default $(cc_can_link_user,-march=rv32g -mabi=ilp32)
1359
1360config ARCH_USERFLAGS
1361	string
1362	default "-march=rv64g -mabi=lp64d" if 64BIT && FPU
1363	default "-march=rv64g -mabi=lp64" if 64BIT
1364	default "-march=rv32g -mabi=ilp32d" if FPU
1365	default "-march=rv32g -mabi=ilp32"
1366
1367menu "Power management options"
1368
1369source "kernel/power/Kconfig"
1370
1371config ARCH_HIBERNATION_POSSIBLE
1372	def_bool y
1373
1374config ARCH_HIBERNATION_HEADER
1375	def_bool HIBERNATION
1376
1377config ARCH_SUSPEND_POSSIBLE
1378	def_bool y
1379
1380endmenu # "Power management options"
1381
1382menu "CPU Power Management"
1383
1384source "drivers/cpuidle/Kconfig"
1385
1386source "drivers/cpufreq/Kconfig"
1387
1388endmenu # "CPU Power Management"
1389
1390source "arch/riscv/kvm/Kconfig"
1391
1392source "drivers/acpi/Kconfig"
1393