scripts/gdb: Fix gdb 'lx-symbols' command
[linux-2.6-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
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
91d4ce98 87 select ARCH_HAS_VM_GET_PAGE_PROT
7a017721 88 select HAVE_ARCH_AUDITSYSCALL
4badad35 89 select ARCH_SUPPORTS_ATOMIC_RMW
5d6ad668 90 select ARCH_SUPPORTS_DEBUG_PAGEALLOC
42a0bb3f 91 select HAVE_NMI
b7c02b73 92 select HAVE_REGS_AND_STACK_ACCESS_API
a37594f1 93 select ARCH_USE_QUEUED_RWLOCKS
145d9785 94 select ARCH_USE_QUEUED_SPINLOCKS
9a08862a
NM
95 select GENERIC_TIME_VSYSCALL
96 select ARCH_CLOCKSOURCE_DATA
3010a5ea 97 select ARCH_HAS_PTE_SPECIAL
2eac9c2d 98 select PCI_DOMAINS if PCI
4eb0716e 99 select ARCH_HAS_GIGANTIC_PAGE
cd1a41ce 100 select HAVE_SOFTIRQ_ON_OWN_STACK
7ecd19cf
KW
101 select HAVE_SETUP_PER_CPU_AREA
102 select NEED_PER_CPU_EMBED_FIRST_CHUNK
103 select NEED_PER_CPU_PAGE_FIRST_CHUNK
26b4c912 104
3c08158e
DM
105config ARCH_PROC_KCORE_TEXT
106 def_bool y
107
97d9f969
BM
108config CPU_BIG_ENDIAN
109 def_bool y
110
c88c545b
DK
111config ARCH_ATU
112 bool
113 default y if SPARC64
114
26b4c912
SR
115config STACKTRACE_SUPPORT
116 bool
117 default y if SPARC64
118
119config LOCKDEP_SUPPORT
120 bool
121 default y if SPARC64
122
bdde6b3c
TK
123config ARCH_HIBERNATION_POSSIBLE
124 def_bool y if SPARC64
125
26b4c912
SR
126config AUDIT_ARCH
127 bool
7e7e93a2 128 default y
26b4c912 129
1da177e4
LT
130config MMU
131 bool
132 default y
133
1da177e4
LT
134config HIGHMEM
135 bool
26b4c912 136 default y if SPARC32
3293efa9 137 select KMAP_LOCAL
1da177e4
LT
138
139config GENERIC_ISA_DMA
140 bool
26b4c912 141 default y if SPARC32
1da177e4 142
81a2936c
KS
143config PGTABLE_LEVELS
144 default 4 if 64BIT
145 default 3
146
e8f4aa60
AP
147config ARCH_SUPPORTS_UPROBES
148 def_bool y if SPARC64
149
26b4c912 150menu "Processor type and features"
1da177e4 151
1da177e4 152config SMP
6b7679dd 153 bool "Symmetric multi-processing support"
a7f7f624 154 help
1da177e4
LT
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
4a474157 159 If you say N here, the kernel will run on uni- and multiprocessor
1da177e4
LT
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,
4a474157 162 uniprocessor machines. On a uniprocessor machine, the kernel
1da177e4
LT
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
4f4cfa6c 169 See also <file:Documentation/admin-guide/lockup-watchdogs.rst> and the SMP-HOWTO
37719576 170 available at <https://www.tldp.org/docs.html#howto>.
1da177e4
LT
171
172 If you don't know what to do here, say N.
173
174config NR_CPUS
26b4c912 175 int "Maximum number of CPUs"
1da177e4 176 depends on SMP
26b4c912 177 range 2 32 if SPARC32
c79a1373 178 range 2 4096 if SPARC64
26b4c912 179 default 32 if SPARC32
c79a1373 180 default 4096 if SPARC64
1da177e4 181
8636a1f9 182source "kernel/Kconfig.hz"
1da177e4 183
d59288b7
AM
184config GENERIC_HWEIGHT
185 bool
e0b20296 186 default y
d59288b7 187
1da177e4
LT
188config GENERIC_CALIBRATE_DELAY
189 bool
190 default y
191
a08b6b79
Z
192config ARCH_MAY_HAVE_PC_FDC
193 bool
194 default y
195
5f81941c
MH
196config EMULATED_CMPXCHG
197 bool
26b4c912 198 default y if SPARC32
5f81941c
MH
199 help
200 Sparc32 does not have a CAS instruction like sparc64. cmpxchg()
201 is emulated, and therefore it is not completely atomic.
202
d670bd4f
SR
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
c57ec52f
DM
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
26b4c912
SR
221config HOTPLUG_CPU
222 bool "Support for hot-pluggable CPUs"
223 depends on SPARC64 && SMP
26b4c912
SR
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
26b4c912
SR
229if SPARC64
230source "drivers/cpufreq/Kconfig"
26b4c912
SR
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
1da177e4
LT
247 bool
248 default y
85a683d0 249 depends on SPARC64 && SMP && PREEMPTION
26b4c912 250
26b4c912
SR
251config NUMA
252 bool "NUMA support"
253 depends on SPARC64 && SMP
254
255config NODES_SHIFT
7485af89
JC
256 int "Maximum NUMA Nodes (as a power of 2)"
257 range 4 5 if SPARC64
258 default "5"
a9ee6cf5 259 depends on NUMA
7485af89
JC
260 help
261 Specify the maximum number of NUMA Nodes available on the target
262 system. Increases memory reserved to accommodate various tables.
26b4c912 263
26b4c912
SR
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
c88c545b
DK
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
bdde6b3c
TK
285if SPARC64
286source "kernel/power/Kconfig"
287endif
288
26b4c912
SR
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
26b4c912
SR
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
1da177e4
LT
327 help
328 Enable power management and CPU standby features on supported
329 SPARC platforms.
330
4b27e0e1
SR
331config SPARC_LED
332 tristate "Sun4m LED driver"
26b4c912 333 depends on SPARC32
4b27e0e1
SR
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
26b4c912
SR
340config SERIAL_CONSOLE
341 bool
342 depends on SPARC32
343 default y
a7f7f624 344 help
26b4c912
SR
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.
4b27e0e1 363
5213a780
KE
364config SPARC_LEON
365 bool "Sparc Leon processor family"
366 depends on SPARC32
9296d94d
FF
367 select USB_EHCI_BIG_ENDIAN_MMIO
368 select USB_EHCI_BIG_ENDIAN_DESC
5efad9ee
JH
369 select USB_UHCI_BIG_ENDIAN_MMIO
370 select USB_UHCI_BIG_ENDIAN_DESC
a7f7f624 371 help
5213a780
KE
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
684151a7
DH
379if SPARC_LEON
380menu "U-Boot options"
381
382config UBOOT_LOAD_ADDR
383 hex "uImage Load Address"
384 default 0x40004000
a7f7f624 385 help
684151a7
DH
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
a7f7f624 393 help
684151a7
DH
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
a7f7f624 402 help
684151a7
DH
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
4b27e0e1
SR
412endmenu
413
414menu "Bus options (PCI etc.)"
4b27e0e1
SR
415config SBUS
416 bool
417 default y
418
419config SBUSCHAR
420 bool
421 default y
422
26b4c912
SR
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
cfe3af5d
DH
430config PCIC_PCI
431 bool
8c47f8d0 432 depends on PCI && SPARC32 && !SPARC_LEON
cfe3af5d
DH
433 default y
434
26893c13
DH
435config LEON_PCI
436 bool
437 depends on PCI && SPARC_LEON
438 default y
439
d8650106
DH
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
1ab0a676 451config SPARC_GRPCI2
5d07b786
DH
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
1da177e4
LT
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
a988fb80 471# Makefile helpers
d670bd4f
SR
472config SPARC64_PCI
473 bool
474 default y
475 depends on SPARC64 && PCI
30aaa808 476
a988fb80
TP
477config SPARC64_PCI_MSI
478 bool
479 default y
480 depends on SPARC64_PCI && PCI_MSI
481
30aaa808
WLII
482endmenu
483
26b4c912
SR
484config COMPAT
485 bool
486 depends on SPARC64
487 default y
af1839eb 488 select HAVE_UID16
48b25c43 489 select ARCH_WANT_OLD_COMPAT_IPC
a274bd49 490 select COMPAT_OLD_SIGACTION
26b4c912 491
1da177e4 492source "drivers/sbus/char/Kconfig"