blob: 082486cddf31bd3573f19d47c7bf5f302035a183 [file] [log] [blame]
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -07001#
2# For a description of the syntax of this configuration file,
3# see Documentation/kbuild/kconfig-language.txt.
4#
5
Christoph Hellwigc3e4ed02018-04-27 08:38:23 +02006config 64BIT
7 bool
8
9config 32BIT
10 bool
11
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070012config RISCV
13 def_bool y
Christoph Hellwigd4a451d2018-04-03 16:24:20 +020014 # even on 32-bit, physical (and DMA) addresses are > 32-bits
15 select PHYS_ADDR_T_64BIT
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070016 select OF
17 select OF_EARLY_FLATTREE
18 select OF_IRQ
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070019 select ARCH_WANT_FRAME_POINTERS
20 select CLONE_BACKWARDS
21 select COMMON_CLK
Christoph Hellwig86e11752018-04-16 14:53:51 +020022 select DMA_DIRECT_OPS
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070023 select GENERIC_CLOCKEVENTS
24 select GENERIC_CPU_DEVICES
25 select GENERIC_IRQ_SHOW
26 select GENERIC_PCI_IOMAP
27 select GENERIC_STRNCPY_FROM_USER
28 select GENERIC_STRNLEN_USER
29 select GENERIC_SMP_IDLE_THREAD
30 select GENERIC_ATOMIC64 if !64BIT || !RISCV_ISA_A
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070031 select HAVE_MEMBLOCK
Christoph Hellwig5ec9c4f2018-01-16 09:37:50 +010032 select HAVE_MEMBLOCK_NODE_MAP
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070033 select HAVE_DMA_CONTIGUOUS
34 select HAVE_GENERIC_DMA_COHERENT
Alan Kao178e9fc2018-04-20 07:27:49 +080035 select HAVE_PERF_EVENTS
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070036 select IRQ_DOMAIN
37 select NO_BOOTMEM
38 select RISCV_ISA_A if SMP
39 select SPARSE_IRQ
40 select SYSCTL_EXCEPTION_TRACE
41 select HAVE_ARCH_TRACEHOOK
42 select MODULES_USE_ELF_RELA if MODULES
43 select THREAD_INFO_IN_TASK
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070044 select RISCV_TIMER
Palmer Dabbeltcc6c9842018-03-07 15:57:28 -080045 select GENERIC_IRQ_MULTI_HANDLER
Laurent Dufour3010a5e2018-06-07 17:06:08 -070046 select ARCH_HAS_PTE_SPECIAL
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070047
48config MMU
49 def_bool y
50
Christoph Hellwig5ec9c4f2018-01-16 09:37:50 +010051config ZONE_DMA32
52 bool
Christoph Hellwigf1306f02018-04-27 08:41:09 +020053 default y if 64BIT
Christoph Hellwig5ec9c4f2018-01-16 09:37:50 +010054
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070055config PAGE_OFFSET
56 hex
57 default 0xC0000000 if 32BIT && MAXPHYSMEM_2GB
58 default 0xffffffff80000000 if 64BIT && MAXPHYSMEM_2GB
59 default 0xffffffe000000000 if 64BIT && MAXPHYSMEM_128GB
60
61config STACKTRACE_SUPPORT
62 def_bool y
63
Alan Kao10626c32017-12-18 17:52:48 +080064config TRACE_IRQFLAGS_SUPPORT
65 def_bool y
66
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070067config RWSEM_GENERIC_SPINLOCK
68 def_bool y
69
70config GENERIC_BUG
71 def_bool y
72 depends on BUG
73 select GENERIC_BUG_RELATIVE_POINTERS if 64BIT
74
75config GENERIC_BUG_RELATIVE_POINTERS
76 bool
77
78config GENERIC_CALIBRATE_DELAY
79 def_bool y
80
81config GENERIC_CSUM
82 def_bool y
83
84config GENERIC_HWEIGHT
85 def_bool y
86
87config PGTABLE_LEVELS
88 int
89 default 3 if 64BIT
90 default 2
91
92config HAVE_KPROBES
93 def_bool n
94
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -070095menu "Platform type"
96
97choice
98 prompt "Base ISA"
99 default ARCH_RV64I
100 help
101 This selects the base ISA that this kernel will traget and must match
102 the target platform.
103
104config ARCH_RV32I
105 bool "RV32I"
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700106 select 32BIT
Matt Redfearne3d59802018-04-11 08:50:17 +0100107 select GENERIC_LIB_ASHLDI3
108 select GENERIC_LIB_ASHRDI3
109 select GENERIC_LIB_LSHRDI3
Zong Li8f791252018-06-25 16:49:38 +0800110 select GENERIC_LIB_UCMPDI2
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700111
112config ARCH_RV64I
113 bool "RV64I"
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700114 select 64BIT
Alan Kao10626c32017-12-18 17:52:48 +0800115 select HAVE_FUNCTION_TRACER
116 select HAVE_FUNCTION_GRAPH_TRACER
Alan Kaoa1d2a6b2018-02-13 13:13:16 +0800117 select HAVE_FTRACE_MCOUNT_RECORD
Alan Kaoc15ac4f2018-02-13 13:13:17 +0800118 select HAVE_DYNAMIC_FTRACE
Alan Kaoaea4c672018-02-13 13:13:20 +0800119 select HAVE_DYNAMIC_FTRACE_WITH_REGS
Christoph Hellwig10314e02018-04-27 08:43:14 +0200120 select SWIOTLB
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700121
122endchoice
123
124# We must be able to map all physical memory into the kernel, but the compiler
125# is still a bit more efficient when generating code if it's setup in a manner
126# such that it can only map 2GiB of memory.
127choice
128 prompt "Kernel Code Model"
129 default CMODEL_MEDLOW if 32BIT
130 default CMODEL_MEDANY if 64BIT
131
132 config CMODEL_MEDLOW
133 bool "medium low code model"
134 config CMODEL_MEDANY
135 bool "medium any code model"
136endchoice
137
Zong Liab1ef682018-03-15 16:50:41 +0800138config MODULE_SECTIONS
139 bool
140 select HAVE_MOD_ARCH_SPECIFIC
141
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700142choice
143 prompt "Maximum Physical Memory"
144 default MAXPHYSMEM_2GB if 32BIT
145 default MAXPHYSMEM_2GB if 64BIT && CMODEL_MEDLOW
146 default MAXPHYSMEM_128GB if 64BIT && CMODEL_MEDANY
147
148 config MAXPHYSMEM_2GB
149 bool "2GiB"
150 config MAXPHYSMEM_128GB
151 depends on 64BIT && CMODEL_MEDANY
Zong Liab1ef682018-03-15 16:50:41 +0800152 select MODULE_SECTIONS if MODULES
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700153 bool "128GiB"
154endchoice
155
156
157config SMP
158 bool "Symmetric Multi-Processing"
159 help
160 This enables support for systems with more than one CPU. If
161 you say N here, the kernel will run on single and
162 multiprocessor machines, but will use only one CPU of a
163 multiprocessor machine. If you say Y here, the kernel will run
164 on many, but not all, single processor machines. On a single
165 processor machine, the kernel will run faster if you say N
166 here.
167
168 If you don't know what to do here, say N.
169
170config NR_CPUS
171 int "Maximum number of CPUs (2-32)"
172 range 2 32
173 depends on SMP
174 default "8"
175
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700176choice
177 prompt "CPU Tuning"
178 default TUNE_GENERIC
179
180config TUNE_GENERIC
181 bool "generic"
182
183endchoice
184
185config RISCV_ISA_C
186 bool "Emit compressed instructions when building Linux"
187 default y
188 help
189 Adds "C" to the ISA subsets that the toolchain is allowed to emit
190 when building Linux, which results in compressed instructions in the
191 Linux binary.
192
193 If you don't know what to do here, say Y.
194
195config RISCV_ISA_A
196 def_bool y
197
Alan Kao178e9fc2018-04-20 07:27:49 +0800198menu "supported PMU type"
199 depends on PERF_EVENTS
200
201config RISCV_BASE_PMU
202 bool "Base Performance Monitoring Unit"
203 def_bool y
204 help
205 A base PMU that serves as a reference implementation and has limited
206 feature of perf. It can run on any RISC-V machines so serves as the
207 fallback, but this option can also be disable to reduce kernel size.
208
209endmenu
210
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700211endmenu
212
213menu "Kernel type"
214
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700215source "kernel/Kconfig.preempt"
216
217source "kernel/Kconfig.hz"
218
219endmenu
220
221menu "Bus support"
222
223config PCI
224 bool "PCI support"
225 select PCI_MSI
226 help
227 This feature enables support for PCI bus system. If you say Y
228 here, the kernel will include drivers and infrastructure code
229 to support PCI bus devices.
230
231 If you don't know what to do here, say Y.
232
233config PCI_DOMAINS
234 def_bool PCI
235
236config PCI_DOMAINS_GENERIC
237 def_bool PCI
238
239source "drivers/pci/Kconfig"
240
241endmenu
242
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700243menu "Power management options"
244
245source kernel/power/Kconfig
246
247endmenu
248
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700249menu "Kernel hacking"
250
251config CMDLINE_BOOL
252 bool "Built-in kernel command line"
253 help
254 For most platforms, it is firmware or second stage bootloader
255 that by default specifies the kernel command line options.
256 However, it might be necessary or advantageous to either override
257 the default kernel command line or add a few extra options to it.
258 For such cases, this option allows hardcoding command line options
259 directly into the kernel.
260
261 For that, choose 'Y' here and fill in the extra boot parameters
262 in CONFIG_CMDLINE.
263
264 The built-in options will be concatenated to the default command
Palmer Dabbeltf6a11d92018-03-13 13:31:20 -0700265 line if CMDLINE_FORCE is set to 'N'. Otherwise, the default
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700266 command line will be ignored and replaced by the built-in string.
267
268config CMDLINE
269 string "Built-in kernel command string"
270 depends on CMDLINE_BOOL
271 default ""
272 help
273 Supply command-line options at build time by entering them here.
274
Palmer Dabbeltf6a11d92018-03-13 13:31:20 -0700275config CMDLINE_FORCE
Palmer Dabbeltfbe934d2017-07-10 18:08:08 -0700276 bool "Built-in command line overrides bootloader arguments"
277 depends on CMDLINE_BOOL
278 help
279 Set this option to 'Y' to have the kernel ignore the bootloader
280 or firmware command line. Instead, the built-in command line
281 will be used exclusively.
282
283 If you don't know what to do here, say N.
284
285config EARLY_PRINTK
286 def_bool y
287
288source "lib/Kconfig.debug"
289
290config CMDLINE_BOOL
291 bool
292endmenu