arm64: read enable-method for CPU0
[linux-2.6-block.git] / arch / arm64 / Kconfig
CommitLineData
8c2c3df3
CM
1config ARM64
2 def_bool y
3 select ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
5686b06c 4 select ARCH_USE_CMPXCHG_LOCKREF
9170100e 5 select ARCH_WANT_OPTIONAL_GPIOLIB
6212a512 6 select ARCH_WANT_COMPAT_IPC_PARSE_VERSION
b6f35981 7 select ARCH_WANT_FRAME_POINTERS
25c92a37 8 select ARM_AMBA
1aee5d7a 9 select ARM_ARCH_TIMER
c4188edc 10 select ARM_GIC
adace895 11 select BUILDTIME_EXTABLE_SORT
db2789b5 12 select CLONE_BACKWARDS
7ca2ef33 13 select COMMON_CLK
8c2c3df3 14 select GENERIC_CLOCKEVENTS
8c2c3df3
CM
15 select GENERIC_IOMAP
16 select GENERIC_IRQ_PROBE
17 select GENERIC_IRQ_SHOW
18 select GENERIC_SMP_IDLE_THREAD
19 select GENERIC_TIME_VSYSCALL
20 select HARDIRQS_SW_RESEND
21 select HAVE_ARCH_TRACEHOOK
9b2a60c4 22 select HAVE_DEBUG_BUGVERBOSE
b69ec42b 23 select HAVE_DEBUG_KMEMLEAK
8c2c3df3
CM
24 select HAVE_DMA_API_DEBUG
25 select HAVE_DMA_ATTRS
26 select HAVE_GENERIC_DMA_COHERENT
8c2c3df3 27 select HAVE_HW_BREAKPOINT if PERF_EVENTS
8c2c3df3
CM
28 select HAVE_MEMBLOCK
29 select HAVE_PERF_EVENTS
8c2c3df3 30 select IRQ_DOMAIN
fea2acaa 31 select MODULES_USE_ELF_RELA
8c2c3df3
CM
32 select NO_BOOTMEM
33 select OF
34 select OF_EARLY_FLATTREE
35 select PERF_USE_VMALLOC
aa1e8ec1
CM
36 select POWER_RESET
37 select POWER_SUPPLY
8c2c3df3
CM
38 select RTC_LIB
39 select SPARSE_IRQ
7ac57a89 40 select SYSCTL_EXCEPTION_TRACE
8c2c3df3
CM
41 help
42 ARM 64-bit (AArch64) Linux support.
43
44config 64BIT
45 def_bool y
46
47config ARCH_PHYS_ADDR_T_64BIT
48 def_bool y
49
50config MMU
51 def_bool y
52
53config NO_IOPORT
54 def_bool y
55
56config STACKTRACE_SUPPORT
57 def_bool y
58
59config LOCKDEP_SUPPORT
60 def_bool y
61
62config TRACE_IRQFLAGS_SUPPORT
63 def_bool y
64
65config GENERIC_LOCKBREAK
66 def_bool y
67 depends on SMP && PREEMPT
68
69config RWSEM_GENERIC_SPINLOCK
70 def_bool y
71
72config GENERIC_HWEIGHT
73 def_bool y
74
75config GENERIC_CSUM
76 def_bool y
77
78config GENERIC_CALIBRATE_DELAY
79 def_bool y
80
81config ZONE_DMA32
82 def_bool y
83
84config ARCH_DMA_ADDR_T_64BIT
85 def_bool y
86
87config NEED_DMA_MAP_STATE
88 def_bool y
89
90config NEED_SG_DMA_LENGTH
91 def_bool y
92
93config SWIOTLB
94 def_bool y
95
96config IOMMU_HELPER
97 def_bool SWIOTLB
98
4cfb3613
AB
99config KERNEL_MODE_NEON
100 def_bool y
101
8c2c3df3
CM
102source "init/Kconfig"
103
104source "kernel/Kconfig.freezer"
105
1ae90e79
CM
106menu "Platform selection"
107
108config ARCH_VEXPRESS
109 bool "ARMv8 software model (Versatile Express)"
110 select ARCH_REQUIRE_GPIOLIB
111 select COMMON_CLK_VERSATILE
aa1e8ec1 112 select POWER_RESET_VEXPRESS
1ae90e79
CM
113 select VEXPRESS_CONFIG
114 help
115 This enables support for the ARMv8 software model (Versatile
116 Express).
8c2c3df3 117
15942853
VK
118config ARCH_XGENE
119 bool "AppliedMicro X-Gene SOC Family"
120 help
121 This enables support for AppliedMicro X-Gene SOC Family
122
8c2c3df3
CM
123endmenu
124
125menu "Bus support"
126
127config ARM_AMBA
128 bool
129
130endmenu
131
132menu "Kernel Features"
133
8c2c3df3
CM
134config ARM64_64K_PAGES
135 bool "Enable 64KB pages support"
136 help
137 This feature enables 64KB pages support (4KB by default)
138 allowing only two levels of page tables and faster TLB
139 look-up. AArch32 emulation is not available when this feature
140 is enabled.
141
142config SMP
143 bool "Symmetric Multi-Processing"
144 select USE_GENERIC_SMP_HELPERS
145 help
146 This enables support for systems with more than one CPU. If
147 you say N here, the kernel will run on single and
148 multiprocessor machines, but will use only one CPU of a
149 multiprocessor machine. If you say Y here, the kernel will run
150 on many, but not all, single processor machines. On a single
151 processor machine, the kernel will run faster if you say N
152 here.
153
154 If you don't know what to do here, say N.
155
156config NR_CPUS
157 int "Maximum number of CPUs (2-32)"
158 range 2 32
159 depends on SMP
15942853
VK
160 # These have to remain sorted largest to smallest
161 default "8" if ARCH_XGENE
8c2c3df3
CM
162 default "4"
163
164source kernel/Kconfig.preempt
165
166config HZ
167 int
168 default 100
169
170config ARCH_HAS_HOLES_MEMORYMODEL
171 def_bool y if SPARSEMEM
172
173config ARCH_SPARSEMEM_ENABLE
174 def_bool y
175 select SPARSEMEM_VMEMMAP_ENABLE
176
177config ARCH_SPARSEMEM_DEFAULT
178 def_bool ARCH_SPARSEMEM_ENABLE
179
180config ARCH_SELECT_MEMORY_MODEL
181 def_bool ARCH_SPARSEMEM_ENABLE
182
183config HAVE_ARCH_PFN_VALID
184 def_bool ARCH_HAS_HOLES_MEMORYMODEL || !SPARSEMEM
185
186config HW_PERF_EVENTS
187 bool "Enable hardware performance counter support for perf events"
188 depends on PERF_EVENTS
189 default y
190 help
191 Enable hardware performance counter support for perf events. If
192 disabled, perf events will use software events only.
193
084bd298
SC
194config SYS_SUPPORTS_HUGETLBFS
195 def_bool y
196
197config ARCH_WANT_GENERAL_HUGETLB
198 def_bool y
199
200config ARCH_WANT_HUGE_PMD_SHARE
201 def_bool y if !ARM64_64K_PAGES
202
af074848
SC
203config HAVE_ARCH_TRANSPARENT_HUGEPAGE
204 def_bool y
205
8c2c3df3
CM
206source "mm/Kconfig"
207
aa42aa13
SS
208config XEN_DOM0
209 def_bool y
210 depends on XEN
211
212config XEN
213 bool "Xen guest support on ARM64 (EXPERIMENTAL)"
214 depends on ARM64 && OF
215 help
216 Say Y if you want to run Linux in a Virtual Machine on Xen on ARM64.
217
d03bb145
SC
218config FORCE_MAX_ZONEORDER
219 int
220 default "14" if (ARM64_64K_PAGES && TRANSPARENT_HUGEPAGE)
221 default "11"
222
8c2c3df3
CM
223endmenu
224
225menu "Boot options"
226
227config CMDLINE
228 string "Default kernel command string"
229 default ""
230 help
231 Provide a set of default command-line options at build time by
232 entering them here. As a minimum, you should specify the the
233 root device (e.g. root=/dev/nfs).
234
235config CMDLINE_FORCE
236 bool "Always use the default kernel command string"
237 help
238 Always use the default kernel command string, even if the boot
239 loader passes other arguments to the kernel.
240 This is useful if you cannot or don't want to change the
241 command-line options your boot loader passes to the kernel.
242
243endmenu
244
245menu "Userspace binary formats"
246
247source "fs/Kconfig.binfmt"
248
249config COMPAT
250 bool "Kernel support for 32-bit EL0"
251 depends on !ARM64_64K_PAGES
252 select COMPAT_BINFMT_ELF
af1839eb 253 select HAVE_UID16
84b9e9b4 254 select OLD_SIGSUSPEND3
51682036 255 select COMPAT_OLD_SIGACTION
8c2c3df3
CM
256 help
257 This option enables support for a 32-bit EL0 running under a 64-bit
258 kernel at EL1. AArch32-specific components such as system calls,
259 the user helper functions, VFP support and the ptrace interface are
260 handled appropriately by the kernel.
261
262 If you want to execute 32-bit userspace applications, say Y.
263
264config SYSVIPC_COMPAT
265 def_bool y
266 depends on COMPAT && SYSVIPC
267
268endmenu
269
270source "net/Kconfig"
271
272source "drivers/Kconfig"
273
274source "fs/Kconfig"
275
c3eb5b14
MZ
276source "arch/arm64/kvm/Kconfig"
277
8c2c3df3
CM
278source "arch/arm64/Kconfig.debug"
279
280source "security/Kconfig"
281
282source "crypto/Kconfig"
283
284source "lib/Kconfig"