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