arm64: errata: add workaround for cortex-a53 erratum #845719
[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_IOMAP
14         select GENERIC_IRQ_PROBE
15         select GENERIC_IRQ_SHOW
16         select GENERIC_SMP_IDLE_THREAD
17         select GENERIC_TIME_VSYSCALL
18         select HARDIRQS_SW_RESEND
19         select HAVE_ARCH_TRACEHOOK
20         select HAVE_DEBUG_BUGVERBOSE
21         select HAVE_DEBUG_KMEMLEAK
22         select HAVE_DMA_API_DEBUG
23         select HAVE_DMA_ATTRS
24         select HAVE_GENERIC_DMA_COHERENT
25         select HAVE_GENERIC_HARDIRQS
26         select HAVE_HW_BREAKPOINT if PERF_EVENTS
27         select HAVE_MEMBLOCK
28         select HAVE_PERF_EVENTS
29         select IRQ_DOMAIN
30         select MODULES_USE_ELF_RELA
31         select NO_BOOTMEM
32         select OF
33         select OF_EARLY_FLATTREE
34         select PERF_USE_VMALLOC
35         select POWER_RESET
36         select POWER_SUPPLY
37         select RTC_LIB
38         select SPARSE_IRQ
39         select SYSCTL_EXCEPTION_TRACE
40         help
41           ARM 64-bit (AArch64) Linux support.
42
43 config 64BIT
44         def_bool y
45
46 config ARCH_PHYS_ADDR_T_64BIT
47         def_bool y
48
49 config MMU
50         def_bool y
51
52 config NO_IOPORT
53         def_bool y
54
55 config STACKTRACE_SUPPORT
56         def_bool y
57
58 config LOCKDEP_SUPPORT
59         def_bool y
60
61 config TRACE_IRQFLAGS_SUPPORT
62         def_bool y
63
64 config GENERIC_LOCKBREAK
65         def_bool y
66         depends on SMP && PREEMPT
67
68 config RWSEM_GENERIC_SPINLOCK
69         def_bool y
70
71 config GENERIC_HWEIGHT
72         def_bool y
73
74 config GENERIC_CSUM
75         def_bool y
76
77 config GENERIC_CALIBRATE_DELAY
78         def_bool y
79
80 config ZONE_DMA32
81         def_bool y
82
83 config ARCH_DMA_ADDR_T_64BIT
84         def_bool y
85
86 config NEED_DMA_MAP_STATE
87         def_bool y
88
89 config NEED_SG_DMA_LENGTH
90         def_bool y
91
92 config SWIOTLB
93         def_bool y
94
95 config IOMMU_HELPER
96         def_bool SWIOTLB
97
98 source "init/Kconfig"
99
100 source "kernel/Kconfig.freezer"
101
102 menu "Platform selection"
103
104 config ARCH_VEXPRESS
105         bool "ARMv8 software model (Versatile Express)"
106         select ARCH_REQUIRE_GPIOLIB
107         select COMMON_CLK_VERSATILE
108         select POWER_RESET_VEXPRESS
109         select VEXPRESS_CONFIG
110         help
111           This enables support for the ARMv8 software model (Versatile
112           Express).
113
114 endmenu
115
116 menu "Bus support"
117
118 config ARM_AMBA
119         bool
120
121 endmenu
122
123 menu "Kernel Features"
124
125 menu "ARM errata workarounds"
126
127 config ARM64_ERRATUM_845719
128         bool "Cortex-A53: 845719: a load might read incorrect data"
129         depends on COMPAT
130         default n
131         help
132           This option adds an alternative code sequence to work around ARM
133           erratum 845719 on Cortex-A53 parts up to r0p4.
134
135           When running a compat (AArch32) userspace on an affected Cortex-A53
136           part, a load at EL0 from a virtual address that matches the bottom 32
137           bits of the virtual address used by a recent load at (AArch64) EL1
138           might return incorrect data.
139
140           The workaround is to write the contextidr_el1 register on exception
141           return to a 32-bit task.
142           Please note that this does not necessarily enable the workaround,
143           as it depends on the alternative framework, which will only patch
144           the kernel if an affected CPU is detected.
145
146           If unsure, say Y.
147
148 endmenu
149
150
151 config ARM64_64K_PAGES
152         bool "Enable 64KB pages support"
153         help
154           This feature enables 64KB pages support (4KB by default)
155           allowing only two levels of page tables and faster TLB
156           look-up. AArch32 emulation is not available when this feature
157           is enabled.
158
159 config SMP
160         bool "Symmetric Multi-Processing"
161         select USE_GENERIC_SMP_HELPERS
162         help
163           This enables support for systems with more than one CPU.  If
164           you say N here, the kernel will run on single and
165           multiprocessor machines, but will use only one CPU of a
166           multiprocessor machine. If you say Y here, the kernel will run
167           on many, but not all, single processor machines. On a single
168           processor machine, the kernel will run faster if you say N
169           here.
170
171           If you don't know what to do here, say N.
172
173 config NR_CPUS
174         int "Maximum number of CPUs (2-32)"
175         range 2 32
176         depends on SMP
177         default "4"
178
179 source kernel/Kconfig.preempt
180
181 config HZ
182         int
183         default 100
184
185 config ARCH_HAS_HOLES_MEMORYMODEL
186         def_bool y if SPARSEMEM
187
188 config ARCH_SPARSEMEM_ENABLE
189         def_bool y
190         select SPARSEMEM_VMEMMAP_ENABLE
191
192 config ARCH_SPARSEMEM_DEFAULT
193         def_bool ARCH_SPARSEMEM_ENABLE
194
195 config ARCH_SELECT_MEMORY_MODEL
196         def_bool ARCH_SPARSEMEM_ENABLE
197
198 config HAVE_ARCH_PFN_VALID
199         def_bool ARCH_HAS_HOLES_MEMORYMODEL || !SPARSEMEM
200
201 config HW_PERF_EVENTS
202         bool "Enable hardware performance counter support for perf events"
203         depends on PERF_EVENTS
204         default y
205         help
206           Enable hardware performance counter support for perf events. If
207           disabled, perf events will use software events only.
208
209 source "mm/Kconfig"
210
211 endmenu
212
213 menu "Boot options"
214
215 config CMDLINE
216         string "Default kernel command string"
217         default ""
218         help
219           Provide a set of default command-line options at build time by
220           entering them here. As a minimum, you should specify the the
221           root device (e.g. root=/dev/nfs).
222
223 config CMDLINE_FORCE
224         bool "Always use the default kernel command string"
225         help
226           Always use the default kernel command string, even if the boot
227           loader passes other arguments to the kernel.
228           This is useful if you cannot or don't want to change the
229           command-line options your boot loader passes to the kernel.
230
231 endmenu
232
233 menu "Userspace binary formats"
234
235 source "fs/Kconfig.binfmt"
236
237 config COMPAT
238         bool "Kernel support for 32-bit EL0"
239         depends on !ARM64_64K_PAGES
240         select COMPAT_BINFMT_ELF
241         select HAVE_UID16
242         select OLD_SIGSUSPEND3
243         select COMPAT_OLD_SIGACTION
244         help
245           This option enables support for a 32-bit EL0 running under a 64-bit
246           kernel at EL1. AArch32-specific components such as system calls,
247           the user helper functions, VFP support and the ptrace interface are
248           handled appropriately by the kernel.
249
250           If you want to execute 32-bit userspace applications, say Y.
251
252 config SYSVIPC_COMPAT
253         def_bool y
254         depends on COMPAT && SYSVIPC
255
256 endmenu
257
258 source "net/Kconfig"
259
260 source "drivers/Kconfig"
261
262 source "fs/Kconfig"
263
264 source "arch/arm64/Kconfig.debug"
265
266 source "security/Kconfig"
267
268 source "crypto/Kconfig"
269
270 source "lib/Kconfig"