Commit | Line | Data |
---|---|---|
ec8f24b7 | 1 | # SPDX-License-Identifier: GPL-2.0-only |
761b6026 | 2 | config 64BIT |
104daea1 MY |
3 | bool "64-bit kernel" if "$(ARCH)" = "sparc" |
4 | default "$(ARCH)" = "sparc64" | |
761b6026 BB |
5 | help |
6 | SPARC is a family of RISC microprocessors designed and marketed by | |
7 | Sun Microsystems, incorporated. They are very widely found in Sun | |
8 | workstations and clones. | |
9 | ||
10 | Say yes to build a 64-bit kernel - formerly known as sparc64 | |
11 | Say no to build a 32-bit kernel - formerly known as sparc | |
12 | ||
35da3e39 SR |
13 | config SPARC |
14 | bool | |
15 | default y | |
ff649a6f | 16 | select ARCH_MIGHT_HAVE_PC_PARPORT if SPARC64 && PCI |
a5252c28 | 17 | select ARCH_MIGHT_HAVE_PC_SERIO |
2f9237d4 | 18 | select DMA_OPS |
7b14c647 | 19 | select OF |
3cfc535c | 20 | select OF_PROMTREE |
2ff2b7ec | 21 | select HAVE_ASM_MODVERSIONS |
26b4c912 | 22 | select HAVE_ARCH_KGDB if !SMP || SPARC64 |
35da3e39 | 23 | select HAVE_ARCH_TRACEHOOK |
282a181b | 24 | select HAVE_ARCH_SECCOMP if SPARC64 |
5f56a5df | 25 | select HAVE_EXIT_THREAD |
eb01d42a | 26 | select HAVE_PCI |
7ac57a89 | 27 | select SYSCTL_EXCEPTION_TRACE |
35da3e39 SR |
28 | select RTC_CLASS |
29 | select RTC_DRV_M48T59 | |
460ea8d7 | 30 | select RTC_SYSTOHC |
4f6500ff | 31 | select HAVE_ARCH_JUMP_LABEL if SPARC64 |
6baa9b20 | 32 | select GENERIC_IRQ_SHOW |
c1d7e01d | 33 | select ARCH_WANT_IPC_PARSE_VERSION |
a21a2fd4 | 34 | select GENERIC_PCI_IOMAP |
fcbfe812 | 35 | select HAS_IOPORT |
d314d74c | 36 | select HAVE_NMI_WATCHDOG if SPARC64 |
7a12b503 DM |
37 | select HAVE_CBPF_JIT if SPARC32 |
38 | select HAVE_EBPF_JIT if SPARC64 | |
9b2a60c4 | 39 | select HAVE_DEBUG_BUGVERBOSE |
f0a2bc7e | 40 | select GENERIC_SMP_IDLE_THREAD |
786d35d4 | 41 | select MODULES_USE_ELF_RELA |
20f1b79d | 42 | select PCI_SYSCALL if PCI |
981aa1d3 | 43 | select PCI_MSI_ARCH_FALLBACKS if PCI_MSI |
eaca6eae | 44 | select ODD_RT_SIGACTION |
52ad6b3f | 45 | select OLD_SIGSUSPEND |
fff7fb0b | 46 | select CPU_NO_EFFICIENT_FFS |
395102db | 47 | select LOCKDEP_SMALL if LOCKDEP |
f616ab59 | 48 | select NEED_DMA_MAP_STATE |
86596f0a | 49 | select NEED_SG_DMA_LENGTH |
4aae683f | 50 | select TRACE_IRQFLAGS_SUPPORT |
35da3e39 | 51 | |
35da3e39 | 52 | config SPARC32 |
761b6026 | 53 | def_bool !64BIT |
942fa985 | 54 | select ARCH_32BIT_OFF_T |
dfaad39c | 55 | select ARCH_HAS_SYNC_DMA_FOR_CPU |
c6df4b17 | 56 | select CLZ_TAB |
7d6db80b CH |
57 | select DMA_DIRECT_REMAP |
58 | select GENERIC_ATOMIC64 | |
af1839eb | 59 | select HAVE_UID16 |
a274bd49 | 60 | select OLD_SIGACTION |
63703f37 | 61 | select ZONE_DMA |
35da3e39 | 62 | |
26b4c912 | 63 | config SPARC64 |
761b6026 | 64 | def_bool 64BIT |
12700c17 | 65 | select ALTERNATE_USER_ADDRESS_SPACE |
26b4c912 | 66 | select HAVE_FUNCTION_TRACER |
9960e9e8 | 67 | select HAVE_FUNCTION_GRAPH_TRACER |
26b4c912 SR |
68 | select HAVE_KRETPROBES |
69 | select HAVE_KPROBES | |
ff2e6d72 | 70 | select MMU_GATHER_RCU_TABLE_FREE if SMP |
1e9fdf21 PZ |
71 | select MMU_GATHER_MERGE_VMAS |
72 | select MMU_GATHER_NO_FLUSH_CACHE | |
b9156ebb | 73 | select HAVE_ARCH_TRANSPARENT_HUGEPAGE |
9be12f9b DM |
74 | select HAVE_DYNAMIC_FTRACE |
75 | select HAVE_FTRACE_MCOUNT_RECORD | |
c658ad1b | 76 | select HAVE_SYSCALL_TRACEPOINTS |
24a9c541 | 77 | select HAVE_CONTEXT_TRACKING_USER |
490f561b | 78 | select HAVE_TIF_NOHZ |
b69ec42b | 79 | select HAVE_DEBUG_KMEMLEAK |
a4ce5a48 | 80 | select IOMMU_HELPER |
ee6a9333 | 81 | select SPARSE_IRQ |
26b4c912 SR |
82 | select RTC_DRV_CMOS |
83 | select RTC_DRV_BQ4802 | |
84 | select RTC_DRV_SUN4V | |
85 | select RTC_DRV_STARFIRE | |
cdd6c482 | 86 | select HAVE_PERF_EVENTS |
906010b2 | 87 | select PERF_USE_VMALLOC |
df013ffb | 88 | select ARCH_HAVE_NMI_SAFE_CMPXCHG |
178a2960 | 89 | select HAVE_C_RECORDMCOUNT |
7a017721 | 90 | select HAVE_ARCH_AUDITSYSCALL |
4badad35 | 91 | select ARCH_SUPPORTS_ATOMIC_RMW |
5d6ad668 | 92 | select ARCH_SUPPORTS_DEBUG_PAGEALLOC |
42a0bb3f | 93 | select HAVE_NMI |
b7c02b73 | 94 | select HAVE_REGS_AND_STACK_ACCESS_API |
a37594f1 | 95 | select ARCH_USE_QUEUED_RWLOCKS |
145d9785 | 96 | select ARCH_USE_QUEUED_SPINLOCKS |
9a08862a NM |
97 | select GENERIC_TIME_VSYSCALL |
98 | select ARCH_CLOCKSOURCE_DATA | |
3010a5ea | 99 | select ARCH_HAS_PTE_SPECIAL |
2eac9c2d | 100 | select PCI_DOMAINS if PCI |
4eb0716e | 101 | select ARCH_HAS_GIGANTIC_PAGE |
cd1a41ce | 102 | select HAVE_SOFTIRQ_ON_OWN_STACK |
7ecd19cf KW |
103 | select HAVE_SETUP_PER_CPU_AREA |
104 | select NEED_PER_CPU_EMBED_FIRST_CHUNK | |
105 | select NEED_PER_CPU_PAGE_FIRST_CHUNK | |
26b4c912 | 106 | |
3c08158e DM |
107 | config ARCH_PROC_KCORE_TEXT |
108 | def_bool y | |
109 | ||
97d9f969 BM |
110 | config CPU_BIG_ENDIAN |
111 | def_bool y | |
112 | ||
c88c545b DK |
113 | config ARCH_ATU |
114 | bool | |
115 | default y if SPARC64 | |
116 | ||
26b4c912 SR |
117 | config STACKTRACE_SUPPORT |
118 | bool | |
119 | default y if SPARC64 | |
120 | ||
121 | config LOCKDEP_SUPPORT | |
122 | bool | |
123 | default y if SPARC64 | |
124 | ||
bdde6b3c TK |
125 | config ARCH_HIBERNATION_POSSIBLE |
126 | def_bool y if SPARC64 | |
127 | ||
26b4c912 SR |
128 | config AUDIT_ARCH |
129 | bool | |
7e7e93a2 | 130 | default y |
26b4c912 | 131 | |
1da177e4 LT |
132 | config MMU |
133 | bool | |
134 | default y | |
135 | ||
1da177e4 LT |
136 | config HIGHMEM |
137 | bool | |
26b4c912 | 138 | default y if SPARC32 |
3293efa9 | 139 | select KMAP_LOCAL |
1da177e4 LT |
140 | |
141 | config GENERIC_ISA_DMA | |
142 | bool | |
26b4c912 | 143 | default y if SPARC32 |
1da177e4 | 144 | |
81a2936c KS |
145 | config PGTABLE_LEVELS |
146 | default 4 if 64BIT | |
147 | default 3 | |
148 | ||
e8f4aa60 AP |
149 | config ARCH_SUPPORTS_UPROBES |
150 | def_bool y if SPARC64 | |
151 | ||
26b4c912 | 152 | menu "Processor type and features" |
1da177e4 | 153 | |
1da177e4 | 154 | config SMP |
6b7679dd | 155 | bool "Symmetric multi-processing support" |
a7f7f624 | 156 | help |
1da177e4 LT |
157 | This enables support for systems with more than one CPU. If you have |
158 | a system with only one CPU, say N. If you have a system with more | |
159 | than one CPU, say Y. | |
160 | ||
4a474157 | 161 | If you say N here, the kernel will run on uni- and multiprocessor |
1da177e4 LT |
162 | machines, but will use only one CPU of a multiprocessor machine. If |
163 | you say Y here, the kernel will run on many, but not all, | |
4a474157 | 164 | uniprocessor machines. On a uniprocessor machine, the kernel |
1da177e4 LT |
165 | will run faster if you say N here. |
166 | ||
167 | People using multiprocessor machines who say Y here should also say | |
168 | Y to "Enhanced Real Time Clock Support", below. The "Advanced Power | |
169 | Management" code will be disabled if you say Y here. | |
170 | ||
4f4cfa6c | 171 | See also <file:Documentation/admin-guide/lockup-watchdogs.rst> and the SMP-HOWTO |
37719576 | 172 | available at <https://www.tldp.org/docs.html#howto>. |
1da177e4 LT |
173 | |
174 | If you don't know what to do here, say N. | |
175 | ||
176 | config NR_CPUS | |
26b4c912 | 177 | int "Maximum number of CPUs" |
1da177e4 | 178 | depends on SMP |
26b4c912 | 179 | range 2 32 if SPARC32 |
c79a1373 | 180 | range 2 4096 if SPARC64 |
26b4c912 | 181 | default 32 if SPARC32 |
c79a1373 | 182 | default 4096 if SPARC64 |
1da177e4 | 183 | |
8636a1f9 | 184 | source "kernel/Kconfig.hz" |
1da177e4 | 185 | |
d59288b7 AM |
186 | config GENERIC_HWEIGHT |
187 | bool | |
e0b20296 | 188 | default y |
d59288b7 | 189 | |
1da177e4 LT |
190 | config GENERIC_CALIBRATE_DELAY |
191 | bool | |
192 | default y | |
193 | ||
a08b6b79 Z |
194 | config ARCH_MAY_HAVE_PC_FDC |
195 | bool | |
196 | default y | |
197 | ||
5f81941c MH |
198 | config EMULATED_CMPXCHG |
199 | bool | |
26b4c912 | 200 | default y if SPARC32 |
5f81941c MH |
201 | help |
202 | Sparc32 does not have a CAS instruction like sparc64. cmpxchg() | |
203 | is emulated, and therefore it is not completely atomic. | |
204 | ||
d670bd4f SR |
205 | # Makefile helpers |
206 | config SPARC32_SMP | |
207 | bool | |
208 | default y | |
209 | depends on SPARC32 && SMP | |
210 | ||
211 | config SPARC64_SMP | |
212 | bool | |
213 | default y | |
214 | depends on SPARC64 && SMP | |
215 | ||
c57ec52f DM |
216 | config EARLYFB |
217 | bool "Support for early boot text console" | |
218 | default y | |
219 | depends on SPARC64 | |
220 | help | |
221 | Say Y here to enable a faster early framebuffer boot console. | |
222 | ||
26b4c912 SR |
223 | config HOTPLUG_CPU |
224 | bool "Support for hot-pluggable CPUs" | |
225 | depends on SPARC64 && SMP | |
26b4c912 SR |
226 | help |
227 | Say Y here to experiment with turning CPUs off and on. CPUs | |
228 | can be controlled through /sys/devices/system/cpu/cpu#. | |
229 | Say N if you want to disable CPU hotplug. | |
230 | ||
26b4c912 SR |
231 | if SPARC64 |
232 | source "drivers/cpufreq/Kconfig" | |
26b4c912 SR |
233 | endif |
234 | ||
235 | config US3_MC | |
236 | tristate "UltraSPARC-III Memory Controller driver" | |
237 | depends on SPARC64 | |
238 | default y | |
239 | help | |
240 | This adds a driver for the UltraSPARC-III memory controller. | |
241 | Loading this driver allows exact mnemonic strings to be | |
242 | printed in the event of a memory error, so that the faulty DIMM | |
243 | on the motherboard can be matched to the error. | |
244 | ||
245 | If in doubt, say Y, as this information can be very useful. | |
246 | ||
247 | # Global things across all Sun machines. | |
248 | config GENERIC_LOCKBREAK | |
1da177e4 LT |
249 | bool |
250 | default y | |
85a683d0 | 251 | depends on SPARC64 && SMP && PREEMPTION |
26b4c912 | 252 | |
26b4c912 SR |
253 | config NUMA |
254 | bool "NUMA support" | |
255 | depends on SPARC64 && SMP | |
256 | ||
257 | config NODES_SHIFT | |
7485af89 JC |
258 | int "Maximum NUMA Nodes (as a power of 2)" |
259 | range 4 5 if SPARC64 | |
260 | default "5" | |
a9ee6cf5 | 261 | depends on NUMA |
7485af89 JC |
262 | help |
263 | Specify the maximum number of NUMA Nodes available on the target | |
264 | system. Increases memory reserved to accommodate various tables. | |
26b4c912 | 265 | |
26b4c912 SR |
266 | config ARCH_SPARSEMEM_ENABLE |
267 | def_bool y if SPARC64 | |
268 | select SPARSEMEM_VMEMMAP_ENABLE | |
269 | ||
270 | config ARCH_SPARSEMEM_DEFAULT | |
271 | def_bool y if SPARC64 | |
272 | ||
0192445c | 273 | config ARCH_FORCE_MAX_ORDER |
c88c545b DK |
274 | int "Maximum zone order" |
275 | default "13" | |
276 | help | |
277 | The kernel memory allocator divides physically contiguous memory | |
278 | blocks into "zones", where each zone is a power of two number of | |
279 | pages. This option selects the largest power of two that the kernel | |
280 | keeps in the memory allocator. If you need to allocate very large | |
281 | blocks of physically contiguous memory, then you may need to | |
282 | increase this value. | |
283 | ||
284 | This config option is actually maximum order plus one. For example, | |
285 | a value of 13 means that the largest free memory block is 2^12 pages. | |
286 | ||
7be6a87c | 287 | if SPARC64 || COMPILE_TEST |
bdde6b3c TK |
288 | source "kernel/power/Kconfig" |
289 | endif | |
290 | ||
26b4c912 SR |
291 | config SCHED_SMT |
292 | bool "SMT (Hyperthreading) scheduler support" | |
293 | depends on SPARC64 && SMP | |
294 | default y | |
295 | help | |
296 | SMT scheduler support improves the CPU scheduler's decision making | |
297 | when dealing with SPARC cpus at a cost of slightly increased overhead | |
298 | in some places. If unsure say N here. | |
299 | ||
300 | config SCHED_MC | |
301 | bool "Multi-core scheduler support" | |
302 | depends on SPARC64 && SMP | |
303 | default y | |
304 | help | |
305 | Multi-core scheduler support improves the CPU scheduler's decision | |
306 | making when dealing with multi-core CPU chips at a cost of slightly | |
307 | increased overhead in some places. If unsure say N here. | |
308 | ||
26b4c912 SR |
309 | config CMDLINE_BOOL |
310 | bool "Default bootloader kernel arguments" | |
311 | depends on SPARC64 | |
312 | ||
313 | config CMDLINE | |
314 | string "Initial kernel command string" | |
315 | depends on CMDLINE_BOOL | |
316 | default "console=ttyS0,9600 root=/dev/sda1" | |
317 | help | |
318 | Say Y here if you want to be able to pass default arguments to | |
319 | the kernel. This will be overridden by the bootloader, if you | |
320 | use one (such as SILO). This is most useful if you want to boot | |
321 | a kernel from TFTP, and want default options to be available | |
322 | with having them passed on the command line. | |
323 | ||
324 | NOTE: This option WILL override the PROM bootargs setting! | |
325 | ||
326 | config SUN_PM | |
327 | bool | |
328 | default y if SPARC32 | |
1da177e4 LT |
329 | help |
330 | Enable power management and CPU standby features on supported | |
331 | SPARC platforms. | |
332 | ||
4b27e0e1 SR |
333 | config SPARC_LED |
334 | tristate "Sun4m LED driver" | |
26b4c912 | 335 | depends on SPARC32 |
4b27e0e1 SR |
336 | help |
337 | This driver toggles the front-panel LED on sun4m systems | |
338 | in a user-specifiable manner. Its state can be probed | |
339 | by reading /proc/led and its blinking mode can be changed | |
340 | via writes to /proc/led | |
341 | ||
26b4c912 SR |
342 | config SERIAL_CONSOLE |
343 | bool | |
344 | depends on SPARC32 | |
345 | default y | |
a7f7f624 | 346 | help |
26b4c912 SR |
347 | If you say Y here, it will be possible to use a serial port as the |
348 | system console (the system console is the device which receives all | |
349 | kernel messages and warnings and which allows logins in single user | |
350 | mode). This could be useful if some terminal or printer is connected | |
351 | to that serial port. | |
352 | ||
353 | Even if you say Y here, the currently visible virtual console | |
354 | (/dev/tty0) will still be used as the system console by default, but | |
355 | you can alter that using a kernel command line option such as | |
356 | "console=ttyS1". (Try "man bootparam" or see the documentation of | |
357 | your boot loader (silo) about how to pass options to the kernel at | |
358 | boot time.) | |
359 | ||
360 | If you don't have a graphics card installed and you say Y here, the | |
361 | kernel will automatically use the first serial line, /dev/ttyS0, as | |
362 | system console. | |
363 | ||
364 | If unsure, say N. | |
4b27e0e1 | 365 | |
5213a780 KE |
366 | config SPARC_LEON |
367 | bool "Sparc Leon processor family" | |
368 | depends on SPARC32 | |
9296d94d FF |
369 | select USB_EHCI_BIG_ENDIAN_MMIO |
370 | select USB_EHCI_BIG_ENDIAN_DESC | |
5efad9ee JH |
371 | select USB_UHCI_BIG_ENDIAN_MMIO |
372 | select USB_UHCI_BIG_ENDIAN_DESC | |
a7f7f624 | 373 | help |
5213a780 KE |
374 | If you say Y here if you are running on a SPARC-LEON processor. |
375 | The LEON processor is a synthesizable VHDL model of the | |
376 | SPARC-v8 standard. LEON is part of the GRLIB collection of | |
377 | IP cores that are distributed under GPL. GRLIB can be downloaded | |
378 | from www.gaisler.com. You can download a sparc-linux cross-compilation | |
379 | toolchain at www.gaisler.com. | |
380 | ||
684151a7 DH |
381 | if SPARC_LEON |
382 | menu "U-Boot options" | |
383 | ||
384 | config UBOOT_LOAD_ADDR | |
385 | hex "uImage Load Address" | |
386 | default 0x40004000 | |
a7f7f624 | 387 | help |
684151a7 DH |
388 | U-Boot kernel load address, the address in physical address space |
389 | where u-boot will place the Linux kernel before booting it. | |
390 | This address is normally the base address of main memory + 0x4000. | |
391 | ||
392 | config UBOOT_FLASH_ADDR | |
393 | hex "uImage.o Load Address" | |
394 | default 0x00080000 | |
a7f7f624 | 395 | help |
684151a7 DH |
396 | Optional setting only affecting the uImage.o ELF-image used to |
397 | download the uImage file to the target using a ELF-loader other than | |
398 | U-Boot. It may for example be used to download an uImage to FLASH with | |
399 | the GRMON utility before even starting u-boot. | |
400 | ||
401 | config UBOOT_ENTRY_ADDR | |
402 | hex "uImage Entry Address" | |
403 | default 0xf0004000 | |
a7f7f624 | 404 | help |
684151a7 DH |
405 | Do not change this unless you know what you're doing. This is |
406 | hardcoded by the SPARC32 and LEON port. | |
407 | ||
408 | This is the virtual address u-boot jumps to when booting the Linux | |
409 | Kernel. | |
410 | ||
411 | endmenu | |
412 | endif | |
413 | ||
4b27e0e1 SR |
414 | endmenu |
415 | ||
416 | menu "Bus options (PCI etc.)" | |
4b27e0e1 SR |
417 | config SBUS |
418 | bool | |
419 | default y | |
420 | ||
421 | config SBUSCHAR | |
422 | bool | |
423 | default y | |
424 | ||
26b4c912 SR |
425 | config SUN_LDOMS |
426 | bool "Sun Logical Domains support" | |
427 | depends on SPARC64 | |
428 | help | |
429 | Say Y here is you want to support virtual devices via | |
430 | Logical Domains. | |
431 | ||
cfe3af5d DH |
432 | config PCIC_PCI |
433 | bool | |
8c47f8d0 | 434 | depends on PCI && SPARC32 && !SPARC_LEON |
cfe3af5d DH |
435 | default y |
436 | ||
26893c13 DH |
437 | config LEON_PCI |
438 | bool | |
439 | depends on PCI && SPARC_LEON | |
440 | default y | |
441 | ||
d8650106 DH |
442 | config SPARC_GRPCI1 |
443 | bool "GRPCI Host Bridge Support" | |
444 | depends on LEON_PCI | |
445 | default y | |
446 | help | |
447 | Say Y here to include the GRPCI Host Bridge Driver. The GRPCI | |
448 | PCI host controller is typically found in GRLIB SPARC32/LEON | |
449 | systems. The driver has one property (all_pci_errors) controlled | |
450 | from the bootloader that makes the GRPCI to generate interrupts | |
451 | on detected PCI Parity and System errors. | |
452 | ||
1ab0a676 | 453 | config SPARC_GRPCI2 |
5d07b786 DH |
454 | bool "GRPCI2 Host Bridge Support" |
455 | depends on LEON_PCI | |
456 | default y | |
457 | help | |
458 | Say Y here to include the GRPCI2 Host Bridge Driver. | |
459 | ||
1da177e4 LT |
460 | config SUN_OPENPROMFS |
461 | tristate "Openprom tree appears in /proc/openprom" | |
462 | help | |
463 | If you say Y, the OpenPROM device tree will be available as a | |
464 | virtual file system, which you can mount to /proc/openprom by "mount | |
465 | -t openpromfs none /proc/openprom". | |
466 | ||
467 | To compile the /proc/openprom support as a module, choose M here: the | |
468 | module will be called openpromfs. | |
469 | ||
470 | Only choose N if you know in advance that you will not need to modify | |
471 | OpenPROM settings on the running system. | |
472 | ||
a988fb80 | 473 | # Makefile helpers |
d670bd4f SR |
474 | config SPARC64_PCI |
475 | bool | |
476 | default y | |
477 | depends on SPARC64 && PCI | |
30aaa808 | 478 | |
a988fb80 TP |
479 | config SPARC64_PCI_MSI |
480 | bool | |
481 | default y | |
482 | depends on SPARC64_PCI && PCI_MSI | |
483 | ||
30aaa808 WLII |
484 | endmenu |
485 | ||
26b4c912 SR |
486 | config COMPAT |
487 | bool | |
488 | depends on SPARC64 | |
489 | default y | |
af1839eb | 490 | select HAVE_UID16 |
48b25c43 | 491 | select ARCH_WANT_OLD_COMPAT_IPC |
a274bd49 | 492 | select COMPAT_OLD_SIGACTION |
26b4c912 | 493 | |
1da177e4 | 494 | source "drivers/sbus/char/Kconfig" |