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