1# SPDX-License-Identifier: GPL-2.0 2config MIPS 3 bool 4 default y 5 select ARCH_32BIT_OFF_T if !64BIT 6 select ARCH_BINFMT_ELF_STATE if MIPS_FP_SUPPORT 7 select ARCH_HAS_CURRENT_STACK_POINTER if !CC_IS_CLANG || CLANG_VERSION >= 140000 8 select ARCH_HAS_DEBUG_VIRTUAL if !64BIT 9 select ARCH_HAS_FORTIFY_SOURCE 10 select ARCH_HAS_KCOV 11 select ARCH_HAS_NON_OVERLAPPING_ADDRESS_SPACE if !EVA 12 select ARCH_HAS_PTE_SPECIAL if !(32BIT && CPU_HAS_RIXI) 13 select ARCH_HAS_STRNCPY_FROM_USER 14 select ARCH_HAS_STRNLEN_USER 15 select ARCH_HAS_TICK_BROADCAST if GENERIC_CLOCKEVENTS_BROADCAST 16 select ARCH_HAS_UBSAN_SANITIZE_ALL 17 select ARCH_HAS_GCOV_PROFILE_ALL 18 select ARCH_KEEP_MEMBLOCK 19 select ARCH_SUPPORTS_UPROBES 20 select ARCH_USE_BUILTIN_BSWAP 21 select ARCH_USE_CMPXCHG_LOCKREF if 64BIT 22 select ARCH_USE_MEMTEST 23 select ARCH_USE_QUEUED_RWLOCKS 24 select ARCH_USE_QUEUED_SPINLOCKS 25 select ARCH_SUPPORTS_HUGETLBFS if CPU_SUPPORTS_HUGEPAGES 26 select ARCH_WANT_DEFAULT_TOPDOWN_MMAP_LAYOUT if MMU 27 select ARCH_WANT_IPC_PARSE_VERSION 28 select ARCH_WANT_LD_ORPHAN_WARN 29 select BUILDTIME_TABLE_SORT 30 select CLONE_BACKWARDS 31 select CPU_NO_EFFICIENT_FFS if (TARGET_ISA_REV < 1) 32 select CPU_PM if CPU_IDLE 33 select GENERIC_ATOMIC64 if !64BIT 34 select GENERIC_CMOS_UPDATE 35 select GENERIC_CPU_AUTOPROBE 36 select GENERIC_GETTIMEOFDAY 37 select GENERIC_IOMAP 38 select GENERIC_IRQ_PROBE 39 select GENERIC_IRQ_SHOW 40 select GENERIC_ISA_DMA if EISA 41 select GENERIC_LIB_ASHLDI3 42 select GENERIC_LIB_ASHRDI3 43 select GENERIC_LIB_CMPDI2 44 select GENERIC_LIB_LSHRDI3 45 select GENERIC_LIB_UCMPDI2 46 select GENERIC_SCHED_CLOCK if !CAVIUM_OCTEON_SOC 47 select GENERIC_SMP_IDLE_THREAD 48 select GENERIC_TIME_VSYSCALL 49 select GUP_GET_PXX_LOW_HIGH if CPU_MIPS32 && PHYS_ADDR_T_64BIT 50 select HAVE_ARCH_COMPILER_H 51 select HAVE_ARCH_JUMP_LABEL 52 select HAVE_ARCH_KGDB if MIPS_FP_SUPPORT 53 select HAVE_ARCH_MMAP_RND_BITS if MMU 54 select HAVE_ARCH_MMAP_RND_COMPAT_BITS if MMU && COMPAT 55 select HAVE_ARCH_SECCOMP_FILTER 56 select HAVE_ARCH_TRACEHOOK 57 select HAVE_ARCH_TRANSPARENT_HUGEPAGE if CPU_SUPPORTS_HUGEPAGES 58 select HAVE_ASM_MODVERSIONS 59 select HAVE_CONTEXT_TRACKING_USER 60 select HAVE_TIF_NOHZ 61 select HAVE_C_RECORDMCOUNT 62 select HAVE_DEBUG_KMEMLEAK 63 select HAVE_DEBUG_STACKOVERFLOW 64 select HAVE_DMA_CONTIGUOUS 65 select HAVE_DYNAMIC_FTRACE 66 select HAVE_EBPF_JIT if !CPU_MICROMIPS && \ 67 !CPU_DADDI_WORKAROUNDS && \ 68 !CPU_R4000_WORKAROUNDS && \ 69 !CPU_R4400_WORKAROUNDS 70 select HAVE_EXIT_THREAD 71 select HAVE_FAST_GUP 72 select HAVE_FTRACE_MCOUNT_RECORD 73 select HAVE_FUNCTION_GRAPH_TRACER 74 select HAVE_FUNCTION_TRACER 75 select HAVE_GCC_PLUGINS 76 select HAVE_GENERIC_VDSO 77 select HAVE_IOREMAP_PROT 78 select HAVE_IRQ_EXIT_ON_IRQ_STACK 79 select HAVE_IRQ_TIME_ACCOUNTING 80 select HAVE_KPROBES 81 select HAVE_KRETPROBES 82 select HAVE_LD_DEAD_CODE_DATA_ELIMINATION 83 select HAVE_MOD_ARCH_SPECIFIC 84 select HAVE_NMI 85 select HAVE_PERF_EVENTS 86 select HAVE_PERF_REGS 87 select HAVE_PERF_USER_STACK_DUMP 88 select HAVE_REGS_AND_STACK_ACCESS_API 89 select HAVE_RSEQ 90 select HAVE_SPARSE_SYSCALL_NR 91 select HAVE_STACKPROTECTOR 92 select HAVE_SYSCALL_TRACEPOINTS 93 select HAVE_VIRT_CPU_ACCOUNTING_GEN if 64BIT || !SMP 94 select IRQ_FORCED_THREADING 95 select ISA if EISA 96 select MODULES_USE_ELF_REL if MODULES 97 select MODULES_USE_ELF_RELA if MODULES && 64BIT 98 select PERF_USE_VMALLOC 99 select PCI_MSI_ARCH_FALLBACKS if PCI_MSI 100 select RTC_LIB 101 select SYSCTL_EXCEPTION_TRACE 102 select TRACE_IRQFLAGS_SUPPORT 103 select ARCH_HAS_ELFCORE_COMPAT 104 select HAVE_ARCH_KCSAN if 64BIT 105 106config MIPS_FIXUP_BIGPHYS_ADDR 107 bool 108 109config MIPS_GENERIC 110 bool 111 112config MACH_INGENIC 113 bool 114 select SYS_SUPPORTS_32BIT_KERNEL 115 select SYS_SUPPORTS_LITTLE_ENDIAN 116 select SYS_SUPPORTS_ZBOOT 117 select DMA_NONCOHERENT 118 select ARCH_HAS_SYNC_DMA_FOR_CPU 119 select IRQ_MIPS_CPU 120 select PINCTRL 121 select GPIOLIB 122 select COMMON_CLK 123 select GENERIC_IRQ_CHIP 124 select BUILTIN_DTB if MIPS_NO_APPENDED_DTB 125 select USE_OF 126 select CPU_SUPPORTS_CPUFREQ 127 select MIPS_EXTERNAL_TIMER 128 129menu "Machine selection" 130 131choice 132 prompt "System type" 133 default MIPS_GENERIC_KERNEL 134 135config MIPS_GENERIC_KERNEL 136 bool "Generic board-agnostic MIPS kernel" 137 select ARCH_HAS_SETUP_DMA_OPS 138 select MIPS_GENERIC 139 select BOOT_RAW 140 select BUILTIN_DTB 141 select CEVT_R4K 142 select CLKSRC_MIPS_GIC 143 select COMMON_CLK 144 select CPU_MIPSR2_IRQ_EI 145 select CPU_MIPSR2_IRQ_VI 146 select CSRC_R4K 147 select DMA_NONCOHERENT 148 select HAVE_PCI 149 select IRQ_MIPS_CPU 150 select MIPS_AUTO_PFN_OFFSET 151 select MIPS_CPU_SCACHE 152 select MIPS_GIC 153 select MIPS_L1_CACHE_SHIFT_7 154 select NO_EXCEPT_FILL 155 select PCI_DRIVERS_GENERIC 156 select SMP_UP if SMP 157 select SWAP_IO_SPACE 158 select SYS_HAS_CPU_MIPS32_R1 159 select SYS_HAS_CPU_MIPS32_R2 160 select SYS_HAS_CPU_MIPS32_R6 161 select SYS_HAS_CPU_MIPS64_R1 162 select SYS_HAS_CPU_MIPS64_R2 163 select SYS_HAS_CPU_MIPS64_R6 164 select SYS_SUPPORTS_32BIT_KERNEL 165 select SYS_SUPPORTS_64BIT_KERNEL 166 select SYS_SUPPORTS_BIG_ENDIAN 167 select SYS_SUPPORTS_HIGHMEM 168 select SYS_SUPPORTS_LITTLE_ENDIAN 169 select SYS_SUPPORTS_MICROMIPS 170 select SYS_SUPPORTS_MIPS16 171 select SYS_SUPPORTS_MIPS_CPS 172 select SYS_SUPPORTS_MULTITHREADING 173 select SYS_SUPPORTS_RELOCATABLE 174 select SYS_SUPPORTS_SMARTMIPS 175 select SYS_SUPPORTS_ZBOOT 176 select UHI_BOOT 177 select USB_EHCI_BIG_ENDIAN_DESC if CPU_BIG_ENDIAN 178 select USB_EHCI_BIG_ENDIAN_MMIO if CPU_BIG_ENDIAN 179 select USB_OHCI_BIG_ENDIAN_DESC if CPU_BIG_ENDIAN 180 select USB_OHCI_BIG_ENDIAN_MMIO if CPU_BIG_ENDIAN 181 select USB_UHCI_BIG_ENDIAN_DESC if CPU_BIG_ENDIAN 182 select USB_UHCI_BIG_ENDIAN_MMIO if CPU_BIG_ENDIAN 183 select USE_OF 184 help 185 Select this to build a kernel which aims to support multiple boards, 186 generally using a flattened device tree passed from the bootloader 187 using the boot protocol defined in the UHI (Unified Hosting 188 Interface) specification. 189 190config MIPS_ALCHEMY 191 bool "Alchemy processor based machines" 192 select PHYS_ADDR_T_64BIT 193 select CEVT_R4K 194 select CSRC_R4K 195 select IRQ_MIPS_CPU 196 select DMA_NONCOHERENT # Au1000,1500,1100 aren't, rest is 197 select MIPS_FIXUP_BIGPHYS_ADDR if PCI 198 select SYS_HAS_CPU_MIPS32_R1 199 select SYS_SUPPORTS_32BIT_KERNEL 200 select SYS_SUPPORTS_APM_EMULATION 201 select GPIOLIB 202 select SYS_SUPPORTS_ZBOOT 203 select COMMON_CLK 204 205config AR7 206 bool "Texas Instruments AR7" 207 select BOOT_ELF32 208 select COMMON_CLK 209 select DMA_NONCOHERENT 210 select CEVT_R4K 211 select CSRC_R4K 212 select IRQ_MIPS_CPU 213 select NO_EXCEPT_FILL 214 select SWAP_IO_SPACE 215 select SYS_HAS_CPU_MIPS32_R1 216 select SYS_HAS_EARLY_PRINTK 217 select SYS_SUPPORTS_32BIT_KERNEL 218 select SYS_SUPPORTS_LITTLE_ENDIAN 219 select SYS_SUPPORTS_MIPS16 220 select SYS_SUPPORTS_ZBOOT_UART16550 221 select GPIOLIB 222 select VLYNQ 223 help 224 Support for the Texas Instruments AR7 System-on-a-Chip 225 family: TNETD7100, 7200 and 7300. 226 227config ATH25 228 bool "Atheros AR231x/AR531x SoC support" 229 select CEVT_R4K 230 select CSRC_R4K 231 select DMA_NONCOHERENT 232 select IRQ_MIPS_CPU 233 select IRQ_DOMAIN 234 select SYS_HAS_CPU_MIPS32_R1 235 select SYS_SUPPORTS_BIG_ENDIAN 236 select SYS_SUPPORTS_32BIT_KERNEL 237 select SYS_HAS_EARLY_PRINTK 238 help 239 Support for Atheros AR231x and Atheros AR531x based boards 240 241config ATH79 242 bool "Atheros AR71XX/AR724X/AR913X based boards" 243 select ARCH_HAS_RESET_CONTROLLER 244 select BOOT_RAW 245 select CEVT_R4K 246 select CSRC_R4K 247 select DMA_NONCOHERENT 248 select GPIOLIB 249 select PINCTRL 250 select COMMON_CLK 251 select IRQ_MIPS_CPU 252 select SYS_HAS_CPU_MIPS32_R2 253 select SYS_HAS_EARLY_PRINTK 254 select SYS_SUPPORTS_32BIT_KERNEL 255 select SYS_SUPPORTS_BIG_ENDIAN 256 select SYS_SUPPORTS_MIPS16 257 select SYS_SUPPORTS_ZBOOT_UART_PROM 258 select USE_OF 259 select USB_EHCI_ROOT_HUB_TT if USB_EHCI_HCD_PLATFORM 260 help 261 Support for the Atheros AR71XX/AR724X/AR913X SoCs. 262 263config BMIPS_GENERIC 264 bool "Broadcom Generic BMIPS kernel" 265 select ARCH_HAS_RESET_CONTROLLER 266 select ARCH_HAS_SYNC_DMA_FOR_CPU_ALL 267 select BOOT_RAW 268 select NO_EXCEPT_FILL 269 select USE_OF 270 select CEVT_R4K 271 select CSRC_R4K 272 select SYNC_R4K 273 select COMMON_CLK 274 select BCM6345_L1_IRQ 275 select BCM7038_L1_IRQ 276 select BCM7120_L2_IRQ 277 select BRCMSTB_L2_IRQ 278 select IRQ_MIPS_CPU 279 select DMA_NONCOHERENT 280 select SYS_SUPPORTS_32BIT_KERNEL 281 select SYS_SUPPORTS_LITTLE_ENDIAN 282 select SYS_SUPPORTS_BIG_ENDIAN 283 select SYS_SUPPORTS_HIGHMEM 284 select SYS_HAS_CPU_BMIPS32_3300 285 select SYS_HAS_CPU_BMIPS4350 286 select SYS_HAS_CPU_BMIPS4380 287 select SYS_HAS_CPU_BMIPS5000 288 select SWAP_IO_SPACE 289 select USB_EHCI_BIG_ENDIAN_DESC if CPU_BIG_ENDIAN 290 select USB_EHCI_BIG_ENDIAN_MMIO if CPU_BIG_ENDIAN 291 select USB_OHCI_BIG_ENDIAN_DESC if CPU_BIG_ENDIAN 292 select USB_OHCI_BIG_ENDIAN_MMIO if CPU_BIG_ENDIAN 293 select HARDIRQS_SW_RESEND 294 select HAVE_PCI 295 select PCI_DRIVERS_GENERIC 296 select FW_CFE 297 help 298 Build a generic DT-based kernel image that boots on select 299 BCM33xx cable modem chips, BCM63xx DSL chips, and BCM7xxx set-top 300 box chips. Note that CONFIG_CPU_BIG_ENDIAN/CONFIG_CPU_LITTLE_ENDIAN 301 must be set appropriately for your board. 302 303config BCM47XX 304 bool "Broadcom BCM47XX based boards" 305 select BOOT_RAW 306 select CEVT_R4K 307 select CSRC_R4K 308 select DMA_NONCOHERENT 309 select HAVE_PCI 310 select IRQ_MIPS_CPU 311 select SYS_HAS_CPU_MIPS32_R1 312 select NO_EXCEPT_FILL 313 select SYS_SUPPORTS_32BIT_KERNEL 314 select SYS_SUPPORTS_LITTLE_ENDIAN 315 select SYS_SUPPORTS_MIPS16 316 select SYS_SUPPORTS_ZBOOT 317 select SYS_HAS_EARLY_PRINTK 318 select USE_GENERIC_EARLY_PRINTK_8250 319 select GPIOLIB 320 select LEDS_GPIO_REGISTER 321 select BCM47XX_NVRAM 322 select BCM47XX_SPROM 323 select BCM47XX_SSB if !BCM47XX_BCMA 324 help 325 Support for BCM47XX based boards 326 327config BCM63XX 328 bool "Broadcom BCM63XX based boards" 329 select BOOT_RAW 330 select CEVT_R4K 331 select CSRC_R4K 332 select SYNC_R4K 333 select DMA_NONCOHERENT 334 select IRQ_MIPS_CPU 335 select SYS_SUPPORTS_32BIT_KERNEL 336 select SYS_SUPPORTS_BIG_ENDIAN 337 select SYS_HAS_EARLY_PRINTK 338 select SYS_HAS_CPU_BMIPS32_3300 339 select SYS_HAS_CPU_BMIPS4350 340 select SYS_HAS_CPU_BMIPS4380 341 select SWAP_IO_SPACE 342 select GPIOLIB 343 select MIPS_L1_CACHE_SHIFT_4 344 select HAVE_LEGACY_CLK 345 help 346 Support for BCM63XX based boards 347 348config MIPS_COBALT 349 bool "Cobalt Server" 350 select CEVT_R4K 351 select CSRC_R4K 352 select CEVT_GT641XX 353 select DMA_NONCOHERENT 354 select FORCE_PCI 355 select I8253 356 select I8259 357 select IRQ_MIPS_CPU 358 select IRQ_GT641XX 359 select PCI_GT64XXX_PCI0 360 select SYS_HAS_CPU_NEVADA 361 select SYS_HAS_EARLY_PRINTK 362 select SYS_SUPPORTS_32BIT_KERNEL 363 select SYS_SUPPORTS_64BIT_KERNEL 364 select SYS_SUPPORTS_LITTLE_ENDIAN 365 select USE_GENERIC_EARLY_PRINTK_8250 366 367config MACH_DECSTATION 368 bool "DECstations" 369 select BOOT_ELF32 370 select CEVT_DS1287 371 select CEVT_R4K if CPU_R4X00 372 select CSRC_IOASIC 373 select CSRC_R4K if CPU_R4X00 374 select CPU_DADDI_WORKAROUNDS if 64BIT 375 select CPU_R4000_WORKAROUNDS if 64BIT 376 select CPU_R4400_WORKAROUNDS if 64BIT 377 select DMA_NONCOHERENT 378 select NO_IOPORT_MAP 379 select IRQ_MIPS_CPU 380 select SYS_HAS_CPU_R3000 381 select SYS_HAS_CPU_R4X00 382 select SYS_SUPPORTS_32BIT_KERNEL 383 select SYS_SUPPORTS_64BIT_KERNEL 384 select SYS_SUPPORTS_LITTLE_ENDIAN 385 select SYS_SUPPORTS_128HZ 386 select SYS_SUPPORTS_256HZ 387 select SYS_SUPPORTS_1024HZ 388 select MIPS_L1_CACHE_SHIFT_4 389 help 390 This enables support for DEC's MIPS based workstations. For details 391 see the Linux/MIPS FAQ on <http://www.linux-mips.org/> and the 392 DECstation porting pages on <http://decstation.unix-ag.org/>. 393 394 If you have one of the following DECstation Models you definitely 395 want to choose R4xx0 for the CPU Type: 396 397 DECstation 5000/50 398 DECstation 5000/150 399 DECstation 5000/260 400 DECsystem 5900/260 401 402 otherwise choose R3000. 403 404config MACH_JAZZ 405 bool "Jazz family of machines" 406 select ARC_MEMORY 407 select ARC_PROMLIB 408 select ARCH_MIGHT_HAVE_PC_PARPORT 409 select ARCH_MIGHT_HAVE_PC_SERIO 410 select DMA_OPS 411 select FW_ARC 412 select FW_ARC32 413 select ARCH_MAY_HAVE_PC_FDC 414 select CEVT_R4K 415 select CSRC_R4K 416 select DEFAULT_SGI_PARTITION if CPU_BIG_ENDIAN 417 select GENERIC_ISA_DMA 418 select HAVE_PCSPKR_PLATFORM 419 select IRQ_MIPS_CPU 420 select I8253 421 select I8259 422 select ISA 423 select SYS_HAS_CPU_R4X00 424 select SYS_SUPPORTS_32BIT_KERNEL 425 select SYS_SUPPORTS_64BIT_KERNEL 426 select SYS_SUPPORTS_100HZ 427 select SYS_SUPPORTS_LITTLE_ENDIAN 428 help 429 This a family of machines based on the MIPS R4030 chipset which was 430 used by several vendors to build RISC/os and Windows NT workstations. 431 Members include the Acer PICA, MIPS Magnum 4000, MIPS Millennium and 432 Olivetti M700-10 workstations. 433 434config MACH_INGENIC_SOC 435 bool "Ingenic SoC based machines" 436 select MIPS_GENERIC 437 select MACH_INGENIC 438 select SYS_SUPPORTS_ZBOOT_UART16550 439 select CPU_SUPPORTS_CPUFREQ 440 select MIPS_EXTERNAL_TIMER 441 442config LANTIQ 443 bool "Lantiq based platforms" 444 select DMA_NONCOHERENT 445 select IRQ_MIPS_CPU 446 select CEVT_R4K 447 select CSRC_R4K 448 select NO_EXCEPT_FILL 449 select SYS_HAS_CPU_MIPS32_R1 450 select SYS_HAS_CPU_MIPS32_R2 451 select SYS_SUPPORTS_BIG_ENDIAN 452 select SYS_SUPPORTS_32BIT_KERNEL 453 select SYS_SUPPORTS_MIPS16 454 select SYS_SUPPORTS_MULTITHREADING 455 select SYS_SUPPORTS_VPE_LOADER 456 select SYS_HAS_EARLY_PRINTK 457 select GPIOLIB 458 select SWAP_IO_SPACE 459 select BOOT_RAW 460 select HAVE_LEGACY_CLK 461 select USE_OF 462 select PINCTRL 463 select PINCTRL_LANTIQ 464 select ARCH_HAS_RESET_CONTROLLER 465 select RESET_CONTROLLER 466 467config MACH_LOONGSON32 468 bool "Loongson 32-bit family of machines" 469 select SYS_SUPPORTS_ZBOOT 470 help 471 This enables support for the Loongson-1 family of machines. 472 473 Loongson-1 is a family of 32-bit MIPS-compatible SoCs developed by 474 the Institute of Computing Technology (ICT), Chinese Academy of 475 Sciences (CAS). 476 477config MACH_LOONGSON2EF 478 bool "Loongson-2E/F family of machines" 479 select SYS_SUPPORTS_ZBOOT 480 help 481 This enables the support of early Loongson-2E/F family of machines. 482 483config MACH_LOONGSON64 484 bool "Loongson 64-bit family of machines" 485 select ARCH_SPARSEMEM_ENABLE 486 select ARCH_MIGHT_HAVE_PC_PARPORT 487 select ARCH_MIGHT_HAVE_PC_SERIO 488 select GENERIC_ISA_DMA_SUPPORT_BROKEN 489 select BOOT_ELF32 490 select BOARD_SCACHE 491 select CSRC_R4K 492 select CEVT_R4K 493 select CPU_HAS_WB 494 select FORCE_PCI 495 select ISA 496 select I8259 497 select IRQ_MIPS_CPU 498 select NO_EXCEPT_FILL 499 select NR_CPUS_DEFAULT_64 500 select USE_GENERIC_EARLY_PRINTK_8250 501 select PCI_DRIVERS_GENERIC 502 select SYS_HAS_CPU_LOONGSON64 503 select SYS_HAS_EARLY_PRINTK 504 select SYS_SUPPORTS_SMP 505 select SYS_SUPPORTS_HOTPLUG_CPU 506 select SYS_SUPPORTS_NUMA 507 select SYS_SUPPORTS_64BIT_KERNEL 508 select SYS_SUPPORTS_HIGHMEM 509 select SYS_SUPPORTS_LITTLE_ENDIAN 510 select SYS_SUPPORTS_ZBOOT 511 select SYS_SUPPORTS_RELOCATABLE 512 select ZONE_DMA32 513 select COMMON_CLK 514 select USE_OF 515 select BUILTIN_DTB 516 select PCI_HOST_GENERIC 517 select HAVE_ARCH_NODEDATA_EXTENSION if NUMA 518 help 519 This enables the support of Loongson-2/3 family of machines. 520 521 Loongson-2 and Loongson-3 are 64-bit general-purpose processors with 522 GS264/GS464/GS464E/GS464V microarchitecture (except old Loongson-2E 523 and Loongson-2F which will be removed), developed by the Institute 524 of Computing Technology (ICT), Chinese Academy of Sciences (CAS). 525 526config MIPS_MALTA 527 bool "MIPS Malta board" 528 select ARCH_MAY_HAVE_PC_FDC 529 select ARCH_MIGHT_HAVE_PC_PARPORT 530 select ARCH_MIGHT_HAVE_PC_SERIO 531 select BOOT_ELF32 532 select BOOT_RAW 533 select BUILTIN_DTB 534 select CEVT_R4K 535 select CLKSRC_MIPS_GIC 536 select COMMON_CLK 537 select CSRC_R4K 538 select DMA_NONCOHERENT 539 select GENERIC_ISA_DMA 540 select HAVE_PCSPKR_PLATFORM 541 select HAVE_PCI 542 select I8253 543 select I8259 544 select IRQ_MIPS_CPU 545 select MIPS_BONITO64 546 select MIPS_CPU_SCACHE 547 select MIPS_GIC 548 select MIPS_L1_CACHE_SHIFT_6 549 select MIPS_MSC 550 select PCI_GT64XXX_PCI0 551 select SMP_UP if SMP 552 select SWAP_IO_SPACE 553 select SYS_HAS_CPU_MIPS32_R1 554 select SYS_HAS_CPU_MIPS32_R2 555 select SYS_HAS_CPU_MIPS32_R3_5 556 select SYS_HAS_CPU_MIPS32_R5 557 select SYS_HAS_CPU_MIPS32_R6 558 select SYS_HAS_CPU_MIPS64_R1 559 select SYS_HAS_CPU_MIPS64_R2 560 select SYS_HAS_CPU_MIPS64_R6 561 select SYS_HAS_CPU_NEVADA 562 select SYS_HAS_CPU_RM7000 563 select SYS_SUPPORTS_32BIT_KERNEL 564 select SYS_SUPPORTS_64BIT_KERNEL 565 select SYS_SUPPORTS_BIG_ENDIAN 566 select SYS_SUPPORTS_HIGHMEM 567 select SYS_SUPPORTS_LITTLE_ENDIAN 568 select SYS_SUPPORTS_MICROMIPS 569 select SYS_SUPPORTS_MIPS16 570 select SYS_SUPPORTS_MIPS_CMP 571 select SYS_SUPPORTS_MIPS_CPS 572 select SYS_SUPPORTS_MULTITHREADING 573 select SYS_SUPPORTS_RELOCATABLE 574 select SYS_SUPPORTS_SMARTMIPS 575 select SYS_SUPPORTS_VPE_LOADER 576 select SYS_SUPPORTS_ZBOOT 577 select USE_OF 578 select WAR_ICACHE_REFILLS 579 select ZONE_DMA32 if 64BIT 580 help 581 This enables support for the MIPS Technologies Malta evaluation 582 board. 583 584config MACH_PIC32 585 bool "Microchip PIC32 Family" 586 help 587 This enables support for the Microchip PIC32 family of platforms. 588 589 Microchip PIC32 is a family of general-purpose 32 bit MIPS core 590 microcontrollers. 591 592config MACH_NINTENDO64 593 bool "Nintendo 64 console" 594 select CEVT_R4K 595 select CSRC_R4K 596 select SYS_HAS_CPU_R4300 597 select SYS_SUPPORTS_BIG_ENDIAN 598 select SYS_SUPPORTS_ZBOOT 599 select SYS_SUPPORTS_32BIT_KERNEL 600 select SYS_SUPPORTS_64BIT_KERNEL 601 select DMA_NONCOHERENT 602 select IRQ_MIPS_CPU 603 604config RALINK 605 bool "Ralink based machines" 606 select CEVT_R4K 607 select COMMON_CLK 608 select CSRC_R4K 609 select BOOT_RAW 610 select DMA_NONCOHERENT 611 select IRQ_MIPS_CPU 612 select USE_OF 613 select SYS_HAS_CPU_MIPS32_R2 614 select SYS_SUPPORTS_32BIT_KERNEL 615 select SYS_SUPPORTS_LITTLE_ENDIAN 616 select SYS_SUPPORTS_MIPS16 617 select SYS_SUPPORTS_ZBOOT 618 select SYS_HAS_EARLY_PRINTK 619 select ARCH_HAS_RESET_CONTROLLER 620 select RESET_CONTROLLER 621 622config MACH_REALTEK_RTL 623 bool "Realtek RTL838x/RTL839x based machines" 624 select MIPS_GENERIC 625 select DMA_NONCOHERENT 626 select IRQ_MIPS_CPU 627 select CSRC_R4K 628 select CEVT_R4K 629 select SYS_HAS_CPU_MIPS32_R1 630 select SYS_HAS_CPU_MIPS32_R2 631 select SYS_SUPPORTS_BIG_ENDIAN 632 select SYS_SUPPORTS_32BIT_KERNEL 633 select SYS_SUPPORTS_MIPS16 634 select SYS_SUPPORTS_MULTITHREADING 635 select SYS_SUPPORTS_VPE_LOADER 636 select BOOT_RAW 637 select PINCTRL 638 select USE_OF 639 640config SGI_IP22 641 bool "SGI IP22 (Indy/Indigo2)" 642 select ARC_MEMORY 643 select ARC_PROMLIB 644 select FW_ARC 645 select FW_ARC32 646 select ARCH_MIGHT_HAVE_PC_SERIO 647 select BOOT_ELF32 648 select CEVT_R4K 649 select CSRC_R4K 650 select DEFAULT_SGI_PARTITION 651 select DMA_NONCOHERENT 652 select HAVE_EISA 653 select I8253 654 select I8259 655 select IP22_CPU_SCACHE 656 select IRQ_MIPS_CPU 657 select GENERIC_ISA_DMA_SUPPORT_BROKEN 658 select SGI_HAS_I8042 659 select SGI_HAS_INDYDOG 660 select SGI_HAS_HAL2 661 select SGI_HAS_SEEQ 662 select SGI_HAS_WD93 663 select SGI_HAS_ZILOG 664 select SWAP_IO_SPACE 665 select SYS_HAS_CPU_R4X00 666 select SYS_HAS_CPU_R5000 667 select SYS_HAS_EARLY_PRINTK 668 select SYS_SUPPORTS_32BIT_KERNEL 669 select SYS_SUPPORTS_64BIT_KERNEL 670 select SYS_SUPPORTS_BIG_ENDIAN 671 select WAR_R4600_V1_INDEX_ICACHEOP 672 select WAR_R4600_V1_HIT_CACHEOP 673 select WAR_R4600_V2_HIT_CACHEOP 674 select MIPS_L1_CACHE_SHIFT_7 675 help 676 This are the SGI Indy, Challenge S and Indigo2, as well as certain 677 OEM variants like the Tandem CMN B006S. To compile a Linux kernel 678 that runs on these, say Y here. 679 680config SGI_IP27 681 bool "SGI IP27 (Origin200/2000)" 682 select ARCH_HAS_PHYS_TO_DMA 683 select ARCH_SPARSEMEM_ENABLE 684 select FW_ARC 685 select FW_ARC64 686 select ARC_CMDLINE_ONLY 687 select BOOT_ELF64 688 select DEFAULT_SGI_PARTITION 689 select FORCE_PCI 690 select SYS_HAS_EARLY_PRINTK 691 select HAVE_PCI 692 select IRQ_MIPS_CPU 693 select IRQ_DOMAIN_HIERARCHY 694 select NR_CPUS_DEFAULT_64 695 select PCI_DRIVERS_GENERIC 696 select PCI_XTALK_BRIDGE 697 select SYS_HAS_CPU_R10000 698 select SYS_SUPPORTS_64BIT_KERNEL 699 select SYS_SUPPORTS_BIG_ENDIAN 700 select SYS_SUPPORTS_NUMA 701 select SYS_SUPPORTS_SMP 702 select WAR_R10000_LLSC 703 select MIPS_L1_CACHE_SHIFT_7 704 select NUMA 705 select HAVE_ARCH_NODEDATA_EXTENSION 706 help 707 This are the SGI Origin 200, Origin 2000 and Onyx 2 Graphics 708 workstations. To compile a Linux kernel that runs on these, say Y 709 here. 710 711config SGI_IP28 712 bool "SGI IP28 (Indigo2 R10k)" 713 select ARC_MEMORY 714 select ARC_PROMLIB 715 select FW_ARC 716 select FW_ARC64 717 select ARCH_MIGHT_HAVE_PC_SERIO 718 select BOOT_ELF64 719 select CEVT_R4K 720 select CSRC_R4K 721 select DEFAULT_SGI_PARTITION 722 select DMA_NONCOHERENT 723 select GENERIC_ISA_DMA_SUPPORT_BROKEN 724 select IRQ_MIPS_CPU 725 select HAVE_EISA 726 select I8253 727 select I8259 728 select SGI_HAS_I8042 729 select SGI_HAS_INDYDOG 730 select SGI_HAS_HAL2 731 select SGI_HAS_SEEQ 732 select SGI_HAS_WD93 733 select SGI_HAS_ZILOG 734 select SWAP_IO_SPACE 735 select SYS_HAS_CPU_R10000 736 select SYS_HAS_EARLY_PRINTK 737 select SYS_SUPPORTS_64BIT_KERNEL 738 select SYS_SUPPORTS_BIG_ENDIAN 739 select WAR_R10000_LLSC 740 select MIPS_L1_CACHE_SHIFT_7 741 help 742 This is the SGI Indigo2 with R10000 processor. To compile a Linux 743 kernel that runs on these, say Y here. 744 745config SGI_IP30 746 bool "SGI IP30 (Octane/Octane2)" 747 select ARCH_HAS_PHYS_TO_DMA 748 select FW_ARC 749 select FW_ARC64 750 select BOOT_ELF64 751 select CEVT_R4K 752 select CSRC_R4K 753 select FORCE_PCI 754 select SYNC_R4K if SMP 755 select ZONE_DMA32 756 select HAVE_PCI 757 select IRQ_MIPS_CPU 758 select IRQ_DOMAIN_HIERARCHY 759 select PCI_DRIVERS_GENERIC 760 select PCI_XTALK_BRIDGE 761 select SYS_HAS_EARLY_PRINTK 762 select SYS_HAS_CPU_R10000 763 select SYS_SUPPORTS_64BIT_KERNEL 764 select SYS_SUPPORTS_BIG_ENDIAN 765 select SYS_SUPPORTS_SMP 766 select WAR_R10000_LLSC 767 select MIPS_L1_CACHE_SHIFT_7 768 select ARC_MEMORY 769 help 770 These are the SGI Octane and Octane2 graphics workstations. To 771 compile a Linux kernel that runs on these, say Y here. 772 773config SGI_IP32 774 bool "SGI IP32 (O2)" 775 select ARC_MEMORY 776 select ARC_PROMLIB 777 select ARCH_HAS_PHYS_TO_DMA 778 select FW_ARC 779 select FW_ARC32 780 select BOOT_ELF32 781 select CEVT_R4K 782 select CSRC_R4K 783 select DMA_NONCOHERENT 784 select HAVE_PCI 785 select IRQ_MIPS_CPU 786 select R5000_CPU_SCACHE 787 select RM7000_CPU_SCACHE 788 select SYS_HAS_CPU_R5000 789 select SYS_HAS_CPU_R10000 if BROKEN 790 select SYS_HAS_CPU_RM7000 791 select SYS_HAS_CPU_NEVADA 792 select SYS_SUPPORTS_64BIT_KERNEL 793 select SYS_SUPPORTS_BIG_ENDIAN 794 select WAR_ICACHE_REFILLS 795 help 796 If you want this kernel to run on SGI O2 workstation, say Y here. 797 798config SIBYTE_CRHINE 799 bool "Sibyte BCM91120C-CRhine" 800 select BOOT_ELF32 801 select SIBYTE_BCM1120 802 select SWAP_IO_SPACE 803 select SYS_HAS_CPU_SB1 804 select SYS_SUPPORTS_BIG_ENDIAN 805 select SYS_SUPPORTS_LITTLE_ENDIAN 806 807config SIBYTE_CARMEL 808 bool "Sibyte BCM91120x-Carmel" 809 select BOOT_ELF32 810 select SIBYTE_BCM1120 811 select SWAP_IO_SPACE 812 select SYS_HAS_CPU_SB1 813 select SYS_SUPPORTS_BIG_ENDIAN 814 select SYS_SUPPORTS_LITTLE_ENDIAN 815 816config SIBYTE_CRHONE 817 bool "Sibyte BCM91125C-CRhone" 818 select BOOT_ELF32 819 select SIBYTE_BCM1125 820 select SWAP_IO_SPACE 821 select SYS_HAS_CPU_SB1 822 select SYS_SUPPORTS_BIG_ENDIAN 823 select SYS_SUPPORTS_HIGHMEM 824 select SYS_SUPPORTS_LITTLE_ENDIAN 825 826config SIBYTE_RHONE 827 bool "Sibyte BCM91125E-Rhone" 828 select BOOT_ELF32 829 select SIBYTE_BCM1125H 830 select SWAP_IO_SPACE 831 select SYS_HAS_CPU_SB1 832 select SYS_SUPPORTS_BIG_ENDIAN 833 select SYS_SUPPORTS_LITTLE_ENDIAN 834 835config SIBYTE_SWARM 836 bool "Sibyte BCM91250A-SWARM" 837 select BOOT_ELF32 838 select HAVE_PATA_PLATFORM 839 select SIBYTE_SB1250 840 select SWAP_IO_SPACE 841 select SYS_HAS_CPU_SB1 842 select SYS_SUPPORTS_BIG_ENDIAN 843 select SYS_SUPPORTS_HIGHMEM 844 select SYS_SUPPORTS_LITTLE_ENDIAN 845 select ZONE_DMA32 if 64BIT 846 select SWIOTLB if ARCH_DMA_ADDR_T_64BIT && PCI 847 848config SIBYTE_LITTLESUR 849 bool "Sibyte BCM91250C2-LittleSur" 850 select BOOT_ELF32 851 select HAVE_PATA_PLATFORM 852 select SIBYTE_SB1250 853 select SWAP_IO_SPACE 854 select SYS_HAS_CPU_SB1 855 select SYS_SUPPORTS_BIG_ENDIAN 856 select SYS_SUPPORTS_HIGHMEM 857 select SYS_SUPPORTS_LITTLE_ENDIAN 858 select ZONE_DMA32 if 64BIT 859 860config SIBYTE_SENTOSA 861 bool "Sibyte BCM91250E-Sentosa" 862 select BOOT_ELF32 863 select SIBYTE_SB1250 864 select SWAP_IO_SPACE 865 select SYS_HAS_CPU_SB1 866 select SYS_SUPPORTS_BIG_ENDIAN 867 select SYS_SUPPORTS_LITTLE_ENDIAN 868 select SWIOTLB if ARCH_DMA_ADDR_T_64BIT && PCI 869 870config SIBYTE_BIGSUR 871 bool "Sibyte BCM91480B-BigSur" 872 select BOOT_ELF32 873 select NR_CPUS_DEFAULT_4 874 select SIBYTE_BCM1x80 875 select SWAP_IO_SPACE 876 select SYS_HAS_CPU_SB1 877 select SYS_SUPPORTS_BIG_ENDIAN 878 select SYS_SUPPORTS_HIGHMEM 879 select SYS_SUPPORTS_LITTLE_ENDIAN 880 select ZONE_DMA32 if 64BIT 881 select SWIOTLB if ARCH_DMA_ADDR_T_64BIT && PCI 882 883config SNI_RM 884 bool "SNI RM200/300/400" 885 select ARC_MEMORY 886 select ARC_PROMLIB 887 select FW_ARC if CPU_LITTLE_ENDIAN 888 select FW_ARC32 if CPU_LITTLE_ENDIAN 889 select FW_SNIPROM if CPU_BIG_ENDIAN 890 select ARCH_MAY_HAVE_PC_FDC 891 select ARCH_MIGHT_HAVE_PC_PARPORT 892 select ARCH_MIGHT_HAVE_PC_SERIO 893 select BOOT_ELF32 894 select CEVT_R4K 895 select CSRC_R4K 896 select DEFAULT_SGI_PARTITION if CPU_BIG_ENDIAN 897 select DMA_NONCOHERENT 898 select GENERIC_ISA_DMA 899 select HAVE_EISA 900 select HAVE_PCSPKR_PLATFORM 901 select HAVE_PCI 902 select IRQ_MIPS_CPU 903 select I8253 904 select I8259 905 select ISA 906 select MIPS_L1_CACHE_SHIFT_6 907 select SWAP_IO_SPACE if CPU_BIG_ENDIAN 908 select SYS_HAS_CPU_R4X00 909 select SYS_HAS_CPU_R5000 910 select SYS_HAS_CPU_R10000 911 select R5000_CPU_SCACHE 912 select SYS_HAS_EARLY_PRINTK 913 select SYS_SUPPORTS_32BIT_KERNEL 914 select SYS_SUPPORTS_64BIT_KERNEL 915 select SYS_SUPPORTS_BIG_ENDIAN 916 select SYS_SUPPORTS_HIGHMEM 917 select SYS_SUPPORTS_LITTLE_ENDIAN 918 select WAR_R4600_V2_HIT_CACHEOP 919 help 920 The SNI RM200/300/400 are MIPS-based machines manufactured by 921 Siemens Nixdorf Informationssysteme (SNI), parent company of Pyramid 922 Technology and now in turn merged with Fujitsu. Say Y here to 923 support this machine type. 924 925config MACH_TX49XX 926 bool "Toshiba TX49 series based machines" 927 select WAR_TX49XX_ICACHE_INDEX_INV 928 929config MIKROTIK_RB532 930 bool "Mikrotik RB532 boards" 931 select CEVT_R4K 932 select CSRC_R4K 933 select DMA_NONCOHERENT 934 select HAVE_PCI 935 select IRQ_MIPS_CPU 936 select SYS_HAS_CPU_MIPS32_R1 937 select SYS_SUPPORTS_32BIT_KERNEL 938 select SYS_SUPPORTS_LITTLE_ENDIAN 939 select SWAP_IO_SPACE 940 select BOOT_RAW 941 select GPIOLIB 942 select MIPS_L1_CACHE_SHIFT_4 943 help 944 Support the Mikrotik(tm) RouterBoard 532 series, 945 based on the IDT RC32434 SoC. 946 947config CAVIUM_OCTEON_SOC 948 bool "Cavium Networks Octeon SoC based boards" 949 select CEVT_R4K 950 select ARCH_HAS_PHYS_TO_DMA 951 select HAVE_RAPIDIO 952 select PHYS_ADDR_T_64BIT 953 select SYS_SUPPORTS_64BIT_KERNEL 954 select SYS_SUPPORTS_BIG_ENDIAN 955 select EDAC_SUPPORT 956 select EDAC_ATOMIC_SCRUB 957 select SYS_SUPPORTS_LITTLE_ENDIAN 958 select SYS_SUPPORTS_HOTPLUG_CPU if CPU_BIG_ENDIAN 959 select SYS_HAS_EARLY_PRINTK 960 select SYS_HAS_CPU_CAVIUM_OCTEON 961 select HAVE_PCI 962 select HAVE_PLAT_DELAY 963 select HAVE_PLAT_FW_INIT_CMDLINE 964 select HAVE_PLAT_MEMCPY 965 select ZONE_DMA32 966 select GPIOLIB 967 select USE_OF 968 select ARCH_SPARSEMEM_ENABLE 969 select SYS_SUPPORTS_SMP 970 select NR_CPUS_DEFAULT_64 971 select MIPS_NR_CPU_NR_MAP_1024 972 select BUILTIN_DTB 973 select MTD 974 select MTD_COMPLEX_MAPPINGS 975 select SWIOTLB 976 select SYS_SUPPORTS_RELOCATABLE 977 help 978 This option supports all of the Octeon reference boards from Cavium 979 Networks. It builds a kernel that dynamically determines the Octeon 980 CPU type and supports all known board reference implementations. 981 Some of the supported boards are: 982 EBT3000 983 EBH3000 984 EBH3100 985 Thunder 986 Kodama 987 Hikari 988 Say Y here for most Octeon reference boards. 989 990endchoice 991 992source "arch/mips/alchemy/Kconfig" 993source "arch/mips/ath25/Kconfig" 994source "arch/mips/ath79/Kconfig" 995source "arch/mips/bcm47xx/Kconfig" 996source "arch/mips/bcm63xx/Kconfig" 997source "arch/mips/bmips/Kconfig" 998source "arch/mips/generic/Kconfig" 999source "arch/mips/ingenic/Kconfig" 1000source "arch/mips/jazz/Kconfig" 1001source "arch/mips/lantiq/Kconfig" 1002source "arch/mips/pic32/Kconfig" 1003source "arch/mips/ralink/Kconfig" 1004source "arch/mips/sgi-ip27/Kconfig" 1005source "arch/mips/sibyte/Kconfig" 1006source "arch/mips/txx9/Kconfig" 1007source "arch/mips/cavium-octeon/Kconfig" 1008source "arch/mips/loongson2ef/Kconfig" 1009source "arch/mips/loongson32/Kconfig" 1010source "arch/mips/loongson64/Kconfig" 1011 1012endmenu 1013 1014config GENERIC_HWEIGHT 1015 bool 1016 default y 1017 1018config GENERIC_CALIBRATE_DELAY 1019 bool 1020 default y 1021 1022config SCHED_OMIT_FRAME_POINTER 1023 bool 1024 default y 1025 1026# 1027# Select some configuration options automatically based on user selections. 1028# 1029config FW_ARC 1030 bool 1031 1032config ARCH_MAY_HAVE_PC_FDC 1033 bool 1034 1035config BOOT_RAW 1036 bool 1037 1038config CEVT_BCM1480 1039 bool 1040 1041config CEVT_DS1287 1042 bool 1043 1044config CEVT_GT641XX 1045 bool 1046 1047config CEVT_R4K 1048 bool 1049 1050config CEVT_SB1250 1051 bool 1052 1053config CEVT_TXX9 1054 bool 1055 1056config CSRC_BCM1480 1057 bool 1058 1059config CSRC_IOASIC 1060 bool 1061 1062config CSRC_R4K 1063 select CLOCKSOURCE_WATCHDOG if CPU_FREQ 1064 bool 1065 1066config CSRC_SB1250 1067 bool 1068 1069config MIPS_CLOCK_VSYSCALL 1070 def_bool CSRC_R4K || CLKSRC_MIPS_GIC 1071 1072config GPIO_TXX9 1073 select GPIOLIB 1074 bool 1075 1076config FW_CFE 1077 bool 1078 1079config ARCH_SUPPORTS_UPROBES 1080 bool 1081 1082config DMA_NONCOHERENT 1083 bool 1084 # 1085 # MIPS allows mixing "slightly different" Cacheability and Coherency 1086 # Attribute bits. It is believed that the uncached access through 1087 # KSEG1 and the implementation specific "uncached accelerated" used 1088 # by pgprot_writcombine can be mixed, and the latter sometimes provides 1089 # significant advantages. 1090 # 1091 select ARCH_HAS_DMA_WRITE_COMBINE 1092 select ARCH_HAS_DMA_PREP_COHERENT 1093 select ARCH_HAS_SYNC_DMA_FOR_DEVICE 1094 select ARCH_HAS_DMA_SET_UNCACHED 1095 select DMA_NONCOHERENT_MMAP 1096 select NEED_DMA_MAP_STATE 1097 1098config SYS_HAS_EARLY_PRINTK 1099 bool 1100 1101config SYS_SUPPORTS_HOTPLUG_CPU 1102 bool 1103 1104config MIPS_BONITO64 1105 bool 1106 1107config MIPS_MSC 1108 bool 1109 1110config SYNC_R4K 1111 bool 1112 1113config NO_IOPORT_MAP 1114 def_bool n 1115 1116config GENERIC_CSUM 1117 def_bool CPU_NO_LOAD_STORE_LR 1118 1119config GENERIC_ISA_DMA 1120 bool 1121 select ZONE_DMA if GENERIC_ISA_DMA_SUPPORT_BROKEN=n 1122 select ISA_DMA_API 1123 1124config GENERIC_ISA_DMA_SUPPORT_BROKEN 1125 bool 1126 select GENERIC_ISA_DMA 1127 1128config HAVE_PLAT_DELAY 1129 bool 1130 1131config HAVE_PLAT_FW_INIT_CMDLINE 1132 bool 1133 1134config HAVE_PLAT_MEMCPY 1135 bool 1136 1137config ISA_DMA_API 1138 bool 1139 1140config SYS_SUPPORTS_RELOCATABLE 1141 bool 1142 help 1143 Selected if the platform supports relocating the kernel. 1144 The platform must provide plat_get_fdt() if it selects CONFIG_USE_OF 1145 to allow access to command line and entropy sources. 1146 1147# 1148# Endianness selection. Sufficiently obscure so many users don't know what to 1149# answer,so we try hard to limit the available choices. Also the use of a 1150# choice statement should be more obvious to the user. 1151# 1152choice 1153 prompt "Endianness selection" 1154 help 1155 Some MIPS machines can be configured for either little or big endian 1156 byte order. These modes require different kernels and a different 1157 Linux distribution. In general there is one preferred byteorder for a 1158 particular system but some systems are just as commonly used in the 1159 one or the other endianness. 1160 1161config CPU_BIG_ENDIAN 1162 bool "Big endian" 1163 depends on SYS_SUPPORTS_BIG_ENDIAN 1164 1165config CPU_LITTLE_ENDIAN 1166 bool "Little endian" 1167 depends on SYS_SUPPORTS_LITTLE_ENDIAN 1168 1169endchoice 1170 1171config EXPORT_UASM 1172 bool 1173 1174config SYS_SUPPORTS_APM_EMULATION 1175 bool 1176 1177config SYS_SUPPORTS_BIG_ENDIAN 1178 bool 1179 1180config SYS_SUPPORTS_LITTLE_ENDIAN 1181 bool 1182 1183config MIPS_HUGE_TLB_SUPPORT 1184 def_bool HUGETLB_PAGE || TRANSPARENT_HUGEPAGE 1185 1186config IRQ_MSP_SLP 1187 bool 1188 1189config IRQ_MSP_CIC 1190 bool 1191 1192config IRQ_TXX9 1193 bool 1194 1195config IRQ_GT641XX 1196 bool 1197 1198config PCI_GT64XXX_PCI0 1199 bool 1200 1201config PCI_XTALK_BRIDGE 1202 bool 1203 1204config NO_EXCEPT_FILL 1205 bool 1206 1207config MIPS_SPRAM 1208 bool 1209 1210config SWAP_IO_SPACE 1211 bool 1212 1213config SGI_HAS_INDYDOG 1214 bool 1215 1216config SGI_HAS_HAL2 1217 bool 1218 1219config SGI_HAS_SEEQ 1220 bool 1221 1222config SGI_HAS_WD93 1223 bool 1224 1225config SGI_HAS_ZILOG 1226 bool 1227 1228config SGI_HAS_I8042 1229 bool 1230 1231config DEFAULT_SGI_PARTITION 1232 bool 1233 1234config FW_ARC32 1235 bool 1236 1237config FW_SNIPROM 1238 bool 1239 1240config BOOT_ELF32 1241 bool 1242 1243config MIPS_L1_CACHE_SHIFT_4 1244 bool 1245 1246config MIPS_L1_CACHE_SHIFT_5 1247 bool 1248 1249config MIPS_L1_CACHE_SHIFT_6 1250 bool 1251 1252config MIPS_L1_CACHE_SHIFT_7 1253 bool 1254 1255config MIPS_L1_CACHE_SHIFT 1256 int 1257 default "7" if MIPS_L1_CACHE_SHIFT_7 1258 default "6" if MIPS_L1_CACHE_SHIFT_6 1259 default "5" if MIPS_L1_CACHE_SHIFT_5 1260 default "4" if MIPS_L1_CACHE_SHIFT_4 1261 default "5" 1262 1263config ARC_CMDLINE_ONLY 1264 bool 1265 1266config ARC_CONSOLE 1267 bool "ARC console support" 1268 depends on SGI_IP22 || SGI_IP28 || (SNI_RM && CPU_LITTLE_ENDIAN) 1269 1270config ARC_MEMORY 1271 bool 1272 1273config ARC_PROMLIB 1274 bool 1275 1276config FW_ARC64 1277 bool 1278 1279config BOOT_ELF64 1280 bool 1281 1282menu "CPU selection" 1283 1284choice 1285 prompt "CPU type" 1286 default CPU_R4X00 1287 1288config CPU_LOONGSON64 1289 bool "Loongson 64-bit CPU" 1290 depends on SYS_HAS_CPU_LOONGSON64 1291 select ARCH_HAS_PHYS_TO_DMA 1292 select CPU_MIPSR2 1293 select CPU_HAS_PREFETCH 1294 select CPU_SUPPORTS_64BIT_KERNEL 1295 select CPU_SUPPORTS_HIGHMEM 1296 select CPU_SUPPORTS_HUGEPAGES 1297 select CPU_SUPPORTS_MSA 1298 select CPU_DIEI_BROKEN if !LOONGSON3_ENHANCEMENT 1299 select CPU_MIPSR2_IRQ_VI 1300 select WEAK_ORDERING 1301 select WEAK_REORDERING_BEYOND_LLSC 1302 select MIPS_ASID_BITS_VARIABLE 1303 select MIPS_PGD_C0_CONTEXT 1304 select MIPS_L1_CACHE_SHIFT_6 1305 select MIPS_FP_SUPPORT 1306 select GPIOLIB 1307 select SWIOTLB 1308 select HAVE_KVM 1309 help 1310 The Loongson GSx64(GS264/GS464/GS464E/GS464V) series of processor 1311 cores implements the MIPS64R2 instruction set with many extensions, 1312 including most 64-bit Loongson-2 (2H, 2K) and Loongson-3 (3A1000, 1313 3B1000, 3B1500, 3A2000, 3A3000 and 3A4000) processors. However, old 1314 Loongson-2E/2F is not covered here and will be removed in future. 1315 1316config LOONGSON3_ENHANCEMENT 1317 bool "New Loongson-3 CPU Enhancements" 1318 default n 1319 depends on CPU_LOONGSON64 1320 help 1321 New Loongson-3 cores (since Loongson-3A R2, as opposed to Loongson-3A 1322 R1, Loongson-3B R1 and Loongson-3B R2) has many enhancements, such as 1323 FTLB, L1-VCache, EI/DI/Wait/Prefetch instruction, DSP/DSPr2 ASE, User 1324 Local register, Read-Inhibit/Execute-Inhibit, SFB (Store Fill Buffer), 1325 Fast TLB refill support, etc. 1326 1327 This option enable those enhancements which are not probed at run 1328 time. If you want a generic kernel to run on all Loongson 3 machines, 1329 please say 'N' here. If you want a high-performance kernel to run on 1330 new Loongson-3 machines only, please say 'Y' here. 1331 1332config CPU_LOONGSON3_WORKAROUNDS 1333 bool "Loongson-3 LLSC Workarounds" 1334 default y if SMP 1335 depends on CPU_LOONGSON64 1336 help 1337 Loongson-3 processors have the llsc issues which require workarounds. 1338 Without workarounds the system may hang unexpectedly. 1339 1340 Say Y, unless you know what you are doing. 1341 1342config CPU_LOONGSON3_CPUCFG_EMULATION 1343 bool "Emulate the CPUCFG instruction on older Loongson cores" 1344 default y 1345 depends on CPU_LOONGSON64 1346 help 1347 Loongson-3A R4 and newer have the CPUCFG instruction available for 1348 userland to query CPU capabilities, much like CPUID on x86. This 1349 option provides emulation of the instruction on older Loongson 1350 cores, back to Loongson-3A1000. 1351 1352 If unsure, please say Y. 1353 1354config CPU_LOONGSON2E 1355 bool "Loongson 2E" 1356 depends on SYS_HAS_CPU_LOONGSON2E 1357 select CPU_LOONGSON2EF 1358 help 1359 The Loongson 2E processor implements the MIPS III instruction set 1360 with many extensions. 1361 1362 It has an internal FPGA northbridge, which is compatible to 1363 bonito64. 1364 1365config CPU_LOONGSON2F 1366 bool "Loongson 2F" 1367 depends on SYS_HAS_CPU_LOONGSON2F 1368 select CPU_LOONGSON2EF 1369 select GPIOLIB 1370 help 1371 The Loongson 2F processor implements the MIPS III instruction set 1372 with many extensions. 1373 1374 Loongson2F have built-in DDR2 and PCIX controller. The PCIX controller 1375 have a similar programming interface with FPGA northbridge used in 1376 Loongson2E. 1377 1378config CPU_LOONGSON1B 1379 bool "Loongson 1B" 1380 depends on SYS_HAS_CPU_LOONGSON1B 1381 select CPU_LOONGSON32 1382 select LEDS_GPIO_REGISTER 1383 help 1384 The Loongson 1B is a 32-bit SoC, which implements the MIPS32 1385 Release 1 instruction set and part of the MIPS32 Release 2 1386 instruction set. 1387 1388config CPU_LOONGSON1C 1389 bool "Loongson 1C" 1390 depends on SYS_HAS_CPU_LOONGSON1C 1391 select CPU_LOONGSON32 1392 select LEDS_GPIO_REGISTER 1393 help 1394 The Loongson 1C is a 32-bit SoC, which implements the MIPS32 1395 Release 1 instruction set and part of the MIPS32 Release 2 1396 instruction set. 1397 1398config CPU_MIPS32_R1 1399 bool "MIPS32 Release 1" 1400 depends on SYS_HAS_CPU_MIPS32_R1 1401 select CPU_HAS_PREFETCH 1402 select CPU_SUPPORTS_32BIT_KERNEL 1403 select CPU_SUPPORTS_HIGHMEM 1404 help 1405 Choose this option to build a kernel for release 1 or later of the 1406 MIPS32 architecture. Most modern embedded systems with a 32-bit 1407 MIPS processor are based on a MIPS32 processor. If you know the 1408 specific type of processor in your system, choose those that one 1409 otherwise CPU_MIPS32_R1 is a safe bet for any MIPS32 system. 1410 Release 2 of the MIPS32 architecture is available since several 1411 years so chances are you even have a MIPS32 Release 2 processor 1412 in which case you should choose CPU_MIPS32_R2 instead for better 1413 performance. 1414 1415config CPU_MIPS32_R2 1416 bool "MIPS32 Release 2" 1417 depends on SYS_HAS_CPU_MIPS32_R2 1418 select CPU_HAS_PREFETCH 1419 select CPU_SUPPORTS_32BIT_KERNEL 1420 select CPU_SUPPORTS_HIGHMEM 1421 select CPU_SUPPORTS_MSA 1422 select HAVE_KVM 1423 help 1424 Choose this option to build a kernel for release 2 or later of the 1425 MIPS32 architecture. Most modern embedded systems with a 32-bit 1426 MIPS processor are based on a MIPS32 processor. If you know the 1427 specific type of processor in your system, choose those that one 1428 otherwise CPU_MIPS32_R1 is a safe bet for any MIPS32 system. 1429 1430config CPU_MIPS32_R5 1431 bool "MIPS32 Release 5" 1432 depends on SYS_HAS_CPU_MIPS32_R5 1433 select CPU_HAS_PREFETCH 1434 select CPU_SUPPORTS_32BIT_KERNEL 1435 select CPU_SUPPORTS_HIGHMEM 1436 select CPU_SUPPORTS_MSA 1437 select HAVE_KVM 1438 select MIPS_O32_FP64_SUPPORT 1439 help 1440 Choose this option to build a kernel for release 5 or later of the 1441 MIPS32 architecture. New MIPS processors, starting with the Warrior 1442 family, are based on a MIPS32r5 processor. If you own an older 1443 processor, you probably need to select MIPS32r1 or MIPS32r2 instead. 1444 1445config CPU_MIPS32_R6 1446 bool "MIPS32 Release 6" 1447 depends on SYS_HAS_CPU_MIPS32_R6 1448 select CPU_HAS_PREFETCH 1449 select CPU_NO_LOAD_STORE_LR 1450 select CPU_SUPPORTS_32BIT_KERNEL 1451 select CPU_SUPPORTS_HIGHMEM 1452 select CPU_SUPPORTS_MSA 1453 select HAVE_KVM 1454 select MIPS_O32_FP64_SUPPORT 1455 help 1456 Choose this option to build a kernel for release 6 or later of the 1457 MIPS32 architecture. New MIPS processors, starting with the Warrior 1458 family, are based on a MIPS32r6 processor. If you own an older 1459 processor, you probably need to select MIPS32r1 or MIPS32r2 instead. 1460 1461config CPU_MIPS64_R1 1462 bool "MIPS64 Release 1" 1463 depends on SYS_HAS_CPU_MIPS64_R1 1464 select CPU_HAS_PREFETCH 1465 select CPU_SUPPORTS_32BIT_KERNEL 1466 select CPU_SUPPORTS_64BIT_KERNEL 1467 select CPU_SUPPORTS_HIGHMEM 1468 select CPU_SUPPORTS_HUGEPAGES 1469 help 1470 Choose this option to build a kernel for release 1 or later of the 1471 MIPS64 architecture. Many modern embedded systems with a 64-bit 1472 MIPS processor are based on a MIPS64 processor. If you know the 1473 specific type of processor in your system, choose those that one 1474 otherwise CPU_MIPS64_R1 is a safe bet for any MIPS64 system. 1475 Release 2 of the MIPS64 architecture is available since several 1476 years so chances are you even have a MIPS64 Release 2 processor 1477 in which case you should choose CPU_MIPS64_R2 instead for better 1478 performance. 1479 1480config CPU_MIPS64_R2 1481 bool "MIPS64 Release 2" 1482 depends on SYS_HAS_CPU_MIPS64_R2 1483 select CPU_HAS_PREFETCH 1484 select CPU_SUPPORTS_32BIT_KERNEL 1485 select CPU_SUPPORTS_64BIT_KERNEL 1486 select CPU_SUPPORTS_HIGHMEM 1487 select CPU_SUPPORTS_HUGEPAGES 1488 select CPU_SUPPORTS_MSA 1489 select HAVE_KVM 1490 help 1491 Choose this option to build a kernel for release 2 or later of the 1492 MIPS64 architecture. Many modern embedded systems with a 64-bit 1493 MIPS processor are based on a MIPS64 processor. If you know the 1494 specific type of processor in your system, choose those that one 1495 otherwise CPU_MIPS64_R1 is a safe bet for any MIPS64 system. 1496 1497config CPU_MIPS64_R5 1498 bool "MIPS64 Release 5" 1499 depends on SYS_HAS_CPU_MIPS64_R5 1500 select CPU_HAS_PREFETCH 1501 select CPU_SUPPORTS_32BIT_KERNEL 1502 select CPU_SUPPORTS_64BIT_KERNEL 1503 select CPU_SUPPORTS_HIGHMEM 1504 select CPU_SUPPORTS_HUGEPAGES 1505 select CPU_SUPPORTS_MSA 1506 select MIPS_O32_FP64_SUPPORT if 32BIT || MIPS32_O32 1507 select HAVE_KVM 1508 help 1509 Choose this option to build a kernel for release 5 or later of the 1510 MIPS64 architecture. This is a intermediate MIPS architecture 1511 release partly implementing release 6 features. Though there is no 1512 any hardware known to be based on this release. 1513 1514config CPU_MIPS64_R6 1515 bool "MIPS64 Release 6" 1516 depends on SYS_HAS_CPU_MIPS64_R6 1517 select CPU_HAS_PREFETCH 1518 select CPU_NO_LOAD_STORE_LR 1519 select CPU_SUPPORTS_32BIT_KERNEL 1520 select CPU_SUPPORTS_64BIT_KERNEL 1521 select CPU_SUPPORTS_HIGHMEM 1522 select CPU_SUPPORTS_HUGEPAGES 1523 select CPU_SUPPORTS_MSA 1524 select MIPS_O32_FP64_SUPPORT if 32BIT || MIPS32_O32 1525 select HAVE_KVM 1526 help 1527 Choose this option to build a kernel for release 6 or later of the 1528 MIPS64 architecture. New MIPS processors, starting with the Warrior 1529 family, are based on a MIPS64r6 processor. If you own an older 1530 processor, you probably need to select MIPS64r1 or MIPS64r2 instead. 1531 1532config CPU_P5600 1533 bool "MIPS Warrior P5600" 1534 depends on SYS_HAS_CPU_P5600 1535 select CPU_HAS_PREFETCH 1536 select CPU_SUPPORTS_32BIT_KERNEL 1537 select CPU_SUPPORTS_HIGHMEM 1538 select CPU_SUPPORTS_MSA 1539 select CPU_SUPPORTS_CPUFREQ 1540 select CPU_MIPSR2_IRQ_VI 1541 select CPU_MIPSR2_IRQ_EI 1542 select HAVE_KVM 1543 select MIPS_O32_FP64_SUPPORT 1544 help 1545 Choose this option to build a kernel for MIPS Warrior P5600 CPU. 1546 It's based on MIPS32r5 ISA with XPA, EVA, dual/quad issue exec pipes, 1547 MMU with two-levels TLB, UCA, MSA, MDU core level features and system 1548 level features like up to six P5600 calculation cores, CM2 with L2 1549 cache, IOCU/IOMMU (though might be unused depending on the system- 1550 specific IP core configuration), GIC, CPC, virtualisation module, 1551 eJTAG and PDtrace. 1552 1553config CPU_R3000 1554 bool "R3000" 1555 depends on SYS_HAS_CPU_R3000 1556 select CPU_HAS_WB 1557 select CPU_R3K_TLB 1558 select CPU_SUPPORTS_32BIT_KERNEL 1559 select CPU_SUPPORTS_HIGHMEM 1560 help 1561 Please make sure to pick the right CPU type. Linux/MIPS is not 1562 designed to be generic, i.e. Kernels compiled for R3000 CPUs will 1563 *not* work on R4000 machines and vice versa. However, since most 1564 of the supported machines have an R4000 (or similar) CPU, R4x00 1565 might be a safe bet. If the resulting kernel does not work, 1566 try to recompile with R3000. 1567 1568config CPU_R4300 1569 bool "R4300" 1570 depends on SYS_HAS_CPU_R4300 1571 select CPU_SUPPORTS_32BIT_KERNEL 1572 select CPU_SUPPORTS_64BIT_KERNEL 1573 help 1574 MIPS Technologies R4300-series processors. 1575 1576config CPU_R4X00 1577 bool "R4x00" 1578 depends on SYS_HAS_CPU_R4X00 1579 select CPU_SUPPORTS_32BIT_KERNEL 1580 select CPU_SUPPORTS_64BIT_KERNEL 1581 select CPU_SUPPORTS_HUGEPAGES 1582 help 1583 MIPS Technologies R4000-series processors other than 4300, including 1584 the R4000, R4400, R4600, and 4700. 1585 1586config CPU_TX49XX 1587 bool "R49XX" 1588 depends on SYS_HAS_CPU_TX49XX 1589 select CPU_HAS_PREFETCH 1590 select CPU_SUPPORTS_32BIT_KERNEL 1591 select CPU_SUPPORTS_64BIT_KERNEL 1592 select CPU_SUPPORTS_HUGEPAGES 1593 1594config CPU_R5000 1595 bool "R5000" 1596 depends on SYS_HAS_CPU_R5000 1597 select CPU_SUPPORTS_32BIT_KERNEL 1598 select CPU_SUPPORTS_64BIT_KERNEL 1599 select CPU_SUPPORTS_HUGEPAGES 1600 help 1601 MIPS Technologies R5000-series processors other than the Nevada. 1602 1603config CPU_R5500 1604 bool "R5500" 1605 depends on SYS_HAS_CPU_R5500 1606 select CPU_SUPPORTS_32BIT_KERNEL 1607 select CPU_SUPPORTS_64BIT_KERNEL 1608 select CPU_SUPPORTS_HUGEPAGES 1609 help 1610 NEC VR5500 and VR5500A series processors implement 64-bit MIPS IV 1611 instruction set. 1612 1613config CPU_NEVADA 1614 bool "RM52xx" 1615 depends on SYS_HAS_CPU_NEVADA 1616 select CPU_SUPPORTS_32BIT_KERNEL 1617 select CPU_SUPPORTS_64BIT_KERNEL 1618 select CPU_SUPPORTS_HUGEPAGES 1619 help 1620 QED / PMC-Sierra RM52xx-series ("Nevada") processors. 1621 1622config CPU_R10000 1623 bool "R10000" 1624 depends on SYS_HAS_CPU_R10000 1625 select CPU_HAS_PREFETCH 1626 select CPU_SUPPORTS_32BIT_KERNEL 1627 select CPU_SUPPORTS_64BIT_KERNEL 1628 select CPU_SUPPORTS_HIGHMEM 1629 select CPU_SUPPORTS_HUGEPAGES 1630 help 1631 MIPS Technologies R10000-series processors. 1632 1633config CPU_RM7000 1634 bool "RM7000" 1635 depends on SYS_HAS_CPU_RM7000 1636 select CPU_HAS_PREFETCH 1637 select CPU_SUPPORTS_32BIT_KERNEL 1638 select CPU_SUPPORTS_64BIT_KERNEL 1639 select CPU_SUPPORTS_HIGHMEM 1640 select CPU_SUPPORTS_HUGEPAGES 1641 1642config CPU_SB1 1643 bool "SB1" 1644 depends on SYS_HAS_CPU_SB1 1645 select CPU_SUPPORTS_32BIT_KERNEL 1646 select CPU_SUPPORTS_64BIT_KERNEL 1647 select CPU_SUPPORTS_HIGHMEM 1648 select CPU_SUPPORTS_HUGEPAGES 1649 select WEAK_ORDERING 1650 1651config CPU_CAVIUM_OCTEON 1652 bool "Cavium Octeon processor" 1653 depends on SYS_HAS_CPU_CAVIUM_OCTEON 1654 select CPU_HAS_PREFETCH 1655 select CPU_SUPPORTS_64BIT_KERNEL 1656 select WEAK_ORDERING 1657 select CPU_SUPPORTS_HIGHMEM 1658 select CPU_SUPPORTS_HUGEPAGES 1659 select USB_EHCI_BIG_ENDIAN_MMIO if CPU_BIG_ENDIAN 1660 select USB_OHCI_BIG_ENDIAN_MMIO if CPU_BIG_ENDIAN 1661 select MIPS_L1_CACHE_SHIFT_7 1662 select HAVE_KVM 1663 help 1664 The Cavium Octeon processor is a highly integrated chip containing 1665 many ethernet hardware widgets for networking tasks. The processor 1666 can have up to 16 Mips64v2 cores and 8 integrated gigabit ethernets. 1667 Full details can be found at http://www.caviumnetworks.com. 1668 1669config CPU_BMIPS 1670 bool "Broadcom BMIPS" 1671 depends on SYS_HAS_CPU_BMIPS 1672 select CPU_MIPS32 1673 select CPU_BMIPS32_3300 if SYS_HAS_CPU_BMIPS32_3300 1674 select CPU_BMIPS4350 if SYS_HAS_CPU_BMIPS4350 1675 select CPU_BMIPS4380 if SYS_HAS_CPU_BMIPS4380 1676 select CPU_BMIPS5000 if SYS_HAS_CPU_BMIPS5000 1677 select CPU_SUPPORTS_32BIT_KERNEL 1678 select DMA_NONCOHERENT 1679 select IRQ_MIPS_CPU 1680 select SWAP_IO_SPACE 1681 select WEAK_ORDERING 1682 select CPU_SUPPORTS_HIGHMEM 1683 select CPU_HAS_PREFETCH 1684 select CPU_SUPPORTS_CPUFREQ 1685 select MIPS_EXTERNAL_TIMER 1686 select GENERIC_IRQ_MIGRATION if HOTPLUG_CPU 1687 help 1688 Support for BMIPS32/3300/4350/4380 and BMIPS5000 processors. 1689 1690endchoice 1691 1692config CPU_MIPS32_3_5_FEATURES 1693 bool "MIPS32 Release 3.5 Features" 1694 depends on SYS_HAS_CPU_MIPS32_R3_5 1695 depends on CPU_MIPS32_R2 || CPU_MIPS32_R5 || CPU_MIPS32_R6 || \ 1696 CPU_P5600 1697 help 1698 Choose this option to build a kernel for release 2 or later of the 1699 MIPS32 architecture including features from the 3.5 release such as 1700 support for Enhanced Virtual Addressing (EVA). 1701 1702config CPU_MIPS32_3_5_EVA 1703 bool "Enhanced Virtual Addressing (EVA)" 1704 depends on CPU_MIPS32_3_5_FEATURES 1705 select EVA 1706 default y 1707 help 1708 Choose this option if you want to enable the Enhanced Virtual 1709 Addressing (EVA) on your MIPS32 core (such as proAptiv). 1710 One of its primary benefits is an increase in the maximum size 1711 of lowmem (up to 3GB). If unsure, say 'N' here. 1712 1713config CPU_MIPS32_R5_FEATURES 1714 bool "MIPS32 Release 5 Features" 1715 depends on SYS_HAS_CPU_MIPS32_R5 1716 depends on CPU_MIPS32_R2 || CPU_MIPS32_R5 || CPU_P5600 1717 help 1718 Choose this option to build a kernel for release 2 or later of the 1719 MIPS32 architecture including features from release 5 such as 1720 support for Extended Physical Addressing (XPA). 1721 1722config CPU_MIPS32_R5_XPA 1723 bool "Extended Physical Addressing (XPA)" 1724 depends on CPU_MIPS32_R5_FEATURES 1725 depends on !EVA 1726 depends on !PAGE_SIZE_4KB 1727 depends on SYS_SUPPORTS_HIGHMEM 1728 select XPA 1729 select HIGHMEM 1730 select PHYS_ADDR_T_64BIT 1731 default n 1732 help 1733 Choose this option if you want to enable the Extended Physical 1734 Addressing (XPA) on your MIPS32 core (such as P5600 series). The 1735 benefit is to increase physical addressing equal to or greater 1736 than 40 bits. Note that this has the side effect of turning on 1737 64-bit addressing which in turn makes the PTEs 64-bit in size. 1738 If unsure, say 'N' here. 1739 1740if CPU_LOONGSON2F 1741config CPU_NOP_WORKAROUNDS 1742 bool 1743 1744config CPU_JUMP_WORKAROUNDS 1745 bool 1746 1747config CPU_LOONGSON2F_WORKAROUNDS 1748 bool "Loongson 2F Workarounds" 1749 default y 1750 select CPU_NOP_WORKAROUNDS 1751 select CPU_JUMP_WORKAROUNDS 1752 help 1753 Loongson 2F01 / 2F02 processors have the NOP & JUMP issues which 1754 require workarounds. Without workarounds the system may hang 1755 unexpectedly. For more information please refer to the gas 1756 -mfix-loongson2f-nop and -mfix-loongson2f-jump options. 1757 1758 Loongson 2F03 and later have fixed these issues and no workarounds 1759 are needed. The workarounds have no significant side effect on them 1760 but may decrease the performance of the system so this option should 1761 be disabled unless the kernel is intended to be run on 2F01 or 2F02 1762 systems. 1763 1764 If unsure, please say Y. 1765endif # CPU_LOONGSON2F 1766 1767config SYS_SUPPORTS_ZBOOT 1768 bool 1769 select HAVE_KERNEL_GZIP 1770 select HAVE_KERNEL_BZIP2 1771 select HAVE_KERNEL_LZ4 1772 select HAVE_KERNEL_LZMA 1773 select HAVE_KERNEL_LZO 1774 select HAVE_KERNEL_XZ 1775 select HAVE_KERNEL_ZSTD 1776 1777config SYS_SUPPORTS_ZBOOT_UART16550 1778 bool 1779 select SYS_SUPPORTS_ZBOOT 1780 1781config SYS_SUPPORTS_ZBOOT_UART_PROM 1782 bool 1783 select SYS_SUPPORTS_ZBOOT 1784 1785config CPU_LOONGSON2EF 1786 bool 1787 select CPU_SUPPORTS_32BIT_KERNEL 1788 select CPU_SUPPORTS_64BIT_KERNEL 1789 select CPU_SUPPORTS_HIGHMEM 1790 select CPU_SUPPORTS_HUGEPAGES 1791 select ARCH_HAS_PHYS_TO_DMA 1792 1793config CPU_LOONGSON32 1794 bool 1795 select CPU_MIPS32 1796 select CPU_MIPSR2 1797 select CPU_HAS_PREFETCH 1798 select CPU_SUPPORTS_32BIT_KERNEL 1799 select CPU_SUPPORTS_HIGHMEM 1800 select CPU_SUPPORTS_CPUFREQ 1801 1802config CPU_BMIPS32_3300 1803 select SMP_UP if SMP 1804 bool 1805 1806config CPU_BMIPS4350 1807 bool 1808 select SYS_SUPPORTS_SMP 1809 select SYS_SUPPORTS_HOTPLUG_CPU 1810 1811config CPU_BMIPS4380 1812 bool 1813 select MIPS_L1_CACHE_SHIFT_6 1814 select SYS_SUPPORTS_SMP 1815 select SYS_SUPPORTS_HOTPLUG_CPU 1816 select CPU_HAS_RIXI 1817 1818config CPU_BMIPS5000 1819 bool 1820 select MIPS_CPU_SCACHE 1821 select MIPS_L1_CACHE_SHIFT_7 1822 select SYS_SUPPORTS_SMP 1823 select SYS_SUPPORTS_HOTPLUG_CPU 1824 select CPU_HAS_RIXI 1825 1826config SYS_HAS_CPU_LOONGSON64 1827 bool 1828 select CPU_SUPPORTS_CPUFREQ 1829 select CPU_HAS_RIXI 1830 1831config SYS_HAS_CPU_LOONGSON2E 1832 bool 1833 1834config SYS_HAS_CPU_LOONGSON2F 1835 bool 1836 select CPU_SUPPORTS_CPUFREQ 1837 select CPU_SUPPORTS_ADDRWINCFG if 64BIT 1838 1839config SYS_HAS_CPU_LOONGSON1B 1840 bool 1841 1842config SYS_HAS_CPU_LOONGSON1C 1843 bool 1844 1845config SYS_HAS_CPU_MIPS32_R1 1846 bool 1847 1848config SYS_HAS_CPU_MIPS32_R2 1849 bool 1850 1851config SYS_HAS_CPU_MIPS32_R3_5 1852 bool 1853 1854config SYS_HAS_CPU_MIPS32_R5 1855 bool 1856 select ARCH_HAS_SYNC_DMA_FOR_CPU if DMA_NONCOHERENT 1857 1858config SYS_HAS_CPU_MIPS32_R6 1859 bool 1860 select ARCH_HAS_SYNC_DMA_FOR_CPU if DMA_NONCOHERENT 1861 1862config SYS_HAS_CPU_MIPS64_R1 1863 bool 1864 1865config SYS_HAS_CPU_MIPS64_R2 1866 bool 1867 1868config SYS_HAS_CPU_MIPS64_R5 1869 bool 1870 select ARCH_HAS_SYNC_DMA_FOR_CPU if DMA_NONCOHERENT 1871 1872config SYS_HAS_CPU_MIPS64_R6 1873 bool 1874 select ARCH_HAS_SYNC_DMA_FOR_CPU if DMA_NONCOHERENT 1875 1876config SYS_HAS_CPU_P5600 1877 bool 1878 select ARCH_HAS_SYNC_DMA_FOR_CPU if DMA_NONCOHERENT 1879 1880config SYS_HAS_CPU_R3000 1881 bool 1882 1883config SYS_HAS_CPU_R4300 1884 bool 1885 1886config SYS_HAS_CPU_R4X00 1887 bool 1888 1889config SYS_HAS_CPU_TX49XX 1890 bool 1891 1892config SYS_HAS_CPU_R5000 1893 bool 1894 1895config SYS_HAS_CPU_R5500 1896 bool 1897 1898config SYS_HAS_CPU_NEVADA 1899 bool 1900 1901config SYS_HAS_CPU_R10000 1902 bool 1903 select ARCH_HAS_SYNC_DMA_FOR_CPU if DMA_NONCOHERENT 1904 1905config SYS_HAS_CPU_RM7000 1906 bool 1907 1908config SYS_HAS_CPU_SB1 1909 bool 1910 1911config SYS_HAS_CPU_CAVIUM_OCTEON 1912 bool 1913 1914config SYS_HAS_CPU_BMIPS 1915 bool 1916 1917config SYS_HAS_CPU_BMIPS32_3300 1918 bool 1919 select SYS_HAS_CPU_BMIPS 1920 1921config SYS_HAS_CPU_BMIPS4350 1922 bool 1923 select SYS_HAS_CPU_BMIPS 1924 1925config SYS_HAS_CPU_BMIPS4380 1926 bool 1927 select SYS_HAS_CPU_BMIPS 1928 1929config SYS_HAS_CPU_BMIPS5000 1930 bool 1931 select SYS_HAS_CPU_BMIPS 1932 select ARCH_HAS_SYNC_DMA_FOR_CPU 1933 1934# 1935# CPU may reorder R->R, R->W, W->R, W->W 1936# Reordering beyond LL and SC is handled in WEAK_REORDERING_BEYOND_LLSC 1937# 1938config WEAK_ORDERING 1939 bool 1940 1941# 1942# CPU may reorder reads and writes beyond LL/SC 1943# CPU may reorder R->LL, R->LL, W->LL, W->LL, R->SC, R->SC, W->SC, W->SC 1944# 1945config WEAK_REORDERING_BEYOND_LLSC 1946 bool 1947endmenu 1948 1949# 1950# These two indicate any level of the MIPS32 and MIPS64 architecture 1951# 1952config CPU_MIPS32 1953 bool 1954 default y if CPU_MIPS32_R1 || CPU_MIPS32_R2 || CPU_MIPS32_R5 || \ 1955 CPU_MIPS32_R6 || CPU_P5600 1956 1957config CPU_MIPS64 1958 bool 1959 default y if CPU_MIPS64_R1 || CPU_MIPS64_R2 || CPU_MIPS64_R5 || \ 1960 CPU_MIPS64_R6 || CPU_LOONGSON64 || CPU_CAVIUM_OCTEON 1961 1962# 1963# These indicate the revision of the architecture 1964# 1965config CPU_MIPSR1 1966 bool 1967 default y if CPU_MIPS32_R1 || CPU_MIPS64_R1 1968 1969config CPU_MIPSR2 1970 bool 1971 default y if CPU_MIPS32_R2 || CPU_MIPS64_R2 || CPU_CAVIUM_OCTEON 1972 select CPU_HAS_RIXI 1973 select CPU_HAS_DIEI if !CPU_DIEI_BROKEN 1974 select MIPS_SPRAM 1975 1976config CPU_MIPSR5 1977 bool 1978 default y if CPU_MIPS32_R5 || CPU_MIPS64_R5 || CPU_P5600 1979 select CPU_HAS_RIXI 1980 select CPU_HAS_DIEI if !CPU_DIEI_BROKEN 1981 select MIPS_SPRAM 1982 1983config CPU_MIPSR6 1984 bool 1985 default y if CPU_MIPS32_R6 || CPU_MIPS64_R6 1986 select CPU_HAS_RIXI 1987 select CPU_HAS_DIEI if !CPU_DIEI_BROKEN 1988 select HAVE_ARCH_BITREVERSE 1989 select MIPS_ASID_BITS_VARIABLE 1990 select MIPS_CRC_SUPPORT 1991 select MIPS_SPRAM 1992 1993config TARGET_ISA_REV 1994 int 1995 default 1 if CPU_MIPSR1 1996 default 2 if CPU_MIPSR2 1997 default 5 if CPU_MIPSR5 1998 default 6 if CPU_MIPSR6 1999 default 0 2000 help 2001 Reflects the ISA revision being targeted by the kernel build. This 2002 is effectively the Kconfig equivalent of MIPS_ISA_REV. 2003 2004config EVA 2005 bool 2006 2007config XPA 2008 bool 2009 2010config SYS_SUPPORTS_32BIT_KERNEL 2011 bool 2012config SYS_SUPPORTS_64BIT_KERNEL 2013 bool 2014config CPU_SUPPORTS_32BIT_KERNEL 2015 bool 2016config CPU_SUPPORTS_64BIT_KERNEL 2017 bool 2018config CPU_SUPPORTS_CPUFREQ 2019 bool 2020config CPU_SUPPORTS_ADDRWINCFG 2021 bool 2022config CPU_SUPPORTS_HUGEPAGES 2023 bool 2024 depends on !(32BIT && (PHYS_ADDR_T_64BIT || EVA)) 2025config MIPS_PGD_C0_CONTEXT 2026 bool 2027 depends on 64BIT 2028 default y if (CPU_MIPSR2 || CPU_MIPSR6) 2029 2030# 2031# Set to y for ptrace access to watch registers. 2032# 2033config HARDWARE_WATCHPOINTS 2034 bool 2035 default y if CPU_MIPSR1 || CPU_MIPSR2 || CPU_MIPSR6 2036 2037menu "Kernel type" 2038 2039choice 2040 prompt "Kernel code model" 2041 help 2042 You should only select this option if you have a workload that 2043 actually benefits from 64-bit processing or if your machine has 2044 large memory. You will only be presented a single option in this 2045 menu if your system does not support both 32-bit and 64-bit kernels. 2046 2047config 32BIT 2048 bool "32-bit kernel" 2049 depends on CPU_SUPPORTS_32BIT_KERNEL && SYS_SUPPORTS_32BIT_KERNEL 2050 select TRAD_SIGNALS 2051 help 2052 Select this option if you want to build a 32-bit kernel. 2053 2054config 64BIT 2055 bool "64-bit kernel" 2056 depends on CPU_SUPPORTS_64BIT_KERNEL && SYS_SUPPORTS_64BIT_KERNEL 2057 help 2058 Select this option if you want to build a 64-bit kernel. 2059 2060endchoice 2061 2062config MIPS_VA_BITS_48 2063 bool "48 bits virtual memory" 2064 depends on 64BIT 2065 help 2066 Support a maximum at least 48 bits of application virtual 2067 memory. Default is 40 bits or less, depending on the CPU. 2068 For page sizes 16k and above, this option results in a small 2069 memory overhead for page tables. For 4k page size, a fourth 2070 level of page tables is added which imposes both a memory 2071 overhead as well as slower TLB fault handling. 2072 2073 If unsure, say N. 2074 2075config ZBOOT_LOAD_ADDRESS 2076 hex "Compressed kernel load address" 2077 default 0xffffffff80400000 if BCM47XX 2078 default 0x0 2079 depends on SYS_SUPPORTS_ZBOOT 2080 help 2081 The address to load compressed kernel, aka vmlinuz. 2082 2083 This is only used if non-zero. 2084 2085choice 2086 prompt "Kernel page size" 2087 default PAGE_SIZE_4KB 2088 2089config PAGE_SIZE_4KB 2090 bool "4kB" 2091 depends on !CPU_LOONGSON2EF && !CPU_LOONGSON64 2092 help 2093 This option select the standard 4kB Linux page size. On some 2094 R3000-family processors this is the only available page size. Using 2095 4kB page size will minimize memory consumption and is therefore 2096 recommended for low memory systems. 2097 2098config PAGE_SIZE_8KB 2099 bool "8kB" 2100 depends on CPU_CAVIUM_OCTEON 2101 depends on !MIPS_VA_BITS_48 2102 help 2103 Using 8kB page size will result in higher performance kernel at 2104 the price of higher memory consumption. This option is available 2105 only on cnMIPS processors. Note that you will need a suitable Linux 2106 distribution to support this. 2107 2108config PAGE_SIZE_16KB 2109 bool "16kB" 2110 depends on !CPU_R3000 2111 help 2112 Using 16kB page size will result in higher performance kernel at 2113 the price of higher memory consumption. This option is available on 2114 all non-R3000 family processors. Note that you will need a suitable 2115 Linux distribution to support this. 2116 2117config PAGE_SIZE_32KB 2118 bool "32kB" 2119 depends on CPU_CAVIUM_OCTEON 2120 depends on !MIPS_VA_BITS_48 2121 help 2122 Using 32kB page size will result in higher performance kernel at 2123 the price of higher memory consumption. This option is available 2124 only on cnMIPS cores. Note that you will need a suitable Linux 2125 distribution to support this. 2126 2127config PAGE_SIZE_64KB 2128 bool "64kB" 2129 depends on !CPU_R3000 2130 help 2131 Using 64kB page size will result in higher performance kernel at 2132 the price of higher memory consumption. This option is available on 2133 all non-R3000 family processor. Not that at the time of this 2134 writing this option is still high experimental. 2135 2136endchoice 2137 2138config ARCH_FORCE_MAX_ORDER 2139 int "Maximum zone order" 2140 default "13" if MIPS_HUGE_TLB_SUPPORT && PAGE_SIZE_64KB 2141 default "12" if MIPS_HUGE_TLB_SUPPORT && PAGE_SIZE_32KB 2142 default "11" if MIPS_HUGE_TLB_SUPPORT && PAGE_SIZE_16KB 2143 default "10" 2144 help 2145 The kernel memory allocator divides physically contiguous memory 2146 blocks into "zones", where each zone is a power of two number of 2147 pages. This option selects the largest power of two that the kernel 2148 keeps in the memory allocator. If you need to allocate very large 2149 blocks of physically contiguous memory, then you may need to 2150 increase this value. 2151 2152 The page size is not necessarily 4KB. Keep this in mind 2153 when choosing a value for this option. 2154 2155config BOARD_SCACHE 2156 bool 2157 2158config IP22_CPU_SCACHE 2159 bool 2160 select BOARD_SCACHE 2161 2162# 2163# Support for a MIPS32 / MIPS64 style S-caches 2164# 2165config MIPS_CPU_SCACHE 2166 bool 2167 select BOARD_SCACHE 2168 2169config R5000_CPU_SCACHE 2170 bool 2171 select BOARD_SCACHE 2172 2173config RM7000_CPU_SCACHE 2174 bool 2175 select BOARD_SCACHE 2176 2177config SIBYTE_DMA_PAGEOPS 2178 bool "Use DMA to clear/copy pages" 2179 depends on CPU_SB1 2180 help 2181 Instead of using the CPU to zero and copy pages, use a Data Mover 2182 channel. These DMA channels are otherwise unused by the standard 2183 SiByte Linux port. Seems to give a small performance benefit. 2184 2185config CPU_HAS_PREFETCH 2186 bool 2187 2188config CPU_GENERIC_DUMP_TLB 2189 bool 2190 default y if !CPU_R3000 2191 2192config MIPS_FP_SUPPORT 2193 bool "Floating Point support" if EXPERT 2194 default y 2195 help 2196 Select y to include support for floating point in the kernel 2197 including initialization of FPU hardware, FP context save & restore 2198 and emulation of an FPU where necessary. Without this support any 2199 userland program attempting to use floating point instructions will 2200 receive a SIGILL. 2201 2202 If you know that your userland will not attempt to use floating point 2203 instructions then you can say n here to shrink the kernel a little. 2204 2205 If unsure, say y. 2206 2207config CPU_R2300_FPU 2208 bool 2209 depends on MIPS_FP_SUPPORT 2210 default y if CPU_R3000 2211 2212config CPU_R3K_TLB 2213 bool 2214 2215config CPU_R4K_FPU 2216 bool 2217 depends on MIPS_FP_SUPPORT 2218 default y if !CPU_R2300_FPU 2219 2220config CPU_R4K_CACHE_TLB 2221 bool 2222 default y if !(CPU_R3K_TLB || CPU_SB1 || CPU_CAVIUM_OCTEON) 2223 2224config MIPS_MT_SMP 2225 bool "MIPS MT SMP support (1 TC on each available VPE)" 2226 default y 2227 depends on SYS_SUPPORTS_MULTITHREADING && !CPU_MIPSR6 && !CPU_MICROMIPS 2228 select CPU_MIPSR2_IRQ_VI 2229 select CPU_MIPSR2_IRQ_EI 2230 select SYNC_R4K 2231 select MIPS_MT 2232 select SMP 2233 select SMP_UP 2234 select SYS_SUPPORTS_SMP 2235 select SYS_SUPPORTS_SCHED_SMT 2236 select MIPS_PERF_SHARED_TC_COUNTERS 2237 help 2238 This is a kernel model which is known as SMVP. This is supported 2239 on cores with the MT ASE and uses the available VPEs to implement 2240 virtual processors which supports SMP. This is equivalent to the 2241 Intel Hyperthreading feature. For further information go to 2242 <http://www.imgtec.com/mips/mips-multithreading.asp>. 2243 2244config MIPS_MT 2245 bool 2246 2247config SCHED_SMT 2248 bool "SMT (multithreading) scheduler support" 2249 depends on SYS_SUPPORTS_SCHED_SMT 2250 default n 2251 help 2252 SMT scheduler support improves the CPU scheduler's decision making 2253 when dealing with MIPS MT enabled cores at a cost of slightly 2254 increased overhead in some places. If unsure say N here. 2255 2256config SYS_SUPPORTS_SCHED_SMT 2257 bool 2258 2259config SYS_SUPPORTS_MULTITHREADING 2260 bool 2261 2262config MIPS_MT_FPAFF 2263 bool "Dynamic FPU affinity for FP-intensive threads" 2264 default y 2265 depends on MIPS_MT_SMP 2266 2267config MIPSR2_TO_R6_EMULATOR 2268 bool "MIPS R2-to-R6 emulator" 2269 depends on CPU_MIPSR6 2270 depends on MIPS_FP_SUPPORT 2271 default y 2272 help 2273 Choose this option if you want to run non-R6 MIPS userland code. 2274 Even if you say 'Y' here, the emulator will still be disabled by 2275 default. You can enable it using the 'mipsr2emu' kernel option. 2276 The only reason this is a build-time option is to save ~14K from the 2277 final kernel image. 2278 2279config SYS_SUPPORTS_VPE_LOADER 2280 bool 2281 depends on SYS_SUPPORTS_MULTITHREADING 2282 help 2283 Indicates that the platform supports the VPE loader, and provides 2284 physical_memsize. 2285 2286config MIPS_VPE_LOADER 2287 bool "VPE loader support." 2288 depends on SYS_SUPPORTS_VPE_LOADER && MODULES 2289 select CPU_MIPSR2_IRQ_VI 2290 select CPU_MIPSR2_IRQ_EI 2291 select MIPS_MT 2292 help 2293 Includes a loader for loading an elf relocatable object 2294 onto another VPE and running it. 2295 2296config MIPS_VPE_LOADER_CMP 2297 bool 2298 default "y" 2299 depends on MIPS_VPE_LOADER && MIPS_CMP 2300 2301config MIPS_VPE_LOADER_MT 2302 bool 2303 default "y" 2304 depends on MIPS_VPE_LOADER && !MIPS_CMP 2305 2306config MIPS_VPE_LOADER_TOM 2307 bool "Load VPE program into memory hidden from linux" 2308 depends on MIPS_VPE_LOADER 2309 default y 2310 help 2311 The loader can use memory that is present but has been hidden from 2312 Linux using the kernel command line option "mem=xxMB". It's up to 2313 you to ensure the amount you put in the option and the space your 2314 program requires is less or equal to the amount physically present. 2315 2316config MIPS_VPE_APSP_API 2317 bool "Enable support for AP/SP API (RTLX)" 2318 depends on MIPS_VPE_LOADER 2319 2320config MIPS_VPE_APSP_API_CMP 2321 bool 2322 default "y" 2323 depends on MIPS_VPE_APSP_API && MIPS_CMP 2324 2325config MIPS_VPE_APSP_API_MT 2326 bool 2327 default "y" 2328 depends on MIPS_VPE_APSP_API && !MIPS_CMP 2329 2330config MIPS_CMP 2331 bool "MIPS CMP framework support (DEPRECATED)" 2332 depends on SYS_SUPPORTS_MIPS_CMP && !CPU_MIPSR6 2333 select SMP 2334 select SYNC_R4K 2335 select SYS_SUPPORTS_SMP 2336 select WEAK_ORDERING 2337 default n 2338 help 2339 Select this if you are using a bootloader which implements the "CMP 2340 framework" protocol (ie. YAMON) and want your kernel to make use of 2341 its ability to start secondary CPUs. 2342 2343 Unless you have a specific need, you should use CONFIG_MIPS_CPS 2344 instead of this. 2345 2346config MIPS_CPS 2347 bool "MIPS Coherent Processing System support" 2348 depends on SYS_SUPPORTS_MIPS_CPS 2349 select MIPS_CM 2350 select MIPS_CPS_PM if HOTPLUG_CPU 2351 select SMP 2352 select SYNC_R4K if (CEVT_R4K || CSRC_R4K) 2353 select SYS_SUPPORTS_HOTPLUG_CPU 2354 select SYS_SUPPORTS_SCHED_SMT if CPU_MIPSR6 2355 select SYS_SUPPORTS_SMP 2356 select WEAK_ORDERING 2357 select GENERIC_IRQ_MIGRATION if HOTPLUG_CPU 2358 help 2359 Select this if you wish to run an SMP kernel across multiple cores 2360 within a MIPS Coherent Processing System. When this option is 2361 enabled the kernel will probe for other cores and boot them with 2362 no external assistance. It is safe to enable this when hardware 2363 support is unavailable. 2364 2365config MIPS_CPS_PM 2366 depends on MIPS_CPS 2367 bool 2368 2369config MIPS_CM 2370 bool 2371 select MIPS_CPC 2372 2373config MIPS_CPC 2374 bool 2375 2376config SB1_PASS_2_WORKAROUNDS 2377 bool 2378 depends on CPU_SB1 && (CPU_SB1_PASS_2_2 || CPU_SB1_PASS_2) 2379 default y 2380 2381config SB1_PASS_2_1_WORKAROUNDS 2382 bool 2383 depends on CPU_SB1 && CPU_SB1_PASS_2 2384 default y 2385 2386choice 2387 prompt "SmartMIPS or microMIPS ASE support" 2388 2389config CPU_NEEDS_NO_SMARTMIPS_OR_MICROMIPS 2390 bool "None" 2391 help 2392 Select this if you want neither microMIPS nor SmartMIPS support 2393 2394config CPU_HAS_SMARTMIPS 2395 depends on SYS_SUPPORTS_SMARTMIPS 2396 bool "SmartMIPS" 2397 help 2398 SmartMIPS is a extension of the MIPS32 architecture aimed at 2399 increased security at both hardware and software level for 2400 smartcards. Enabling this option will allow proper use of the 2401 SmartMIPS instructions by Linux applications. However a kernel with 2402 this option will not work on a MIPS core without SmartMIPS core. If 2403 you don't know you probably don't have SmartMIPS and should say N 2404 here. 2405 2406config CPU_MICROMIPS 2407 depends on 32BIT && SYS_SUPPORTS_MICROMIPS && !CPU_MIPSR6 2408 bool "microMIPS" 2409 help 2410 When this option is enabled the kernel will be built using the 2411 microMIPS ISA 2412 2413endchoice 2414 2415config CPU_HAS_MSA 2416 bool "Support for the MIPS SIMD Architecture" 2417 depends on CPU_SUPPORTS_MSA 2418 depends on MIPS_FP_SUPPORT 2419 depends on 64BIT || MIPS_O32_FP64_SUPPORT 2420 help 2421 MIPS SIMD Architecture (MSA) introduces 128 bit wide vector registers 2422 and a set of SIMD instructions to operate on them. When this option 2423 is enabled the kernel will support allocating & switching MSA 2424 vector register contexts. If you know that your kernel will only be 2425 running on CPUs which do not support MSA or that your userland will 2426 not be making use of it then you may wish to say N here to reduce 2427 the size & complexity of your kernel. 2428 2429 If unsure, say Y. 2430 2431config CPU_HAS_WB 2432 bool 2433 2434config XKS01 2435 bool 2436 2437config CPU_HAS_DIEI 2438 depends on !CPU_DIEI_BROKEN 2439 bool 2440 2441config CPU_DIEI_BROKEN 2442 bool 2443 2444config CPU_HAS_RIXI 2445 bool 2446 2447config CPU_NO_LOAD_STORE_LR 2448 bool 2449 help 2450 CPU lacks support for unaligned load and store instructions: 2451 LWL, LWR, SWL, SWR (Load/store word left/right). 2452 LDL, LDR, SDL, SDR (Load/store doubleword left/right, for 64bit 2453 systems). 2454 2455# 2456# Vectored interrupt mode is an R2 feature 2457# 2458config CPU_MIPSR2_IRQ_VI 2459 bool 2460 2461# 2462# Extended interrupt mode is an R2 feature 2463# 2464config CPU_MIPSR2_IRQ_EI 2465 bool 2466 2467config CPU_HAS_SYNC 2468 bool 2469 depends on !CPU_R3000 2470 default y 2471 2472# 2473# CPU non-features 2474# 2475 2476# Work around the "daddi" and "daddiu" CPU errata: 2477# 2478# - The `daddi' instruction fails to trap on overflow. 2479# "MIPS R4000PC/SC Errata, Processor Revision 2.2 and 3.0", 2480# erratum #23 2481# 2482# - The `daddiu' instruction can produce an incorrect result. 2483# "MIPS R4000PC/SC Errata, Processor Revision 2.2 and 3.0", 2484# erratum #41 2485# "MIPS R4000MC Errata, Processor Revision 2.2 and 3.0", erratum 2486# #15 2487# "MIPS R4400PC/SC Errata, Processor Revision 1.0", erratum #7 2488# "MIPS R4400MC Errata, Processor Revision 1.0", erratum #5 2489config CPU_DADDI_WORKAROUNDS 2490 bool 2491 2492# Work around certain R4000 CPU errata (as implemented by GCC): 2493# 2494# - A double-word or a variable shift may give an incorrect result 2495# if executed immediately after starting an integer division: 2496# "MIPS R4000PC/SC Errata, Processor Revision 2.2 and 3.0", 2497# erratum #28 2498# "MIPS R4000MC Errata, Processor Revision 2.2 and 3.0", erratum 2499# #19 2500# 2501# - A double-word or a variable shift may give an incorrect result 2502# if executed while an integer multiplication is in progress: 2503# "MIPS R4000PC/SC Errata, Processor Revision 2.2 and 3.0", 2504# errata #16 & #28 2505# 2506# - An integer division may give an incorrect result if started in 2507# a delay slot of a taken branch or a jump: 2508# "MIPS R4000PC/SC Errata, Processor Revision 2.2 and 3.0", 2509# erratum #52 2510config CPU_R4000_WORKAROUNDS 2511 bool 2512 select CPU_R4400_WORKAROUNDS 2513 2514# Work around certain R4400 CPU errata (as implemented by GCC): 2515# 2516# - A double-word or a variable shift may give an incorrect result 2517# if executed immediately after starting an integer division: 2518# "MIPS R4400MC Errata, Processor Revision 1.0", erratum #10 2519# "MIPS R4400MC Errata, Processor Revision 2.0 & 3.0", erratum #4 2520config CPU_R4400_WORKAROUNDS 2521 bool 2522 2523config CPU_R4X00_BUGS64 2524 bool 2525 default y if SYS_HAS_CPU_R4X00 && 64BIT && (TARGET_ISA_REV < 1) 2526 2527config MIPS_ASID_SHIFT 2528 int 2529 default 6 if CPU_R3000 2530 default 0 2531 2532config MIPS_ASID_BITS 2533 int 2534 default 0 if MIPS_ASID_BITS_VARIABLE 2535 default 6 if CPU_R3000 2536 default 8 2537 2538config MIPS_ASID_BITS_VARIABLE 2539 bool 2540 2541config MIPS_CRC_SUPPORT 2542 bool 2543 2544# R4600 erratum. Due to the lack of errata information the exact 2545# technical details aren't known. I've experimentally found that disabling 2546# interrupts during indexed I-cache flushes seems to be sufficient to deal 2547# with the issue. 2548config WAR_R4600_V1_INDEX_ICACHEOP 2549 bool 2550 2551# Pleasures of the R4600 V1.x. Cite from the IDT R4600 V1.7 errata: 2552# 2553# 18. The CACHE instructions Hit_Writeback_Invalidate_D, Hit_Writeback_D, 2554# Hit_Invalidate_D and Create_Dirty_Excl_D should only be 2555# executed if there is no other dcache activity. If the dcache is 2556# accessed for another instruction immediately preceding when these 2557# cache instructions are executing, it is possible that the dcache 2558# tag match outputs used by these cache instructions will be 2559# incorrect. These cache instructions should be preceded by at least 2560# four instructions that are not any kind of load or store 2561# instruction. 2562# 2563# This is not allowed: lw 2564# nop 2565# nop 2566# nop 2567# cache Hit_Writeback_Invalidate_D 2568# 2569# This is allowed: lw 2570# nop 2571# nop 2572# nop 2573# nop 2574# cache Hit_Writeback_Invalidate_D 2575config WAR_R4600_V1_HIT_CACHEOP 2576 bool 2577 2578# Writeback and invalidate the primary cache dcache before DMA. 2579# 2580# R4600 v2.0 bug: "The CACHE instructions Hit_Writeback_Inv_D, 2581# Hit_Writeback_D, Hit_Invalidate_D and Create_Dirty_Exclusive_D will only 2582# operate correctly if the internal data cache refill buffer is empty. These 2583# CACHE instructions should be separated from any potential data cache miss 2584# by a load instruction to an uncached address to empty the response buffer." 2585# (Revision 2.0 device errata from IDT available on https://www.idt.com/ 2586# in .pdf format.) 2587config WAR_R4600_V2_HIT_CACHEOP 2588 bool 2589 2590# From TX49/H2 manual: "If the instruction (i.e. CACHE) is issued for 2591# the line which this instruction itself exists, the following 2592# operation is not guaranteed." 2593# 2594# Workaround: do two phase flushing for Index_Invalidate_I 2595config WAR_TX49XX_ICACHE_INDEX_INV 2596 bool 2597 2598# The RM7000 processors and the E9000 cores have a bug (though PMC-Sierra 2599# opposes it being called that) where invalid instructions in the same 2600# I-cache line worth of instructions being fetched may case spurious 2601# exceptions. 2602config WAR_ICACHE_REFILLS 2603 bool 2604 2605# On the R10000 up to version 2.6 (not sure about 2.7) there is a bug that 2606# may cause ll / sc and lld / scd sequences to execute non-atomically. 2607config WAR_R10000_LLSC 2608 bool 2609 2610# 34K core erratum: "Problems Executing the TLBR Instruction" 2611config WAR_MIPS34K_MISSED_ITLB 2612 bool 2613 2614# 2615# - Highmem only makes sense for the 32-bit kernel. 2616# - The current highmem code will only work properly on physically indexed 2617# caches such as R3000, SB1, R7000 or those that look like they're virtually 2618# indexed such as R4000/R4400 SC and MC versions or R10000. So for the 2619# moment we protect the user and offer the highmem option only on machines 2620# where it's known to be safe. This will not offer highmem on a few systems 2621# such as MIPS32 and MIPS64 CPUs which may have virtual and physically 2622# indexed CPUs but we're playing safe. 2623# - We use SYS_SUPPORTS_HIGHMEM to offer highmem only for systems where we 2624# know they might have memory configurations that could make use of highmem 2625# support. 2626# 2627config HIGHMEM 2628 bool "High Memory Support" 2629 depends on 32BIT && CPU_SUPPORTS_HIGHMEM && SYS_SUPPORTS_HIGHMEM && !CPU_MIPS32_3_5_EVA 2630 select KMAP_LOCAL 2631 2632config CPU_SUPPORTS_HIGHMEM 2633 bool 2634 2635config SYS_SUPPORTS_HIGHMEM 2636 bool 2637 2638config SYS_SUPPORTS_SMARTMIPS 2639 bool 2640 2641config SYS_SUPPORTS_MICROMIPS 2642 bool 2643 2644config SYS_SUPPORTS_MIPS16 2645 bool 2646 help 2647 This option must be set if a kernel might be executed on a MIPS16- 2648 enabled CPU even if MIPS16 is not actually being used. In other 2649 words, it makes the kernel MIPS16-tolerant. 2650 2651config CPU_SUPPORTS_MSA 2652 bool 2653 2654config ARCH_FLATMEM_ENABLE 2655 def_bool y 2656 depends on !NUMA && !CPU_LOONGSON2EF 2657 2658config ARCH_SPARSEMEM_ENABLE 2659 bool 2660 2661config NUMA 2662 bool "NUMA Support" 2663 depends on SYS_SUPPORTS_NUMA 2664 select SMP 2665 select HAVE_SETUP_PER_CPU_AREA 2666 select NEED_PER_CPU_EMBED_FIRST_CHUNK 2667 help 2668 Say Y to compile the kernel to support NUMA (Non-Uniform Memory 2669 Access). This option improves performance on systems with more 2670 than two nodes; on two node systems it is generally better to 2671 leave it disabled; on single node systems leave this option 2672 disabled. 2673 2674config SYS_SUPPORTS_NUMA 2675 bool 2676 2677config HAVE_ARCH_NODEDATA_EXTENSION 2678 bool 2679 2680config RELOCATABLE 2681 bool "Relocatable kernel" 2682 depends on SYS_SUPPORTS_RELOCATABLE 2683 depends on CPU_MIPS32_R2 || CPU_MIPS64_R2 || \ 2684 CPU_MIPS32_R5 || CPU_MIPS64_R5 || \ 2685 CPU_MIPS32_R6 || CPU_MIPS64_R6 || \ 2686 CPU_P5600 || CAVIUM_OCTEON_SOC || \ 2687 CPU_LOONGSON64 2688 help 2689 This builds a kernel image that retains relocation information 2690 so it can be loaded someplace besides the default 1MB. 2691 The relocations make the kernel binary about 15% larger, 2692 but are discarded at runtime 2693 2694config RELOCATION_TABLE_SIZE 2695 hex "Relocation table size" 2696 depends on RELOCATABLE 2697 range 0x0 0x01000000 2698 default "0x00200000" if CPU_LOONGSON64 2699 default "0x00100000" 2700 help 2701 A table of relocation data will be appended to the kernel binary 2702 and parsed at boot to fix up the relocated kernel. 2703 2704 This option allows the amount of space reserved for the table to be 2705 adjusted, although the default of 1Mb should be ok in most cases. 2706 2707 The build will fail and a valid size suggested if this is too small. 2708 2709 If unsure, leave at the default value. 2710 2711config RANDOMIZE_BASE 2712 bool "Randomize the address of the kernel image" 2713 depends on RELOCATABLE 2714 help 2715 Randomizes the physical and virtual address at which the 2716 kernel image is loaded, as a security feature that 2717 deters exploit attempts relying on knowledge of the location 2718 of kernel internals. 2719 2720 Entropy is generated using any coprocessor 0 registers available. 2721 2722 The kernel will be offset by up to RANDOMIZE_BASE_MAX_OFFSET. 2723 2724 If unsure, say N. 2725 2726config RANDOMIZE_BASE_MAX_OFFSET 2727 hex "Maximum kASLR offset" if EXPERT 2728 depends on RANDOMIZE_BASE 2729 range 0x0 0x40000000 if EVA || 64BIT 2730 range 0x0 0x08000000 2731 default "0x01000000" 2732 help 2733 When kASLR is active, this provides the maximum offset that will 2734 be applied to the kernel image. It should be set according to the 2735 amount of physical RAM available in the target system minus 2736 PHYSICAL_START and must be a power of 2. 2737 2738 This is limited by the size of KSEG0, 256Mb on 32-bit or 1Gb with 2739 EVA or 64-bit. The default is 16Mb. 2740 2741config NODES_SHIFT 2742 int 2743 default "6" 2744 depends on NUMA 2745 2746config HW_PERF_EVENTS 2747 bool "Enable hardware performance counter support for perf events" 2748 depends on PERF_EVENTS && (CPU_MIPS32 || CPU_MIPS64 || CPU_R10000 || CPU_SB1 || CPU_CAVIUM_OCTEON || CPU_LOONGSON64) 2749 default y 2750 help 2751 Enable hardware performance counter support for perf events. If 2752 disabled, perf events will use software events only. 2753 2754config DMI 2755 bool "Enable DMI scanning" 2756 depends on MACH_LOONGSON64 2757 select DMI_SCAN_MACHINE_NON_EFI_FALLBACK 2758 default y 2759 help 2760 Enabled scanning of DMI to identify machine quirks. Say Y 2761 here unless you have verified that your setup is not 2762 affected by entries in the DMI blacklist. Required by PNP 2763 BIOS code. 2764 2765config SMP 2766 bool "Multi-Processing support" 2767 depends on SYS_SUPPORTS_SMP 2768 help 2769 This enables support for systems with more than one CPU. If you have 2770 a system with only one CPU, say N. If you have a system with more 2771 than one CPU, say Y. 2772 2773 If you say N here, the kernel will run on uni- and multiprocessor 2774 machines, but will use only one CPU of a multiprocessor machine. If 2775 you say Y here, the kernel will run on many, but not all, 2776 uniprocessor machines. On a uniprocessor machine, the kernel 2777 will run faster if you say N here. 2778 2779 People using multiprocessor machines who say Y here should also say 2780 Y to "Enhanced Real Time Clock Support", below. 2781 2782 See also the SMP-HOWTO available at 2783 <https://www.tldp.org/docs.html#howto>. 2784 2785 If you don't know what to do here, say N. 2786 2787config HOTPLUG_CPU 2788 bool "Support for hot-pluggable CPUs" 2789 depends on SMP && SYS_SUPPORTS_HOTPLUG_CPU 2790 help 2791 Say Y here to allow turning CPUs off and on. CPUs can be 2792 controlled through /sys/devices/system/cpu. 2793 (Note: power management support will enable this option 2794 automatically on SMP systems. ) 2795 Say N if you want to disable CPU hotplug. 2796 2797config SMP_UP 2798 bool 2799 2800config SYS_SUPPORTS_MIPS_CMP 2801 bool 2802 2803config SYS_SUPPORTS_MIPS_CPS 2804 bool 2805 2806config SYS_SUPPORTS_SMP 2807 bool 2808 2809config NR_CPUS_DEFAULT_4 2810 bool 2811 2812config NR_CPUS_DEFAULT_8 2813 bool 2814 2815config NR_CPUS_DEFAULT_16 2816 bool 2817 2818config NR_CPUS_DEFAULT_32 2819 bool 2820 2821config NR_CPUS_DEFAULT_64 2822 bool 2823 2824config NR_CPUS 2825 int "Maximum number of CPUs (2-256)" 2826 range 2 256 2827 depends on SMP 2828 default "4" if NR_CPUS_DEFAULT_4 2829 default "8" if NR_CPUS_DEFAULT_8 2830 default "16" if NR_CPUS_DEFAULT_16 2831 default "32" if NR_CPUS_DEFAULT_32 2832 default "64" if NR_CPUS_DEFAULT_64 2833 help 2834 This allows you to specify the maximum number of CPUs which this 2835 kernel will support. The maximum supported value is 32 for 32-bit 2836 kernel and 64 for 64-bit kernels; the minimum value which makes 2837 sense is 1 for Qemu (useful only for kernel debugging purposes) 2838 and 2 for all others. 2839 2840 This is purely to save memory - each supported CPU adds 2841 approximately eight kilobytes to the kernel image. For best 2842 performance should round up your number of processors to the next 2843 power of two. 2844 2845config MIPS_PERF_SHARED_TC_COUNTERS 2846 bool 2847 2848config MIPS_NR_CPU_NR_MAP_1024 2849 bool 2850 2851config MIPS_NR_CPU_NR_MAP 2852 int 2853 depends on SMP 2854 default 1024 if MIPS_NR_CPU_NR_MAP_1024 2855 default NR_CPUS if !MIPS_NR_CPU_NR_MAP_1024 2856 2857# 2858# Timer Interrupt Frequency Configuration 2859# 2860 2861choice 2862 prompt "Timer frequency" 2863 default HZ_250 2864 help 2865 Allows the configuration of the timer frequency. 2866 2867 config HZ_24 2868 bool "24 HZ" if SYS_SUPPORTS_24HZ || SYS_SUPPORTS_ARBIT_HZ 2869 2870 config HZ_48 2871 bool "48 HZ" if SYS_SUPPORTS_48HZ || SYS_SUPPORTS_ARBIT_HZ 2872 2873 config HZ_100 2874 bool "100 HZ" if SYS_SUPPORTS_100HZ || SYS_SUPPORTS_ARBIT_HZ 2875 2876 config HZ_128 2877 bool "128 HZ" if SYS_SUPPORTS_128HZ || SYS_SUPPORTS_ARBIT_HZ 2878 2879 config HZ_250 2880 bool "250 HZ" if SYS_SUPPORTS_250HZ || SYS_SUPPORTS_ARBIT_HZ 2881 2882 config HZ_256 2883 bool "256 HZ" if SYS_SUPPORTS_256HZ || SYS_SUPPORTS_ARBIT_HZ 2884 2885 config HZ_1000 2886 bool "1000 HZ" if SYS_SUPPORTS_1000HZ || SYS_SUPPORTS_ARBIT_HZ 2887 2888 config HZ_1024 2889 bool "1024 HZ" if SYS_SUPPORTS_1024HZ || SYS_SUPPORTS_ARBIT_HZ 2890 2891endchoice 2892 2893config SYS_SUPPORTS_24HZ 2894 bool 2895 2896config SYS_SUPPORTS_48HZ 2897 bool 2898 2899config SYS_SUPPORTS_100HZ 2900 bool 2901 2902config SYS_SUPPORTS_128HZ 2903 bool 2904 2905config SYS_SUPPORTS_250HZ 2906 bool 2907 2908config SYS_SUPPORTS_256HZ 2909 bool 2910 2911config SYS_SUPPORTS_1000HZ 2912 bool 2913 2914config SYS_SUPPORTS_1024HZ 2915 bool 2916 2917config SYS_SUPPORTS_ARBIT_HZ 2918 bool 2919 default y if !SYS_SUPPORTS_24HZ && \ 2920 !SYS_SUPPORTS_48HZ && \ 2921 !SYS_SUPPORTS_100HZ && \ 2922 !SYS_SUPPORTS_128HZ && \ 2923 !SYS_SUPPORTS_250HZ && \ 2924 !SYS_SUPPORTS_256HZ && \ 2925 !SYS_SUPPORTS_1000HZ && \ 2926 !SYS_SUPPORTS_1024HZ 2927 2928config HZ 2929 int 2930 default 24 if HZ_24 2931 default 48 if HZ_48 2932 default 100 if HZ_100 2933 default 128 if HZ_128 2934 default 250 if HZ_250 2935 default 256 if HZ_256 2936 default 1000 if HZ_1000 2937 default 1024 if HZ_1024 2938 2939config SCHED_HRTICK 2940 def_bool HIGH_RES_TIMERS 2941 2942config KEXEC 2943 bool "Kexec system call" 2944 select KEXEC_CORE 2945 help 2946 kexec is a system call that implements the ability to shutdown your 2947 current kernel, and to start another kernel. It is like a reboot 2948 but it is independent of the system firmware. And like a reboot 2949 you can start any kernel with it, not just Linux. 2950 2951 The name comes from the similarity to the exec system call. 2952 2953 It is an ongoing process to be certain the hardware in a machine 2954 is properly shutdown, so do not be surprised if this code does not 2955 initially work for you. As of this writing the exact hardware 2956 interface is strongly in flux, so no good recommendation can be 2957 made. 2958 2959config CRASH_DUMP 2960 bool "Kernel crash dumps" 2961 help 2962 Generate crash dump after being started by kexec. 2963 This should be normally only set in special crash dump kernels 2964 which are loaded in the main kernel with kexec-tools into 2965 a specially reserved region and then later executed after 2966 a crash by kdump/kexec. The crash dump kernel must be compiled 2967 to a memory address not used by the main kernel or firmware using 2968 PHYSICAL_START. 2969 2970config PHYSICAL_START 2971 hex "Physical address where the kernel is loaded" 2972 default "0xffffffff84000000" 2973 depends on CRASH_DUMP 2974 help 2975 This gives the CKSEG0 or KSEG0 address where the kernel is loaded. 2976 If you plan to use kernel for capturing the crash dump change 2977 this value to start of the reserved region (the "X" value as 2978 specified in the "crashkernel=YM@XM" command line boot parameter 2979 passed to the panic-ed kernel). 2980 2981config MIPS_O32_FP64_SUPPORT 2982 bool "Support for O32 binaries using 64-bit FP" if !CPU_MIPSR6 2983 depends on 32BIT || MIPS32_O32 2984 help 2985 When this is enabled, the kernel will support use of 64-bit floating 2986 point registers with binaries using the O32 ABI along with the 2987 EF_MIPS_FP64 ELF header flag (typically built with -mfp64). On 2988 32-bit MIPS systems this support is at the cost of increasing the 2989 size and complexity of the compiled FPU emulator. Thus if you are 2990 running a MIPS32 system and know that none of your userland binaries 2991 will require 64-bit floating point, you may wish to reduce the size 2992 of your kernel & potentially improve FP emulation performance by 2993 saying N here. 2994 2995 Although binutils currently supports use of this flag the details 2996 concerning its effect upon the O32 ABI in userland are still being 2997 worked on. In order to avoid userland becoming dependent upon current 2998 behaviour before the details have been finalised, this option should 2999 be considered experimental and only enabled by those working upon 3000 said details. 3001 3002 If unsure, say N. 3003 3004config USE_OF 3005 bool 3006 select OF 3007 select OF_EARLY_FLATTREE 3008 select IRQ_DOMAIN 3009 3010config UHI_BOOT 3011 bool 3012 3013config BUILTIN_DTB 3014 bool 3015 3016choice 3017 prompt "Kernel appended dtb support" if USE_OF 3018 default MIPS_NO_APPENDED_DTB 3019 3020 config MIPS_NO_APPENDED_DTB 3021 bool "None" 3022 help 3023 Do not enable appended dtb support. 3024 3025 config MIPS_ELF_APPENDED_DTB 3026 bool "vmlinux" 3027 help 3028 With this option, the boot code will look for a device tree binary 3029 DTB) included in the vmlinux ELF section .appended_dtb. By default 3030 it is empty and the DTB can be appended using binutils command 3031 objcopy: 3032 3033 objcopy --update-section .appended_dtb=<filename>.dtb vmlinux 3034 3035 This is meant as a backward compatibility convenience for those 3036 systems with a bootloader that can't be upgraded to accommodate 3037 the documented boot protocol using a device tree. 3038 3039 config MIPS_RAW_APPENDED_DTB 3040 bool "vmlinux.bin or vmlinuz.bin" 3041 help 3042 With this option, the boot code will look for a device tree binary 3043 DTB) appended to raw vmlinux.bin or vmlinuz.bin. 3044 (e.g. cat vmlinux.bin <filename>.dtb > vmlinux_w_dtb). 3045 3046 This is meant as a backward compatibility convenience for those 3047 systems with a bootloader that can't be upgraded to accommodate 3048 the documented boot protocol using a device tree. 3049 3050 Beware that there is very little in terms of protection against 3051 this option being confused by leftover garbage in memory that might 3052 look like a DTB header after a reboot if no actual DTB is appended 3053 to vmlinux.bin. Do not leave this option active in a production kernel 3054 if you don't intend to always append a DTB. 3055endchoice 3056 3057choice 3058 prompt "Kernel command line type" if !CMDLINE_OVERRIDE 3059 default MIPS_CMDLINE_FROM_DTB if USE_OF && !ATH79 && !MACH_INGENIC && \ 3060 !MACH_LOONGSON64 && !MIPS_MALTA && \ 3061 !CAVIUM_OCTEON_SOC 3062 default MIPS_CMDLINE_FROM_BOOTLOADER 3063 3064 config MIPS_CMDLINE_FROM_DTB 3065 depends on USE_OF 3066 bool "Dtb kernel arguments if available" 3067 3068 config MIPS_CMDLINE_DTB_EXTEND 3069 depends on USE_OF 3070 bool "Extend dtb kernel arguments with bootloader arguments" 3071 3072 config MIPS_CMDLINE_FROM_BOOTLOADER 3073 bool "Bootloader kernel arguments if available" 3074 3075 config MIPS_CMDLINE_BUILTIN_EXTEND 3076 depends on CMDLINE_BOOL 3077 bool "Extend builtin kernel arguments with bootloader arguments" 3078endchoice 3079 3080endmenu 3081 3082config LOCKDEP_SUPPORT 3083 bool 3084 default y 3085 3086config STACKTRACE_SUPPORT 3087 bool 3088 default y 3089 3090config PGTABLE_LEVELS 3091 int 3092 default 4 if PAGE_SIZE_4KB && MIPS_VA_BITS_48 3093 default 3 if 64BIT && (!PAGE_SIZE_64KB || MIPS_VA_BITS_48) 3094 default 2 3095 3096config MIPS_AUTO_PFN_OFFSET 3097 bool 3098 3099menu "Bus options (PCI, PCMCIA, EISA, ISA, TC)" 3100 3101config PCI_DRIVERS_GENERIC 3102 select PCI_DOMAINS_GENERIC if PCI 3103 bool 3104 3105config PCI_DRIVERS_LEGACY 3106 def_bool !PCI_DRIVERS_GENERIC 3107 select NO_GENERIC_PCI_IOPORT_MAP 3108 select PCI_DOMAINS if PCI 3109 3110# 3111# ISA support is now enabled via select. Too many systems still have the one 3112# or other ISA chip on the board that users don't know about so don't expect 3113# users to choose the right thing ... 3114# 3115config ISA 3116 bool 3117 3118config TC 3119 bool "TURBOchannel support" 3120 depends on MACH_DECSTATION 3121 help 3122 TURBOchannel is a DEC (now Compaq (now HP)) bus for Alpha and MIPS 3123 processors. TURBOchannel programming specifications are available 3124 at: 3125 <ftp://ftp.hp.com/pub/alphaserver/archive/triadd/> 3126 and: 3127 <http://www.computer-refuge.org/classiccmp/ftp.digital.com/pub/DEC/TriAdd/> 3128 Linux driver support status is documented at: 3129 <http://www.linux-mips.org/wiki/DECstation> 3130 3131config MMU 3132 bool 3133 default y 3134 3135config ARCH_MMAP_RND_BITS_MIN 3136 default 12 if 64BIT 3137 default 8 3138 3139config ARCH_MMAP_RND_BITS_MAX 3140 default 18 if 64BIT 3141 default 15 3142 3143config ARCH_MMAP_RND_COMPAT_BITS_MIN 3144 default 8 3145 3146config ARCH_MMAP_RND_COMPAT_BITS_MAX 3147 default 15 3148 3149config I8253 3150 bool 3151 select CLKSRC_I8253 3152 select CLKEVT_I8253 3153 select MIPS_EXTERNAL_TIMER 3154endmenu 3155 3156config TRAD_SIGNALS 3157 bool 3158 3159config MIPS32_COMPAT 3160 bool 3161 3162config COMPAT 3163 bool 3164 3165config MIPS32_O32 3166 bool "Kernel support for o32 binaries" 3167 depends on 64BIT 3168 select ARCH_WANT_OLD_COMPAT_IPC 3169 select COMPAT 3170 select MIPS32_COMPAT 3171 help 3172 Select this option if you want to run o32 binaries. These are pure 3173 32-bit binaries as used by the 32-bit Linux/MIPS port. Most of 3174 existing binaries are in this format. 3175 3176 If unsure, say Y. 3177 3178config MIPS32_N32 3179 bool "Kernel support for n32 binaries" 3180 depends on 64BIT 3181 select ARCH_WANT_COMPAT_IPC_PARSE_VERSION 3182 select COMPAT 3183 select MIPS32_COMPAT 3184 help 3185 Select this option if you want to run n32 binaries. These are 3186 64-bit binaries using 32-bit quantities for addressing and certain 3187 data that would normally be 64-bit. They are used in special 3188 cases. 3189 3190 If unsure, say N. 3191 3192config CC_HAS_MNO_BRANCH_LIKELY 3193 def_bool y 3194 depends on $(cc-option,-mno-branch-likely) 3195 3196# https://github.com/llvm/llvm-project/issues/61045 3197config CC_HAS_BROKEN_INLINE_COMPAT_BRANCH 3198 def_bool y if CC_IS_CLANG 3199 3200menu "Power management options" 3201 3202config ARCH_HIBERNATION_POSSIBLE 3203 def_bool y 3204 depends on SYS_SUPPORTS_HOTPLUG_CPU || !SMP 3205 3206config ARCH_SUSPEND_POSSIBLE 3207 def_bool y 3208 depends on SYS_SUPPORTS_HOTPLUG_CPU || !SMP 3209 3210source "kernel/power/Kconfig" 3211 3212endmenu 3213 3214config MIPS_EXTERNAL_TIMER 3215 bool 3216 3217menu "CPU Power Management" 3218 3219if CPU_SUPPORTS_CPUFREQ && MIPS_EXTERNAL_TIMER 3220source "drivers/cpufreq/Kconfig" 3221endif # CPU_SUPPORTS_CPUFREQ && MIPS_EXTERNAL_TIMER 3222 3223source "drivers/cpuidle/Kconfig" 3224 3225endmenu 3226 3227source "arch/mips/kvm/Kconfig" 3228 3229source "arch/mips/vdso/Kconfig" 3230