arm64: optionally set CP15BEN in SCTLR
[firefly-linux-kernel-4.4.55.git] / arch / arm64 / Kconfig
1 config ARM64
2         def_bool y
3         select ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
4         select ARCH_WANT_OPTIONAL_GPIOLIB
5         select ARCH_WANT_COMPAT_IPC_PARSE_VERSION
6         select ARCH_WANT_FRAME_POINTERS
7         select ARM_AMBA
8         select ARM_ARCH_TIMER
9         select ARM_GIC
10         select CLONE_BACKWARDS
11         select COMMON_CLK
12         select GENERIC_CLOCKEVENTS
13         select GENERIC_CLOCKEVENTS_BROADCAST if SMP
14         select GENERIC_CPU_AUTOPROBE
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
22         select HAVE_DEBUG_BUGVERBOSE
23         select HAVE_DEBUG_KMEMLEAK
24         select HAVE_DMA_API_DEBUG
25         select HAVE_DMA_ATTRS
26         select HAVE_GENERIC_DMA_COHERENT
27         select HAVE_GENERIC_HARDIRQS
28         select HAVE_HW_BREAKPOINT if PERF_EVENTS
29         select HAVE_MEMBLOCK
30         select HAVE_PERF_EVENTS
31         select IRQ_DOMAIN
32         select MODULES_USE_ELF_RELA
33         select NO_BOOTMEM
34         select OF
35         select OF_EARLY_FLATTREE
36         select PERF_USE_VMALLOC
37         select POWER_RESET
38         select POWER_SUPPLY
39         select RTC_LIB
40         select SPARSE_IRQ
41         select SYSCTL_EXCEPTION_TRACE
42         help
43           ARM 64-bit (AArch64) Linux support.
44
45 config 64BIT
46         def_bool y
47
48 config ARCH_PHYS_ADDR_T_64BIT
49         def_bool y
50
51 config MMU
52         def_bool y
53
54 config NO_IOPORT
55         def_bool y
56
57 config STACKTRACE_SUPPORT
58         def_bool y
59
60 config LOCKDEP_SUPPORT
61         def_bool y
62
63 config TRACE_IRQFLAGS_SUPPORT
64         def_bool y
65
66 config GENERIC_LOCKBREAK
67         def_bool y
68         depends on SMP && PREEMPT
69
70 config RWSEM_GENERIC_SPINLOCK
71         def_bool y
72
73 config GENERIC_HWEIGHT
74         def_bool y
75
76 config GENERIC_CSUM
77         def_bool y
78
79 config GENERIC_CALIBRATE_DELAY
80         def_bool y
81
82 config ZONE_DMA32
83         def_bool y
84
85 config ARCH_DMA_ADDR_T_64BIT
86         def_bool y
87
88 config NEED_DMA_MAP_STATE
89         def_bool y
90
91 config NEED_SG_DMA_LENGTH
92         def_bool y
93
94 config SWIOTLB
95         def_bool y
96
97 config IOMMU_HELPER
98         def_bool SWIOTLB
99
100 source "init/Kconfig"
101
102 source "kernel/Kconfig.freezer"
103
104 menu "Platform selection"
105
106 config ARCH_VEXPRESS
107         bool "ARMv8 software model (Versatile Express)"
108         select ARCH_REQUIRE_GPIOLIB
109         select COMMON_CLK_VERSATILE
110         select POWER_RESET_VEXPRESS
111         select VEXPRESS_CONFIG
112         help
113           This enables support for the ARMv8 software model (Versatile
114           Express).
115
116 endmenu
117
118 menu "Bus support"
119
120 config ARM_AMBA
121         bool
122
123 endmenu
124
125 menu "Kernel Features"
126
127 config ARM64_64K_PAGES
128         bool "Enable 64KB pages support"
129         help
130           This feature enables 64KB pages support (4KB by default)
131           allowing only two levels of page tables and faster TLB
132           look-up. AArch32 emulation is not available when this feature
133           is enabled.
134
135 config SMP
136         bool "Symmetric Multi-Processing"
137         select USE_GENERIC_SMP_HELPERS
138         help
139           This enables support for systems with more than one CPU.  If
140           you say N here, the kernel will run on single and
141           multiprocessor machines, but will use only one CPU of a
142           multiprocessor machine. If you say Y here, the kernel will run
143           on many, but not all, single processor machines. On a single
144           processor machine, the kernel will run faster if you say N
145           here.
146
147           If you don't know what to do here, say N.
148
149 config NR_CPUS
150         int "Maximum number of CPUs (2-32)"
151         range 2 32
152         depends on SMP
153         default "4"
154
155 config SWP_EMULATE
156         bool "Emulate SWP/SWPB instructions"
157         help
158           ARMv6 architecture deprecates use of the SWP/SWPB instructions. ARMv8
159           oblosetes the use of SWP/SWPB instructions. ARMv7 multiprocessing
160           extensions introduce the ability to disable these instructions,
161           triggering an undefined instruction exception when executed. Say Y
162           here to enable software emulation of these instructions for userspace
163           (not kernel) using LDREX/STREX. Also creates /proc/cpu/swp_emulation
164           for statistics.
165
166           In some older versions of glibc [<=2.8] SWP is used during futex
167           trylock() operations with the assumption that the code will not
168           be preempted. This invalid assumption may be more likely to fail
169           with SWP emulation enabled, leading to deadlock of the user
170           application.
171
172           NOTE: when accessing uncached shared regions, LDREX/STREX rely
173           on an external transaction monitoring block called a global
174           monitor to maintain update atomicity. If your system does not
175           implement a global monitor, this option can cause programs that
176           perform SWP operations to uncached memory to deadlock.
177
178           If unsure, say Y.
179
180 source kernel/Kconfig.preempt
181
182 config HZ
183         int
184         default 100
185
186 config ARCH_HAS_HOLES_MEMORYMODEL
187         def_bool y if SPARSEMEM
188
189 config ARCH_SPARSEMEM_ENABLE
190         def_bool y
191         select SPARSEMEM_VMEMMAP_ENABLE
192
193 config ARCH_SPARSEMEM_DEFAULT
194         def_bool ARCH_SPARSEMEM_ENABLE
195
196 config ARCH_SELECT_MEMORY_MODEL
197         def_bool ARCH_SPARSEMEM_ENABLE
198
199 config HAVE_ARCH_PFN_VALID
200         def_bool ARCH_HAS_HOLES_MEMORYMODEL || !SPARSEMEM
201
202 config HW_PERF_EVENTS
203         bool "Enable hardware performance counter support for perf events"
204         depends on PERF_EVENTS
205         default y
206         help
207           Enable hardware performance counter support for perf events. If
208           disabled, perf events will use software events only.
209
210 config ARMV7_COMPAT
211         bool "Kernel support for ARMv7 applications"
212         depends on COMPAT
213         select SWP_EMULATE
214         help
215          This option enables features that allow that ran on an ARMv7 or older
216          processor to continue functioning.
217
218          If you want to execute ARMv7 applications, say Y
219
220
221 config ARMV7_COMPAT_CP15_BARRIER
222         bool "Allow applications to use the CP15 barrier operations"
223         depends on ARMV7_COMPAT
224         default y
225         help
226          This option allows applications to use deprecated CP15 barrier
227          instructions. This is useful because this was the only way to create
228          a barrier on older ARM processors.
229
230          If you want to execute ARMv7 applications, say Y
231
232 source "mm/Kconfig"
233
234 endmenu
235
236 menu "Boot options"
237
238 config CMDLINE
239         string "Default kernel command string"
240         default ""
241         help
242           Provide a set of default command-line options at build time by
243           entering them here. As a minimum, you should specify the the
244           root device (e.g. root=/dev/nfs).
245
246 choice
247         prompt "Kernel command line type" if CMDLINE != ""
248         default CMDLINE_FROM_BOOTLOADER
249
250 config CMDLINE_FROM_BOOTLOADER
251         bool "Use bootloader kernel arguments if available"
252         help
253           Uses the command-line options passed by the boot loader. If
254           the boot loader doesn't provide any, the default kernel command
255           string provided in CMDLINE will be used.
256
257 config CMDLINE_EXTEND
258         bool "Extend bootloader kernel arguments"
259         help
260           The command-line arguments provided by the boot loader will be
261           appended to the default kernel command string.
262
263 config CMDLINE_FORCE
264         bool "Always use the default kernel command string"
265         help
266           Always use the default kernel command string, even if the boot
267           loader passes other arguments to the kernel.
268           This is useful if you cannot or don't want to change the
269           command-line options your boot loader passes to the kernel.
270 endchoice
271
272 config BUILD_ARM64_APPENDED_DTB_IMAGE
273         bool "Build a concatenated Image.gz/dtb by default"
274         depends on OF
275         help
276           Enabling this option will cause a concatenated Image.gz and list of
277           DTBs to be built by default (instead of a standalone Image.gz.)
278           The image will built in arch/arm64/boot/Image.gz-dtb
279
280 config BUILD_ARM64_APPENDED_DTB_IMAGE_NAMES
281         string "Default dtb names"
282         depends on BUILD_ARM64_APPENDED_DTB_IMAGE
283         help
284           Space separated list of names of dtbs to append when
285           building a concatenated Image.gz-dtb.
286
287 endmenu
288
289 menu "Userspace binary formats"
290
291 source "fs/Kconfig.binfmt"
292
293 config COMPAT
294         bool "Kernel support for 32-bit EL0"
295         depends on !ARM64_64K_PAGES
296         select COMPAT_BINFMT_ELF
297         select HAVE_UID16
298         select OLD_SIGSUSPEND3
299         select COMPAT_OLD_SIGACTION
300         help
301           This option enables support for a 32-bit EL0 running under a 64-bit
302           kernel at EL1. AArch32-specific components such as system calls,
303           the user helper functions, VFP support and the ptrace interface are
304           handled appropriately by the kernel.
305
306           If you want to execute 32-bit userspace applications, say Y.
307
308 config SYSVIPC_COMPAT
309         def_bool y
310         depends on COMPAT && SYSVIPC
311
312 endmenu
313
314 source "net/Kconfig"
315
316 source "drivers/Kconfig"
317
318 source "fs/Kconfig"
319
320 source "arch/arm64/Kconfig.debug"
321
322 source "security/Kconfig"
323
324 source "crypto/Kconfig"
325 if CRYPTO
326 source "arch/arm64/crypto/Kconfig"
327 endif
328
329 source "lib/Kconfig"