Browse Source

remove sortext stuff, fix macos x host builds

Waldemar Brodkorb 10 years ago
parent
commit
194b03d5d9
1 changed files with 4937 additions and 10 deletions
  1. 4937 10
      toolchain/kernel-headers/patches/3.9.11/sortext.patch

+ 4937 - 10
toolchain/kernel-headers/patches/3.9.11/sortext.patch

@@ -1,22 +1,4949 @@
-diff -Nur linux-3.5.2.orig/arch/mips/Kconfig linux-3.5.2/arch/mips/Kconfig
---- linux-3.5.2.orig/arch/mips/Kconfig	2012-08-15 16:55:25.000000000 +0200
-+++ linux-3.5.2/arch/mips/Kconfig	2012-08-23 11:10:29.000000000 +0200
-@@ -31,7 +31,6 @@
+diff -Nur linux-3.9.11.orig/arch/arm/Kconfig linux-3.9.11/arch/arm/Kconfig
+--- linux-3.9.11.orig/arch/arm/Kconfig	2013-07-21 02:16:17.000000000 +0200
++++ linux-3.9.11/arch/arm/Kconfig	2013-09-12 07:26:36.000000000 +0200
+@@ -6,7 +6,6 @@
+ 	select ARCH_HAVE_CUSTOM_GPIO_H
+ 	select ARCH_HAS_TICK_BROADCAST if GENERIC_CLOCKEVENTS_BROADCAST
+ 	select ARCH_WANT_IPC_PARSE_VERSION
+-	select BUILDTIME_EXTABLE_SORT if MMU
+ 	select CPU_PM if (SUSPEND || CPU_IDLE)
+ 	select DCACHE_WORD_ACCESS if (CPU_V6 || CPU_V6K || CPU_V7) && !CPU_BIG_ENDIAN && MMU
+ 	select GENERIC_ATOMIC64 if (CPU_V6 || !CPU_32v6K || !AEABI)
+diff -Nur linux-3.9.11.orig/arch/mips/Kconfig linux-3.9.11/arch/mips/Kconfig
+--- linux-3.9.11.orig/arch/mips/Kconfig	2013-07-21 02:16:17.000000000 +0200
++++ linux-3.9.11/arch/mips/Kconfig	2013-09-12 07:26:20.000000000 +0200
+@@ -34,7 +34,6 @@
  	select HAVE_MEMBLOCK_NODE_MAP
  	select ARCH_DISCARD_MEMBLOCK
  	select GENERIC_SMP_IDLE_THREAD
 -	select BUILDTIME_EXTABLE_SORT
  	select GENERIC_CLOCKEVENTS
  	select GENERIC_CMOS_UPDATE
