1# x86 general configuration options 2 3# Copyright (c) 2014-2015 Wind River Systems, Inc. 4# SPDX-License-Identifier: Apache-2.0 5 6menu "X86 Architecture Options" 7 depends on X86 8 9config ARCH 10 default "x86" 11 12# 13# CPU Families - the SoC configuration should select the right one. 14# 15 16config CPU_ATOM 17 bool 18 select CPU_HAS_FPU 19 select ARCH_HAS_STACK_PROTECTION if X86_MMU 20 select ARCH_HAS_USERSPACE if X86_MMU 21 select X86_CPU_HAS_MMX 22 select X86_CPU_HAS_SSE 23 select X86_CPU_HAS_SSE2 24 select X86_CPU_HAS_SSE3 25 select CPU_HAS_DCACHE 26 help 27 This option signifies the use of a CPU from the Atom family. 28 29config CPU_APOLLO_LAKE 30 bool 31 select CPU_HAS_FPU 32 select ARCH_HAS_STACK_PROTECTION if X86_MMU 33 select ARCH_HAS_USERSPACE if X86_MMU 34 select X86_MMU 35 select X86_CPU_HAS_MMX 36 select X86_CPU_HAS_SSE 37 select X86_CPU_HAS_SSE2 38 select X86_CPU_HAS_SSE3 39 select X86_CPU_HAS_SSSE3 40 select X86_CPU_HAS_SSE41 41 select X86_CPU_HAS_SSE42 42 select CPU_HAS_DCACHE 43 help 44 This option signifies the use of a CPU from the Apollo Lake family. 45 46config CPU_LAKEMONT 47 bool 48 select CPU_HAS_FPU 49 select ARCH_HAS_STACK_PROTECTION if X86_MMU 50 select ARCH_HAS_USERSPACE if X86_MMU 51 select X86_CPU_HAS_MMX 52 select X86_CPU_HAS_SSE 53 select X86_CPU_HAS_SSE2 54 select X86_CPU_HAS_SSE3 55 select X86_CPU_HAS_SSSE3 56 select CPU_HAS_DCACHE 57 help 58 This option signifies the use of a CPU from the Lakemont family. 59 60# 61# Configuration common to both IA32 and Intel64 sub-architectures. 62# 63 64config X86_64 65 bool "Run in 64-bit mode" 66 select 64BIT 67 select USE_SWITCH 68 select USE_SWITCH_SUPPORTED 69 select SCHED_IPI_SUPPORTED 70 select X86_MMU 71 select X86_CPU_HAS_MMX 72 select X86_CPU_HAS_SSE 73 select X86_CPU_HAS_SSE2 74 select X86_MMX 75 select X86_SSE 76 select X86_SSE2 77 78menu "x86 Features" 79 80config X86_CPU_HAS_MMX 81 bool 82 83config X86_CPU_HAS_SSE 84 bool 85 86config X86_CPU_HAS_SSE2 87 bool 88 89config X86_CPU_HAS_SSE3 90 bool 91 92config X86_CPU_HAS_SSSE3 93 bool 94 95config X86_CPU_HAS_SSE41 96 bool 97 98config X86_CPU_HAS_SSE42 99 bool 100 101config X86_CPU_HAS_SSE4A 102 bool 103 104if FPU || X86_64 105 106config X86_MMX 107 bool "MMX Support" 108 depends on X86_CPU_HAS_MMX 109 help 110 This option enables MMX support, and the use of MMX registers 111 by threads. 112 113config X86_SSE 114 bool "SSE Support" 115 depends on X86_CPU_HAS_SSE 116 help 117 This option enables SSE support, and the use of SSE registers 118 by threads. 119 120config X86_SSE2 121 bool "SSE2 Support" 122 depends on X86_CPU_HAS_SSE2 123 select X86_SSE 124 help 125 This option enables SSE2 support. 126 127config X86_SSE3 128 bool "SSE3 Support" 129 depends on X86_CPU_HAS_SSE3 130 select X86_SSE 131 help 132 This option enables SSE3 support. 133 134config X86_SSSE3 135 bool "SSSE3 (Supplemental SSE3) Support" 136 depends on X86_CPU_HAS_SSSE3 137 select X86_SSE 138 help 139 This option enables Supplemental SSE3 support. 140 141config X86_SSE41 142 bool "SSE4.1 Support" 143 depends on X86_CPU_HAS_SSE41 144 select X86_SSE 145 help 146 This option enables SSE4.1 support. 147 148config X86_SSE42 149 bool "SSE4.2 Support" 150 depends on X86_CPU_HAS_SSE42 151 select X86_SSE 152 help 153 This option enables SSE4.2 support. 154 155config X86_SSE4A 156 bool "SSE4A Support" 157 depends on X86_CPU_HAS_SSE4A 158 select X86_SSE 159 help 160 This option enables SSE4A support. 161 162config X86_SSE_FP_MATH 163 bool "Compiler-generated SSEx instructions for floating point math" 164 depends on X86_SSE 165 help 166 This option allows the compiler to generate SSEx instructions for 167 performing floating point math. This can greatly improve performance 168 when exactly the same operations are to be performed on multiple 169 data objects; however, it can also significantly reduce performance 170 when preemptive task switches occur because of the larger register 171 set that must be saved and restored. 172 173 Disabling this option means that the compiler utilizes only the 174 x87 instruction set for floating point operations. 175 176endif # FPU || X86_64 177 178endmenu 179 180config SRAM_OFFSET 181 default 0x100000 if X86_PC_COMPATIBLE 182 help 183 A lot of x86 that resemble PCs have many reserved physical memory 184 regions within the first megabyte. Specify an offset from the 185 beginning of RAM to load the kernel in physical memory, avoiding these 186 regions. 187 188 Note that this does not include the "locore" which contains real mode 189 bootstrap code within the first 64K of physical memory. 190 191 This value normally need to be page-aligned. 192 193config KERNEL_VM_OFFSET 194 default 0x100000 if MMU 195 196config MAX_IRQ_LINES 197 int "Number of IRQ lines" 198 default 128 199 range 0 224 200 help 201 This option specifies the number of IRQ lines in the system. It 202 determines the size of the _irq_to_interrupt_vector_table, which 203 is used to track the association between vectors and IRQ numbers. 204 205config IRQ_OFFLOAD_VECTOR 206 int "IDT vector to use for IRQ offload" 207 default 33 208 range 32 $(UINT8_MAX) 209 depends on IRQ_OFFLOAD 210 211config PIC_DISABLE 212 bool "Disable PIC" 213 help 214 This option disables all interrupts on the legacy i8259 PICs at boot. 215 216choice 217 prompt "Reboot implementation" 218 depends on REBOOT 219 default REBOOT_RST_CNT 220 221 config REBOOT_RST_CNT 222 bool "Reboot via RST_CNT register" 223 help 224 Reboot via the RST_CNT register, going back to BIOS. 225endchoice 226 227config PCIE_MMIO_CFG 228 bool "Use MMIO PCI configuration space access" 229 select ACPI 230 help 231 Selects the use of the memory-mapped PCI Express Extended 232 Configuration Space instead of the traditional 0xCF8/0xCFC 233 IO Port registers. 234 235config KERNEL_VM_SIZE 236 default 0x40000000 if ACPI 237 238config X86_PC_COMPATIBLE 239 bool 240 default y 241 select ARCH_HAS_RESERVED_PAGE_FRAMES 242 select HAS_SRAM_OFFSET 243 help 244 Hidden option to signal building for PC-compatible platforms 245 with BIOS, ACPI, etc. 246 247config X86_MEMMAP 248 bool "Use memory map" 249 select ARCH_HAS_RESERVED_PAGE_FRAMES 250 help 251 Enable the use of memory map to identify regions of memory. 252 253 The memory map can be populated via Multiboot 254 (CONFIG_MULTIBOOT=y and CONFIG_MULTIBOOT_MEMMAP=y) or 255 can be manually defined via x86_memmap[]. 256 257config X86_MEMMAP_ENTRIES 258 int "Number of memory map entries" 259 depends on X86_MEMMAP 260 range 1 256 261 default 1 if !MULTIBOOT_MEMMAP 262 default 64 if MULTIBOOT_MEMMAP 263 help 264 Maximum number of memory regions to hold in the memory map. 265 266config MULTIBOOT 267 bool "Generate multiboot header" 268 depends on X86_PC_COMPATIBLE 269 default y 270 help 271 Embed a multiboot header in the output executable. This is used 272 by some boot loaders (e.g., GRUB) when loading Zephyr. It is safe 273 to leave this option on if you're not sure. It only expands the 274 text segment by 12-16 bytes and is typically ignored if not needed. 275 276if MULTIBOOT 277 278config MULTIBOOT_INFO 279 bool "Preserve multiboot information structure" 280 help 281 Multiboot passes a pointer to an information structure to the 282 kernel entry point. Some drivers (e.g., the multiboot framebuffer 283 display driver) need to refer to information in this structure, 284 and so set this option to preserve the data in a permanent location. 285 286config MULTIBOOT_MEMMAP 287 bool "Use multiboot memory map if provided" 288 select MULTIBOOT_INFO 289 select X86_MEMMAP 290 help 291 Use the multiboot memory map if the loader provides one. 292 293endif # MULTIBOOT 294 295config X86_VERY_EARLY_CONSOLE 296 bool "Support very early boot printk" 297 depends on PRINTK 298 help 299 Non-emulated X86 devices often require special hardware to attach 300 a debugger, which may not be easily available. This option adds a 301 very minimal serial driver which gets initialized at the very 302 beginning of z_cstart(), via arch_kernel_init(). This driver enables 303 printk to emit messages to the 16550 UART port 0 instance in device 304 tree. This mini-driver assumes I/O to the UART is done via ports. 305 306config X86_MMU 307 bool "Memory Management Unit" 308 select MMU 309 help 310 This options enables the memory management unit present in x86 311 and creates a set of page tables at boot time that is runtime- 312 mutable. 313 314config X86_COMMON_PAGE_TABLE 315 bool "Use a single page table for all threads" 316 default n 317 depends on USERSPACE 318 depends on !SMP 319 depends on !X86_KPTI 320 help 321 If this option is enabled, userspace memory domains will not have their 322 own page tables. Instead, context switching operations will modify 323 page tables in place. This is much slower, but uses much less RAM 324 for page tables. 325 326config X86_MAX_ADDITIONAL_MEM_DOMAINS 327 int "Maximum number of memory domains" 328 default 3 329 depends on X86_MMU && USERSPACE && !X86_COMMON_PAGE_TABLE 330 help 331 The initial page tables at boot are pre-allocated, and used for the 332 default memory domain. Instantiation of additional memory domains 333 if common page tables are in use requires a pool of free pinned 334 memory pages for constructing page tables. 335 336 Zephyr test cases assume 3 additional domains can be instantiated. 337 338config X86_EXTRA_PAGE_TABLE_PAGES 339 int "Reserve extra pages in page table" 340 default 1 if X86_PAE && (KERNEL_VM_BASE != SRAM_BASE_ADDRESS) 341 default 0 342 depends on X86_MMU 343 help 344 The whole page table is pre-allocated at build time and is 345 dependent on the range of address space. This allows reserving 346 extra pages (of size CONFIG_MMU_PAGE_SIZE) to the page table 347 so that gen_mmu.py can make use of these extra pages. 348 349 Says 0 unless absolutely sure that this is necessary. 350 351config X86_NO_MELTDOWN 352 bool 353 help 354 This hidden option should be set on a per-SOC basis to indicate that 355 a particular SOC is not vulnerable to the Meltdown CPU vulnerability, 356 as described in CVE-2017-5754. 357 358config X86_NO_SPECTRE_V1 359 bool 360 help 361 This hidden option should be set on a per-SOC basis to indicate that 362 a particular SOC is not vulnerable to the Spectre V1, V1.1, V1.2, and 363 swapgs CPU vulnerabilities as described in CVE-2017-5753, 364 CVE-2018-3693, and CVE-2019-1125. 365 366config X86_NO_SPECTRE_V2 367 bool 368 help 369 This hidden option should be set on a per-SOC basis to indicate that 370 a particular SOC is not vulnerable to the Spectre V2 CPU 371 vulnerability, as described in CVE-2017-5715. 372 373config X86_NO_SPECTRE_V4 374 bool 375 help 376 This hidden option should be set on a per-SOC basis to indicate that 377 a particular SOC is not vulnerable to the Spectre V4 CPU 378 vulnerability, as described in CVE-2018-3639. 379 380config X86_NO_LAZY_FP 381 bool 382 help 383 This hidden option should be set on a per-SOC basis to indicate 384 that a particular SOC is not vulnerable to the Lazy FP CPU 385 vulnerability, as described in CVE-2018-3665. 386 387config X86_NO_SPECULATIVE_VULNERABILITIES 388 bool 389 select X86_NO_MELTDOWN 390 select X86_NO_SPECTRE_V1 391 select X86_NO_SPECTRE_V2 392 select X86_NO_SPECTRE_V4 393 select X86_NO_LAZY_FP 394 help 395 This hidden option should be set on a per-SOC basis to indicate that 396 a particular SOC does not perform any kind of speculative execution, 397 or is a newer chip which is immune to the class of vulnerabilities 398 which exploit speculative execution side channel attacks. 399 400config X86_DISABLE_SSBD 401 bool "Disable Speculative Store Bypass" 402 depends on USERSPACE 403 default y if !X86_NO_SPECTRE_V4 404 help 405 This option will disable Speculative Store Bypass in order to 406 mitigate against certain kinds of side channel attacks. Quoting 407 the "Speculative Execution Side Channels" document, version 2.0: 408 409 When SSBD is set, loads will not execute speculatively 410 until the addresses of all older stores are known. This 411 ensure s that a load does not speculatively consume stale 412 data values due to bypassing an older store on the same 413 logical processor. 414 415 If enabled, this applies to all threads in the system. 416 417 Even if enabled, will have no effect on CPUs that do not 418 require this feature. 419 420config X86_ENABLE_EXTENDED_IBRS 421 bool "Extended IBRS" 422 depends on USERSPACE 423 default y if !X86_NO_SPECTRE_V2 424 help 425 This option will enable the Extended Indirect Branch Restricted 426 Speculation 'always on' feature. This mitigates Indirect Branch 427 Control vulnerabilities (aka Spectre V2). 428 429config X86_BOUNDS_CHECK_BYPASS_MITIGATION 430 bool 431 depends on USERSPACE 432 default y if !X86_NO_SPECTRE_V1 433 select BOUNDS_CHECK_BYPASS_MITIGATION 434 help 435 Hidden config to select arch-independent option to enable 436 Spectre V1 mitigations by default if the CPU is not known 437 to be immune to it. 438 439config X86_KPTI 440 bool "Kernel page table isolation" 441 default y 442 depends on USERSPACE 443 depends on !X86_NO_MELTDOWN 444 help 445 Implements kernel page table isolation to mitigate Meltdown exploits 446 to read Kernel RAM. Incurs a significant performance cost for 447 user thread interrupts and system calls, and significant footprint 448 increase for additional page tables and trampoline stacks. 449 450config X86_EFI 451 bool "EFI" 452 default y 453 depends on BUILD_OUTPUT_EFI 454 help 455 Enable EFI support. This means you build your image with zefi 456 support. See arch/x86/zefi/README.txt for more information. 457 458config X86_EFI_CONSOLE 459 bool 460 depends on X86_EFI && X86_64 && !X86_VERY_EARLY_CONSOLE 461 select EFI_CONSOLE 462 default y if !UART_CONSOLE 463 help 464 This enables the use of the UEFI console device as the 465 Zephyr printk handler. It requires that no interferences 466 with hardware used by the firmware console (e.g. a UART or 467 framebuffer) happens from Zephyr code, and that all memory 468 used by the firmware environment and its page tables be 469 separate and preserved. In general this is safe to assume, 470 but no automatic checking exists at runtime to verify. 471 Likewise be sure to disable any other console/printk 472 drivers! 473 474config PRIVILEGED_STACK_SIZE 475 # Must be multiple of CONFIG_MMU_PAGE_SIZE 476 default 4096 if X86_MMU 477 478source "arch/x86/core/Kconfig.ia32" 479source "arch/x86/core/Kconfig.intel64" 480 481endmenu 482