xtensa: fix high memory/reserved memory collision
[cris-mirror.git] / arch / metag / Kconfig
blobc7b62a3395390e38765956f8cd3b119e82be41c5
1 # SPDX-License-Identifier: GPL-2.0
2 config METAG
3         def_bool y
4         select EMBEDDED
5         select GENERIC_ATOMIC64
6         select GENERIC_CLOCKEVENTS
7         select GENERIC_IRQ_SHOW
8         select GENERIC_SMP_IDLE_THREAD
9         select HAVE_64BIT_ALIGNED_ACCESS
10         select HAVE_ARCH_TRACEHOOK
11         select HAVE_C_RECORDMCOUNT
12         select HAVE_DEBUG_KMEMLEAK
13         select HAVE_DEBUG_STACKOVERFLOW
14         select HAVE_DYNAMIC_FTRACE
15         select HAVE_EXIT_THREAD
16         select HAVE_FTRACE_MCOUNT_RECORD
17         select HAVE_FUNCTION_TRACER
18         select HAVE_KERNEL_BZIP2
19         select HAVE_KERNEL_GZIP
20         select HAVE_KERNEL_LZO
21         select HAVE_KERNEL_XZ
22         select HAVE_MEMBLOCK
23         select HAVE_MEMBLOCK_NODE_MAP
24         select HAVE_MOD_ARCH_SPECIFIC
25         select HAVE_OPROFILE
26         select HAVE_PERF_EVENTS
27         select HAVE_SYSCALL_TRACEPOINTS
28         select HAVE_UNDERSCORE_SYMBOL_PREFIX
29         select IRQ_DOMAIN
30         select GENERIC_IRQ_EFFECTIVE_AFF_MASK
31         select MODULES_USE_ELF_RELA
32         select OF
33         select OF_EARLY_FLATTREE
34         select SPARSE_IRQ
35         select CPU_NO_EFFICIENT_FFS
37 config STACKTRACE_SUPPORT
38         def_bool y
40 config LOCKDEP_SUPPORT
41         def_bool y
43 config RWSEM_GENERIC_SPINLOCK
44         def_bool y
46 config RWSEM_XCHGADD_ALGORITHM
47         bool
49 config GENERIC_HWEIGHT
50         def_bool y
52 config GENERIC_CALIBRATE_DELAY
53         def_bool y
55 config NO_IOPORT_MAP
56         def_bool y
58 source "init/Kconfig"
60 source "kernel/Kconfig.freezer"
62 menu "Processor type and features"
64 config MMU
65         def_bool y
67 config STACK_GROWSUP
68         def_bool y
70 config HOTPLUG_CPU
71         bool "Enable CPU hotplug support"
72         depends on SMP
73         help
74           Say Y here to allow turning CPUs off and on. CPUs can be
75           controlled through /sys/devices/system/cpu.
77           Say N if you want to disable CPU hotplug.
79 config HIGHMEM
80         bool "High Memory Support"
81         help
82           The address space of Meta processors is only 4 Gigabytes large
83           and it has to accommodate user address space, kernel address
84           space as well as some memory mapped IO. That means that, if you
85           have a large amount of physical memory and/or IO, not all of the
86           memory can be "permanently mapped" by the kernel. The physical
87           memory that is not permanently mapped is called "high memory".
89           Depending on the selected kernel/user memory split, minimum
90           vmalloc space and actual amount of RAM, you may not need this
91           option which should result in a slightly faster kernel.
93           If unsure, say n.
95 source "arch/metag/mm/Kconfig"
97 source "arch/metag/Kconfig.soc"
99 config METAG_META12
100         bool
101         help
102           Select this from the SoC config symbol to indicate that it contains a
103           Meta 1.2 core.
105 config METAG_META21
106         bool
107         help
108           Select this from the SoC config symbol to indicate that it contains a
109           Meta 2.1 core.
111 config SMP
112         bool "Symmetric multi-processing support"
113         depends on METAG_META21 && METAG_META21_MMU
114         help
115           This enables support for systems with more than one thread running
116           Linux. If you have a system with only one thread running Linux,
117           say N. Otherwise, say Y.
119 config NR_CPUS
120         int "Maximum number of CPUs (2-4)" if SMP
121         range 2 4 if SMP
122         default "1" if !SMP
123         default "4" if SMP
125 config METAG_SMP_WRITE_REORDERING
126         bool
127         help
128           This attempts to prevent cache-memory incoherence due to external
129           reordering of writes from different hardware threads when SMP is
130           enabled. It adds fences (system event 0) to smp_mb and smp_rmb in an
131           attempt to catch some of the cases, and also before writes to shared
132           memory in LOCK1 protected atomics and spinlocks.
133           This will not completely prevent cache incoherency on affected cores.
135 config METAG_LNKGET_AROUND_CACHE
136         bool
137         depends on METAG_META21
138         help
139           This indicates that the LNKGET/LNKSET instructions go around the
140           cache, which requires some extra cache flushes when the memory needs
141           to be accessed by normal GET/SET instructions too.
143 choice
144         prompt "Atomicity primitive"
145         default METAG_ATOMICITY_LNKGET
146         help
147           This option selects the mechanism for performing atomic operations.
149 config METAG_ATOMICITY_IRQSOFF
150         depends on !SMP
151         bool "irqsoff"
152         help
153           This option disables interrupts to achieve atomicity. This mechanism
154           is not SMP-safe.
156 config METAG_ATOMICITY_LNKGET
157         depends on METAG_META21
158         bool "lnkget/lnkset"
159         help
160           This option uses the LNKGET and LNKSET instructions to achieve
161           atomicity. LNKGET/LNKSET are load-link/store-conditional instructions.
162           Choose this option if your system requires low latency.
164 config METAG_ATOMICITY_LOCK1
165         depends on SMP
166         bool "lock1"
167         help
168           This option uses the LOCK1 instruction for atomicity. This is mainly
169           provided as a debugging aid if the lnkget/lnkset atomicity primitive
170           isn't working properly.
172 endchoice
174 config METAG_FPU
175         bool "FPU Support"
176         depends on METAG_META21
177         default y
178         help
179           This option allows processes to use FPU hardware available with this
180           CPU. If this option is not enabled FPU registers will not be saved
181           and restored on context-switch.
183           If you plan on running programs which are compiled to use hard floats
184           say Y here.
186 config METAG_DSP
187         bool "DSP Support"
188         help
189           This option allows processes to use DSP hardware available
190           with this CPU. If this option is not enabled DSP registers
191           will not be saved and restored on context-switch.
193           If you plan on running DSP programs say Y here.
195 config METAG_PERFCOUNTER_IRQS
196         bool "PerfCounters interrupt support"
197         depends on METAG_META21
198         help
199           This option enables using interrupts to collect information from
200           Performance Counters. This option is supported in new META21
201           (starting from HTP265).
203           When disabled, Performance Counters information will be collected
204           based on Timer Interrupt.
206 config HW_PERF_EVENTS
207         def_bool METAG_PERFCOUNTER_IRQS && PERF_EVENTS
209 config METAG_DA
210         bool "DA support"
211         help
212           Say Y if you plan to use a DA debug adapter with Linux. The presence
213           of the DA will be detected automatically at boot, so it is safe to say
214           Y to this option even when booting without a DA.
216           This enables support for services provided by DA JTAG debug adapters,
217           such as:
218           - communication over DA channels (such as the console driver).
219           - use of the DA filesystem.
221 menu "Boot options"
223 config METAG_BUILTIN_DTB
224         bool "Embed DTB in kernel image"
225         default y
226         help
227           Embeds a device tree binary in the kernel image.
229 config METAG_BUILTIN_DTB_NAME
230         string "Built in DTB"
231         depends on METAG_BUILTIN_DTB
232         help
233           Set the name of the DTB to embed (leave blank to pick one
234           automatically based on kernel configuration).
236 config CMDLINE_BOOL
237         bool "Default bootloader kernel arguments"
239 config CMDLINE
240         string "Kernel command line"
241         depends on CMDLINE_BOOL
242         help
243           On some architectures there is currently no way for the boot loader
244           to pass arguments to the kernel. For these architectures, you should
245           supply some command-line options at build time by entering them
246           here.
248 config CMDLINE_FORCE
249         bool "Force default kernel command string"
250         depends on CMDLINE_BOOL
251         help
252           Set this to have arguments from the default kernel command string
253           override those passed by the boot loader.
255 endmenu
257 source "kernel/Kconfig.preempt"
259 source kernel/Kconfig.hz
261 endmenu
263 menu "Power management options"
265 source kernel/power/Kconfig
267 endmenu
269 menu "Executable file formats"
271 source "fs/Kconfig.binfmt"
273 endmenu
275 source "net/Kconfig"
277 source "drivers/Kconfig"
279 source "fs/Kconfig"
281 source "arch/metag/Kconfig.debug"
283 source "security/Kconfig"
285 source "crypto/Kconfig"
287 source "lib/Kconfig"