sparc: allow PM configs for sparc32 COMPILE_TEST
[linux-block.git] / arch / sparc / Kconfig
CommitLineData
ec8f24b7 1# SPDX-License-Identifier: GPL-2.0-only
761b6026 2config 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
13config 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 51config 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 62config 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
106config ARCH_PROC_KCORE_TEXT
107 def_bool y
108
97d9f969
BM
109config CPU_BIG_ENDIAN
110 def_bool y
111
c88c545b
DK
112config ARCH_ATU
113 bool
114 default y if SPARC64
115
26b4c912
SR
116config STACKTRACE_SUPPORT
117 bool
118 default y if SPARC64
119
120config LOCKDEP_SUPPORT
121 bool
122 default y if SPARC64
123
bdde6b3c
TK
124config ARCH_HIBERNATION_POSSIBLE
125 def_bool y if SPARC64
126
26b4c912
SR
127config AUDIT_ARCH
128 bool
7e7e93a2 129 default y
26b4c912 130
1da177e4
LT
131config MMU
132 bool
133 default y
134
1da177e4
LT
135config HIGHMEM
136 bool
26b4c912 137 default y if SPARC32
3293efa9 138 select KMAP_LOCAL
1da177e4
LT
139
140config GENERIC_ISA_DMA
141 bool
26b4c912 142 default y if SPARC32
1da177e4 143
81a2936c
KS
144config PGTABLE_LEVELS
145 default 4 if 64BIT
146 default 3
147
e8f4aa60
AP
148config ARCH_SUPPORTS_UPROBES
149 def_bool y if SPARC64
150
26b4c912 151menu "Processor type and features"
1da177e4 152
1da177e4 153config 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
175config 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 183source "kernel/Kconfig.hz"
1da177e4 184
d59288b7
AM
185config GENERIC_HWEIGHT
186 bool
e0b20296 187 default y
d59288b7 188
1da177e4
LT
189config GENERIC_CALIBRATE_DELAY
190 bool
191 default y
192
a08b6b79
Z
193config ARCH_MAY_HAVE_PC_FDC
194 bool
195 default y
196
5f81941c
MH
197config 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
205config SPARC32_SMP
206 bool
207 default y
208 depends on SPARC32 && SMP
209
210config SPARC64_SMP
211 bool
212 default y
213 depends on SPARC64 && SMP
214
c57ec52f
DM
215config 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
222config 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
230if SPARC64
231source "drivers/cpufreq/Kconfig"
26b4c912
SR
232endif
233
234config 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.
247config GENERIC_LOCKBREAK
1da177e4
LT
248 bool
249 default y
85a683d0 250 depends on SPARC64 && SMP && PREEMPTION
26b4c912 251
26b4c912
SR
252config NUMA
253 bool "NUMA support"
254 depends on SPARC64 && SMP
255
256config 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
265config ARCH_SPARSEMEM_ENABLE
266 def_bool y if SPARC64
267 select SPARSEMEM_VMEMMAP_ENABLE
268
269config ARCH_SPARSEMEM_DEFAULT
270 def_bool y if SPARC64
271
0192445c 272config 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 286if SPARC64 || COMPILE_TEST
bdde6b3c
TK
287source "kernel/power/Kconfig"
288endif
289
26b4c912
SR
290config 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
299config 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
308config CMDLINE_BOOL
309 bool "Default bootloader kernel arguments"
310 depends on SPARC64
311
312config 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
325config 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
332config 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
341config 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
365config 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
380if SPARC_LEON
381menu "U-Boot options"
382
383config 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
391config 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
400config 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
410endmenu
411endif
412
4b27e0e1
SR
413endmenu
414
415menu "Bus options (PCI etc.)"
4b27e0e1
SR
416config SBUS
417 bool
418 default y
419
420config SBUSCHAR
421 bool
422 default y
423
26b4c912
SR
424config 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
431config PCIC_PCI
432 bool
8c47f8d0 433 depends on PCI && SPARC32 && !SPARC_LEON
cfe3af5d
DH
434 default y
435
26893c13
DH
436config LEON_PCI
437 bool
438 depends on PCI && SPARC_LEON
439 default y
440
d8650106
DH
441config 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 452config 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
459config 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
473config SPARC64_PCI
474 bool
475 default y
476 depends on SPARC64 && PCI
30aaa808 477
a988fb80
TP
478config SPARC64_PCI_MSI
479 bool
480 default y
481 depends on SPARC64_PCI && PCI_MSI
482
30aaa808
WLII
483endmenu
484
26b4c912
SR
485config 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 493source "drivers/sbus/char/Kconfig"