- 
-diff -Nur linux-3.5.2.orig/arch/x86/Kconfig linux-3.5.2/arch/x86/Kconfig
---- linux-3.5.2.orig/arch/x86/Kconfig	2012-08-15 16:55:25.000000000 +0200
-+++ linux-3.5.2/arch/x86/Kconfig	2012-08-23 11:10:17.000000000 +0200
-@@ -85,7 +85,6 @@
- 	select DCACHE_WORD_ACCESS
+ 	select HAVE_MOD_ARCH_SPECIFIC
+diff -Nur linux-3.9.11.orig/arch/mips/Kconfig.orig linux-3.9.11/arch/mips/Kconfig.orig
+--- linux-3.9.11.orig/arch/mips/Kconfig.orig	1970-01-01 01:00:00.000000000 +0100
++++ linux-3.9.11/arch/mips/Kconfig.orig	2013-07-21 02:16:17.000000000 +0200
+@@ -0,0 +1,2557 @@
++config MIPS
++	bool
++	default y
++	select HAVE_GENERIC_DMA_COHERENT
++	select HAVE_IDE
++	select HAVE_OPROFILE
++	select HAVE_PERF_EVENTS
++	select PERF_USE_VMALLOC
++	select HAVE_ARCH_KGDB
++	select ARCH_HAVE_CUSTOM_GPIO_H
++	select HAVE_FUNCTION_TRACER
++	select HAVE_FUNCTION_TRACE_MCOUNT_TEST
++	select HAVE_DYNAMIC_FTRACE
++	select HAVE_FTRACE_MCOUNT_RECORD
++	select HAVE_C_RECORDMCOUNT
++	select HAVE_FUNCTION_GRAPH_TRACER
++	select HAVE_KPROBES
++	select HAVE_KRETPROBES
++	select HAVE_DEBUG_KMEMLEAK
++	select ARCH_BINFMT_ELF_RANDOMIZE_PIE
++	select HAVE_ARCH_TRANSPARENT_HUGEPAGE if CPU_SUPPORTS_HUGEPAGES && 64BIT
++	select RTC_LIB if !MACH_LOONGSON
++	select GENERIC_ATOMIC64 if !64BIT
++	select ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
++	select HAVE_DMA_ATTRS
++	select HAVE_DMA_API_DEBUG
++	select HAVE_GENERIC_HARDIRQS
++	select GENERIC_IRQ_PROBE
++	select GENERIC_IRQ_SHOW
++	select HAVE_ARCH_JUMP_LABEL
++	select ARCH_WANT_IPC_PARSE_VERSION
++	select IRQ_FORCED_THREADING
++	select HAVE_MEMBLOCK
++	select HAVE_MEMBLOCK_NODE_MAP
++	select ARCH_DISCARD_MEMBLOCK
++	select GENERIC_SMP_IDLE_THREAD
++	select BUILDTIME_EXTABLE_SORT
++	select GENERIC_CLOCKEVENTS
++	select GENERIC_CMOS_UPDATE
++	select HAVE_MOD_ARCH_SPECIFIC
++	select VIRT_TO_BUS
++	select MODULES_USE_ELF_REL if MODULES
++	select MODULES_USE_ELF_RELA if MODULES && 64BIT
++	select CLONE_BACKWARDS
++
++menu "Machine selection"
++
++config ZONE_DMA
++	bool
++
++choice
++	prompt "System type"
++	default SGI_IP22
++
++config MIPS_ALCHEMY
++	bool "Alchemy processor based machines"
++	select 64BIT_PHYS_ADDR
++	select CEVT_R4K
++	select CSRC_R4K
++	select IRQ_CPU
++	select SYS_HAS_CPU_MIPS32_R1
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_APM_EMULATION
++	select GENERIC_GPIO
++	select ARCH_WANT_OPTIONAL_GPIOLIB
++	select SYS_SUPPORTS_ZBOOT
++	select USB_ARCH_HAS_OHCI
++	select USB_ARCH_HAS_EHCI
++
++config AR7
++	bool "Texas Instruments AR7"
++	select BOOT_ELF32
++	select DMA_NONCOHERENT
++	select CEVT_R4K
++	select CSRC_R4K
++	select IRQ_CPU
++	select NO_EXCEPT_FILL
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_MIPS32_R1
++	select SYS_HAS_EARLY_PRINTK
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select SYS_SUPPORTS_ZBOOT_UART16550
++	select ARCH_REQUIRE_GPIOLIB
++	select VLYNQ
++	select HAVE_CLK
++	help
++	  Support for the Texas Instruments AR7 System-on-a-Chip
++	  family: TNETD7100, 7200 and 7300.
++
++config ATH79
++	bool "Atheros AR71XX/AR724X/AR913X based boards"
++	select ARCH_REQUIRE_GPIOLIB
++	select BOOT_RAW
++	select CEVT_R4K
++	select CSRC_R4K
++	select DMA_NONCOHERENT
++	select HAVE_CLK
++	select IRQ_CPU
++	select MIPS_MACHINE
++	select SYS_HAS_CPU_MIPS32_R2
++	select SYS_HAS_EARLY_PRINTK
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	help
++	  Support for the Atheros AR71XX/AR724X/AR913X SoCs.
++
++config BCM47XX
++	bool "Broadcom BCM47XX based boards"
++	select ARCH_WANT_OPTIONAL_GPIOLIB
++	select BOOT_RAW
++	select CEVT_R4K
++	select CSRC_R4K
++	select DMA_NONCOHERENT
++	select FW_CFE
++	select HW_HAS_PCI
++	select IRQ_CPU
++	select NO_EXCEPT_FILL
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select SYS_HAS_EARLY_PRINTK
++	help
++	 Support for BCM47XX based boards
++
++config BCM63XX
++	bool "Broadcom BCM63XX based boards"
++	select CEVT_R4K
++	select CSRC_R4K
++	select DMA_NONCOHERENT
++	select IRQ_CPU
++	select SYS_HAS_CPU_MIPS32_R1
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_HAS_EARLY_PRINTK
++	select SWAP_IO_SPACE
++	select ARCH_REQUIRE_GPIOLIB
++	select HAVE_CLK
++	help
++	 Support for BCM63XX based boards
++
++config MIPS_COBALT
++	bool "Cobalt Server"
++	select CEVT_R4K
++	select CSRC_R4K
++	select CEVT_GT641XX
++	select DMA_NONCOHERENT
++	select HW_HAS_PCI
++	select I8253
++	select I8259
++	select IRQ_CPU
++	select IRQ_GT641XX
++	select PCI_GT64XXX_PCI0
++	select PCI
++	select SYS_HAS_CPU_NEVADA
++	select SYS_HAS_EARLY_PRINTK
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++
++config MACH_DECSTATION
++	bool "DECstations"
++	select BOOT_ELF32
++	select CEVT_DS1287
++	select CEVT_R4K
++	select CSRC_IOASIC
++	select CSRC_R4K
++	select CPU_DADDI_WORKAROUNDS if 64BIT
++	select CPU_R4000_WORKAROUNDS if 64BIT
++	select CPU_R4400_WORKAROUNDS if 64BIT
++	select DMA_NONCOHERENT
++	select NO_IOPORT
++	select IRQ_CPU
++	select SYS_HAS_CPU_R3000
++	select SYS_HAS_CPU_R4X00
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select SYS_SUPPORTS_128HZ
++	select SYS_SUPPORTS_256HZ
++	select SYS_SUPPORTS_1024HZ
++	help
++	  This enables support for DEC's MIPS based workstations.  For details
++	  see the Linux/MIPS FAQ on <http://www.linux-mips.org/> and the
++	  DECstation porting pages on <http://decstation.unix-ag.org/>.
++
++	  If you have one of the following DECstation Models you definitely
++	  want to choose R4xx0 for the CPU Type:
++
++		DECstation 5000/50
++		DECstation 5000/150
++		DECstation 5000/260
++		DECsystem 5900/260
++
++	  otherwise choose R3000.
++
++config MACH_JAZZ
++	bool "Jazz family of machines"
++	select FW_ARC
++	select FW_ARC32
++	select ARCH_MAY_HAVE_PC_FDC
++	select CEVT_R4K
++	select CSRC_R4K
++	select DEFAULT_SGI_PARTITION if CPU_BIG_ENDIAN
++	select GENERIC_ISA_DMA
++	select HAVE_PCSPKR_PLATFORM
++	select IRQ_CPU
++	select I8253
++	select I8259
++	select ISA
++	select SYS_HAS_CPU_R4X00
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_100HZ
++	help
++	 This a family of machines based on the MIPS R4030 chipset which was
++	 used by several vendors to build RISC/os and Windows NT workstations.
++	 Members include the Acer PICA, MIPS Magnum 4000, MIPS Millennium and
++	 Olivetti M700-10 workstations.
++
++config MACH_JZ4740
++	bool "Ingenic JZ4740 based machines"
++	select SYS_HAS_CPU_MIPS32_R1
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select SYS_SUPPORTS_ZBOOT_UART16550
++	select DMA_NONCOHERENT
++	select IRQ_CPU
++	select GENERIC_GPIO
++	select ARCH_REQUIRE_GPIOLIB
++	select SYS_HAS_EARLY_PRINTK
++	select HAVE_PWM
++	select HAVE_CLK
++	select GENERIC_IRQ_CHIP
++
++config LANTIQ
++	bool "Lantiq based platforms"
++	select DMA_NONCOHERENT
++	select IRQ_CPU
++	select CEVT_R4K
++	select CSRC_R4K
++	select SYS_HAS_CPU_MIPS32_R1
++	select SYS_HAS_CPU_MIPS32_R2
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_MULTITHREADING
++	select SYS_HAS_EARLY_PRINTK
++	select ARCH_REQUIRE_GPIOLIB
++	select SWAP_IO_SPACE
++	select BOOT_RAW
++	select HAVE_MACH_CLKDEV
++	select CLKDEV_LOOKUP
++	select USE_OF
++	select PINCTRL
++	select PINCTRL_LANTIQ
++
++config LASAT
++	bool "LASAT Networks platforms"
++	select CEVT_R4K
++	select CSRC_R4K
++	select DMA_NONCOHERENT
++	select SYS_HAS_EARLY_PRINTK
++	select HW_HAS_PCI
++	select IRQ_CPU
++	select PCI_GT64XXX_PCI0
++	select MIPS_NILE4
++	select R5000_CPU_SCACHE
++	select SYS_HAS_CPU_R5000
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL if BROKEN
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++
++config MACH_LOONGSON
++	bool "Loongson family of machines"
++	select SYS_SUPPORTS_ZBOOT
++	help
++	  This enables the support of Loongson family of machines.
++
++	  Loongson is a family of general-purpose MIPS-compatible CPUs.
++	  developed at Institute of Computing Technology (ICT),
++	  Chinese Academy of Sciences (CAS) in the People's Republic
++	  of China. The chief architect is Professor Weiwu Hu.
++
++config MACH_LOONGSON1
++	bool "Loongson 1 family of machines"
++	select SYS_SUPPORTS_ZBOOT
++	help
++	  This enables support for the Loongson 1 based machines.
++
++	  Loongson 1 is a family of 32-bit MIPS-compatible SoCs developed by
++	  the ICT (Institute of Computing Technology) and the Chinese Academy
++	  of Sciences.
++
++config MIPS_MALTA
++	bool "MIPS Malta board"
++	select ARCH_MAY_HAVE_PC_FDC
++	select BOOT_ELF32
++	select BOOT_RAW
++	select CEVT_R4K
++	select CSRC_R4K
++	select CSRC_GIC
++	select DMA_NONCOHERENT
++	select GENERIC_ISA_DMA
++	select HAVE_PCSPKR_PLATFORM
++	select IRQ_CPU
++	select IRQ_GIC
++	select HW_HAS_PCI
++	select I8253
++	select I8259
++	select MIPS_BOARDS_GEN
++	select MIPS_BONITO64
++	select MIPS_CPU_SCACHE
++	select PCI_GT64XXX_PCI0
++	select MIPS_MSC
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_MIPS32_R1
++	select SYS_HAS_CPU_MIPS32_R2
++	select SYS_HAS_CPU_MIPS64_R1
++	select SYS_HAS_CPU_MIPS64_R2
++	select SYS_HAS_CPU_NEVADA
++	select SYS_HAS_CPU_RM7000
++	select SYS_HAS_EARLY_PRINTK
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select SYS_SUPPORTS_MIPS_CMP
++	select SYS_SUPPORTS_MULTITHREADING
++	select SYS_SUPPORTS_SMARTMIPS
++	select SYS_SUPPORTS_ZBOOT
++	help
++	  This enables support for the MIPS Technologies Malta evaluation
++	  board.
++
++config MIPS_SEAD3
++	bool "MIPS SEAD3 board"
++	select BOOT_ELF32
++	select BOOT_RAW
++	select CEVT_R4K
++	select CSRC_R4K
++	select CPU_MIPSR2_IRQ_VI
++	select CPU_MIPSR2_IRQ_EI
++	select DMA_NONCOHERENT
++	select IRQ_CPU
++	select IRQ_GIC
++	select MIPS_BOARDS_GEN
++	select MIPS_CPU_SCACHE
++	select MIPS_MSC
++	select SYS_HAS_CPU_MIPS32_R1
++	select SYS_HAS_CPU_MIPS32_R2
++	select SYS_HAS_CPU_MIPS64_R1
++	select SYS_HAS_EARLY_PRINTK
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select SYS_SUPPORTS_SMARTMIPS
++	select USB_ARCH_HAS_EHCI
++	select USB_EHCI_BIG_ENDIAN_DESC
++	select USB_EHCI_BIG_ENDIAN_MMIO
++	select USE_OF
++	help
++	  This enables support for the MIPS Technologies SEAD3 evaluation
++	  board.
++
++config NEC_MARKEINS
++	bool "NEC EMMA2RH Mark-eins board"
++	select SOC_EMMA2RH
++	select HW_HAS_PCI
++	help
++	  This enables support for the NEC Electronics Mark-eins boards.
++
++config MACH_VR41XX
++	bool "NEC VR4100 series based machines"
++	select CEVT_R4K
++	select CSRC_R4K
++	select SYS_HAS_CPU_VR41XX
++	select ARCH_REQUIRE_GPIOLIB
++
++config NXP_STB220
++	bool "NXP STB220 board"
++	select SOC_PNX833X
++	help
++	 Support for NXP Semiconductors STB220 Development Board.
++
++config NXP_STB225
++	bool "NXP 225 board"
++	select SOC_PNX833X
++	select SOC_PNX8335
++	help
++	 Support for NXP Semiconductors STB225 Development Board.
++
++config PMC_MSP
++	bool "PMC-Sierra MSP chipsets"
++	select CEVT_R4K
++	select CSRC_R4K
++	select DMA_NONCOHERENT
++	select SWAP_IO_SPACE
++	select NO_EXCEPT_FILL
++	select BOOT_RAW
++	select SYS_HAS_CPU_MIPS32_R1
++	select SYS_HAS_CPU_MIPS32_R2
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select IRQ_CPU
++	select SERIAL_8250
++	select SERIAL_8250_CONSOLE
++	help
++	  This adds support for the PMC-Sierra family of Multi-Service
++	  Processor System-On-A-Chips.  These parts include a number
++	  of integrated peripherals, interfaces and DSPs in addition to
++	  a variety of MIPS cores.
++
++config POWERTV
++	bool "Cisco PowerTV"
++	select BOOT_ELF32
++	select CEVT_R4K
++	select CPU_MIPSR2_IRQ_VI
++	select CPU_MIPSR2_IRQ_EI
++	select CSRC_POWERTV
++	select DMA_NONCOHERENT
++	select HW_HAS_PCI
++	select SYS_HAS_EARLY_PRINTK
++	select SYS_HAS_CPU_MIPS32_R2
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_HIGHMEM
++	select USB_OHCI_LITTLE_ENDIAN
++	help
++	  This enables support for the Cisco PowerTV Platform.
++
++config RALINK
++	bool "Ralink based machines"
++	select CEVT_R4K
++	select CSRC_R4K
++	select BOOT_RAW
++	select DMA_NONCOHERENT
++	select IRQ_CPU
++	select USE_OF
++	select SYS_HAS_CPU_MIPS32_R1
++	select SYS_HAS_CPU_MIPS32_R2
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select SYS_HAS_EARLY_PRINTK
++	select HAVE_MACH_CLKDEV
++	select CLKDEV_LOOKUP
++
++config SGI_IP22
++	bool "SGI IP22 (Indy/Indigo2)"
++	select FW_ARC
++	select FW_ARC32
++	select BOOT_ELF32
++	select CEVT_R4K
++	select CSRC_R4K
++	select DEFAULT_SGI_PARTITION
++	select DMA_NONCOHERENT
++	select HW_HAS_EISA
++	select I8253
++	select I8259
++	select IP22_CPU_SCACHE
++	select IRQ_CPU
++	select GENERIC_ISA_DMA_SUPPORT_BROKEN
++	select SGI_HAS_I8042
++	select SGI_HAS_INDYDOG
++	select SGI_HAS_HAL2
++	select SGI_HAS_SEEQ
++	select SGI_HAS_WD93
++	select SGI_HAS_ZILOG
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_R4X00
++	select SYS_HAS_CPU_R5000
++	#
++	# Disable EARLY_PRINTK for now since it leads to overwritten prom
++	# memory during early boot on some machines.
++	#
++	# See http://www.linux-mips.org/cgi-bin/mesg.cgi?a=linux-mips&i=20091119164009.GA15038%40deprecation.cyrius.com
++	# for a more details discussion
++	#
++	# select SYS_HAS_EARLY_PRINTK
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	help
++	  This are the SGI Indy, Challenge S and Indigo2, as well as certain
++	  OEM variants like the Tandem CMN B006S. To compile a Linux kernel
++	  that runs on these, say Y here.
++
++config SGI_IP27
++	bool "SGI IP27 (Origin200/2000)"
++	select FW_ARC
++	select FW_ARC64
++	select BOOT_ELF64
++	select DEFAULT_SGI_PARTITION
++	select DMA_COHERENT
++	select SYS_HAS_EARLY_PRINTK
++	select HW_HAS_PCI
++	select NR_CPUS_DEFAULT_64
++	select SYS_HAS_CPU_R10000
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_NUMA
++	select SYS_SUPPORTS_SMP
++	help
++	  This are the SGI Origin 200, Origin 2000 and Onyx 2 Graphics
++	  workstations.  To compile a Linux kernel that runs on these, say Y
++	  here.
++
++config SGI_IP28
++	bool "SGI IP28 (Indigo2 R10k)"
++	select FW_ARC
++	select FW_ARC64
++	select BOOT_ELF64
++	select CEVT_R4K
++	select CSRC_R4K
++	select DEFAULT_SGI_PARTITION
++	select DMA_NONCOHERENT
++	select GENERIC_ISA_DMA_SUPPORT_BROKEN
++	select IRQ_CPU
++	select HW_HAS_EISA
++	select I8253
++	select I8259
++	select SGI_HAS_I8042
++	select SGI_HAS_INDYDOG
++	select SGI_HAS_HAL2
++	select SGI_HAS_SEEQ
++	select SGI_HAS_WD93
++	select SGI_HAS_ZILOG
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_R10000
++	#
++	# Disable EARLY_PRINTK for now since it leads to overwritten prom
++	# memory during early boot on some machines.
++	#
++	# See http://www.linux-mips.org/cgi-bin/mesg.cgi?a=linux-mips&i=20091119164009.GA15038%40deprecation.cyrius.com
++	# for a more details discussion
++	#
++	# select SYS_HAS_EARLY_PRINTK
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++      help
++        This is the SGI Indigo2 with R10000 processor.  To compile a Linux
++        kernel that runs on these, say Y here.
++
++config SGI_IP32
++	bool "SGI IP32 (O2)"
++	select FW_ARC
++	select FW_ARC32
++	select BOOT_ELF32
++	select CEVT_R4K
++	select CSRC_R4K
++	select DMA_NONCOHERENT
++	select HW_HAS_PCI
++	select IRQ_CPU
++	select R5000_CPU_SCACHE
++	select RM7000_CPU_SCACHE
++	select SYS_HAS_CPU_R5000
++	select SYS_HAS_CPU_R10000 if BROKEN
++	select SYS_HAS_CPU_RM7000
++	select SYS_HAS_CPU_NEVADA
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	help
++	  If you want this kernel to run on SGI O2 workstation, say Y here.
++
++config SIBYTE_CRHINE
++	bool "Sibyte BCM91120C-CRhine"
++	select BOOT_ELF32
++	select DMA_COHERENT
++	select SIBYTE_BCM1120
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_SB1
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++
++config SIBYTE_CARMEL
++	bool "Sibyte BCM91120x-Carmel"
++	select BOOT_ELF32
++	select DMA_COHERENT
++	select SIBYTE_BCM1120
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_SB1
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++
++config SIBYTE_CRHONE
++	bool "Sibyte BCM91125C-CRhone"
++	select BOOT_ELF32
++	select DMA_COHERENT
++	select SIBYTE_BCM1125
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_SB1
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_HIGHMEM
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++
++config SIBYTE_RHONE
++	bool "Sibyte BCM91125E-Rhone"
++	select BOOT_ELF32
++	select DMA_COHERENT
++	select SIBYTE_BCM1125H
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_SB1
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++
++config SIBYTE_SWARM
++	bool "Sibyte BCM91250A-SWARM"
++	select BOOT_ELF32
++	select DMA_COHERENT
++	select HAVE_PATA_PLATFORM
++	select NR_CPUS_DEFAULT_2
++	select SIBYTE_SB1250
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_SB1
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_HIGHMEM
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select ZONE_DMA32 if 64BIT
++
++config SIBYTE_LITTLESUR
++	bool "Sibyte BCM91250C2-LittleSur"
++	select BOOT_ELF32
++	select DMA_COHERENT
++	select HAVE_PATA_PLATFORM
++	select NR_CPUS_DEFAULT_2
++	select SIBYTE_SB1250
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_SB1
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_HIGHMEM
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++
++config SIBYTE_SENTOSA
++	bool "Sibyte BCM91250E-Sentosa"
++	select BOOT_ELF32
++	select DMA_COHERENT
++	select NR_CPUS_DEFAULT_2
++	select SIBYTE_SB1250
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_SB1
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++
++config SIBYTE_BIGSUR
++	bool "Sibyte BCM91480B-BigSur"
++	select BOOT_ELF32
++	select DMA_COHERENT
++	select NR_CPUS_DEFAULT_4
++	select SIBYTE_BCM1x80
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_SB1
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_HIGHMEM
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select ZONE_DMA32 if 64BIT
++
++config SNI_RM
++	bool "SNI RM200/300/400"
++	select FW_ARC if CPU_LITTLE_ENDIAN
++	select FW_ARC32 if CPU_LITTLE_ENDIAN
++	select FW_SNIPROM if CPU_BIG_ENDIAN
++	select ARCH_MAY_HAVE_PC_FDC
++	select BOOT_ELF32
++	select CEVT_R4K
++	select CSRC_R4K
++	select DEFAULT_SGI_PARTITION if CPU_BIG_ENDIAN
++	select DMA_NONCOHERENT
++	select GENERIC_ISA_DMA
++	select HAVE_PCSPKR_PLATFORM
++	select HW_HAS_EISA
++	select HW_HAS_PCI
++	select IRQ_CPU
++	select I8253
++	select I8259
++	select ISA
++	select SWAP_IO_SPACE if CPU_BIG_ENDIAN
++	select SYS_HAS_CPU_R4X00
++	select SYS_HAS_CPU_R5000
++	select SYS_HAS_CPU_R10000
++	select R5000_CPU_SCACHE
++	select SYS_HAS_EARLY_PRINTK
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_HIGHMEM
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	help
++	  The SNI RM200/300/400 are MIPS-based machines manufactured by
++	  Siemens Nixdorf Informationssysteme (SNI), parent company of Pyramid
++	  Technology and now in turn merged with Fujitsu.  Say Y here to
++	  support this machine type.
++
++config MACH_TX39XX
++	bool "Toshiba TX39 series based machines"
++
++config MACH_TX49XX
++	bool "Toshiba TX49 series based machines"
++
++config MIKROTIK_RB532
++	bool "Mikrotik RB532 boards"
++	select CEVT_R4K
++	select CSRC_R4K
++	select DMA_NONCOHERENT
++	select HW_HAS_PCI
++	select IRQ_CPU
++	select SYS_HAS_CPU_MIPS32_R1
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select SWAP_IO_SPACE
++	select BOOT_RAW
++	select ARCH_REQUIRE_GPIOLIB
++	help
++	  Support the Mikrotik(tm) RouterBoard 532 series,
++	  based on the IDT RC32434 SoC.
++
++config WR_PPMC
++	bool "Wind River PPMC board"
++	select CEVT_R4K
++	select CSRC_R4K
++	select IRQ_CPU
++	select BOOT_ELF32
++	select DMA_NONCOHERENT
++	select HW_HAS_PCI
++	select PCI_GT64XXX_PCI0
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_MIPS32_R1
++	select SYS_HAS_CPU_MIPS32_R2
++	select SYS_HAS_CPU_MIPS64_R1
++	select SYS_HAS_CPU_NEVADA
++	select SYS_HAS_CPU_RM7000
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	help
++	  This enables support for the Wind River MIPS32 4KC PPMC evaluation
++	  board, which is based on GT64120 bridge chip.
++
++config CAVIUM_OCTEON_SIMULATOR
++	bool "Cavium Networks Octeon Simulator"
++	select CEVT_R4K
++	select 64BIT_PHYS_ADDR
++	select DMA_COHERENT
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_HOTPLUG_CPU
++	select SYS_HAS_CPU_CAVIUM_OCTEON
++	select HOLES_IN_ZONE
++	help
++	  The Octeon simulator is software performance model of the Cavium
++	  Octeon Processor. It supports simulating Octeon processors on x86
++	  hardware.
++
++config CAVIUM_OCTEON_REFERENCE_BOARD
++	bool "Cavium Networks Octeon reference board"
++	select CEVT_R4K
++	select 64BIT_PHYS_ADDR
++	select DMA_COHERENT
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select EDAC_SUPPORT
++	select SYS_SUPPORTS_HOTPLUG_CPU
++	select SYS_HAS_EARLY_PRINTK
++	select SYS_HAS_CPU_CAVIUM_OCTEON
++	select SWAP_IO_SPACE
++	select HW_HAS_PCI
++	select ARCH_SUPPORTS_MSI
++	select ZONE_DMA32
++	select USB_ARCH_HAS_OHCI
++	select USB_ARCH_HAS_EHCI
++	select HOLES_IN_ZONE
++	help
++	  This option supports all of the Octeon reference boards from Cavium
++	  Networks. It builds a kernel that dynamically determines the Octeon
++	  CPU type and supports all known board reference implementations.
++	  Some of the supported boards are:
++		EBT3000
++		EBH3000
++		EBH3100
++		Thunder
++		Kodama
++		Hikari
++	  Say Y here for most Octeon reference boards.
++
++config NLM_XLR_BOARD
++	bool "Netlogic XLR/XLS based systems"
++	select BOOT_ELF32
++	select NLM_COMMON
++	select SYS_HAS_CPU_XLR
++	select SYS_SUPPORTS_SMP
++	select HW_HAS_PCI
++	select SWAP_IO_SPACE
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select 64BIT_PHYS_ADDR
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_HIGHMEM
++	select DMA_COHERENT
++	select NR_CPUS_DEFAULT_32
++	select CEVT_R4K
++	select CSRC_R4K
++	select IRQ_CPU
++	select ARCH_SUPPORTS_MSI
++	select ZONE_DMA32 if 64BIT
++	select SYNC_R4K
++	select SYS_HAS_EARLY_PRINTK
++	select USB_ARCH_HAS_OHCI if USB_SUPPORT
++	select USB_ARCH_HAS_EHCI if USB_SUPPORT
++	help
++	  Support for systems based on Netlogic XLR and XLS processors.
++	  Say Y here if you have a XLR or XLS based board.
++
++config NLM_XLP_BOARD
++	bool "Netlogic XLP based systems"
++	select BOOT_ELF32
++	select NLM_COMMON
++	select SYS_HAS_CPU_XLP
++	select SYS_SUPPORTS_SMP
++	select HW_HAS_PCI
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select 64BIT_PHYS_ADDR
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select SYS_SUPPORTS_HIGHMEM
++	select DMA_COHERENT
++	select NR_CPUS_DEFAULT_32
++	select CEVT_R4K
++	select CSRC_R4K
++	select IRQ_CPU
++	select ZONE_DMA32 if 64BIT
++	select SYNC_R4K
++	select SYS_HAS_EARLY_PRINTK
++	select USE_OF
++	help
++	  This board is based on Netlogic XLP Processor.
++	  Say Y here if you have a XLP based board.
++
++endchoice
++
++source "arch/mips/alchemy/Kconfig"
++source "arch/mips/ath79/Kconfig"
++source "arch/mips/bcm47xx/Kconfig"
++source "arch/mips/bcm63xx/Kconfig"
++source "arch/mips/jazz/Kconfig"
++source "arch/mips/jz4740/Kconfig"
++source "arch/mips/lantiq/Kconfig"
++source "arch/mips/lasat/Kconfig"
++source "arch/mips/pmcs-msp71xx/Kconfig"
++source "arch/mips/powertv/Kconfig"
++source "arch/mips/ralink/Kconfig"
++source "arch/mips/sgi-ip27/Kconfig"
++source "arch/mips/sibyte/Kconfig"
++source "arch/mips/txx9/Kconfig"
++source "arch/mips/vr41xx/Kconfig"
++source "arch/mips/cavium-octeon/Kconfig"
++source "arch/mips/loongson/Kconfig"
++source "arch/mips/loongson1/Kconfig"
++source "arch/mips/netlogic/Kconfig"
++
++endmenu
++
++config RWSEM_GENERIC_SPINLOCK
++	bool
++	default y
++
++config RWSEM_XCHGADD_ALGORITHM
++	bool
++
++config ARCH_HAS_ILOG2_U32
++	bool
++	default n
++
++config ARCH_HAS_ILOG2_U64
++	bool
++	default n
++
++config GENERIC_HWEIGHT
++	bool
++	default y
++
++config GENERIC_CALIBRATE_DELAY
++	bool
++	default y
++
++config SCHED_OMIT_FRAME_POINTER
++	bool
++	default y
++
++#
++# Select some configuration options automatically based on user selections.
++#
++config FW_ARC
++	bool
++
++config ARCH_MAY_HAVE_PC_FDC
++	bool
++
++config BOOT_RAW
++	bool
++
++config CEVT_BCM1480
++	bool
++
++config CEVT_DS1287
++	bool
++
++config CEVT_GT641XX
++	bool
++
++config CEVT_R4K
++	bool
++
++config CEVT_SB1250
++	bool
++
++config CEVT_TXX9
++	bool
++
++config CSRC_BCM1480
++	bool
++
++config CSRC_IOASIC
++	bool
++
++config CSRC_POWERTV
++	bool
++
++config CSRC_R4K
++	bool
++
++config CSRC_GIC
++	bool
++
++config CSRC_SB1250
++	bool
++
++config GPIO_TXX9
++	select GENERIC_GPIO
++	select ARCH_REQUIRE_GPIOLIB
++	bool
++
++config FW_CFE
++	bool
++
++config ARCH_DMA_ADDR_T_64BIT
++	def_bool (HIGHMEM && 64BIT_PHYS_ADDR) || 64BIT
++
++config DMA_COHERENT
++	bool
++
++config DMA_NONCOHERENT
++	bool
++	select NEED_DMA_MAP_STATE
++
++config NEED_DMA_MAP_STATE
++	bool
++
++config SYS_HAS_EARLY_PRINTK
++	bool
++
++config HOTPLUG_CPU
++	bool "Support for hot-pluggable CPUs"
++	depends on SMP && HOTPLUG && SYS_SUPPORTS_HOTPLUG_CPU
++	help
++	  Say Y here to allow turning CPUs off and on. CPUs can be
++	  controlled through /sys/devices/system/cpu.
++	  (Note: power management support will enable this option
++	    automatically on SMP systems. )
++	  Say N if you want to disable CPU hotplug.
++
++config SYS_SUPPORTS_HOTPLUG_CPU
++	bool
++
++config I8259
++	bool
++
++config MIPS_BONITO64
++	bool
++
++config MIPS_MSC
++	bool
++
++config MIPS_NILE4
++	bool
++
++config MIPS_DISABLE_OBSOLETE_IDE
++	bool
++
++config SYNC_R4K
++	bool
++
++config MIPS_MACHINE
++	def_bool n
++
++config NO_IOPORT
++	def_bool n
++
++config GENERIC_ISA_DMA
++	bool
++	select ZONE_DMA if GENERIC_ISA_DMA_SUPPORT_BROKEN=n
++	select ISA_DMA_API
++
++config GENERIC_ISA_DMA_SUPPORT_BROKEN
++	bool
++	select GENERIC_ISA_DMA
++
++config ISA_DMA_API
++	bool
++
++config GENERIC_GPIO
++	bool
++
++config HOLES_IN_ZONE
++	bool
++
++#
++# Endianness selection.  Sufficiently obscure so many users don't know what to
++# answer,so we try hard to limit the available choices.  Also the use of a
++# choice statement should be more obvious to the user.
++#
++choice
++	prompt "Endianness selection"
++	help
++	  Some MIPS machines can be configured for either little or big endian
++	  byte order. These modes require different kernels and a different
++	  Linux distribution.  In general there is one preferred byteorder for a
++	  particular system but some systems are just as commonly used in the
++	  one or the other endianness.
++
++config CPU_BIG_ENDIAN
++	bool "Big endian"
++	depends on SYS_SUPPORTS_BIG_ENDIAN
++
++config CPU_LITTLE_ENDIAN
++	bool "Little endian"
++	depends on SYS_SUPPORTS_LITTLE_ENDIAN
++	help
++
++endchoice
++
++config EXPORT_UASM
++	bool
++
++config SYS_SUPPORTS_APM_EMULATION
++	bool
++
++config SYS_SUPPORTS_BIG_ENDIAN
++	bool
++
++config SYS_SUPPORTS_LITTLE_ENDIAN
++	bool
++
++config SYS_SUPPORTS_HUGETLBFS
++	bool
++	depends on CPU_SUPPORTS_HUGEPAGES && 64BIT
++	default y
++
++config MIPS_HUGE_TLB_SUPPORT
++	def_bool HUGETLB_PAGE || TRANSPARENT_HUGEPAGE
++
++config IRQ_CPU
++	bool
++
++config IRQ_CPU_RM7K
++	bool
++
++config IRQ_MSP_SLP
++	bool
++
++config IRQ_MSP_CIC
++	bool
++
++config IRQ_TXX9
++	bool
++
++config IRQ_GT641XX
++	bool
++
++config IRQ_GIC
++	bool
++
++config MIPS_BOARDS_GEN
++	bool
++
++config PCI_GT64XXX_PCI0
++	bool
++
++config NO_EXCEPT_FILL
++	bool
++
++config SOC_EMMA2RH
++	bool
++	select CEVT_R4K
++	select CSRC_R4K
++	select DMA_NONCOHERENT
++	select IRQ_CPU
++	select SWAP_IO_SPACE
++	select SYS_HAS_CPU_R5500
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_BIG_ENDIAN
++
++config SOC_PNX833X
++	bool
++	select CEVT_R4K
++	select CSRC_R4K
++	select IRQ_CPU
++	select DMA_NONCOHERENT
++	select SYS_HAS_CPU_MIPS32_R2
++	select SYS_SUPPORTS_32BIT_KERNEL
++	select SYS_SUPPORTS_LITTLE_ENDIAN
++	select SYS_SUPPORTS_BIG_ENDIAN
++	select GENERIC_GPIO
++	select CPU_MIPSR2_IRQ_VI
++
++config SOC_PNX8335
++	bool
++	select SOC_PNX833X
++
++config SWAP_IO_SPACE
++	bool
++
++config SGI_HAS_INDYDOG
++	bool
++
++config SGI_HAS_HAL2
++	bool
++
++config SGI_HAS_SEEQ
++	bool
++
++config SGI_HAS_WD93
++	bool
++
++config SGI_HAS_ZILOG
++	bool
++
++config SGI_HAS_I8042
++	bool
++
++config DEFAULT_SGI_PARTITION
++	bool
++
++config FW_ARC32
++	bool
++
++config FW_SNIPROM
++	bool
++
++config BOOT_ELF32
++	bool
++
++config MIPS_L1_CACHE_SHIFT
++	int
++	default "4" if MACH_DECSTATION || MIKROTIK_RB532 || PMC_MSP4200_EVAL
++	default "6" if MIPS_CPU_SCACHE
++	default "7" if SGI_IP22 || SGI_IP27 || SGI_IP28 || SNI_RM || CPU_CAVIUM_OCTEON
++	default "5"
++
++config HAVE_STD_PC_SERIAL_PORT
++	bool
++
++config ARC_CONSOLE
++	bool "ARC console support"
++	depends on SGI_IP22 || SGI_IP28 || (SNI_RM && CPU_LITTLE_ENDIAN)
++
++config ARC_MEMORY
++	bool
++	depends on MACH_JAZZ || SNI_RM || SGI_IP32
++	default y
++
++config ARC_PROMLIB
++	bool
++	depends on MACH_JAZZ || SNI_RM || SGI_IP22 || SGI_IP28 || SGI_IP32
++	default y
++
++config FW_ARC64
++	bool
++
++config BOOT_ELF64
++	bool
++
++menu "CPU selection"
++
++choice
++	prompt "CPU type"
++	default CPU_R4X00
++
++config CPU_LOONGSON2E
++	bool "Loongson 2E"
++	depends on SYS_HAS_CPU_LOONGSON2E
++	select CPU_LOONGSON2
++	help
++	  The Loongson 2E processor implements the MIPS III instruction set
++	  with many extensions.
++
++	  It has an internal FPGA northbridge, which is compatible to
++	  bonito64.
++
++config CPU_LOONGSON2F
++	bool "Loongson 2F"
++	depends on SYS_HAS_CPU_LOONGSON2F
++	select CPU_LOONGSON2
++	select GENERIC_GPIO
++	select ARCH_REQUIRE_GPIOLIB
++	help
++	  The Loongson 2F processor implements the MIPS III instruction set
++	  with many extensions.
++
++	  Loongson2F have built-in DDR2 and PCIX controller. The PCIX controller
++	  have a similar programming interface with FPGA northbridge used in
++	  Loongson2E.
++
++config CPU_LOONGSON1B
++	bool "Loongson 1B"
++	depends on SYS_HAS_CPU_LOONGSON1B
++	select CPU_LOONGSON1
++	help
++	  The Loongson 1B is a 32-bit SoC, which implements the MIPS32
++	  release 2 instruction set.
++
++config CPU_MIPS32_R1
++	bool "MIPS32 Release 1"
++	depends on SYS_HAS_CPU_MIPS32_R1
++	select CPU_HAS_PREFETCH
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++	help
++	  Choose this option to build a kernel for release 1 or later of the
++	  MIPS32 architecture.  Most modern embedded systems with a 32-bit
++	  MIPS processor are based on a MIPS32 processor.  If you know the
++	  specific type of processor in your system, choose those that one
++	  otherwise CPU_MIPS32_R1 is a safe bet for any MIPS32 system.
++	  Release 2 of the MIPS32 architecture is available since several
++	  years so chances are you even have a MIPS32 Release 2 processor
++	  in which case you should choose CPU_MIPS32_R2 instead for better
++	  performance.
++
++config CPU_MIPS32_R2
++	bool "MIPS32 Release 2"
++	depends on SYS_HAS_CPU_MIPS32_R2
++	select CPU_HAS_PREFETCH
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++	help
++	  Choose this option to build a kernel for release 2 or later of the
++	  MIPS32 architecture.  Most modern embedded systems with a 32-bit
++	  MIPS processor are based on a MIPS32 processor.  If you know the
++	  specific type of processor in your system, choose those that one
++	  otherwise CPU_MIPS32_R1 is a safe bet for any MIPS32 system.
++
++config CPU_MIPS64_R1
++	bool "MIPS64 Release 1"
++	depends on SYS_HAS_CPU_MIPS64_R1
++	select CPU_HAS_PREFETCH
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++	select CPU_SUPPORTS_HUGEPAGES
++	help
++	  Choose this option to build a kernel for release 1 or later of the
++	  MIPS64 architecture.  Many modern embedded systems with a 64-bit
++	  MIPS processor are based on a MIPS64 processor.  If you know the
++	  specific type of processor in your system, choose those that one
++	  otherwise CPU_MIPS64_R1 is a safe bet for any MIPS64 system.
++	  Release 2 of the MIPS64 architecture is available since several
++	  years so chances are you even have a MIPS64 Release 2 processor
++	  in which case you should choose CPU_MIPS64_R2 instead for better
++	  performance.
++
++config CPU_MIPS64_R2
++	bool "MIPS64 Release 2"
++	depends on SYS_HAS_CPU_MIPS64_R2
++	select CPU_HAS_PREFETCH
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++	select CPU_SUPPORTS_HUGEPAGES
++	help
++	  Choose this option to build a kernel for release 2 or later of the
++	  MIPS64 architecture.  Many modern embedded systems with a 64-bit
++	  MIPS processor are based on a MIPS64 processor.  If you know the
++	  specific type of processor in your system, choose those that one
++	  otherwise CPU_MIPS64_R1 is a safe bet for any MIPS64 system.
++
++config CPU_R3000
++	bool "R3000"
++	depends on SYS_HAS_CPU_R3000
++	select CPU_HAS_WB
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++	help
++	  Please make sure to pick the right CPU type. Linux/MIPS is not
++	  designed to be generic, i.e. Kernels compiled for R3000 CPUs will
++	  *not* work on R4000 machines and vice versa.  However, since most
++	  of the supported machines have an R4000 (or similar) CPU, R4x00
++	  might be a safe bet.  If the resulting kernel does not work,
++	  try to recompile with R3000.
++
++config CPU_TX39XX
++	bool "R39XX"
++	depends on SYS_HAS_CPU_TX39XX
++	select CPU_SUPPORTS_32BIT_KERNEL
++
++config CPU_VR41XX
++	bool "R41xx"
++	depends on SYS_HAS_CPU_VR41XX
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	help
++	  The options selects support for the NEC VR4100 series of processors.
++	  Only choose this option if you have one of these processors as a
++	  kernel built with this option will not run on any other type of
++	  processor or vice versa.
++
++config CPU_R4300
++	bool "R4300"
++	depends on SYS_HAS_CPU_R4300
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	help
++	  MIPS Technologies R4300-series processors.
++
++config CPU_R4X00
++	bool "R4x00"
++	depends on SYS_HAS_CPU_R4X00
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HUGEPAGES
++	help
++	  MIPS Technologies R4000-series processors other than 4300, including
++	  the R4000, R4400, R4600, and 4700.
++
++config CPU_TX49XX
++	bool "R49XX"
++	depends on SYS_HAS_CPU_TX49XX
++	select CPU_HAS_PREFETCH
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HUGEPAGES
++
++config CPU_R5000
++	bool "R5000"
++	depends on SYS_HAS_CPU_R5000
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HUGEPAGES
++	help
++	  MIPS Technologies R5000-series processors other than the Nevada.
++
++config CPU_R5432
++	bool "R5432"
++	depends on SYS_HAS_CPU_R5432
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HUGEPAGES
++
++config CPU_R5500
++	bool "R5500"
++	depends on SYS_HAS_CPU_R5500
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HUGEPAGES
++	help
++	  NEC VR5500 and VR5500A series processors implement 64-bit MIPS IV
++	  instruction set.
++
++config CPU_R6000
++	bool "R6000"
++	depends on SYS_HAS_CPU_R6000
++	select CPU_SUPPORTS_32BIT_KERNEL
++	help
++	  MIPS Technologies R6000 and R6000A series processors.  Note these
++	  processors are extremely rare and the support for them is incomplete.
++
++config CPU_NEVADA
++	bool "RM52xx"
++	depends on SYS_HAS_CPU_NEVADA
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HUGEPAGES
++	help
++	  QED / PMC-Sierra RM52xx-series ("Nevada") processors.
++
++config CPU_R8000
++	bool "R8000"
++	depends on SYS_HAS_CPU_R8000
++	select CPU_HAS_PREFETCH
++	select CPU_SUPPORTS_64BIT_KERNEL
++	help
++	  MIPS Technologies R8000 processors.  Note these processors are
++	  uncommon and the support for them is incomplete.
++
++config CPU_R10000
++	bool "R10000"
++	depends on SYS_HAS_CPU_R10000
++	select CPU_HAS_PREFETCH
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++	select CPU_SUPPORTS_HUGEPAGES
++	help
++	  MIPS Technologies R10000-series processors.
++
++config CPU_RM7000
++	bool "RM7000"
++	depends on SYS_HAS_CPU_RM7000
++	select CPU_HAS_PREFETCH
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++	select CPU_SUPPORTS_HUGEPAGES
++
++config CPU_SB1
++	bool "SB1"
++	depends on SYS_HAS_CPU_SB1
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++	select CPU_SUPPORTS_HUGEPAGES
++	select WEAK_ORDERING
++
++config CPU_CAVIUM_OCTEON
++	bool "Cavium Octeon processor"
++	depends on SYS_HAS_CPU_CAVIUM_OCTEON
++	select ARCH_SPARSEMEM_ENABLE
++	select CPU_HAS_PREFETCH
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select SYS_SUPPORTS_SMP
++	select NR_CPUS_DEFAULT_16
++	select WEAK_ORDERING
++	select CPU_SUPPORTS_HIGHMEM
++	select CPU_SUPPORTS_HUGEPAGES
++	select LIBFDT
++	select USE_OF
++	help
++	  The Cavium Octeon processor is a highly integrated chip containing
++	  many ethernet hardware widgets for networking tasks. The processor
++	  can have up to 16 Mips64v2 cores and 8 integrated gigabit ethernets.
++	  Full details can be found at http://www.caviumnetworks.com.
++
++config CPU_BMIPS3300
++	bool "BMIPS3300"
++	depends on SYS_HAS_CPU_BMIPS3300
++	select CPU_BMIPS
++	help
++	  Broadcom BMIPS3300 processors.
++
++config CPU_BMIPS4350
++	bool "BMIPS4350"
++	depends on SYS_HAS_CPU_BMIPS4350
++	select CPU_BMIPS
++	select SYS_SUPPORTS_SMP
++	select SYS_SUPPORTS_HOTPLUG_CPU
++	help
++	  Broadcom BMIPS4350 ("VIPER") processors.
++
++config CPU_BMIPS4380
++	bool "BMIPS4380"
++	depends on SYS_HAS_CPU_BMIPS4380
++	select CPU_BMIPS
++	select SYS_SUPPORTS_SMP
++	select SYS_SUPPORTS_HOTPLUG_CPU
++	help
++	  Broadcom BMIPS4380 processors.
++
++config CPU_BMIPS5000
++	bool "BMIPS5000"
++	depends on SYS_HAS_CPU_BMIPS5000
++	select CPU_BMIPS
++	select CPU_SUPPORTS_HIGHMEM
++	select MIPS_CPU_SCACHE
++	select SYS_SUPPORTS_SMP
++	select SYS_SUPPORTS_HOTPLUG_CPU
++	help
++	  Broadcom BMIPS5000 processors.
++
++config CPU_XLR
++	bool "Netlogic XLR SoC"
++	depends on SYS_HAS_CPU_XLR
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++	select CPU_SUPPORTS_HUGEPAGES
++	select WEAK_ORDERING
++	select WEAK_REORDERING_BEYOND_LLSC
++	help
++	  Netlogic Microsystems XLR/XLS processors.
++
++config CPU_XLP
++	bool "Netlogic XLP SoC"
++	depends on SYS_HAS_CPU_XLP
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++	select WEAK_ORDERING
++	select WEAK_REORDERING_BEYOND_LLSC
++	select CPU_HAS_PREFETCH
++	select CPU_MIPSR2
++	help
++	  Netlogic Microsystems XLP processors.
++endchoice
++
++if CPU_LOONGSON2F
++config CPU_NOP_WORKAROUNDS
++	bool
++
++config CPU_JUMP_WORKAROUNDS
++	bool
++
++config CPU_LOONGSON2F_WORKAROUNDS
++	bool "Loongson 2F Workarounds"
++	default y
++	select CPU_NOP_WORKAROUNDS
++	select CPU_JUMP_WORKAROUNDS
++	help
++	  Loongson 2F01 / 2F02 processors have the NOP & JUMP issues which
++	  require workarounds.  Without workarounds the system may hang
++	  unexpectedly.  For more information please refer to the gas
++	  -mfix-loongson2f-nop and -mfix-loongson2f-jump options.
++
++	  Loongson 2F03 and later have fixed these issues and no workarounds
++	  are needed.  The workarounds have no significant side effect on them
++	  but may decrease the performance of the system so this option should
++	  be disabled unless the kernel is intended to be run on 2F01 or 2F02
++	  systems.
++
++	  If unsure, please say Y.
++endif # CPU_LOONGSON2F
++
++config SYS_SUPPORTS_ZBOOT
++	bool
++	select HAVE_KERNEL_GZIP
++	select HAVE_KERNEL_BZIP2
++	select HAVE_KERNEL_LZMA
++	select HAVE_KERNEL_LZO
++
++config SYS_SUPPORTS_ZBOOT_UART16550
++	bool
++	select SYS_SUPPORTS_ZBOOT
++
++config CPU_LOONGSON2
++	bool
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_64BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++	select CPU_SUPPORTS_HUGEPAGES
++
++config CPU_LOONGSON1
++	bool
++	select CPU_MIPS32
++	select CPU_MIPSR2
++	select CPU_HAS_PREFETCH
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select CPU_SUPPORTS_HIGHMEM
++
++config CPU_BMIPS
++	bool
++	select CPU_MIPS32
++	select CPU_SUPPORTS_32BIT_KERNEL
++	select DMA_NONCOHERENT
++	select IRQ_CPU
++	select SWAP_IO_SPACE
++	select WEAK_ORDERING
++
++config SYS_HAS_CPU_LOONGSON2E
++	bool
++
++config SYS_HAS_CPU_LOONGSON2F
++	bool
++	select CPU_SUPPORTS_CPUFREQ
++	select CPU_SUPPORTS_ADDRWINCFG if 64BIT
++	select CPU_SUPPORTS_UNCACHED_ACCELERATED
++
++config SYS_HAS_CPU_LOONGSON1B
++	bool
++
++config SYS_HAS_CPU_MIPS32_R1
++	bool
++
++config SYS_HAS_CPU_MIPS32_R2
++	bool
++
++config SYS_HAS_CPU_MIPS64_R1
++	bool
++
++config SYS_HAS_CPU_MIPS64_R2
++	bool
++
++config SYS_HAS_CPU_R3000
++	bool
++
++config SYS_HAS_CPU_TX39XX
++	bool
++
++config SYS_HAS_CPU_VR41XX
++	bool
++
++config SYS_HAS_CPU_R4300
++	bool
++
++config SYS_HAS_CPU_R4X00
++	bool
++
++config SYS_HAS_CPU_TX49XX
++	bool
++
++config SYS_HAS_CPU_R5000
++	bool
++
++config SYS_HAS_CPU_R5432
++	bool
++
++config SYS_HAS_CPU_R5500
++	bool
++
++config SYS_HAS_CPU_R6000
++	bool
++
++config SYS_HAS_CPU_NEVADA
++	bool
++
++config SYS_HAS_CPU_R8000
++	bool
++
++config SYS_HAS_CPU_R10000
++	bool
++
++config SYS_HAS_CPU_RM7000
++	bool
++
++config SYS_HAS_CPU_SB1
++	bool
++
++config SYS_HAS_CPU_CAVIUM_OCTEON
++	bool
++
++config SYS_HAS_CPU_BMIPS3300
++	bool
++
++config SYS_HAS_CPU_BMIPS4350
++	bool
++
++config SYS_HAS_CPU_BMIPS4380
++	bool
++
++config SYS_HAS_CPU_BMIPS5000
++	bool
++
++config SYS_HAS_CPU_XLR
++	bool
++
++config SYS_HAS_CPU_XLP
++	bool
++
++#
++# CPU may reorder R->R, R->W, W->R, W->W
++# Reordering beyond LL and SC is handled in WEAK_REORDERING_BEYOND_LLSC
++#
++config WEAK_ORDERING
++	bool
++
++#
++# CPU may reorder reads and writes beyond LL/SC
++# CPU may reorder R->LL, R->LL, W->LL, W->LL, R->SC, R->SC, W->SC, W->SC
++#
++config WEAK_REORDERING_BEYOND_LLSC
++	bool
++endmenu
++
++#
++# These two indicate any level of the MIPS32 and MIPS64 architecture
++#
++config CPU_MIPS32
++	bool
++	default y if CPU_MIPS32_R1 || CPU_MIPS32_R2
++
++config CPU_MIPS64
++	bool
++	default y if CPU_MIPS64_R1 || CPU_MIPS64_R2
++
++#
++# These two indicate the revision of the architecture, either Release 1 or Release 2
++#
++config CPU_MIPSR1
++	bool
++	default y if CPU_MIPS32_R1 || CPU_MIPS64_R1
++
++config CPU_MIPSR2
++	bool
++	default y if CPU_MIPS32_R2 || CPU_MIPS64_R2 || CPU_CAVIUM_OCTEON
++
++config SYS_SUPPORTS_32BIT_KERNEL
++	bool
++config SYS_SUPPORTS_64BIT_KERNEL
++	bool
++config CPU_SUPPORTS_32BIT_KERNEL
++	bool
++config CPU_SUPPORTS_64BIT_KERNEL
++	bool
++config CPU_SUPPORTS_CPUFREQ
++	bool
++config CPU_SUPPORTS_ADDRWINCFG
++	bool
++config CPU_SUPPORTS_HUGEPAGES
++	bool
++config CPU_SUPPORTS_UNCACHED_ACCELERATED
++	bool
++config MIPS_PGD_C0_CONTEXT
++	bool
++	default y if 64BIT && CPU_MIPSR2 && !CPU_XLP
++
++#
++# Set to y for ptrace access to watch registers.
++#
++config HARDWARE_WATCHPOINTS
++       bool
++       default y if CPU_MIPSR1 || CPU_MIPSR2
++
++menu "Kernel type"
++
++choice
++	prompt "Kernel code model"
++	help
++	  You should only select this option if you have a workload that
++	  actually benefits from 64-bit processing or if your machine has
++	  large memory.  You will only be presented a single option in this
++	  menu if your system does not support both 32-bit and 64-bit kernels.
++
++config 32BIT
++	bool "32-bit kernel"
++	depends on CPU_SUPPORTS_32BIT_KERNEL && SYS_SUPPORTS_32BIT_KERNEL
++	select TRAD_SIGNALS
++	help
++	  Select this option if you want to build a 32-bit kernel.
++config 64BIT
++	bool "64-bit kernel"
++	depends on CPU_SUPPORTS_64BIT_KERNEL && SYS_SUPPORTS_64BIT_KERNEL
++	select HAVE_SYSCALL_WRAPPERS
++	help
++	  Select this option if you want to build a 64-bit kernel.
++
++endchoice
++
++choice
++	prompt "Kernel page size"
++	default PAGE_SIZE_4KB
++
++config PAGE_SIZE_4KB
++	bool "4kB"
++	depends on !CPU_LOONGSON2
++	help
++	 This option select the standard 4kB Linux page size.  On some
++	 R3000-family processors this is the only available page size.  Using
++	 4kB page size will minimize memory consumption and is therefore
++	 recommended for low memory systems.
++
++config PAGE_SIZE_8KB
++	bool "8kB"
++	depends on CPU_R8000 || CPU_CAVIUM_OCTEON
++	help
++	  Using 8kB page size will result in higher performance kernel at
++	  the price of higher memory consumption.  This option is available
++	  only on R8000 and cnMIPS processors.  Note that you will need a
++	  suitable Linux distribution to support this.
++
++config PAGE_SIZE_16KB
++	bool "16kB"
++	depends on !CPU_R3000 && !CPU_TX39XX
++	help
++	  Using 16kB page size will result in higher performance kernel at
++	  the price of higher memory consumption.  This option is available on
++	  all non-R3000 family processors.  Note that you will need a suitable
++	  Linux distribution to support this.
++
++config PAGE_SIZE_32KB
++	bool "32kB"
++	depends on CPU_CAVIUM_OCTEON
++	help
++	  Using 32kB page size will result in higher performance kernel at
++	  the price of higher memory consumption.  This option is available
++	  only on cnMIPS cores.  Note that you will need a suitable Linux
++	  distribution to support this.
++
++config PAGE_SIZE_64KB
++	bool "64kB"
++	depends on !CPU_R3000 && !CPU_TX39XX
++	help
++	  Using 64kB page size will result in higher performance kernel at
++	  the price of higher memory consumption.  This option is available on
++	  all non-R3000 family processor.  Not that at the time of this
++	  writing this option is still high experimental.
++
++endchoice
++
++config FORCE_MAX_ZONEORDER
++	int "Maximum zone order"
++	range 14 64 if HUGETLB_PAGE && PAGE_SIZE_64KB
++	default "14" if HUGETLB_PAGE && PAGE_SIZE_64KB
++	range 13 64 if HUGETLB_PAGE && PAGE_SIZE_32KB
++	default "13" if HUGETLB_PAGE && PAGE_SIZE_32KB
++	range 12 64 if HUGETLB_PAGE && PAGE_SIZE_16KB
++	default "12" if HUGETLB_PAGE && PAGE_SIZE_16KB
++	range 11 64
++	default "11"
++	help
++	  The kernel memory allocator divides physically contiguous memory
++	  blocks into "zones", where each zone is a power of two number of
++	  pages.  This option selects the largest power of two that the kernel
++	  keeps in the memory allocator.  If you need to allocate very large
++	  blocks of physically contiguous memory, then you may need to
++	  increase this value.
++
++	  This config option is actually maximum order plus one. For example,
++	  a value of 11 means that the largest free memory block is 2^10 pages.
++
++	  The page size is not necessarily 4KB.  Keep this in mind
++	  when choosing a value for this option.
++
++config BOARD_SCACHE
++	bool
++
++config IP22_CPU_SCACHE
++	bool
++	select BOARD_SCACHE
++
++#
++# Support for a MIPS32 / MIPS64 style S-caches
++#
++config MIPS_CPU_SCACHE
++	bool
++	select BOARD_SCACHE
++
++config R5000_CPU_SCACHE
++	bool
++	select BOARD_SCACHE
++
++config RM7000_CPU_SCACHE
++	bool
++	select BOARD_SCACHE
++
++config SIBYTE_DMA_PAGEOPS
++	bool "Use DMA to clear/copy pages"
++	depends on CPU_SB1
++	help
++	  Instead of using the CPU to zero and copy pages, use a Data Mover
++	  channel.  These DMA channels are otherwise unused by the standard
++	  SiByte Linux port.  Seems to give a small performance benefit.
++
++config CPU_HAS_PREFETCH
++	bool
++
++config CPU_GENERIC_DUMP_TLB
++	bool
++	default y if !(CPU_R3000 || CPU_R6000 || CPU_R8000 || CPU_TX39XX)
++
++config CPU_R4K_FPU
++	bool
++	default y if !(CPU_R3000 || CPU_R6000 || CPU_TX39XX || CPU_CAVIUM_OCTEON)
++
++config CPU_R4K_CACHE_TLB
++	bool
++	default y if !(CPU_R3000 || CPU_R8000 || CPU_SB1 || CPU_TX39XX || CPU_CAVIUM_OCTEON)
++
++choice
++	prompt "MIPS MT options"
++
++config MIPS_MT_DISABLED
++	bool "Disable multithreading support."
++	help
++	  Use this option if your workload can't take advantage of
++	  MIPS hardware multithreading support.  On systems that don't have
++	  the option of an MT-enabled processor this option will be the only
++	  option in this menu.
++
++config MIPS_MT_SMP
++	bool "Use 1 TC on each available VPE for SMP"
++	depends on SYS_SUPPORTS_MULTITHREADING
++	select CPU_MIPSR2_IRQ_VI
++	select CPU_MIPSR2_IRQ_EI
++	select MIPS_MT
++	select NR_CPUS_DEFAULT_2
++	select SMP
++	select SYS_SUPPORTS_SCHED_SMT if SMP
++	select SYS_SUPPORTS_SMP
++	select SMP_UP
++	select MIPS_PERF_SHARED_TC_COUNTERS
++	help
++	  This is a kernel model which is known a VSMP but lately has been
++	  marketesed into SMVP.
++	  Virtual SMP uses the processor's VPEs  to implement virtual
++	  processors. In currently available configuration of the 34K processor
++	  this allows for a dual processor. Both processors will share the same
++	  primary caches; each will obtain the half of the TLB for it's own
++	  exclusive use. For a layman this model can be described as similar to
++	  what Intel calls Hyperthreading.
++
++	  For further information see http://www.linux-mips.org/wiki/34K#VSMP
++
++config MIPS_MT_SMTC
++	bool "SMTC: Use all TCs on all VPEs for SMP"
++	depends on CPU_MIPS32_R2
++	#depends on CPU_MIPS64_R2		# once there is hardware ...
++	depends on SYS_SUPPORTS_MULTITHREADING
++	select CPU_MIPSR2_IRQ_VI
++	select CPU_MIPSR2_IRQ_EI
++	select MIPS_MT
++	select NR_CPUS_DEFAULT_8
++	select SMP
++	select SYS_SUPPORTS_SMP
++	select SMP_UP
++	help
++	  This is a kernel model which is known a SMTC or lately has been
++	  marketesed into SMVP.
++	  is presenting the available TC's of the core as processors to Linux.
++	  On currently available 34K processors this means a Linux system will
++	  see up to 5 processors. The implementation of the SMTC kernel differs
++	  significantly from VSMP and cannot efficiently coexist in the same
++	  kernel binary so the choice between VSMP and SMTC is a compile time
++	  decision.
++
++	  For further information see http://www.linux-mips.org/wiki/34K#SMTC
++
++endchoice
++
++config MIPS_MT
++	bool
++
++config SCHED_SMT
++	bool "SMT (multithreading) scheduler support"
++	depends on SYS_SUPPORTS_SCHED_SMT
++	default n
++	help
++	  SMT scheduler support improves the CPU scheduler's decision making
++	  when dealing with MIPS MT enabled cores at a cost of slightly
++	  increased overhead in some places. If unsure say N here.
++
++config SYS_SUPPORTS_SCHED_SMT
++	bool
++
++config SYS_SUPPORTS_MULTITHREADING
++	bool
++
++config MIPS_MT_FPAFF
++	bool "Dynamic FPU affinity for FP-intensive threads"
++	default y
++	depends on MIPS_MT_SMP || MIPS_MT_SMTC
++
++config MIPS_VPE_LOADER
++	bool "VPE loader support."
++	depends on SYS_SUPPORTS_MULTITHREADING
++	select CPU_MIPSR2_IRQ_VI
++	select CPU_MIPSR2_IRQ_EI
++	select MIPS_MT
++	help
++	  Includes a loader for loading an elf relocatable object
++	  onto another VPE and running it.
++
++config MIPS_MT_SMTC_IM_BACKSTOP
++	bool "Use per-TC register bits as backstop for inhibited IM bits"
++	depends on MIPS_MT_SMTC
++	default n
++	help
++	  To support multiple TC microthreads acting as "CPUs" within
++	  a VPE, VPE-wide interrupt mask bits must be specially manipulated
++	  during interrupt handling. To support legacy drivers and interrupt
++	  controller management code, SMTC has a "backstop" to track and
++	  if necessary restore the interrupt mask. This has some performance
++	  impact on interrupt service overhead.
++
++config MIPS_MT_SMTC_IRQAFF
++	bool "Support IRQ affinity API"
++	depends on MIPS_MT_SMTC
++	default n
++	help
++	  Enables SMP IRQ affinity API (/proc/irq/*/smp_affinity, etc.)
++	  for SMTC Linux kernel. Requires platform support, of which
++	  an example can be found in the MIPS kernel i8259 and Malta
++	  platform code.  Adds some overhead to interrupt dispatch, and
++	  should be used only if you know what you are doing.
++
++config MIPS_VPE_LOADER_TOM
++	bool "Load VPE program into memory hidden from linux"
++	depends on MIPS_VPE_LOADER
++	default y
++	help
++	  The loader can use memory that is present but has been hidden from
++	  Linux using the kernel command line option "mem=xxMB". It's up to
++	  you to ensure the amount you put in the option and the space your
++	  program requires is less or equal to the amount physically present.
++
++# this should possibly be in drivers/char, but it is rather cpu related. Hmmm
++config MIPS_VPE_APSP_API
++	bool "Enable support for AP/SP API (RTLX)"
++	depends on MIPS_VPE_LOADER
++	help
++
++config MIPS_CMP
++	bool "MIPS CMP framework support"
++	depends on SYS_SUPPORTS_MIPS_CMP
++	select SYNC_R4K
++	select SYS_SUPPORTS_SMP
++	select SYS_SUPPORTS_SCHED_SMT if SMP
++	select WEAK_ORDERING
++	default n
++	help
++	  This is a placeholder option for the GCMP work. It will need to
++	  be handled differently...
++
++config SB1_PASS_1_WORKAROUNDS
++	bool
++	depends on CPU_SB1_PASS_1
++	default y
++
++config SB1_PASS_2_WORKAROUNDS
++	bool
++	depends on CPU_SB1 && (CPU_SB1_PASS_2_2 || CPU_SB1_PASS_2)
++	default y
++
++config SB1_PASS_2_1_WORKAROUNDS
++	bool
++	depends on CPU_SB1 && CPU_SB1_PASS_2
++	default y
++
++config 64BIT_PHYS_ADDR
++	bool
++
++config ARCH_PHYS_ADDR_T_64BIT
++       def_bool 64BIT_PHYS_ADDR
++
++config CPU_HAS_SMARTMIPS
++	depends on SYS_SUPPORTS_SMARTMIPS
++	bool "Support for the SmartMIPS ASE"
++	help
++	  SmartMIPS is a extension of the MIPS32 architecture aimed at
++	  increased security at both hardware and software level for
++	  smartcards.  Enabling this option will allow proper use of the
++	  SmartMIPS instructions by Linux applications.  However a kernel with
++	  this option will not work on a MIPS core without SmartMIPS core.  If
++	  you don't know you probably don't have SmartMIPS and should say N
++	  here.
++
++config CPU_HAS_WB
++	bool
++
++config XKS01
++	bool
++
++#
++# Vectored interrupt mode is an R2 feature
++#
++config CPU_MIPSR2_IRQ_VI
++	bool
++
++#
++# Extended interrupt mode is an R2 feature
++#
++config CPU_MIPSR2_IRQ_EI
++	bool
++
++config CPU_HAS_SYNC
++	bool
++	depends on !CPU_R3000
++	default y
++
++#
++# CPU non-features
++#
++config CPU_DADDI_WORKAROUNDS
++	bool
++
++config CPU_R4000_WORKAROUNDS
++	bool
++	select CPU_R4400_WORKAROUNDS
++
++config CPU_R4400_WORKAROUNDS
++	bool
++
++#
++# - Highmem only makes sense for the 32-bit kernel.
++# - The current highmem code will only work properly on physically indexed
++#   caches such as R3000, SB1, R7000 or those that look like they're virtually
++#   indexed such as R4000/R4400 SC and MC versions or R10000.  So for the
++#   moment we protect the user and offer the highmem option only on machines
++#   where it's known to be safe.  This will not offer highmem on a few systems
++#   such as MIPS32 and MIPS64 CPUs which may have virtual and physically
++#   indexed CPUs but we're playing safe.
++# - We use SYS_SUPPORTS_HIGHMEM to offer highmem only for systems where we
++#   know they might have memory configurations that could make use of highmem
++#   support.
++#
++config HIGHMEM
++	bool "High Memory Support"
++	depends on 32BIT && CPU_SUPPORTS_HIGHMEM && SYS_SUPPORTS_HIGHMEM
++
++config CPU_SUPPORTS_HIGHMEM
++	bool
++
++config SYS_SUPPORTS_HIGHMEM
++	bool
++
++config SYS_SUPPORTS_SMARTMIPS
++	bool
++
++config ARCH_FLATMEM_ENABLE
++	def_bool y
++	depends on !NUMA && !CPU_LOONGSON2
++
++config ARCH_DISCONTIGMEM_ENABLE
++	bool
++	default y if SGI_IP27
++	help
++	  Say Y to support efficient handling of discontiguous physical memory,
++	  for architectures which are either NUMA (Non-Uniform Memory Access)
++	  or have huge holes in the physical address space for other reasons.
++	  See <file:Documentation/vm/numa> for more.
++
++config ARCH_SPARSEMEM_ENABLE
++	bool
++	select SPARSEMEM_STATIC
++
++config NUMA
++	bool "NUMA Support"
++	depends on SYS_SUPPORTS_NUMA
++	help
++	  Say Y to compile the kernel to support NUMA (Non-Uniform Memory
++	  Access).  This option improves performance on systems with more
++	  than two nodes; on two node systems it is generally better to
++	  leave it disabled; on single node systems disable this option
++	  disabled.
++
++config SYS_SUPPORTS_NUMA
++	bool
++
++config NODES_SHIFT
++	int
++	default "6"
++	depends on NEED_MULTIPLE_NODES
++
++config HW_PERF_EVENTS
++	bool "Enable hardware performance counter support for perf events"
++	depends on PERF_EVENTS && !MIPS_MT_SMTC && OPROFILE=n && (CPU_MIPS32 || CPU_MIPS64 || CPU_R10000 || CPU_SB1 || CPU_CAVIUM_OCTEON || CPU_XLP)
++	default y
++	help
++	  Enable hardware performance counter support for perf events. If
++	  disabled, perf events will use software events only.
++
++source "mm/Kconfig"
++
++config SMP
++	bool "Multi-Processing support"
++	depends on SYS_SUPPORTS_SMP
++	select USE_GENERIC_SMP_HELPERS
++	help
++	  This enables support for systems with more than one CPU. If you have
++	  a system with only one CPU, like most personal computers, say N. If
++	  you have a system with more than one CPU, say Y.
++
++	  If you say N here, the kernel will run on single and multiprocessor
++	  machines, but will use only one CPU of a multiprocessor machine. If
++	  you say Y here, the kernel will run on many, but not all,
++	  singleprocessor machines. On a singleprocessor machine, the kernel
++	  will run faster if you say N here.
++
++	  People using multiprocessor machines who say Y here should also say
++	  Y to "Enhanced Real Time Clock Support", below.
++
++	  See also the SMP-HOWTO available at
++	  <http://www.tldp.org/docs.html#howto>.
++
++	  If you don't know what to do here, say N.
++
++config SMP_UP
++	bool
++
++config SYS_SUPPORTS_MIPS_CMP
++	bool
++
++config SYS_SUPPORTS_SMP
++	bool
++
++config NR_CPUS_DEFAULT_1
++	bool
++
++config NR_CPUS_DEFAULT_2
++	bool
++
++config NR_CPUS_DEFAULT_4
++	bool
++
++config NR_CPUS_DEFAULT_8
++	bool
++
++config NR_CPUS_DEFAULT_16
++	bool
++
++config NR_CPUS_DEFAULT_32
++	bool
++
++config NR_CPUS_DEFAULT_64
++	bool
++
++config NR_CPUS
++	int "Maximum number of CPUs (2-64)"
++	range 1 64 if NR_CPUS_DEFAULT_1
++	depends on SMP
++	default "1" if NR_CPUS_DEFAULT_1
++	default "2" if NR_CPUS_DEFAULT_2
++	default "4" if NR_CPUS_DEFAULT_4
++	default "8" if NR_CPUS_DEFAULT_8
++	default "16" if NR_CPUS_DEFAULT_16
++	default "32" if NR_CPUS_DEFAULT_32
++	default "64" if NR_CPUS_DEFAULT_64
++	help
++	  This allows you to specify the maximum number of CPUs which this
++	  kernel will support.  The maximum supported value is 32 for 32-bit
++	  kernel and 64 for 64-bit kernels; the minimum value which makes
++	  sense is 1 for Qemu (useful only for kernel debugging purposes)
++	  and 2 for all others.
++
++	  This is purely to save memory - each supported CPU adds
++	  approximately eight kilobytes to the kernel image.  For best
++	  performance should round up your number of processors to the next
++	  power of two.
++
++config MIPS_PERF_SHARED_TC_COUNTERS
++	bool
++
++#
++# Timer Interrupt Frequency Configuration
++#
++
++choice
++	prompt "Timer frequency"
++	default HZ_250
++	help
++	 Allows the configuration of the timer frequency.
++
++	config HZ_48
++		bool "48 HZ" if SYS_SUPPORTS_48HZ || SYS_SUPPORTS_ARBIT_HZ
++
++	config HZ_100
++		bool "100 HZ" if SYS_SUPPORTS_100HZ || SYS_SUPPORTS_ARBIT_HZ
++
++	config HZ_128
++		bool "128 HZ" if SYS_SUPPORTS_128HZ || SYS_SUPPORTS_ARBIT_HZ
++
++	config HZ_250
++		bool "250 HZ" if SYS_SUPPORTS_250HZ || SYS_SUPPORTS_ARBIT_HZ
++
++	config HZ_256
++		bool "256 HZ" if SYS_SUPPORTS_256HZ || SYS_SUPPORTS_ARBIT_HZ
++
++	config HZ_1000
++		bool "1000 HZ" if SYS_SUPPORTS_1000HZ || SYS_SUPPORTS_ARBIT_HZ
++
++	config HZ_1024
++		bool "1024 HZ" if SYS_SUPPORTS_1024HZ || SYS_SUPPORTS_ARBIT_HZ
++
++endchoice
++
++config SYS_SUPPORTS_48HZ
++	bool
++
++config SYS_SUPPORTS_100HZ
++	bool
++
++config SYS_SUPPORTS_128HZ
++	bool
++
++config SYS_SUPPORTS_250HZ
++	bool
++
++config SYS_SUPPORTS_256HZ
++	bool
++
++config SYS_SUPPORTS_1000HZ
++	bool
++
++config SYS_SUPPORTS_1024HZ
++	bool
++
++config SYS_SUPPORTS_ARBIT_HZ
++	bool
++	default y if !SYS_SUPPORTS_48HZ && !SYS_SUPPORTS_100HZ && \
++		     !SYS_SUPPORTS_128HZ && !SYS_SUPPORTS_250HZ && \
++		     !SYS_SUPPORTS_256HZ && !SYS_SUPPORTS_1000HZ && \
++		     !SYS_SUPPORTS_1024HZ
++
++config HZ
++	int
++	default 48 if HZ_48
++	default 100 if HZ_100
++	default 128 if HZ_128
++	default 250 if HZ_250
++	default 256 if HZ_256
++	default 1000 if HZ_1000
++	default 1024 if HZ_1024
++
++source "kernel/Kconfig.preempt"
++
++config KEXEC
++	bool "Kexec system call"
++	help
++	  kexec is a system call that implements the ability to shutdown your
++	  current kernel, and to start another kernel.  It is like a reboot
++	  but it is independent of the system firmware.   And like a reboot
++	  you can start any kernel with it, not just Linux.
++
++	  The name comes from the similarity to the exec system call.
++
++	  It is an ongoing process to be certain the hardware in a machine
++	  is properly shutdown, so do not be surprised if this code does not
++	  initially work for you.  It may help to enable device hotplugging
++	  support.  As of this writing the exact hardware interface is
++	  strongly in flux, so no good recommendation can be made.
++
++config CRASH_DUMP
++	  bool "Kernel crash dumps"
++	  help
++	  Generate crash dump after being started by kexec.
++	  This should be normally only set in special crash dump kernels
++	  which are loaded in the main kernel with kexec-tools into
++	  a specially reserved region and then later executed after
++	  a crash by kdump/kexec. The crash dump kernel must be compiled
++	  to a memory address not used by the main kernel or firmware using
++	  PHYSICAL_START.
++
++config PHYSICAL_START
++	  hex "Physical address where the kernel is loaded"
++	  default "0xffffffff84000000" if 64BIT
++	  default "0x84000000" if 32BIT
++	  depends on CRASH_DUMP
++	  help
++	  This gives the CKSEG0 or KSEG0 address where the kernel is loaded.
++	  If you plan to use kernel for capturing the crash dump change
++	  this value to start of the reserved region (the "X" value as
++	  specified in the "crashkernel=YM@XM" command line boot parameter
++	  passed to the panic-ed kernel).
++
++config SECCOMP
++	bool "Enable seccomp to safely compute untrusted bytecode"
++	depends on PROC_FS
++	default y
++	help
++	  This kernel feature is useful for number crunching applications
++	  that may need to compute untrusted bytecode during their
++	  execution. By using pipes or other transports made available to
++	  the process as file descriptors supporting the read/write
++	  syscalls, it's possible to isolate those applications in
++	  their own address space using seccomp. Once seccomp is
++	  enabled via /proc/<pid>/seccomp, it cannot be disabled
++	  and the task is only allowed to execute a few safe syscalls
++	  defined by each seccomp mode.
++
++	  If unsure, say Y. Only embedded should say N here.
++
++config USE_OF
++	bool
++	select OF
++	select OF_EARLY_FLATTREE
++	select IRQ_DOMAIN
++
++endmenu
++
++config LOCKDEP_SUPPORT
++	bool
++	default y
++
++config STACKTRACE_SUPPORT
++	bool
++	default y
++
++source "init/Kconfig"
++
++source "kernel/Kconfig.freezer"
++
++menu "Bus options (PCI, PCMCIA, EISA, ISA, TC)"
++
++config HW_HAS_EISA
++	bool
++config HW_HAS_PCI
++	bool
++
++config PCI
++	bool "Support for PCI controller"
++	depends on HW_HAS_PCI
++	select PCI_DOMAINS
++	select GENERIC_PCI_IOMAP
++	select NO_GENERIC_PCI_IOPORT_MAP
++	help
++	  Find out whether you have a PCI motherboard. PCI is the name of a
++	  bus system, i.e. the way the CPU talks to the other stuff inside
++	  your box. Other bus systems are ISA, EISA, or VESA. If you have PCI,
++	  say Y, otherwise N.
++
++config PCI_DOMAINS
++	bool
++
++source "drivers/pci/Kconfig"
++
++source "drivers/pci/pcie/Kconfig"
++
++#
++# ISA support is now enabled via select.  Too many systems still have the one
++# or other ISA chip on the board that users don't know about so don't expect
++# users to choose the right thing ...
++#
++config ISA
++	bool
++
++config EISA
++	bool "EISA support"
++	depends on HW_HAS_EISA
++	select ISA
++	select GENERIC_ISA_DMA
++	---help---
++	  The Extended Industry Standard Architecture (EISA) bus was
++	  developed as an open alternative to the IBM MicroChannel bus.
++
++	  The EISA bus provided some of the features of the IBM MicroChannel
++	  bus while maintaining backward compatibility with cards made for
++	  the older ISA bus.  The EISA bus saw limited use between 1988 and
++	  1995 when it was made obsolete by the PCI bus.
++
++	  Say Y here if you are building a kernel for an EISA-based machine.
++
++	  Otherwise, say N.
++
++source "drivers/eisa/Kconfig"
++
++config TC
++	bool "TURBOchannel support"
++	depends on MACH_DECSTATION
++	help
++	  TURBOchannel is a DEC (now Compaq (now HP)) bus for Alpha and MIPS
++	  processors.  TURBOchannel programming specifications are available
++	  at:
++	  <ftp://ftp.hp.com/pub/alphaserver/archive/triadd/>
++	  and:
++	  <http://www.computer-refuge.org/classiccmp/ftp.digital.com/pub/DEC/TriAdd/>
++	  Linux driver support status is documented at:
++	  <http://www.linux-mips.org/wiki/DECstation>
++
++config MMU
++	bool
++	default y
++
++config I8253
++	bool
++	select CLKSRC_I8253
++	select CLKEVT_I8253
++	select MIPS_EXTERNAL_TIMER
++
++config ZONE_DMA32
++	bool
++
++source "drivers/pcmcia/Kconfig"
++
++source "drivers/pci/hotplug/Kconfig"
++
++config RAPIDIO
++	bool "RapidIO support"
++	depends on PCI
++	default n
++	help
++	  If you say Y here, the kernel will include drivers and
++	  infrastructure code to support RapidIO interconnect devices.
++
++source "drivers/rapidio/Kconfig"
++
++endmenu
++
++menu "Executable file formats"
++
++source "fs/Kconfig.binfmt"
++
++config TRAD_SIGNALS
++	bool
++
++config MIPS32_COMPAT
++	bool "Kernel support for Linux/MIPS 32-bit binary compatibility"
++	depends on 64BIT
++	help
++	  Select this option if you want Linux/MIPS 32-bit binary
++	  compatibility. Since all software available for Linux/MIPS is
++	  currently 32-bit you should say Y here.
++
++config COMPAT
++	bool
++	depends on MIPS32_COMPAT
++	select ARCH_WANT_OLD_COMPAT_IPC
++	default y
++
++config SYSVIPC_COMPAT
++	bool
++	depends on COMPAT && SYSVIPC
++	default y
++
++config MIPS32_O32
++	bool "Kernel support for o32 binaries"
++	depends on MIPS32_COMPAT
++	help
++	  Select this option if you want to run o32 binaries.  These are pure
++	  32-bit binaries as used by the 32-bit Linux/MIPS port.  Most of
++	  existing binaries are in this format.
++
++	  If unsure, say Y.
++
++config MIPS32_N32
++	bool "Kernel support for n32 binaries"
++	depends on MIPS32_COMPAT
++	help
++	  Select this option if you want to run n32 binaries.  These are
++	  64-bit binaries using 32-bit quantities for addressing and certain
++	  data that would normally be 64-bit.  They are used in special
++	  cases.
++
++	  If unsure, say N.
++
++config BINFMT_ELF32
++	bool
++	default y if MIPS32_O32 || MIPS32_N32
++
++endmenu
++
++menu "Power management options"
++
++config ARCH_HIBERNATION_POSSIBLE
++	def_bool y
++	depends on SYS_SUPPORTS_HOTPLUG_CPU || !SMP
++
++config ARCH_SUSPEND_POSSIBLE
++	def_bool y
++	depends on SYS_SUPPORTS_HOTPLUG_CPU || !SMP
++
++source "kernel/power/Kconfig"
++
++endmenu
++
++source "arch/mips/kernel/cpufreq/Kconfig"
++
++source "net/Kconfig"
++
++source "drivers/Kconfig"
++
++source "drivers/firmware/Kconfig"
++
++source "fs/Kconfig"
++
++source "arch/mips/Kconfig.debug"
++
++source "security/Kconfig"
++
++source "crypto/Kconfig"
++
++source "lib/Kconfig"
+diff -Nur linux-3.9.11.orig/arch/x86/Kconfig linux-3.9.11/arch/x86/Kconfig
+--- linux-3.9.11.orig/arch/x86/Kconfig	2013-07-21 02:16:17.000000000 +0200
++++ linux-3.9.11/arch/x86/Kconfig	2013-09-12 07:26:20.000000000 +0200
+@@ -99,7 +99,6 @@
  	select GENERIC_SMP_IDLE_THREAD
+ 	select ARCH_WANT_IPC_PARSE_VERSION if X86_32
  	select HAVE_ARCH_SECCOMP_FILTER
 -	select BUILDTIME_EXTABLE_SORT
  	select GENERIC_CMOS_UPDATE
  	select CLOCKSOURCE_WATCHDOG
  	select GENERIC_CLOCKEVENTS
+diff -Nur linux-3.9.11.orig/arch/x86/Kconfig.orig linux-3.9.11/arch/x86/Kconfig.orig
+--- linux-3.9.11.orig/arch/x86/Kconfig.orig	1970-01-01 01:00:00.000000000 +0100
++++ linux-3.9.11/arch/x86/Kconfig.orig	2013-07-21 02:16:17.000000000 +0200
+@@ -0,0 +1,2351 @@
++# Select 32 or 64 bit
++config 64BIT
++	bool "64-bit kernel" if ARCH = "x86"
++	default ARCH != "i386"
++	---help---
++	  Say yes to build a 64-bit kernel - formerly known as x86_64
++	  Say no to build a 32-bit kernel - formerly known as i386
++
++config X86_32
++	def_bool y
++	depends on !64BIT
++	select CLKSRC_I8253
++	select HAVE_UID16
++
++config X86_64
++	def_bool y
++	depends on 64BIT
++	select X86_DEV_DMA_OPS
++
++### Arch settings
++config X86
++	def_bool y
++	select HAVE_AOUT if X86_32
++	select HAVE_UNSTABLE_SCHED_CLOCK
++	select ARCH_SUPPORTS_NUMA_BALANCING
++	select ARCH_WANTS_PROT_NUMA_PROT_NONE
++	select HAVE_IDE
++	select HAVE_OPROFILE
++	select HAVE_PCSPKR_PLATFORM
++	select HAVE_PERF_EVENTS
++	select HAVE_IOREMAP_PROT
++	select HAVE_KPROBES
++	select HAVE_MEMBLOCK
++	select HAVE_MEMBLOCK_NODE_MAP
++	select ARCH_DISCARD_MEMBLOCK
++	select ARCH_WANT_OPTIONAL_GPIOLIB
++	select ARCH_WANT_FRAME_POINTERS
++	select HAVE_DMA_ATTRS
++	select HAVE_DMA_CONTIGUOUS if !SWIOTLB
++	select HAVE_KRETPROBES
++	select HAVE_OPTPROBES
++	select HAVE_KPROBES_ON_FTRACE
++	select HAVE_FTRACE_MCOUNT_RECORD
++	select HAVE_FENTRY if X86_64
++	select HAVE_C_RECORDMCOUNT
++	select HAVE_DYNAMIC_FTRACE
++	select HAVE_DYNAMIC_FTRACE_WITH_REGS
++	select HAVE_FUNCTION_TRACER
++	select HAVE_FUNCTION_GRAPH_TRACER
++	select HAVE_FUNCTION_GRAPH_FP_TEST
++	select HAVE_FUNCTION_TRACE_MCOUNT_TEST
++	select HAVE_SYSCALL_TRACEPOINTS
++	select SYSCTL_EXCEPTION_TRACE
++	select HAVE_KVM
++	select HAVE_ARCH_KGDB
++	select HAVE_ARCH_TRACEHOOK
++	select HAVE_GENERIC_DMA_COHERENT if X86_32
++	select HAVE_EFFICIENT_UNALIGNED_ACCESS
++	select USER_STACKTRACE_SUPPORT
++	select HAVE_REGS_AND_STACK_ACCESS_API
++	select HAVE_DMA_API_DEBUG
++	select HAVE_KERNEL_GZIP
++	select HAVE_KERNEL_BZIP2
++	select HAVE_KERNEL_LZMA
++	select HAVE_KERNEL_XZ
++	select HAVE_KERNEL_LZO
++	select HAVE_HW_BREAKPOINT
++	select HAVE_MIXED_BREAKPOINTS_REGS
++	select PERF_EVENTS
++	select HAVE_PERF_EVENTS_NMI
++	select HAVE_PERF_REGS
++	select HAVE_PERF_USER_STACK_DUMP
++	select HAVE_DEBUG_KMEMLEAK
++	select ANON_INODES
++	select HAVE_ALIGNED_STRUCT_PAGE if SLUB
++	select HAVE_CMPXCHG_LOCAL
++	select HAVE_CMPXCHG_DOUBLE
++	select HAVE_ARCH_KMEMCHECK
++	select HAVE_USER_RETURN_NOTIFIER
++	select ARCH_BINFMT_ELF_RANDOMIZE_PIE
++	select HAVE_ARCH_JUMP_LABEL
++	select HAVE_TEXT_POKE_SMP
++	select HAVE_GENERIC_HARDIRQS
++	select ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
++	select SPARSE_IRQ
++	select GENERIC_FIND_FIRST_BIT
++	select GENERIC_IRQ_PROBE
++	select GENERIC_PENDING_IRQ if SMP
++	select GENERIC_IRQ_SHOW
++	select GENERIC_CLOCKEVENTS_MIN_ADJUST
++	select IRQ_FORCED_THREADING
++	select USE_GENERIC_SMP_HELPERS if SMP
++	select HAVE_BPF_JIT if X86_64
++	select HAVE_ARCH_TRANSPARENT_HUGEPAGE
++	select CLKEVT_I8253
++	select ARCH_HAVE_NMI_SAFE_CMPXCHG
++	select GENERIC_IOMAP
++	select DCACHE_WORD_ACCESS
++	select GENERIC_SMP_IDLE_THREAD
++	select ARCH_WANT_IPC_PARSE_VERSION if X86_32
++	select HAVE_ARCH_SECCOMP_FILTER
++	select BUILDTIME_EXTABLE_SORT
++	select GENERIC_CMOS_UPDATE
++	select CLOCKSOURCE_WATCHDOG
++	select GENERIC_CLOCKEVENTS
++	select ARCH_CLOCKSOURCE_DATA if X86_64
++	select GENERIC_CLOCKEVENTS_BROADCAST if X86_64 || (X86_32 && X86_LOCAL_APIC)
++	select GENERIC_TIME_VSYSCALL if X86_64
++	select KTIME_SCALAR if X86_32
++	select GENERIC_STRNCPY_FROM_USER
++	select GENERIC_STRNLEN_USER
++	select HAVE_CONTEXT_TRACKING if X86_64
++	select HAVE_IRQ_TIME_ACCOUNTING
++	select VIRT_TO_BUS
++	select MODULES_USE_ELF_REL if X86_32
++	select MODULES_USE_ELF_RELA if X86_64
++	select CLONE_BACKWARDS if X86_32
++	select ARCH_USE_BUILTIN_BSWAP
++	select OLD_SIGSUSPEND3 if X86_32 || IA32_EMULATION
++	select OLD_SIGACTION if X86_32
++	select COMPAT_OLD_SIGACTION if IA32_EMULATION
++
++config INSTRUCTION_DECODER
++	def_bool y
++	depends on KPROBES || PERF_EVENTS || UPROBES
++
++config OUTPUT_FORMAT
++	string
++	default "elf32-i386" if X86_32
++	default "elf64-x86-64" if X86_64
++
++config ARCH_DEFCONFIG
++	string
++	default "arch/x86/configs/i386_defconfig" if X86_32
++	default "arch/x86/configs/x86_64_defconfig" if X86_64
++
++config LOCKDEP_SUPPORT
++	def_bool y
++
++config STACKTRACE_SUPPORT
++	def_bool y
++
++config HAVE_LATENCYTOP_SUPPORT
++	def_bool y
++
++config MMU
++	def_bool y
++
++config SBUS
++	bool
++
++config NEED_DMA_MAP_STATE
++	def_bool y
++	depends on X86_64 || INTEL_IOMMU || DMA_API_DEBUG
++
++config NEED_SG_DMA_LENGTH
++	def_bool y
++
++config GENERIC_ISA_DMA
++	def_bool y
++	depends on ISA_DMA_API
++
++config GENERIC_BUG
++	def_bool y
++	depends on BUG
++	select GENERIC_BUG_RELATIVE_POINTERS if X86_64
++
++config GENERIC_BUG_RELATIVE_POINTERS
++	bool
++
++config GENERIC_HWEIGHT
++	def_bool y
++
++config GENERIC_GPIO
++	bool
++
++config ARCH_MAY_HAVE_PC_FDC
++	def_bool y
++	depends on ISA_DMA_API
++
++config RWSEM_XCHGADD_ALGORITHM
++	def_bool y
++
++config GENERIC_CALIBRATE_DELAY
++	def_bool y
++
++config ARCH_HAS_CPU_RELAX
++	def_bool y
++
++config ARCH_HAS_DEFAULT_IDLE
++	def_bool y
++
++config ARCH_HAS_CACHE_LINE_SIZE
++	def_bool y
++
++config ARCH_HAS_CPU_AUTOPROBE
++	def_bool y
++
++config HAVE_SETUP_PER_CPU_AREA
++	def_bool y
++
++config NEED_PER_CPU_EMBED_FIRST_CHUNK
++	def_bool y
++
++config NEED_PER_CPU_PAGE_FIRST_CHUNK
++	def_bool y
++
++config ARCH_HIBERNATION_POSSIBLE
++	def_bool y
++
++config ARCH_SUSPEND_POSSIBLE
++	def_bool y
++
++config ZONE_DMA32
++	bool
++	default X86_64
++
++config AUDIT_ARCH
++	bool
++	default X86_64
++
++config ARCH_SUPPORTS_OPTIMIZED_INLINING
++	def_bool y
++
++config ARCH_SUPPORTS_DEBUG_PAGEALLOC
++	def_bool y
++
++config HAVE_INTEL_TXT
++	def_bool y
++	depends on INTEL_IOMMU && ACPI
++
++config X86_32_SMP
++	def_bool y
++	depends on X86_32 && SMP
++
++config X86_64_SMP
++	def_bool y
++	depends on X86_64 && SMP
++
++config X86_HT
++	def_bool y
++	depends on SMP
++
++config X86_32_LAZY_GS
++	def_bool y
++	depends on X86_32 && !CC_STACKPROTECTOR
++
++config ARCH_HWEIGHT_CFLAGS
++	string
++	default "-fcall-saved-ecx -fcall-saved-edx" if X86_32
++	default "-fcall-saved-rdi -fcall-saved-rsi -fcall-saved-rdx -fcall-saved-rcx -fcall-saved-r8 -fcall-saved-r9 -fcall-saved-r10 -fcall-saved-r11" if X86_64
++
++config ARCH_CPU_PROBE_RELEASE
++	def_bool y
++	depends on HOTPLUG_CPU
++
++config ARCH_SUPPORTS_UPROBES
++	def_bool y
++
++source "init/Kconfig"
++source "kernel/Kconfig.freezer"
++
++menu "Processor type and features"
++
++config ZONE_DMA
++	bool "DMA memory allocation support" if EXPERT
++	default y
++	help
++	  DMA memory allocation support allows devices with less than 32-bit
++	  addressing to allocate within the first 16MB of address space.
++	  Disable if no such devices will be used.
++
++	  If unsure, say Y.
++
++config SMP
++	bool "Symmetric multi-processing support"
++	---help---
++	  This enables support for systems with more than one CPU. If you have
++	  a system with only one CPU, like most personal computers, say N. If
++	  you have a system with more than one CPU, say Y.
++
++	  If you say N here, the kernel will run on single and multiprocessor
++	  machines, but will use only one CPU of a multiprocessor machine. If
++	  you say Y here, the kernel will run on many, but not all,
++	  singleprocessor machines. On a singleprocessor machine, the kernel
++	  will run faster if you say N here.
++
++	  Note that if you say Y here and choose architecture "586" or
++	  "Pentium" under "Processor family", the kernel will not work on 486
++	  architectures. Similarly, multiprocessor kernels for the "PPro"
++	  architecture may not work on all Pentium based boards.
++
++	  People using multiprocessor machines who say Y here should also say
++	  Y to "Enhanced Real Time Clock Support", below. The "Advanced Power
++	  Management" code will be disabled if you say Y here.
++
++	  See also <file:Documentation/x86/i386/IO-APIC.txt>,
++	  <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO available at
++	  <http://www.tldp.org/docs.html#howto>.
++
++	  If you don't know what to do here, say N.
++
++config X86_X2APIC
++	bool "Support x2apic"
++	depends on X86_LOCAL_APIC && X86_64 && IRQ_REMAP
++	---help---
++	  This enables x2apic support on CPUs that have this feature.
++
++	  This allows 32-bit apic IDs (so it can support very large systems),
++	  and accesses the local apic via MSRs not via mmio.
++
++	  If you don't know what to do here, say N.
++
++config X86_MPPARSE
++	bool "Enable MPS table" if ACPI || SFI
++	default y
++	depends on X86_LOCAL_APIC
++	---help---
++	  For old smp systems that do not have proper acpi support. Newer systems
++	  (esp with 64bit cpus) with acpi support, MADT and DSDT will override it
++
++config X86_BIGSMP
++	bool "Support for big SMP systems with more than 8 CPUs"
++	depends on X86_32 && SMP
++	---help---
++	  This option is needed for the systems that have more than 8 CPUs
++
++config GOLDFISH
++       def_bool y
++       depends on X86_GOLDFISH
++
++if X86_32
++config X86_EXTENDED_PLATFORM
++	bool "Support for extended (non-PC) x86 platforms"
++	default y
++	---help---
++	  If you disable this option then the kernel will only support
++	  standard PC platforms. (which covers the vast majority of
++	  systems out there.)
++
++	  If you enable this option then you'll be able to select support
++	  for the following (non-PC) 32 bit x86 platforms:
++		AMD Elan
++		NUMAQ (IBM/Sequent)
++		RDC R-321x SoC
++		SGI 320/540 (Visual Workstation)
++		STA2X11-based (e.g. Northville)
++		Summit/EXA (IBM x440)
++		Unisys ES7000 IA32 series
++		Moorestown MID devices
++
++	  If you have one of these systems, or if you want to build a
++	  generic distribution kernel, say Y here - otherwise say N.
++endif
++
++if X86_64
++config X86_EXTENDED_PLATFORM
++	bool "Support for extended (non-PC) x86 platforms"
++	default y
++	---help---
++	  If you disable this option then the kernel will only support
++	  standard PC platforms. (which covers the vast majority of
++	  systems out there.)
++
++	  If you enable this option then you'll be able to select support
++	  for the following (non-PC) 64 bit x86 platforms:
++		Numascale NumaChip
++		ScaleMP vSMP
++		SGI Ultraviolet
++
++	  If you have one of these systems, or if you want to build a
++	  generic distribution kernel, say Y here - otherwise say N.
++endif
++# This is an alphabetically sorted list of 64 bit extended platforms
++# Please maintain the alphabetic order if and when there are additions
++config X86_NUMACHIP
++	bool "Numascale NumaChip"
++	depends on X86_64
++	depends on X86_EXTENDED_PLATFORM
++	depends on NUMA
++	depends on SMP
++	depends on X86_X2APIC
++	depends on PCI_MMCONFIG
++	---help---
++	  Adds support for Numascale NumaChip large-SMP systems. Needed to
++	  enable more than ~168 cores.
++	  If you don't have one of these, you should say N here.
++
++config X86_VSMP
++	bool "ScaleMP vSMP"
++	select PARAVIRT_GUEST
++	select PARAVIRT
++	depends on X86_64 && PCI
++	depends on X86_EXTENDED_PLATFORM
++	depends on SMP
++	---help---
++	  Support for ScaleMP vSMP systems.  Say 'Y' here if this kernel is
++	  supposed to run on these EM64T-based machines.  Only choose this option
++	  if you have one of these machines.
++
++config X86_UV
++	bool "SGI Ultraviolet"
++	depends on X86_64
++	depends on X86_EXTENDED_PLATFORM
++	depends on NUMA
++	depends on X86_X2APIC
++	---help---
++	  This option is needed in order to support SGI Ultraviolet systems.
++	  If you don't have one of these, you should say N here.
++
++# Following is an alphabetically sorted list of 32 bit extended platforms
++# Please maintain the alphabetic order if and when there are additions
++
++config X86_GOLDFISH
++       bool "Goldfish (Virtual Platform)"
++       depends on X86_32
++       ---help---
++	 Enable support for the Goldfish virtual platform used primarily
++	 for Android development. Unless you are building for the Android
++	 Goldfish emulator say N here.
++
++config X86_INTEL_CE
++	bool "CE4100 TV platform"
++	depends on PCI
++	depends on PCI_GODIRECT
++	depends on X86_32
++	depends on X86_EXTENDED_PLATFORM
++	select X86_REBOOTFIXUPS
++	select OF
++	select OF_EARLY_FLATTREE
++	select IRQ_DOMAIN
++	---help---
++	  Select for the Intel CE media processor (CE4100) SOC.
++	  This option compiles in support for the CE4100 SOC for settop
++	  boxes and media devices.
++
++config X86_WANT_INTEL_MID
++	bool "Intel MID platform support"
++	depends on X86_32
++	depends on X86_EXTENDED_PLATFORM
++	---help---
++	  Select to build a kernel capable of supporting Intel MID platform
++	  systems which do not have the PCI legacy interfaces (Moorestown,
++	  Medfield). If you are building for a PC class system say N here.
++
++if X86_WANT_INTEL_MID
++
++config X86_INTEL_MID
++	bool
++
++config X86_MDFLD
++       bool "Medfield MID platform"
++	depends on PCI
++	depends on PCI_GOANY
++	depends on X86_IO_APIC
++	select X86_INTEL_MID
++	select SFI
++	select DW_APB_TIMER
++	select APB_TIMER
++	select I2C
++	select SPI
++	select INTEL_SCU_IPC
++	select X86_PLATFORM_DEVICES
++	select MFD_INTEL_MSIC
++	---help---
++	  Medfield is Intel's Low Power Intel Architecture (LPIA) based Moblin
++	  Internet Device(MID) platform. 
++	  Unlike standard x86 PCs, Medfield does not have many legacy devices
++	  nor standard legacy replacement devices/features. e.g. Medfield does
++	  not contain i8259, i8254, HPET, legacy BIOS, most of the io ports.
++
++endif
++
++config X86_INTEL_LPSS
++	bool "Intel Low Power Subsystem Support"
++	depends on ACPI
++	select COMMON_CLK
++	---help---
++	  Select to build support for Intel Low Power Subsystem such as
++	  found on Intel Lynxpoint PCH. Selecting this option enables
++	  things like clock tree (common clock framework) which are needed
++	  by the LPSS peripheral drivers.
++
++config X86_RDC321X
++	bool "RDC R-321x SoC"
++	depends on X86_32
++	depends on X86_EXTENDED_PLATFORM
++	select M486
++	select X86_REBOOTFIXUPS
++	---help---
++	  This option is needed for RDC R-321x system-on-chip, also known
++	  as R-8610-(G).
++	  If you don't have one of these chips, you should say N here.
++
++config X86_32_NON_STANDARD
++	bool "Support non-standard 32-bit SMP architectures"
++	depends on X86_32 && SMP
++	depends on X86_EXTENDED_PLATFORM
++	---help---
++	  This option compiles in the NUMAQ, Summit, bigsmp, ES7000,
++	  STA2X11, default subarchitectures.  It is intended for a generic
++	  binary kernel. If you select them all, kernel will probe it
++	  one by one and will fallback to default.
++
++# Alphabetically sorted list of Non standard 32 bit platforms
++
++config X86_NUMAQ
++	bool "NUMAQ (IBM/Sequent)"
++	depends on X86_32_NON_STANDARD
++	depends on PCI
++	select NUMA
++	select X86_MPPARSE
++	---help---
++	  This option is used for getting Linux to run on a NUMAQ (IBM/Sequent)
++	  NUMA multiquad box. This changes the way that processors are
++	  bootstrapped, and uses Clustered Logical APIC addressing mode instead
++	  of Flat Logical.  You will need a new lynxer.elf file to flash your
++	  firmware with - send email to <Martin.Bligh@us.ibm.com>.
++
++config X86_SUPPORTS_MEMORY_FAILURE
++	def_bool y
++	# MCE code calls memory_failure():
++	depends on X86_MCE
++	# On 32-bit this adds too big of NODES_SHIFT and we run out of page flags:
++	depends on !X86_NUMAQ
++	# On 32-bit SPARSEMEM adds too big of SECTIONS_WIDTH:
++	depends on X86_64 || !SPARSEMEM
++	select ARCH_SUPPORTS_MEMORY_FAILURE
++
++config X86_VISWS
++	bool "SGI 320/540 (Visual Workstation)"
++	depends on X86_32 && PCI && X86_MPPARSE && PCI_GODIRECT
++	depends on X86_32_NON_STANDARD
++	---help---
++	  The SGI Visual Workstation series is an IA32-based workstation
++	  based on SGI systems chips with some legacy PC hardware attached.
++
++	  Say Y here to create a kernel to run on the SGI 320 or 540.
++
++	  A kernel compiled for the Visual Workstation will run on general
++	  PCs as well. See <file:Documentation/sgi-visws.txt> for details.
++
++config STA2X11
++	bool "STA2X11 Companion Chip Support"
++	depends on X86_32_NON_STANDARD && PCI
++	select X86_DEV_DMA_OPS
++	select X86_DMA_REMAP
++	select SWIOTLB
++	select MFD_STA2X11
++	select ARCH_REQUIRE_GPIOLIB
++	default n
++	---help---
++	  This adds support for boards based on the STA2X11 IO-Hub,
++	  a.k.a. "ConneXt". The chip is used in place of the standard
++	  PC chipset, so all "standard" peripherals are missing. If this
++	  option is selected the kernel will still be able to boot on
++	  standard PC machines.
++
++config X86_SUMMIT
++	bool "Summit/EXA (IBM x440)"
++	depends on X86_32_NON_STANDARD
++	---help---
++	  This option is needed for IBM systems that use the Summit/EXA chipset.
++	  In particular, it is needed for the x440.
++
++config X86_ES7000
++	bool "Unisys ES7000 IA32 series"
++	depends on X86_32_NON_STANDARD && X86_BIGSMP
++	---help---
++	  Support for Unisys ES7000 systems.  Say 'Y' here if this kernel is
++	  supposed to run on an IA32-based Unisys ES7000 system.
++
++config X86_32_IRIS
++	tristate "Eurobraille/Iris poweroff module"
++	depends on X86_32
++	---help---
++	  The Iris machines from EuroBraille do not have APM or ACPI support
++	  to shut themselves down properly.  A special I/O sequence is
++	  needed to do so, which is what this module does at
++	  kernel shutdown.
++
++	  This is only for Iris machines from EuroBraille.
++
++	  If unused, say N.
++
++config SCHED_OMIT_FRAME_POINTER
++	def_bool y
++	prompt "Single-depth WCHAN output"
++	depends on X86
++	---help---
++	  Calculate simpler /proc/<PID>/wchan values. If this option
++	  is disabled then wchan values will recurse back to the
++	  caller function. This provides more accurate wchan values,
++	  at the expense of slightly more scheduling overhead.
++
++	  If in doubt, say "Y".
++
++menuconfig PARAVIRT_GUEST
++	bool "Paravirtualized guest support"
++	---help---
++	  Say Y here to get to see options related to running Linux under
++	  various hypervisors.  This option alone does not add any kernel code.
++
++	  If you say N, all options in this submenu will be skipped and disabled.
++
++if PARAVIRT_GUEST
++
++config PARAVIRT_TIME_ACCOUNTING
++	bool "Paravirtual steal time accounting"
++	select PARAVIRT
++	default n
++	---help---
++	  Select this option to enable fine granularity task steal time
++	  accounting. Time spent executing other tasks in parallel with
++	  the current vCPU is discounted from the vCPU power. To account for
++	  that, there can be a small performance impact.
++
++	  If in doubt, say N here.
++
++source "arch/x86/xen/Kconfig"
++
++config KVM_GUEST
++	bool "KVM Guest support (including kvmclock)"
++	select PARAVIRT
++	select PARAVIRT
++	select PARAVIRT_CLOCK
++	default y if PARAVIRT_GUEST
++	---help---
++	  This option enables various optimizations for running under the KVM
++	  hypervisor. It includes a paravirtualized clock, so that instead
++	  of relying on a PIT (or probably other) emulation by the
++	  underlying device model, the host provides the guest with
++	  timing infrastructure such as time of day, and system time
++
++source "arch/x86/lguest/Kconfig"
++
++config PARAVIRT
++	bool "Enable paravirtualization code"
++	---help---
++	  This changes the kernel so it can modify itself when it is run
++	  under a hypervisor, potentially improving performance significantly
++	  over full virtualization.  However, when run without a hypervisor
++	  the kernel is theoretically slower and slightly larger.
++
++config PARAVIRT_SPINLOCKS
++	bool "Paravirtualization layer for spinlocks"
++	depends on PARAVIRT && SMP
++	---help---
++	  Paravirtualized spinlocks allow a pvops backend to replace the
++	  spinlock implementation with something virtualization-friendly
++	  (for example, block the virtual CPU rather than spinning).
++
++	  Unfortunately the downside is an up to 5% performance hit on
++	  native kernels, with various workloads.
++
++	  If you are unsure how to answer this question, answer N.
++
++config PARAVIRT_CLOCK
++	bool
++
++endif
++
++config PARAVIRT_DEBUG
++	bool "paravirt-ops debugging"
++	depends on PARAVIRT && DEBUG_KERNEL
++	---help---
++	  Enable to debug paravirt_ops internals.  Specifically, BUG if
++	  a paravirt_op is missing when it is called.
++
++config NO_BOOTMEM
++	def_bool y
++
++config MEMTEST
++	bool "Memtest"
++	---help---
++	  This option adds a kernel parameter 'memtest', which allows memtest
++	  to be set.
++	        memtest=0, mean disabled; -- default
++	        memtest=1, mean do 1 test pattern;
++	        ...
++	        memtest=4, mean do 4 test patterns.
++	  If you are unsure how to answer this question, answer N.
++
++config X86_SUMMIT_NUMA
++	def_bool y
++	depends on X86_32 && NUMA && X86_32_NON_STANDARD
++
++config X86_CYCLONE_TIMER
++	def_bool y
++	depends on X86_SUMMIT
++
++source "arch/x86/Kconfig.cpu"
++
++config HPET_TIMER
++	def_bool X86_64
++	prompt "HPET Timer Support" if X86_32
++	---help---
++	  Use the IA-PC HPET (High Precision Event Timer) to manage
++	  time in preference to the PIT and RTC, if a HPET is
++	  present.
++	  HPET is the next generation timer replacing legacy 8254s.
++	  The HPET provides a stable time base on SMP
++	  systems, unlike the TSC, but it is more expensive to access,
++	  as it is off-chip.  You can find the HPET spec at
++	  <http://www.intel.com/hardwaredesign/hpetspec_1.pdf>.
++
++	  You can safely choose Y here.  However, HPET will only be
++	  activated if the platform and the BIOS support this feature.
++	  Otherwise the 8254 will be used for timing services.
++
++	  Choose N to continue using the legacy 8254 timer.
++
++config HPET_EMULATE_RTC
++	def_bool y
++	depends on HPET_TIMER && (RTC=y || RTC=m || RTC_DRV_CMOS=m || RTC_DRV_CMOS=y)
++
++config APB_TIMER
++       def_bool y if X86_INTEL_MID
++       prompt "Intel MID APB Timer Support" if X86_INTEL_MID
++       select DW_APB_TIMER
++       depends on X86_INTEL_MID && SFI
++       help
++         APB timer is the replacement for 8254, HPET on X86 MID platforms.
++         The APBT provides a stable time base on SMP
++         systems, unlike the TSC, but it is more expensive to access,
++         as it is off-chip. APB timers are always running regardless of CPU
++         C states, they are used as per CPU clockevent device when possible.
++
++# Mark as expert because too many people got it wrong.
++# The code disables itself when not needed.
++config DMI
++	default y
++	bool "Enable DMI scanning" if EXPERT
++	---help---
++	  Enabled scanning of DMI to identify machine quirks. Say Y
++	  here unless you have verified that your setup is not
++	  affected by entries in the DMI blacklist. Required by PNP
++	  BIOS code.
++
++config GART_IOMMU
++	bool "GART IOMMU support" if EXPERT
++	default y
++	select SWIOTLB
++	depends on X86_64 && PCI && AMD_NB
++	---help---
++	  Support for full DMA access of devices with 32bit memory access only
++	  on systems with more than 3GB. This is usually needed for USB,
++	  sound, many IDE/SATA chipsets and some other devices.
++	  Provides a driver for the AMD Athlon64/Opteron/Turion/Sempron GART
++	  based hardware IOMMU and a software bounce buffer based IOMMU used
++	  on Intel systems and as fallback.
++	  The code is only active when needed (enough memory and limited
++	  device) unless CONFIG_IOMMU_DEBUG or iommu=force is specified
++	  too.
++
++config CALGARY_IOMMU
++	bool "IBM Calgary IOMMU support"
++	select SWIOTLB
++	depends on X86_64 && PCI
++	---help---
++	  Support for hardware IOMMUs in IBM's xSeries x366 and x460
++	  systems. Needed to run systems with more than 3GB of memory
++	  properly with 32-bit PCI devices that do not support DAC
++	  (Double Address Cycle). Calgary also supports bus level
++	  isolation, where all DMAs pass through the IOMMU.  This
++	  prevents them from going anywhere except their intended
++	  destination. This catches hard-to-find kernel bugs and
++	  mis-behaving drivers and devices that do not use the DMA-API
++	  properly to set up their DMA buffers.  The IOMMU can be
++	  turned off at boot time with the iommu=off parameter.
++	  Normally the kernel will make the right choice by itself.
++	  If unsure, say Y.
++
++config CALGARY_IOMMU_ENABLED_BY_DEFAULT
++	def_bool y
++	prompt "Should Calgary be enabled by default?"
++	depends on CALGARY_IOMMU
++	---help---
++	  Should Calgary be enabled by default? if you choose 'y', Calgary
++	  will be used (if it exists). If you choose 'n', Calgary will not be
++	  used even if it exists. If you choose 'n' and would like to use
++	  Calgary anyway, pass 'iommu=calgary' on the kernel command line.
++	  If unsure, say Y.
++
++# need this always selected by IOMMU for the VIA workaround
++config SWIOTLB
++	def_bool y if X86_64
++	---help---
++	  Support for software bounce buffers used on x86-64 systems
++	  which don't have a hardware IOMMU. Using this PCI devices
++	  which can only access 32-bits of memory can be used on systems
++	  with more than 3 GB of memory.
++	  If unsure, say Y.
++
++config IOMMU_HELPER
++	def_bool y
++	depends on CALGARY_IOMMU || GART_IOMMU || SWIOTLB || AMD_IOMMU
++
++config MAXSMP
++	bool "Enable Maximum number of SMP Processors and NUMA Nodes"
++	depends on X86_64 && SMP && DEBUG_KERNEL
++	select CPUMASK_OFFSTACK
++	---help---
++	  Enable maximum number of CPUS and NUMA Nodes for this architecture.
++	  If unsure, say N.
++
++config NR_CPUS
++	int "Maximum number of CPUs" if SMP && !MAXSMP
++	range 2 8 if SMP && X86_32 && !X86_BIGSMP
++	range 2 512 if SMP && !MAXSMP
++	default "1" if !SMP
++	default "4096" if MAXSMP
++	default "32" if SMP && (X86_NUMAQ || X86_SUMMIT || X86_BIGSMP || X86_ES7000)
++	default "8" if SMP
++	---help---
++	  This allows you to specify the maximum number of CPUs which this
++	  kernel will support.  The maximum supported value is 512 and the
++	  minimum value which makes sense is 2.
++
++	  This is purely to save memory - each supported CPU adds
++	  approximately eight kilobytes to the kernel image.
++
++config SCHED_SMT
++	bool "SMT (Hyperthreading) scheduler support"
++	depends on X86_HT
++	---help---
++	  SMT scheduler support improves the CPU scheduler's decision making
++	  when dealing with Intel Pentium 4 chips with HyperThreading at a
++	  cost of slightly increased overhead in some places. If unsure say
++	  N here.
++
++config SCHED_MC
++	def_bool y
++	prompt "Multi-core scheduler support"
++	depends on X86_HT
++	---help---
++	  Multi-core scheduler support improves the CPU scheduler's decision
++	  making when dealing with multi-core CPU chips at a cost of slightly
++	  increased overhead in some places. If unsure say N here.
++
++source "kernel/Kconfig.preempt"
++
++config X86_UP_APIC
++	bool "Local APIC support on uniprocessors"
++	depends on X86_32 && !SMP && !X86_32_NON_STANDARD
++	---help---
++	  A local APIC (Advanced Programmable Interrupt Controller) is an
++	  integrated interrupt controller in the CPU. If you have a single-CPU
++	  system which has a processor with a local APIC, you can say Y here to
++	  enable and use it. If you say Y here even though your machine doesn't
++	  have a local APIC, then the kernel will still run with no slowdown at
++	  all. The local APIC supports CPU-generated self-interrupts (timer,
++	  performance counters), and the NMI watchdog which detects hard
++	  lockups.
++
++config X86_UP_IOAPIC
++	bool "IO-APIC support on uniprocessors"
++	depends on X86_UP_APIC
++	---help---
++	  An IO-APIC (I/O Advanced Programmable Interrupt Controller) is an
++	  SMP-capable replacement for PC-style interrupt controllers. Most
++	  SMP systems and many recent uniprocessor systems have one.
++
++	  If you have a single-CPU system with an IO-APIC, you can say Y here
++	  to use it. If you say Y here even though your machine doesn't have
++	  an IO-APIC, then the kernel will still run with no slowdown at all.
++
++config X86_LOCAL_APIC
++	def_bool y
++	depends on X86_64 || SMP || X86_32_NON_STANDARD || X86_UP_APIC
++
++config X86_IO_APIC
++	def_bool y
++	depends on X86_64 || SMP || X86_32_NON_STANDARD || X86_UP_IOAPIC
++
++config X86_VISWS_APIC
++	def_bool y
++	depends on X86_32 && X86_VISWS
++
++config X86_REROUTE_FOR_BROKEN_BOOT_IRQS
++	bool "Reroute for broken boot IRQs"
++	depends on X86_IO_APIC
++	---help---
++	  This option enables a workaround that fixes a source of
++	  spurious interrupts. This is recommended when threaded
++	  interrupt handling is used on systems where the generation of
++	  superfluous "boot interrupts" cannot be disabled.
++
++	  Some chipsets generate a legacy INTx "boot IRQ" when the IRQ
++	  entry in the chipset's IO-APIC is masked (as, e.g. the RT
++	  kernel does during interrupt handling). On chipsets where this
++	  boot IRQ generation cannot be disabled, this workaround keeps
++	  the original IRQ line masked so that only the equivalent "boot
++	  IRQ" is delivered to the CPUs. The workaround also tells the
++	  kernel to set up the IRQ handler on the boot IRQ line. In this
++	  way only one interrupt is delivered to the kernel. Otherwise
++	  the spurious second interrupt may cause the kernel to bring
++	  down (vital) interrupt lines.
++
++	  Only affects "broken" chipsets. Interrupt sharing may be
++	  increased on these systems.
++
++config X86_MCE
++	bool "Machine Check / overheating reporting"
++	default y
++	---help---
++	  Machine Check support allows the processor to notify the
++	  kernel if it detects a problem (e.g. overheating, data corruption).
++	  The action the kernel takes depends on the severity of the problem,
++	  ranging from warning messages to halting the machine.
++
++config X86_MCE_INTEL
++	def_bool y
++	prompt "Intel MCE features"
++	depends on X86_MCE && X86_LOCAL_APIC
++	---help---
++	   Additional support for intel specific MCE features such as
++	   the thermal monitor.
++
++config X86_MCE_AMD
++	def_bool y
++	prompt "AMD MCE features"
++	depends on X86_MCE && X86_LOCAL_APIC
++	---help---
++	   Additional support for AMD specific MCE features such as
++	   the DRAM Error Threshold.
++
++config X86_ANCIENT_MCE
++	bool "Support for old Pentium 5 / WinChip machine checks"
++	depends on X86_32 && X86_MCE
++	---help---
++	  Include support for machine check handling on old Pentium 5 or WinChip
++	  systems. These typically need to be enabled explicitely on the command
++	  line.
++
++config X86_MCE_THRESHOLD
++	depends on X86_MCE_AMD || X86_MCE_INTEL
++	def_bool y
++
++config X86_MCE_INJECT
++	depends on X86_MCE
++	tristate "Machine check injector support"
++	---help---
++	  Provide support for injecting machine checks for testing purposes.
++	  If you don't know what a machine check is and you don't do kernel
++	  QA it is safe to say n.
++
++config X86_THERMAL_VECTOR
++	def_bool y
++	depends on X86_MCE_INTEL
++
++config VM86
++	bool "Enable VM86 support" if EXPERT
++	default y
++	depends on X86_32
++	---help---
++	  This option is required by programs like DOSEMU to run 16-bit legacy
++	  code on X86 processors. It also may be needed by software like
++	  XFree86 to initialize some video cards via BIOS. Disabling this
++	  option saves about 6k.
++
++config TOSHIBA
++	tristate "Toshiba Laptop support"
++	depends on X86_32
++	---help---
++	  This adds a driver to safely access the System Management Mode of
++	  the CPU on Toshiba portables with a genuine Toshiba BIOS. It does
++	  not work on models with a Phoenix BIOS. The System Management Mode
++	  is used to set the BIOS and power saving options on Toshiba portables.
++
++	  For information on utilities to make use of this driver see the
++	  Toshiba Linux utilities web site at:
++	  <http://www.buzzard.org.uk/toshiba/>.
++
++	  Say Y if you intend to run this kernel on a Toshiba portable.
++	  Say N otherwise.
++
++config I8K
++	tristate "Dell laptop support"
++	select HWMON
++	---help---
++	  This adds a driver to safely access the System Management Mode
++	  of the CPU on the Dell Inspiron 8000. The System Management Mode
++	  is used to read cpu temperature and cooling fan status and to
++	  control the fans on the I8K portables.
++
++	  This driver has been tested only on the Inspiron 8000 but it may
++	  also work with other Dell laptops. You can force loading on other
++	  models by passing the parameter `force=1' to the module. Use at
++	  your own risk.
++
++	  For information on utilities to make use of this driver see the
++	  I8K Linux utilities web site at:
++	  <http://people.debian.org/~dz/i8k/>
++
++	  Say Y if you intend to run this kernel on a Dell Inspiron 8000.
++	  Say N otherwise.
++
++config X86_REBOOTFIXUPS
++	bool "Enable X86 board specific fixups for reboot"
++	depends on X86_32
++	---help---
++	  This enables chipset and/or board specific fixups to be done
++	  in order to get reboot to work correctly. This is only needed on
++	  some combinations of hardware and BIOS. The symptom, for which
++	  this config is intended, is when reboot ends with a stalled/hung
++	  system.
++
++	  Currently, the only fixup is for the Geode machines using
++	  CS5530A and CS5536 chipsets and the RDC R-321x SoC.
++
++	  Say Y if you want to enable the fixup. Currently, it's safe to
++	  enable this option even if you don't need it.
++	  Say N otherwise.
++
++config MICROCODE
++	tristate "CPU microcode loading support"
++	select FW_LOADER
++	---help---
++
++	  If you say Y here, you will be able to update the microcode on
++	  certain Intel and AMD processors. The Intel support is for the
++	  IA32 family, e.g. Pentium Pro, Pentium II, Pentium III, Pentium 4,
++	  Xeon etc. The AMD support is for families 0x10 and later. You will
++	  obviously need the actual microcode binary data itself which is not
++	  shipped with the Linux kernel.
++
++	  This option selects the general module only, you need to select
++	  at least one vendor specific module as well.
++
++	  To compile this driver as a module, choose M here: the module
++	  will be called microcode.
++
++config MICROCODE_INTEL
++	bool "Intel microcode loading support"
++	depends on MICROCODE
++	default MICROCODE
++	select FW_LOADER
++	---help---
++	  This options enables microcode patch loading support for Intel
++	  processors.
++
++	  For latest news and information on obtaining all the required
++	  Intel ingredients for this driver, check:
++	  <http://www.urbanmyth.org/microcode/>.
++
++config MICROCODE_AMD
++	bool "AMD microcode loading support"
++	depends on MICROCODE
++	select FW_LOADER
++	---help---
++	  If you select this option, microcode patch loading support for AMD
++	  processors will be enabled.
++
++config MICROCODE_OLD_INTERFACE
++	def_bool y
++	depends on MICROCODE
++
++config MICROCODE_INTEL_LIB
++	def_bool y
++	depends on MICROCODE_INTEL
++
++config MICROCODE_INTEL_EARLY
++	bool "Early load microcode"
++	depends on MICROCODE_INTEL && BLK_DEV_INITRD
++	default y
++	help
++	  This option provides functionality to read additional microcode data
++	  at the beginning of initrd image. The data tells kernel to load
++	  microcode to CPU's as early as possible. No functional change if no
++	  microcode data is glued to the initrd, therefore it's safe to say Y.
++
++config MICROCODE_EARLY
++	def_bool y
++	depends on MICROCODE_INTEL_EARLY
++
++config X86_MSR
++	tristate "/dev/cpu/*/msr - Model-specific register support"
++	---help---
++	  This device gives privileged processes access to the x86
++	  Model-Specific Registers (MSRs).  It is a character device with
++	  major 202 and minors 0 to 31 for /dev/cpu/0/msr to /dev/cpu/31/msr.
++	  MSR accesses are directed to a specific CPU on multi-processor
++	  systems.
++
++config X86_CPUID
++	tristate "/dev/cpu/*/cpuid - CPU information support"
++	---help---
++	  This device gives processes access to the x86 CPUID instruction to
++	  be executed on a specific processor.  It is a character device
++	  with major 203 and minors 0 to 31 for /dev/cpu/0/cpuid to
++	  /dev/cpu/31/cpuid.
++
++choice
++	prompt "High Memory Support"
++	default HIGHMEM64G if X86_NUMAQ
++	default HIGHMEM4G
++	depends on X86_32
++
++config NOHIGHMEM
++	bool "off"
++	depends on !X86_NUMAQ
++	---help---
++	  Linux can use up to 64 Gigabytes of physical memory on x86 systems.
++	  However, the address space of 32-bit x86 processors is only 4
++	  Gigabytes large. That means that, if you have a large amount of
++	  physical memory, not all of it can be "permanently mapped" by the
++	  kernel. The physical memory that's not permanently mapped is called
++	  "high memory".
++
++	  If you are compiling a kernel which will never run on a machine with
++	  more than 1 Gigabyte total physical RAM, answer "off" here (default
++	  choice and suitable for most users). This will result in a "3GB/1GB"
++	  split: 3GB are mapped so that each process sees a 3GB virtual memory
++	  space and the remaining part of the 4GB virtual memory space is used
++	  by the kernel to permanently map as much physical memory as
++	  possible.
++
++	  If the machine has between 1 and 4 Gigabytes physical RAM, then
++	  answer "4GB" here.
++
++	  If more than 4 Gigabytes is used then answer "64GB" here. This
++	  selection turns Intel PAE (Physical Address Extension) mode on.
++	  PAE implements 3-level paging on IA32 processors. PAE is fully
++	  supported by Linux, PAE mode is implemented on all recent Intel
++	  processors (Pentium Pro and better). NOTE: If you say "64GB" here,
++	  then the kernel will not boot on CPUs that don't support PAE!
++
++	  The actual amount of total physical memory will either be
++	  auto detected or can be forced by using a kernel command line option
++	  such as "mem=256M". (Try "man bootparam" or see the documentation of
++	  your boot loader (lilo or loadlin) about how to pass options to the
++	  kernel at boot time.)
++
++	  If unsure, say "off".
++
++config HIGHMEM4G
++	bool "4GB"
++	depends on !X86_NUMAQ
++	---help---
++	  Select this if you have a 32-bit processor and between 1 and 4
++	  gigabytes of physical RAM.
++
++config HIGHMEM64G
++	bool "64GB"
++	depends on !M486
++	select X86_PAE
++	---help---
++	  Select this if you have a 32-bit processor and more than 4
++	  gigabytes of physical RAM.
++
++endchoice
++
++choice
++	prompt "Memory split" if EXPERT
++	default VMSPLIT_3G
++	depends on X86_32
++	---help---
++	  Select the desired split between kernel and user memory.
++
++	  If the address range available to the kernel is less than the
++	  physical memory installed, the remaining memory will be available
++	  as "high memory". Accessing high memory is a little more costly
++	  than low memory, as it needs to be mapped into the kernel first.
++	  Note that increasing the kernel address space limits the range
++	  available to user programs, making the address space there
++	  tighter.  Selecting anything other than the default 3G/1G split
++	  will also likely make your kernel incompatible with binary-only
++	  kernel modules.
++
++	  If you are not absolutely sure what you are doing, leave this
++	  option alone!
++
++	config VMSPLIT_3G
++		bool "3G/1G user/kernel split"
++	config VMSPLIT_3G_OPT
++		depends on !X86_PAE
++		bool "3G/1G user/kernel split (for full 1G low memory)"
++	config VMSPLIT_2G
++		bool "2G/2G user/kernel split"
++	config VMSPLIT_2G_OPT
++		depends on !X86_PAE
++		bool "2G/2G user/kernel split (for full 2G low memory)"
++	config VMSPLIT_1G
++		bool "1G/3G user/kernel split"
++endchoice
++
++config PAGE_OFFSET
++	hex
++	default 0xB0000000 if VMSPLIT_3G_OPT
++	default 0x80000000 if VMSPLIT_2G
++	default 0x78000000 if VMSPLIT_2G_OPT
++	default 0x40000000 if VMSPLIT_1G
++	default 0xC0000000
++	depends on X86_32
++
++config HIGHMEM
++	def_bool y
++	depends on X86_32 && (HIGHMEM64G || HIGHMEM4G)
++
++config X86_PAE
++	bool "PAE (Physical Address Extension) Support"
++	depends on X86_32 && !HIGHMEM4G
++	---help---
++	  PAE is required for NX support, and furthermore enables
++	  larger swapspace support for non-overcommit purposes. It
++	  has the cost of more pagetable lookup overhead, and also
++	  consumes more pagetable space per process.
++
++config ARCH_PHYS_ADDR_T_64BIT
++	def_bool y
++	depends on X86_64 || X86_PAE
++
++config ARCH_DMA_ADDR_T_64BIT
++	def_bool y
++	depends on X86_64 || HIGHMEM64G
++
++config DIRECT_GBPAGES
++	bool "Enable 1GB pages for kernel pagetables" if EXPERT
++	default y
++	depends on X86_64
++	---help---
++	  Allow the kernel linear mapping to use 1GB pages on CPUs that
++	  support it. This can improve the kernel's performance a tiny bit by
++	  reducing TLB pressure. If in doubt, say "Y".
++
++# Common NUMA Features
++config NUMA
++	bool "Numa Memory Allocation and Scheduler Support"
++	depends on SMP
++	depends on X86_64 || (X86_32 && HIGHMEM64G && (X86_NUMAQ || X86_BIGSMP || X86_SUMMIT && ACPI))
++	default y if (X86_NUMAQ || X86_SUMMIT || X86_BIGSMP)
++	---help---
++	  Enable NUMA (Non Uniform Memory Access) support.
++
++	  The kernel will try to allocate memory used by a CPU on the
++	  local memory controller of the CPU and add some more
++	  NUMA awareness to the kernel.
++
++	  For 64-bit this is recommended if the system is Intel Core i7
++	  (or later), AMD Opteron, or EM64T NUMA.
++
++	  For 32-bit this is only needed on (rare) 32-bit-only platforms
++	  that support NUMA topologies, such as NUMAQ / Summit, or if you
++	  boot a 32-bit kernel on a 64-bit NUMA platform.
++
++	  Otherwise, you should say N.
++
++comment "NUMA (Summit) requires SMP, 64GB highmem support, ACPI"
++	depends on X86_32 && X86_SUMMIT && (!HIGHMEM64G || !ACPI)
++
++config AMD_NUMA
++	def_bool y
++	prompt "Old style AMD Opteron NUMA detection"
++	depends on X86_64 && NUMA && PCI
++	---help---
++	  Enable AMD NUMA node topology detection.  You should say Y here if
++	  you have a multi processor AMD system. This uses an old method to
++	  read the NUMA configuration directly from the builtin Northbridge
++	  of Opteron. It is recommended to use X86_64_ACPI_NUMA instead,
++	  which also takes priority if both are compiled in.
++
++config X86_64_ACPI_NUMA
++	def_bool y
++	prompt "ACPI NUMA detection"
++	depends on X86_64 && NUMA && ACPI && PCI
++	select ACPI_NUMA
++	---help---
++	  Enable ACPI SRAT based node topology detection.
++
++# Some NUMA nodes have memory ranges that span
++# other nodes.  Even though a pfn is valid and
++# between a node's start and end pfns, it may not
++# reside on that node.  See memmap_init_zone()
++# for details.
++config NODES_SPAN_OTHER_NODES
++	def_bool y
++	depends on X86_64_ACPI_NUMA
++
++config NUMA_EMU
++	bool "NUMA emulation"
++	depends on NUMA
++	---help---
++	  Enable NUMA emulation. A flat machine will be split
++	  into virtual nodes when booted with "numa=fake=N", where N is the
++	  number of nodes. This is only useful for debugging.
++
++config NODES_SHIFT
++	int "Maximum NUMA Nodes (as a power of 2)" if !MAXSMP
++	range 1 10
++	default "10" if MAXSMP
++	default "6" if X86_64
++	default "4" if X86_NUMAQ
++	default "3"
++	depends on NEED_MULTIPLE_NODES
++	---help---
++	  Specify the maximum number of NUMA Nodes available on the target
++	  system.  Increases memory reserved to accommodate various tables.
++
++config ARCH_HAVE_MEMORY_PRESENT
++	def_bool y
++	depends on X86_32 && DISCONTIGMEM
++
++config NEED_NODE_MEMMAP_SIZE
++	def_bool y
++	depends on X86_32 && (DISCONTIGMEM || SPARSEMEM)
++
++config ARCH_FLATMEM_ENABLE
++	def_bool y
++	depends on X86_32 && !NUMA
++
++config ARCH_DISCONTIGMEM_ENABLE
++	def_bool y
++	depends on NUMA && X86_32
++
++config ARCH_DISCONTIGMEM_DEFAULT
++	def_bool y
++	depends on NUMA && X86_32
++
++config ARCH_SPARSEMEM_ENABLE
++	def_bool y
++	depends on X86_64 || NUMA || X86_32 || X86_32_NON_STANDARD
++	select SPARSEMEM_STATIC if X86_32
++	select SPARSEMEM_VMEMMAP_ENABLE if X86_64
++
++config ARCH_SPARSEMEM_DEFAULT
++	def_bool y
++	depends on X86_64
++
++config ARCH_SELECT_MEMORY_MODEL
++	def_bool y
++	depends on ARCH_SPARSEMEM_ENABLE
++
++config ARCH_MEMORY_PROBE
++	def_bool y
++	depends on X86_64 && MEMORY_HOTPLUG
++
++config ARCH_PROC_KCORE_TEXT
++	def_bool y
++	depends on X86_64 && PROC_KCORE
++
++config ILLEGAL_POINTER_VALUE
++       hex
++       default 0 if X86_32
++       default 0xdead000000000000 if X86_64
++
++source "mm/Kconfig"
++
++config HIGHPTE
++	bool "Allocate 3rd-level pagetables from highmem"
++	depends on HIGHMEM
++	---help---
++	  The VM uses one page table entry for each page of physical memory.
++	  For systems with a lot of RAM, this can be wasteful of precious
++	  low memory.  Setting this option will put user-space page table
++	  entries in high memory.
++
++config X86_CHECK_BIOS_CORRUPTION
++	bool "Check for low memory corruption"
++	---help---
++	  Periodically check for memory corruption in low memory, which
++	  is suspected to be caused by BIOS.  Even when enabled in the
++	  configuration, it is disabled at runtime.  Enable it by
++	  setting "memory_corruption_check=1" on the kernel command
++	  line.  By default it scans the low 64k of memory every 60
++	  seconds; see the memory_corruption_check_size and
++	  memory_corruption_check_period parameters in
++	  Documentation/kernel-parameters.txt to adjust this.
++
++	  When enabled with the default parameters, this option has
++	  almost no overhead, as it reserves a relatively small amount
++	  of memory and scans it infrequently.  It both detects corruption
++	  and prevents it from affecting the running system.
++
++	  It is, however, intended as a diagnostic tool; if repeatable
++	  BIOS-originated corruption always affects the same memory,
++	  you can use memmap= to prevent the kernel from using that
++	  memory.
++
++config X86_BOOTPARAM_MEMORY_CORRUPTION_CHECK
++	bool "Set the default setting of memory_corruption_check"
++	depends on X86_CHECK_BIOS_CORRUPTION
++	default y
++	---help---
++	  Set whether the default state of memory_corruption_check is
++	  on or off.
++
++config X86_RESERVE_LOW
++	int "Amount of low memory, in kilobytes, to reserve for the BIOS"
++	default 64
++	range 4 640
++	---help---
++	  Specify the amount of low memory to reserve for the BIOS.
++
++	  The first page contains BIOS data structures that the kernel
++	  must not use, so that page must always be reserved.
++
++	  By default we reserve the first 64K of physical RAM, as a
++	  number of BIOSes are known to corrupt that memory range
++	  during events such as suspend/resume or monitor cable
++	  insertion, so it must not be used by the kernel.
++
++	  You can set this to 4 if you are absolutely sure that you
++	  trust the BIOS to get all its memory reservations and usages
++	  right.  If you know your BIOS have problems beyond the
++	  default 64K area, you can set this to 640 to avoid using the
++	  entire low memory range.
++
++	  If you have doubts about the BIOS (e.g. suspend/resume does
++	  not work or there's kernel crashes after certain hardware
++	  hotplug events) then you might want to enable
++	  X86_CHECK_BIOS_CORRUPTION=y to allow the kernel to check
++	  typical corruption patterns.
++
++	  Leave this to the default value of 64 if you are unsure.
++
++config MATH_EMULATION
++	bool
++	prompt "Math emulation" if X86_32
++	---help---
++	  Linux can emulate a math coprocessor (used for floating point
++	  operations) if you don't have one. 486DX and Pentium processors have
++	  a math coprocessor built in, 486SX and 386 do not, unless you added
++	  a 487DX or 387, respectively. (The messages during boot time can
++	  give you some hints here ["man dmesg"].) Everyone needs either a
++	  coprocessor or this emulation.
++
++	  If you don't have a math coprocessor, you need to say Y here; if you
++	  say Y here even though you have a coprocessor, the coprocessor will
++	  be used nevertheless. (This behavior can be changed with the kernel
++	  command line option "no387", which comes handy if your coprocessor
++	  is broken. Try "man bootparam" or see the documentation of your boot
++	  loader (lilo or loadlin) about how to pass options to the kernel at
++	  boot time.) This means that it is a good idea to say Y here if you
++	  intend to use this kernel on different machines.
++
++	  More information about the internals of the Linux math coprocessor
++	  emulation can be found in <file:arch/x86/math-emu/README>.
++
++	  If you are not sure, say Y; apart from resulting in a 66 KB bigger
++	  kernel, it won't hurt.
++
++config MTRR
++	def_bool y
++	prompt "MTRR (Memory Type Range Register) support" if EXPERT
++	---help---
++	  On Intel P6 family processors (Pentium Pro, Pentium II and later)
++	  the Memory Type Range Registers (MTRRs) may be used to control
++	  processor access to memory ranges. This is most useful if you have
++	  a video (VGA) card on a PCI or AGP bus. Enabling write-combining
++	  allows bus write transfers to be combined into a larger transfer
++	  before bursting over the PCI/AGP bus. This can increase performance
++	  of image write operations 2.5 times or more. Saying Y here creates a
++	  /proc/mtrr file which may be used to manipulate your processor's
++	  MTRRs. Typically the X server should use this.
++
++	  This code has a reasonably generic interface so that similar
++	  control registers on other processors can be easily supported
++	  as well:
++
++	  The Cyrix 6x86, 6x86MX and M II processors have Address Range
++	  Registers (ARRs) which provide a similar functionality to MTRRs. For
++	  these, the ARRs are used to emulate the MTRRs.
++	  The AMD K6-2 (stepping 8 and above) and K6-3 processors have two
++	  MTRRs. The Centaur C6 (WinChip) has 8 MCRs, allowing
++	  write-combining. All of these processors are supported by this code
++	  and it makes sense to say Y here if you have one of them.
++
++	  Saying Y here also fixes a problem with buggy SMP BIOSes which only
++	  set the MTRRs for the boot CPU and not for the secondary CPUs. This
++	  can lead to all sorts of problems, so it's good to say Y here.
++
++	  You can safely say Y even if your machine doesn't have MTRRs, you'll
++	  just add about 9 KB to your kernel.
++
++	  See <file:Documentation/x86/mtrr.txt> for more information.
++
++config MTRR_SANITIZER
++	def_bool y
++	prompt "MTRR cleanup support"
++	depends on MTRR
++	---help---
++	  Convert MTRR layout from continuous to discrete, so X drivers can
++	  add writeback entries.
++
++	  Can be disabled with disable_mtrr_cleanup on the kernel command line.
++	  The largest mtrr entry size for a continuous block can be set with
++	  mtrr_chunk_size.
++
++	  If unsure, say Y.
++
++config MTRR_SANITIZER_ENABLE_DEFAULT
++	int "MTRR cleanup enable value (0-1)"
++	range 0 1
++	default "0"
++	depends on MTRR_SANITIZER
++	---help---
++	  Enable mtrr cleanup default value
++
++config MTRR_SANITIZER_SPARE_REG_NR_DEFAULT
++	int "MTRR cleanup spare reg num (0-7)"
++	range 0 7
++	default "1"
++	depends on MTRR_SANITIZER
++	---help---
++	  mtrr cleanup spare entries default, it can be changed via
++	  mtrr_spare_reg_nr=N on the kernel command line.
++
++config X86_PAT
++	def_bool y
++	prompt "x86 PAT support" if EXPERT
++	depends on MTRR
++	---help---
++	  Use PAT attributes to setup page level cache control.
++
++	  PATs are the modern equivalents of MTRRs and are much more
++	  flexible than MTRRs.
++
++	  Say N here if you see bootup problems (boot crash, boot hang,
++	  spontaneous reboots) or a non-working video driver.
++
++	  If unsure, say Y.
++
++config ARCH_USES_PG_UNCACHED
++	def_bool y
++	depends on X86_PAT
++
++config ARCH_RANDOM
++	def_bool y
++	prompt "x86 architectural random number generator" if EXPERT
++	---help---
++	  Enable the x86 architectural RDRAND instruction
++	  (Intel Bull Mountain technology) to generate random numbers.
++	  If supported, this is a high bandwidth, cryptographically
++	  secure hardware random number generator.
++
++config X86_SMAP
++	def_bool y
++	prompt "Supervisor Mode Access Prevention" if EXPERT
++	---help---
++	  Supervisor Mode Access Prevention (SMAP) is a security
++	  feature in newer Intel processors.  There is a small
++	  performance cost if this enabled and turned on; there is
++	  also a small increase in the kernel size if this is enabled.
++
++	  If unsure, say Y.
++
++config EFI
++	bool "EFI runtime service support"
++	depends on ACPI
++	select UCS2_STRING
++	---help---
++	  This enables the kernel to use EFI runtime services that are
++	  available (such as the EFI variable services).
++
++	  This option is only useful on systems that have EFI firmware.
++	  In addition, you should use the latest ELILO loader available
++	  at <http://elilo.sourceforge.net> in order to take advantage
++	  of EFI runtime services. However, even with this option, the
++	  resultant kernel should continue to boot on existing non-EFI
++	  platforms.
++
++config EFI_STUB
++       bool "EFI stub support"
++       depends on EFI
++       ---help---
++          This kernel feature allows a bzImage to be loaded directly
++	  by EFI firmware without the use of a bootloader.
++
++	  See Documentation/x86/efi-stub.txt for more information.
++
++config SECCOMP
++	def_bool y
++	prompt "Enable seccomp to safely compute untrusted bytecode"
++	---help---
++	  This kernel feature is useful for number crunching applications
++	  that may need to compute untrusted bytecode during their
++	  execution. By using pipes or other transports made available to
++	  the process as file descriptors supporting the read/write
++	  syscalls, it's possible to isolate those applications in
++	  their own address space using seccomp. Once seccomp is
++	  enabled via prctl(PR_SET_SECCOMP), it cannot be disabled
++	  and the task is only allowed to execute a few safe syscalls
++	  defined by each seccomp mode.
++
++	  If unsure, say Y. Only embedded should say N here.
++
++config CC_STACKPROTECTOR
++	bool "Enable -fstack-protector buffer overflow detection"
++	---help---
++	  This option turns on the -fstack-protector GCC feature. This
++	  feature puts, at the beginning of functions, a canary value on
++	  the stack just before the return address, and validates
++	  the value just before actually returning.  Stack based buffer
++	  overflows (that need to overwrite this return address) now also
++	  overwrite the canary, which gets detected and the attack is then
++	  neutralized via a kernel panic.
++
++	  This feature requires gcc version 4.2 or above, or a distribution
++	  gcc with the feature backported. Older versions are automatically
++	  detected and for those versions, this configuration option is
++	  ignored. (and a warning is printed during bootup)
++
++source kernel/Kconfig.hz
++
++config KEXEC
++	bool "kexec system call"
++	---help---
++	  kexec is a system call that implements the ability to shutdown your
++	  current kernel, and to start another kernel.  It is like a reboot
++	  but it is independent of the system firmware.   And like a reboot
++	  you can start any kernel with it, not just Linux.
++
++	  The name comes from the similarity to the exec system call.
++
++	  It is an ongoing process to be certain the hardware in a machine
++	  is properly shutdown, so do not be surprised if this code does not
++	  initially work for you.  It may help to enable device hotplugging
++	  support.  As of this writing the exact hardware interface is
++	  strongly in flux, so no good recommendation can be made.
++
++config CRASH_DUMP
++	bool "kernel crash dumps"
++	depends on X86_64 || (X86_32 && HIGHMEM)
++	---help---
++	  Generate crash dump after being started by kexec.
++	  This should be normally only set in special crash dump kernels
++	  which are loaded in the main kernel with kexec-tools into
++	  a specially reserved region and then later executed after
++	  a crash by kdump/kexec. The crash dump kernel must be compiled
++	  to a memory address not used by the main kernel or BIOS using
++	  PHYSICAL_START, or it must be built as a relocatable image
++	  (CONFIG_RELOCATABLE=y).
++	  For more details see Documentation/kdump/kdump.txt
++
++config KEXEC_JUMP
++	bool "kexec jump"
++	depends on KEXEC && HIBERNATION
++	---help---
++	  Jump between original kernel and kexeced kernel and invoke
++	  code in physical address mode via KEXEC
++
++config PHYSICAL_START
++	hex "Physical address where the kernel is loaded" if (EXPERT || CRASH_DUMP)
++	default "0x1000000"
++	---help---
++	  This gives the physical address where the kernel is loaded.
++
++	  If kernel is a not relocatable (CONFIG_RELOCATABLE=n) then
++	  bzImage will decompress itself to above physical address and
++	  run from there. Otherwise, bzImage will run from the address where
++	  it has been loaded by the boot loader and will ignore above physical
++	  address.
++
++	  In normal kdump cases one does not have to set/change this option
++	  as now bzImage can be compiled as a completely relocatable image
++	  (CONFIG_RELOCATABLE=y) and be used to load and run from a different
++	  address. This option is mainly useful for the folks who don't want
++	  to use a bzImage for capturing the crash dump and want to use a
++	  vmlinux instead. vmlinux is not relocatable hence a kernel needs
++	  to be specifically compiled to run from a specific memory area
++	  (normally a reserved region) and this option comes handy.
++
++	  So if you are using bzImage for capturing the crash dump,
++	  leave the value here unchanged to 0x1000000 and set
++	  CONFIG_RELOCATABLE=y.  Otherwise if you plan to use vmlinux
++	  for capturing the crash dump change this value to start of
++	  the reserved region.  In other words, it can be set based on
++	  the "X" value as specified in the "crashkernel=YM@XM"
++	  command line boot parameter passed to the panic-ed
++	  kernel. Please take a look at Documentation/kdump/kdump.txt
++	  for more details about crash dumps.
++
++	  Usage of bzImage for capturing the crash dump is recommended as
++	  one does not have to build two kernels. Same kernel can be used
++	  as production kernel and capture kernel. Above option should have
++	  gone away after relocatable bzImage support is introduced. But it
++	  is present because there are users out there who continue to use
++	  vmlinux for dump capture. This option should go away down the
++	  line.
++
++	  Don't change this unless you know what you are doing.
++
++config RELOCATABLE
++	bool "Build a relocatable kernel"
++	default y
++	---help---
++	  This builds a kernel image that retains relocation information
++	  so it can be loaded someplace besides the default 1MB.
++	  The relocations tend to make the kernel binary about 10% larger,
++	  but are discarded at runtime.
++
++	  One use is for the kexec on panic case where the recovery kernel
++	  must live at a different physical address than the primary
++	  kernel.
++
++	  Note: If CONFIG_RELOCATABLE=y, then the kernel runs from the address
++	  it has been loaded at and the compile time physical address
++	  (CONFIG_PHYSICAL_START) is ignored.
++
++# Relocation on x86-32 needs some additional build support
++config X86_NEED_RELOCS
++	def_bool y
++	depends on X86_32 && RELOCATABLE
++
++config PHYSICAL_ALIGN
++	hex "Alignment value to which kernel should be aligned" if X86_32
++	default "0x1000000"
++	range 0x2000 0x1000000
++	---help---
++	  This value puts the alignment restrictions on physical address
++	  where kernel is loaded and run from. Kernel is compiled for an
++	  address which meets above alignment restriction.
++
++	  If bootloader loads the kernel at a non-aligned address and
++	  CONFIG_RELOCATABLE is set, kernel will move itself to nearest
++	  address aligned to above value and run from there.
++
++	  If bootloader loads the kernel at a non-aligned address and
++	  CONFIG_RELOCATABLE is not set, kernel will ignore the run time
++	  load address and decompress itself to the address it has been
++	  compiled for and run from there. The address for which kernel is
++	  compiled already meets above alignment restrictions. Hence the
++	  end result is that kernel runs from a physical address meeting
++	  above alignment restrictions.
++
++	  Don't change this unless you know what you are doing.
++
++config HOTPLUG_CPU
++	bool "Support for hot-pluggable CPUs"
++	depends on SMP && HOTPLUG
++	---help---
++	  Say Y here to allow turning CPUs off and on. CPUs can be
++	  controlled through /sys/devices/system/cpu.
++	  ( Note: power management support will enable this option
++	    automatically on SMP systems. )
++	  Say N if you want to disable CPU hotplug.
++
++config BOOTPARAM_HOTPLUG_CPU0
++	bool "Set default setting of cpu0_hotpluggable"
++	default n
++	depends on HOTPLUG_CPU
++	---help---
++	  Set whether default state of cpu0_hotpluggable is on or off.
++
++	  Say Y here to enable CPU0 hotplug by default. If this switch
++	  is turned on, there is no need to give cpu0_hotplug kernel
++	  parameter and the CPU0 hotplug feature is enabled by default.
++
++	  Please note: there are two known CPU0 dependencies if you want
++	  to enable the CPU0 hotplug feature either by this switch or by
++	  cpu0_hotplug kernel parameter.
++
++	  First, resume from hibernate or suspend always starts from CPU0.
++	  So hibernate and suspend are prevented if CPU0 is offline.
++
++	  Second dependency is PIC interrupts always go to CPU0. CPU0 can not
++	  offline if any interrupt can not migrate out of CPU0. There may
++	  be other CPU0 dependencies.
++
++	  Please make sure the dependencies are under your control before
++	  you enable this feature.
++
++	  Say N if you don't want to enable CPU0 hotplug feature by default.
++	  You still can enable the CPU0 hotplug feature at boot by kernel
++	  parameter cpu0_hotplug.
++
++config DEBUG_HOTPLUG_CPU0
++	def_bool n
++	prompt "Debug CPU0 hotplug"
++	depends on HOTPLUG_CPU
++	---help---
++	  Enabling this option offlines CPU0 (if CPU0 can be offlined) as
++	  soon as possible and boots up userspace with CPU0 offlined. User
++	  can online CPU0 back after boot time.
++
++	  To debug CPU0 hotplug, you need to enable CPU0 offline/online
++	  feature by either turning on CONFIG_BOOTPARAM_HOTPLUG_CPU0 during
++	  compilation or giving cpu0_hotplug kernel parameter at boot.
++
++	  If unsure, say N.
++
++config COMPAT_VDSO
++	def_bool y
++	prompt "Compat VDSO support"
++	depends on X86_32 || IA32_EMULATION
++	---help---
++	  Map the 32-bit VDSO to the predictable old-style address too.
++
++	  Say N here if you are running a sufficiently recent glibc
++	  version (2.3.3 or later), to remove the high-mapped
++	  VDSO mapping and to exclusively use the randomized VDSO.
++
++	  If unsure, say Y.
++
++config CMDLINE_BOOL
++	bool "Built-in kernel command line"
++	---help---
++	  Allow for specifying boot arguments to the kernel at
++	  build time.  On some systems (e.g. embedded ones), it is
++	  necessary or convenient to provide some or all of the
++	  kernel boot arguments with the kernel itself (that is,
++	  to not rely on the boot loader to provide them.)
++
++	  To compile command line arguments into the kernel,
++	  set this option to 'Y', then fill in the
++	  the boot arguments in CONFIG_CMDLINE.
++
++	  Systems with fully functional boot loaders (i.e. non-embedded)
++	  should leave this option set to 'N'.
++
++config CMDLINE
++	string "Built-in kernel command string"
++	depends on CMDLINE_BOOL
++	default ""
++	---help---
++	  Enter arguments here that should be compiled into the kernel
++	  image and used at boot time.  If the boot loader provides a
++	  command line at boot time, it is appended to this string to
++	  form the full kernel command line, when the system boots.
++
++	  However, you can use the CONFIG_CMDLINE_OVERRIDE option to
++	  change this behavior.
++
++	  In most cases, the command line (whether built-in or provided
++	  by the boot loader) should specify the device for the root
++	  file system.
++
++config CMDLINE_OVERRIDE
++	bool "Built-in command line overrides boot loader arguments"
++	depends on CMDLINE_BOOL
++	---help---
++	  Set this option to 'Y' to have the kernel ignore the boot loader
++	  command line, and use ONLY the built-in command line.
++
++	  This is used to work around broken boot loaders.  This should
++	  be set to 'N' under normal conditions.
++
++endmenu
++
++config ARCH_ENABLE_MEMORY_HOTPLUG
++	def_bool y
++	depends on X86_64 || (X86_32 && HIGHMEM)
++
++config ARCH_ENABLE_MEMORY_HOTREMOVE
++	def_bool y
++	depends on MEMORY_HOTPLUG
++
++config USE_PERCPU_NUMA_NODE_ID
++	def_bool y
++	depends on NUMA
++
++menu "Power management and ACPI options"
++
++config ARCH_HIBERNATION_HEADER
++	def_bool y
++	depends on X86_64 && HIBERNATION
++
++source "kernel/power/Kconfig"
++
++source "drivers/acpi/Kconfig"
++
++source "drivers/sfi/Kconfig"
++
++config X86_APM_BOOT
++	def_bool y
++	depends on APM
++
++menuconfig APM
++	tristate "APM (Advanced Power Management) BIOS support"
++	depends on X86_32 && PM_SLEEP
++	---help---
++	  APM is a BIOS specification for saving power using several different
++	  techniques. This is mostly useful for battery powered laptops with
++	  APM compliant BIOSes. If you say Y here, the system time will be
++	  reset after a RESUME operation, the /proc/apm device will provide
++	  battery status information, and user-space programs will receive
++	  notification of APM "events" (e.g. battery status change).
++
++	  If you select "Y" here, you can disable actual use of the APM
++	  BIOS by passing the "apm=off" option to the kernel at boot time.
++
++	  Note that the APM support is almost completely disabled for
++	  machines with more than one CPU.
++
++	  In order to use APM, you will need supporting software. For location
++	  and more information, read <file:Documentation/power/apm-acpi.txt>
++	  and the Battery Powered Linux mini-HOWTO, available from
++	  <http://www.tldp.org/docs.html#howto>.
++
++	  This driver does not spin down disk drives (see the hdparm(8)
++	  manpage ("man 8 hdparm") for that), and it doesn't turn off
++	  VESA-compliant "green" monitors.
++
++	  This driver does not support the TI 4000M TravelMate and the ACER
++	  486/DX4/75 because they don't have compliant BIOSes. Many "green"
++	  desktop machines also don't have compliant BIOSes, and this driver
++	  may cause those machines to panic during the boot phase.
++
++	  Generally, if you don't have a battery in your machine, there isn't
++	  much point in using this driver and you should say N. If you get
++	  random kernel OOPSes or reboots that don't seem to be related to
++	  anything, try disabling/enabling this option (or disabling/enabling
++	  APM in your BIOS).
++
++	  Some other things you should try when experiencing seemingly random,
++	  "weird" problems:
++
++	  1) make sure that you have enough swap space and that it is
++	  enabled.
++	  2) pass the "no-hlt" option to the kernel
++	  3) switch on floating point emulation in the kernel and pass
++	  the "no387" option to the kernel
++	  4) pass the "floppy=nodma" option to the kernel
++	  5) pass the "mem=4M" option to the kernel (thereby disabling
++	  all but the first 4 MB of RAM)
++	  6) make sure that the CPU is not over clocked.
++	  7) read the sig11 FAQ at <http://www.bitwizard.nl/sig11/>
++	  8) disable the cache from your BIOS settings
++	  9) install a fan for the video card or exchange video RAM
++	  10) install a better fan for the CPU
++	  11) exchange RAM chips
++	  12) exchange the motherboard.
++
++	  To compile this driver as a module, choose M here: the
++	  module will be called apm.
++
++if APM
++
++config APM_IGNORE_USER_SUSPEND
++	bool "Ignore USER SUSPEND"
++	---help---
++	  This option will ignore USER SUSPEND requests. On machines with a
++	  compliant APM BIOS, you want to say N. However, on the NEC Versa M
++	  series notebooks, it is necessary to say Y because of a BIOS bug.
++
++config APM_DO_ENABLE
++	bool "Enable PM at boot time"
++	---help---
++	  Enable APM features at boot time. From page 36 of the APM BIOS
++	  specification: "When disabled, the APM BIOS does not automatically
++	  power manage devices, enter the Standby State, enter the Suspend
++	  State, or take power saving steps in response to CPU Idle calls."
++	  This driver will make CPU Idle calls when Linux is idle (unless this
++	  feature is turned off -- see "Do CPU IDLE calls", below). This
++	  should always save battery power, but more complicated APM features
++	  will be dependent on your BIOS implementation. You may need to turn
++	  this option off if your computer hangs at boot time when using APM
++	  support, or if it beeps continuously instead of suspending. Turn
++	  this off if you have a NEC UltraLite Versa 33/C or a Toshiba
++	  T400CDT. This is off by default since most machines do fine without
++	  this feature.
++
++config APM_CPU_IDLE
++	depends on CPU_IDLE
++	bool "Make CPU Idle calls when idle"
++	---help---
++	  Enable calls to APM CPU Idle/CPU Busy inside the kernel's idle loop.
++	  On some machines, this can activate improved power savings, such as
++	  a slowed CPU clock rate, when the machine is idle. These idle calls
++	  are made after the idle loop has run for some length of time (e.g.,
++	  333 mS). On some machines, this will cause a hang at boot time or
++	  whenever the CPU becomes idle. (On machines with more than one CPU,
++	  this option does nothing.)
++
++config APM_DISPLAY_BLANK
++	bool "Enable console blanking using APM"
++	---help---
++	  Enable console blanking using the APM. Some laptops can use this to
++	  turn off the LCD backlight when the screen blanker of the Linux
++	  virtual console blanks the screen. Note that this is only used by
++	  the virtual console screen blanker, and won't turn off the backlight
++	  when using the X Window system. This also doesn't have anything to
++	  do with your VESA-compliant power-saving monitor. Further, this
++	  option doesn't work for all laptops -- it might not turn off your
++	  backlight at all, or it might print a lot of errors to the console,
++	  especially if you are using gpm.
++
++config APM_ALLOW_INTS
++	bool "Allow interrupts during APM BIOS calls"
++	---help---
++	  Normally we disable external interrupts while we are making calls to
++	  the APM BIOS as a measure to lessen the effects of a badly behaving
++	  BIOS implementation.  The BIOS should reenable interrupts if it
++	  needs to.  Unfortunately, some BIOSes do not -- especially those in
++	  many of the newer IBM Thinkpads.  If you experience hangs when you
++	  suspend, try setting this to Y.  Otherwise, say N.
++
++endif # APM
++
++source "drivers/cpufreq/Kconfig"
++
++source "drivers/cpuidle/Kconfig"
++
++source "drivers/idle/Kconfig"
++
++endmenu
++
++
++menu "Bus options (PCI etc.)"
++
++config PCI
++	bool "PCI support"
++	default y
++	select ARCH_SUPPORTS_MSI if (X86_LOCAL_APIC && X86_IO_APIC)
++	---help---
++	  Find out whether you have a PCI motherboard. PCI is the name of a
++	  bus system, i.e. the way the CPU talks to the other stuff inside
++	  your box. Other bus systems are ISA, EISA, MicroChannel (MCA) or
++	  VESA. If you have PCI, say Y, otherwise N.
++
++choice
++	prompt "PCI access mode"
++	depends on X86_32 && PCI
++	default PCI_GOANY
++	---help---
++	  On PCI systems, the BIOS can be used to detect the PCI devices and
++	  determine their configuration. However, some old PCI motherboards
++	  have BIOS bugs and may crash if this is done. Also, some embedded
++	  PCI-based systems don't have any BIOS at all. Linux can also try to
++	  detect the PCI hardware directly without using the BIOS.
++
++	  With this option, you can specify how Linux should detect the
++	  PCI devices. If you choose "BIOS", the BIOS will be used,
++	  if you choose "Direct", the BIOS won't be used, and if you
++	  choose "MMConfig", then PCI Express MMCONFIG will be used.
++	  If you choose "Any", the kernel will try MMCONFIG, then the
++	  direct access method and falls back to the BIOS if that doesn't
++	  work. If unsure, go with the default, which is "Any".
++
++config PCI_GOBIOS
++	bool "BIOS"
++
++config PCI_GOMMCONFIG
++	bool "MMConfig"
++
++config PCI_GODIRECT
++	bool "Direct"
++
++config PCI_GOOLPC
++	bool "OLPC XO-1"
++	depends on OLPC
++
++config PCI_GOANY
++	bool "Any"
++
++endchoice
++
++config PCI_BIOS
++	def_bool y
++	depends on X86_32 && PCI && (PCI_GOBIOS || PCI_GOANY)
++
++# x86-64 doesn't support PCI BIOS access from long mode so always go direct.
++config PCI_DIRECT
++	def_bool y
++	depends on PCI && (X86_64 || (PCI_GODIRECT || PCI_GOANY || PCI_GOOLPC || PCI_GOMMCONFIG))
++
++config PCI_MMCONFIG
++	def_bool y
++	depends on X86_32 && PCI && (ACPI || SFI) && (PCI_GOMMCONFIG || PCI_GOANY)
++
++config PCI_OLPC
++	def_bool y
++	depends on PCI && OLPC && (PCI_GOOLPC || PCI_GOANY)
++
++config PCI_XEN
++	def_bool y
++	depends on PCI && XEN
++	select SWIOTLB_XEN
++
++config PCI_DOMAINS
++	def_bool y
++	depends on PCI
++
++config PCI_MMCONFIG
++	bool "Support mmconfig PCI config space access"
++	depends on X86_64 && PCI && ACPI
++
++config PCI_CNB20LE_QUIRK
++	bool "Read CNB20LE Host Bridge Windows" if EXPERT
++	depends on PCI
++	help
++	  Read the PCI windows out of the CNB20LE host bridge. This allows
++	  PCI hotplug to work on systems with the CNB20LE chipset which do
++	  not have ACPI.
++
++	  There's no public spec for this chipset, and this functionality
++	  is known to be incomplete.
++
++	  You should say N unless you know you need this.
++
++source "drivers/pci/pcie/Kconfig"
++
++source "drivers/pci/Kconfig"
++
++# x86_64 have no ISA slots, but can have ISA-style DMA.
++config ISA_DMA_API
++	bool "ISA-style DMA support" if (X86_64 && EXPERT)
++	default y
++	help
++	  Enables ISA-style DMA support for devices requiring such controllers.
++	  If unsure, say Y.
++
++if X86_32
++
++config ISA
++	bool "ISA support"
++	---help---
++	  Find out whether you have ISA slots on your motherboard.  ISA is the
++	  name of a bus system, i.e. the way the CPU talks to the other stuff
++	  inside your box.  Other bus systems are PCI, EISA, MicroChannel
++	  (MCA) or VESA.  ISA is an older system, now being displaced by PCI;
++	  newer boards don't support it.  If you have ISA, say Y, otherwise N.
++
++config EISA
++	bool "EISA support"
++	depends on ISA
++	---help---
++	  The Extended Industry Standard Architecture (EISA) bus was
++	  developed as an open alternative to the IBM MicroChannel bus.
++
++	  The EISA bus provided some of the features of the IBM MicroChannel
++	  bus while maintaining backward compatibility with cards made for
++	  the older ISA bus.  The EISA bus saw limited use between 1988 and
++	  1995 when it was made obsolete by the PCI bus.
++
++	  Say Y here if you are building a kernel for an EISA-based machine.
++
++	  Otherwise, say N.
++
++source "drivers/eisa/Kconfig"
++
++config SCx200
++	tristate "NatSemi SCx200 support"
++	---help---
++	  This provides basic support for National Semiconductor's
++	  (now AMD's) Geode processors.  The driver probes for the
++	  PCI-IDs of several on-chip devices, so its a good dependency
++	  for other scx200_* drivers.
++
++	  If compiled as a module, the driver is named scx200.
++
++config SCx200HR_TIMER
++	tristate "NatSemi SCx200 27MHz High-Resolution Timer Support"
++	depends on SCx200
++	default y
++	---help---
++	  This driver provides a clocksource built upon the on-chip
++	  27MHz high-resolution timer.  Its also a workaround for
++	  NSC Geode SC-1100's buggy TSC, which loses time when the
++	  processor goes idle (as is done by the scheduler).  The
++	  other workaround is idle=poll boot option.
++
++config OLPC
++	bool "One Laptop Per Child support"
++	depends on !X86_PAE
++	select GPIOLIB
++	select OF
++	select OF_PROMTREE
++	select IRQ_DOMAIN
++	---help---
++	  Add support for detecting the unique features of the OLPC
++	  XO hardware.
++
++config OLPC_XO1_PM
++	bool "OLPC XO-1 Power Management"
++	depends on OLPC && MFD_CS5535 && PM_SLEEP
++	select MFD_CORE
++	---help---
++	  Add support for poweroff and suspend of the OLPC XO-1 laptop.
++
++config OLPC_XO1_RTC
++	bool "OLPC XO-1 Real Time Clock"
++	depends on OLPC_XO1_PM && RTC_DRV_CMOS
++	---help---
++	  Add support for the XO-1 real time clock, which can be used as a
++	  programmable wakeup source.
++
++config OLPC_XO1_SCI
++	bool "OLPC XO-1 SCI extras"
++	depends on OLPC && OLPC_XO1_PM
++	depends on INPUT=y
++	select POWER_SUPPLY
++	select GPIO_CS5535
++	select MFD_CORE
++	---help---
++	  Add support for SCI-based features of the OLPC XO-1 laptop:
++	   - EC-driven system wakeups
++	   - Power button
++	   - Ebook switch
++	   - Lid switch
++	   - AC adapter status updates
++	   - Battery status updates
++
++config OLPC_XO15_SCI
++	bool "OLPC XO-1.5 SCI extras"
++	depends on OLPC && ACPI
++	select POWER_SUPPLY
++	---help---
++	  Add support for SCI-based features of the OLPC XO-1.5 laptop:
++	   - EC-driven system wakeups
++	   - AC adapter status updates
++	   - Battery status updates
++
++config ALIX
++	bool "PCEngines ALIX System Support (LED setup)"
++	select GPIOLIB
++	---help---
++	  This option enables system support for the PCEngines ALIX.
++	  At present this just sets up LEDs for GPIO control on
++	  ALIX2/3/6 boards.  However, other system specific setup should
++	  get added here.
++
++	  Note: You must still enable the drivers for GPIO and LED support
++	  (GPIO_CS5535 & LEDS_GPIO) to actually use the LEDs
++
++	  Note: You have to set alix.force=1 for boards with Award BIOS.
++
++config NET5501
++	bool "Soekris Engineering net5501 System Support (LEDS, GPIO, etc)"
++	select GPIOLIB
++	---help---
++	  This option enables system support for the Soekris Engineering net5501.
++
++config GEOS
++	bool "Traverse Technologies GEOS System Support (LEDS, GPIO, etc)"
++	select GPIOLIB
++	depends on DMI
++	---help---
++	  This option enables system support for the Traverse Technologies GEOS.
++
++config TS5500
++	bool "Technologic Systems TS-5500 platform support"
++	depends on MELAN
++	select CHECK_SIGNATURE
++	select NEW_LEDS
++	select LEDS_CLASS
++	---help---
++	  This option enables system support for the Technologic Systems TS-5500.
++
++endif # X86_32
++
++config AMD_NB
++	def_bool y
++	depends on CPU_SUP_AMD && PCI
++
++source "drivers/pcmcia/Kconfig"
++
++source "drivers/pci/hotplug/Kconfig"
++
++config RAPIDIO
++	bool "RapidIO support"
++	depends on PCI
++	default n
++	help
++	  If you say Y here, the kernel will include drivers and
++	  infrastructure code to support RapidIO interconnect devices.
++
++source "drivers/rapidio/Kconfig"
++
++endmenu
++
++
++menu "Executable file formats / Emulations"
++
++source "fs/Kconfig.binfmt"
++
++config IA32_EMULATION
++	bool "IA32 Emulation"
++	depends on X86_64
++	select BINFMT_ELF
++	select COMPAT_BINFMT_ELF
++	select HAVE_UID16
++	---help---
++	  Include code to run legacy 32-bit programs under a
++	  64-bit kernel. You should likely turn this on, unless you're
++	  100% sure that you don't have any 32-bit programs left.
++
++config IA32_AOUT
++	tristate "IA32 a.out support"
++	depends on IA32_EMULATION
++	---help---
++	  Support old a.out binaries in the 32bit emulation.
++
++config X86_X32
++	bool "x32 ABI for 64-bit mode"
++	depends on X86_64 && IA32_EMULATION
++	---help---
++	  Include code to run binaries for the x32 native 32-bit ABI
++	  for 64-bit processors.  An x32 process gets access to the
++	  full 64-bit register file and wide data path while leaving
++	  pointers at 32 bits for smaller memory footprint.
++
++	  You will need a recent binutils (2.22 or later) with
++	  elf32_x86_64 support enabled to compile a kernel with this
++	  option set.
++
++config COMPAT
++	def_bool y
++	depends on IA32_EMULATION || X86_X32
++	select ARCH_WANT_OLD_COMPAT_IPC
++
++if COMPAT
++config COMPAT_FOR_U64_ALIGNMENT
++	def_bool y
++
++config SYSVIPC_COMPAT
++	def_bool y
++	depends on SYSVIPC
++
++config KEYS_COMPAT
++	def_bool y
++	depends on KEYS
++endif
++
++endmenu
++
++
++config HAVE_ATOMIC_IOMAP
++	def_bool y
++	depends on X86_32
++
++config HAVE_TEXT_POKE_SMP
++	bool
++	select STOP_MACHINE if SMP
++
++config X86_DEV_DMA_OPS
++	bool
++	depends on X86_64 || STA2X11
++
++config X86_DMA_REMAP
++	bool
++	depends on STA2X11
++
++source "net/Kconfig"
++
++source "drivers/Kconfig"
++
++source "drivers/firmware/Kconfig"
++
++source "fs/Kconfig"
++
++source "arch/x86/Kconfig.debug"
++
++source "security/Kconfig"
++
++source "crypto/Kconfig"
++
++source "arch/x86/kvm/Kconfig"
++
++source "lib/Kconfig"