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