1# SPDX-License-Identifier: GPL-2.0 2config 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 36 37config STACKTRACE_SUPPORT 38 def_bool y 39 40config LOCKDEP_SUPPORT 41 def_bool y 42 43config RWSEM_GENERIC_SPINLOCK 44 def_bool y 45 46config RWSEM_XCHGADD_ALGORITHM 47 bool 48 49config GENERIC_HWEIGHT 50 def_bool y 51 52config GENERIC_CALIBRATE_DELAY 53 def_bool y 54 55config NO_IOPORT_MAP 56 def_bool y 57 58source "init/Kconfig" 59 60source "kernel/Kconfig.freezer" 61 62menu "Processor type and features" 63 64config MMU 65 def_bool y 66 67config STACK_GROWSUP 68 def_bool y 69 70config 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. 76 77 Say N if you want to disable CPU hotplug. 78 79config 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". 88 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. 92 93 If unsure, say n. 94 95source "arch/metag/mm/Kconfig" 96 97source "arch/metag/Kconfig.soc" 98 99config 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. 104 105config 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. 110 111config 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. 118 119config 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 124 125config 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. 134 135config 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. 142 143choice 144 prompt "Atomicity primitive" 145 default METAG_ATOMICITY_LNKGET 146 help 147 This option selects the mechanism for performing atomic operations. 148 149config 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. 155 156config 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. 163 164config 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. 171 172endchoice 173 174config 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. 182 183 If you plan on running programs which are compiled to use hard floats 184 say Y here. 185 186config 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. 192 193 If you plan on running DSP programs say Y here. 194 195config 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). 202 203 When disabled, Performance Counters information will be collected 204 based on Timer Interrupt. 205 206config HW_PERF_EVENTS 207 def_bool METAG_PERFCOUNTER_IRQS && PERF_EVENTS 208 209config 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. 215 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. 220 221menu "Boot options" 222 223config 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. 228 229config 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). 235 236config CMDLINE_BOOL 237 bool "Default bootloader kernel arguments" 238 239config 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. 247 248config 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. 254 255endmenu 256 257source "kernel/Kconfig.preempt" 258 259source kernel/Kconfig.hz 260 261endmenu 262 263menu "Power management options" 264 265source kernel/power/Kconfig 266 267endmenu 268 269menu "Executable file formats" 270 271source "fs/Kconfig.binfmt" 272 273endmenu 274 275source "net/Kconfig" 276 277source "drivers/Kconfig" 278 279source "fs/Kconfig" 280 281source "arch/metag/Kconfig.debug" 282 283source "security/Kconfig" 284 285source "crypto/Kconfig" 286 287source "lib/Kconfig" 288