arm64: emulate the swp/swpb instruction
[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 source "mm/Kconfig"
222
223 endmenu
224
225 menu "Boot options"
226
227 config 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
235 choice
236         prompt "Kernel command line type" if CMDLINE != ""
237         default CMDLINE_FROM_BOOTLOADER
238
239 config CMDLINE_FROM_BOOTLOADER
240         bool "Use bootloader kernel arguments if available"
241         help
242           Uses the command-line options passed by the boot loader. If
243           the boot loader doesn't provide any, the default kernel command
244           string provided in CMDLINE will be used.
245
246 config CMDLINE_EXTEND
247         bool "Extend bootloader kernel arguments"
248         help
249           The command-line arguments provided by the boot loader will be
250           appended to the default kernel command string.
251
252 config CMDLINE_FORCE
253         bool "Always use the default kernel command string"
254         help
255           Always use the default kernel command string, even if the boot
256           loader passes other arguments to the kernel.
257           This is useful if you cannot or don't want to change the
258           command-line options your boot loader passes to the kernel.
259 endchoice
260
261 config BUILD_ARM64_APPENDED_DTB_IMAGE
262         bool "Build a concatenated Image.gz/dtb by default"
263         depends on OF
264         help
265           Enabling this option will cause a concatenated Image.gz and list of
266           DTBs to be built by default (instead of a standalone Image.gz.)
267           The image will built in arch/arm64/boot/Image.gz-dtb
268
269 config BUILD_ARM64_APPENDED_DTB_IMAGE_NAMES
270         string "Default dtb names"
271         depends on BUILD_ARM64_APPENDED_DTB_IMAGE
272         help
273           Space separated list of names of dtbs to append when
274           building a concatenated Image.gz-dtb.
275
276 endmenu
277
278 menu "Userspace binary formats"
279
280 source "fs/Kconfig.binfmt"
281
282 config COMPAT
283         bool "Kernel support for 32-bit EL0"
284         depends on !ARM64_64K_PAGES
285         select COMPAT_BINFMT_ELF
286         select HAVE_UID16
287         select OLD_SIGSUSPEND3
288         select COMPAT_OLD_SIGACTION
289         help
290           This option enables support for a 32-bit EL0 running under a 64-bit
291           kernel at EL1. AArch32-specific components such as system calls,
292           the user helper functions, VFP support and the ptrace interface are
293           handled appropriately by the kernel.
294
295           If you want to execute 32-bit userspace applications, say Y.
296
297 config SYSVIPC_COMPAT
298         def_bool y
299         depends on COMPAT && SYSVIPC
300
301 endmenu
302
303 source "net/Kconfig"
304
305 source "drivers/Kconfig"
306
307 source "fs/Kconfig"
308
309 source "arch/arm64/Kconfig.debug"
310
311 source "security/Kconfig"
312
313 source "crypto/Kconfig"
314 if CRYPTO
315 source "arch/arm64/crypto/Kconfig"
316 endif
317
318 source "lib/Kconfig"