blob: b52f7eba6765a6948efe75dcc3a5464e27ecfb99 [file] [log] [blame]
Vineet Guptacfdbc2e2013-01-18 15:12:20 +05301#
2# Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
3#
4# This program is free software; you can redistribute it and/or modify
5# it under the terms of the GNU General Public License version 2 as
6# published by the Free Software Foundation.
7#
8
9config ARC
10 def_bool y
Vineet Guptaf06d19e2013-11-15 12:08:05 +053011 select BUILDTIME_EXTABLE_SORT
Vineet Guptad7f8a082014-09-10 11:10:54 +053012 select COMMON_CLK
Vineet Gupta4adeefe2013-01-18 15:12:18 +053013 select CLONE_BACKWARDS
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053014 # ARC Busybox based initramfs absolutely relies on DEVTMPFS for /dev
15 select DEVTMPFS if !INITRAMFS_SOURCE=""
16 select GENERIC_ATOMIC64
17 select GENERIC_CLOCKEVENTS
18 select GENERIC_FIND_FIRST_BIT
19 # for now, we don't need GENERIC_IRQ_PROBE, CONFIG_GENERIC_IRQ_CHIP
20 select GENERIC_IRQ_SHOW
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053021 select GENERIC_PENDING_IRQ if SMP
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053022 select GENERIC_SMP_IDLE_THREAD
Mischa Jonkerf46121b2013-01-18 15:12:24 +053023 select HAVE_ARCH_KGDB
Vineet Gupta547f1122013-01-18 15:12:22 +053024 select HAVE_ARCH_TRACEHOOK
Gilad Ben-Yossef43689022013-01-22 16:48:45 +053025 select HAVE_IOREMAP_PROT
Vineet Gupta4d86dfb2013-01-22 17:03:59 +053026 select HAVE_KPROBES
27 select HAVE_KRETPROBES
Vineet Guptac121c502013-01-18 15:12:20 +053028 select HAVE_MEMBLOCK
Vineet Gupta854a0d92013-01-22 17:03:19 +053029 select HAVE_MOD_ARCH_SPECIFIC if ARC_DW2_UNWIND
Vineet Gupta769bc1f2013-01-22 17:02:38 +053030 select HAVE_OPROFILE
Vineet Gupta9c575642013-01-18 15:12:24 +053031 select HAVE_PERF_EVENTS
Vineet Gupta999159a2013-01-22 17:00:52 +053032 select IRQ_DOMAIN
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053033 select MODULES_USE_ELF_RELA
Vineet Guptac121c502013-01-18 15:12:20 +053034 select NO_BOOTMEM
Vineet Gupta999159a2013-01-22 17:00:52 +053035 select OF
36 select OF_EARLY_FLATTREE
Vineet Gupta9c575642013-01-18 15:12:24 +053037 select PERF_USE_VMALLOC
Dave Hansend1a1dc02013-07-01 13:04:42 -070038 select HAVE_DEBUG_STACKOVERFLOW
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053039
Vineet Gupta0dafafc2013-09-06 14:18:17 +053040config TRACE_IRQFLAGS_SUPPORT
41 def_bool y
42
43config LOCKDEP_SUPPORT
44 def_bool y
45
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053046config SCHED_OMIT_FRAME_POINTER
47 def_bool y
48
49config GENERIC_CSUM
50 def_bool y
51
52config RWSEM_GENERIC_SPINLOCK
53 def_bool y
54
55config ARCH_FLATMEM_ENABLE
56 def_bool y
57
58config MMU
59 def_bool y
60
Uwe Kleine-Königce816fa2014-04-07 15:39:19 -070061config NO_IOPORT_MAP
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053062 def_bool y
63
64config GENERIC_CALIBRATE_DELAY
65 def_bool y
66
67config GENERIC_HWEIGHT
68 def_bool y
69
Vineet Gupta44c8bb92013-01-18 15:12:23 +053070config STACKTRACE_SUPPORT
71 def_bool y
72 select STACKTRACE
73
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053074config HAVE_LATENCYTOP_SUPPORT
75 def_bool y
76
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053077source "init/Kconfig"
78source "kernel/Kconfig.freezer"
79
80menu "ARC Architecture Configuration"
81
Vineet Gupta93ad7002013-01-22 16:51:50 +053082menu "ARC Platform/SoC/Board"
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053083
Vineet Guptafd155792015-02-20 19:12:18 +053084source "arch/arc/plat-sim/Kconfig"
Christian Ruppert072eb692013-04-12 08:40:59 +020085source "arch/arc/plat-tb10x/Kconfig"
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053086#New platform adds here
Vineet Gupta93ad7002013-01-22 16:51:50 +053087
Vineet Gupta53d98952013-01-18 15:12:25 +053088endmenu
Vineet Guptacfdbc2e2013-01-18 15:12:20 +053089
90menu "ARC CPU Configuration"
91
92choice
93 prompt "ARC Core"
94 default ARC_CPU_770
95
96config ARC_CPU_750D
97 bool "ARC750D"
98 help
99 Support for ARC750 core
100
101config ARC_CPU_770
102 bool "ARC770"
Vineet Gupta742f8af2013-11-07 14:47:16 +0530103 select ARC_HAS_SWAPE
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530104 help
105 Support for ARC770 core introduced with Rel 4.10 (Summer 2011)
106 This core has a bunch of cool new features:
107 -MMU-v3: Variable Page Sz (4k, 8k, 16k), bigger J-TLB (128x4)
108 Shared Address Spaces (for sharing TLB entires in MMU)
109 -Caches: New Prog Model, Region Flush
110 -Insns: endian swap, load-locked/store-conditional, time-stamp-ctr
111
112endchoice
113
114config CPU_BIG_ENDIAN
115 bool "Enable Big Endian Mode"
116 default n
117 help
118 Build kernel for Big Endian Mode of ARC CPU
119
Vineet Gupta41195d22013-01-18 15:12:23 +0530120config SMP
121 bool "Symmetric Multi-Processing (Incomplete)"
122 default n
Vineet Gupta41195d22013-01-18 15:12:23 +0530123 help
124 This enables support for systems with more than one CPU. If you have
Robert Graffham4a474152014-01-23 15:55:29 -0800125 a system with only one CPU, say N. If you have a system with more
126 than one CPU, say Y.
Vineet Gupta41195d22013-01-18 15:12:23 +0530127
128if SMP
129
130config ARC_HAS_COH_CACHES
131 def_bool n
132
Vineet Gupta41195d22013-01-18 15:12:23 +0530133config ARC_HAS_REENTRANT_IRQ_LV2
134 def_bool n
135
136endif
137
138config NR_CPUS
Noam Camus3aa4f802013-06-03 15:19:59 +0300139 int "Maximum number of CPUs (2-4096)"
140 range 2 4096
Vineet Gupta41195d22013-01-18 15:12:23 +0530141 depends on SMP
142 default "2"
143
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530144menuconfig ARC_CACHE
145 bool "Enable Cache Support"
146 default y
Vineet Gupta41195d22013-01-18 15:12:23 +0530147 # if SMP, cache enabled ONLY if ARC implementation has cache coherency
148 depends on !SMP || ARC_HAS_COH_CACHES
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530149
150if ARC_CACHE
151
152config ARC_CACHE_LINE_SHIFT
153 int "Cache Line Length (as power of 2)"
154 range 5 7
155 default "6"
156 help
157 Starting with ARC700 4.9, Cache line length is configurable,
158 This option specifies "N", with Line-len = 2 power N
159 So line lengths of 32, 64, 128 are specified by 5,6,7, respectively
160 Linux only supports same line lengths for I and D caches.
161
162config ARC_HAS_ICACHE
163 bool "Use Instruction Cache"
164 default y
165
166config ARC_HAS_DCACHE
167 bool "Use Data Cache"
168 default y
169
170config ARC_CACHE_PAGES
171 bool "Per Page Cache Control"
172 default y
173 depends on ARC_HAS_ICACHE || ARC_HAS_DCACHE
174 help
175 This can be used to over-ride the global I/D Cache Enable on a
176 per-page basis (but only for pages accessed via MMU such as
177 Kernel Virtual address or User Virtual Address)
178 TLB entries have a per-page Cache Enable Bit.
179 Note that Global I/D ENABLE + Per Page DISABLE works but corollary
180 Global DISABLE + Per Page ENABLE won't work
181
Vineet Gupta4102b532013-05-09 21:54:51 +0530182config ARC_CACHE_VIPT_ALIASING
183 bool "Support VIPT Aliasing D$"
Alexey Brodkin2f9e9962013-06-18 16:40:29 +0400184 depends on ARC_HAS_DCACHE
Vineet Gupta4102b532013-05-09 21:54:51 +0530185 default n
186
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530187endif #ARC_CACHE
188
Vineet Gupta8b5850f2013-01-18 15:12:25 +0530189config ARC_HAS_ICCM
190 bool "Use ICCM"
191 help
192 Single Cycle RAMS to store Fast Path Code
193 default n
194
195config ARC_ICCM_SZ
196 int "ICCM Size in KB"
197 default "64"
198 depends on ARC_HAS_ICCM
199
200config ARC_HAS_DCCM
201 bool "Use DCCM"
202 help
203 Single Cycle RAMS to store Fast Path Data
204 default n
205
206config ARC_DCCM_SZ
207 int "DCCM Size in KB"
208 default "64"
209 depends on ARC_HAS_DCCM
210
211config ARC_DCCM_BASE
212 hex "DCCM map address"
213 default "0xA0000000"
214 depends on ARC_HAS_DCCM
215
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530216config ARC_HAS_HW_MPY
217 bool "Use Hardware Multiplier (Normal or Faster XMAC)"
218 default y
219 help
220 Influences how gcc generates code for MPY operations.
221 If enabled, MPYxx insns are generated, provided by Standard/XMAC
222 Multipler. Otherwise software multipy lib is used
223
224choice
225 prompt "ARC700 MMU Version"
226 default ARC_MMU_V3 if ARC_CPU_770
227 default ARC_MMU_V2 if ARC_CPU_750D
228
229config ARC_MMU_V1
230 bool "MMU v1"
231 help
232 Orig ARC700 MMU
233
234config ARC_MMU_V2
235 bool "MMU v2"
236 help
237 Fixed the deficiency of v1 - possible thrashing in memcpy sceanrio
238 when 2 D-TLB and 1 I-TLB entries index into same 2way set.
239
240config ARC_MMU_V3
241 bool "MMU v3"
242 depends on ARC_CPU_770
243 help
244 Introduced with ARC700 4.10: New Features
245 Variable Page size (1k-16k), var JTLB size 128 x (2 or 4)
246 Shared Address Spaces (SASID)
247
248endchoice
249
250
251choice
252 prompt "MMU Page Size"
253 default ARC_PAGE_SIZE_8K
254
255config ARC_PAGE_SIZE_8K
256 bool "8KB"
257 help
258 Choose between 8k vs 16k
259
260config ARC_PAGE_SIZE_16K
261 bool "16KB"
262 depends on ARC_MMU_V3
263
264config ARC_PAGE_SIZE_4K
265 bool "4KB"
266 depends on ARC_MMU_V3
267
268endchoice
269
Vineet Gupta4788a592013-01-18 15:12:22 +0530270config ARC_COMPACT_IRQ_LEVELS
271 bool "ARCompact IRQ Priorities: High(2)/Low(1)"
272 default n
273 # Timer HAS to be high priority, for any other high priority config
274 select ARC_IRQ3_LV2
Vineet Gupta41195d22013-01-18 15:12:23 +0530275 # if SMP, LV2 enabled ONLY if ARC implementation has LV2 re-entrancy
276 depends on !SMP || ARC_HAS_REENTRANT_IRQ_LV2
Vineet Gupta4788a592013-01-18 15:12:22 +0530277
278if ARC_COMPACT_IRQ_LEVELS
279
280config ARC_IRQ3_LV2
281 bool
282
283config ARC_IRQ5_LV2
284 bool
285
286config ARC_IRQ6_LV2
287 bool
288
289endif
290
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530291config ARC_FPU_SAVE_RESTORE
292 bool "Enable FPU state persistence across context switch"
293 default n
294 help
295 Double Precision Floating Point unit had dedictaed regs which
296 need to be saved/restored across context-switch.
297 Note that ARC FPU is overly simplistic, unlike say x86, which has
298 hardware pieces to allow software to conditionally save/restore,
299 based on actual usage of FPU by a task. Thus our implemn does
300 this for all tasks in system.
301
Vineet Guptafbf8e132013-03-30 15:07:47 +0530302config ARC_CANT_LLSC
303 def_bool n
304
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530305config ARC_HAS_LLSC
306 bool "Insn: LLOCK/SCOND (efficient atomic ops)"
307 default y
Vineet Guptafbf8e132013-03-30 15:07:47 +0530308 depends on ARC_CPU_770 && !ARC_CANT_LLSC
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530309
310config ARC_HAS_SWAPE
311 bool "Insn: SWAPE (endian-swap)"
312 default y
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530313
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530314endmenu # "ARC CPU Configuration"
315
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530316config LINUX_LINK_BASE
317 hex "Linux Link Address"
318 default "0x80000000"
319 help
320 ARC700 divides the 32 bit phy address space into two equal halves
321 -Lower 2G (0 - 0x7FFF_FFFF ) is user virtual, translated by MMU
322 -Upper 2G (0x8000_0000 onwards) is untranslated, for kernel
323 Typically Linux kernel is linked at the start of untransalted addr,
324 hence the default value of 0x8zs.
325 However some customers have peripherals mapped at this addr, so
326 Linux needs to be scooted a bit.
327 If you don't know what the above means, leave this setting alone.
328
Vineet Gupta080c3742013-02-11 19:52:57 +0530329config ARC_CURR_IN_REG
330 bool "Dedicate Register r25 for current_task pointer"
331 default y
332 help
333 This reserved Register R25 to point to Current Task in
334 kernel mode. This saves memory access for each such access
335
Vineet Gupta2e651ea2013-01-23 16:30:36 +0530336
Vineet Gupta1736a562014-09-08 11:18:15 +0530337config ARC_EMUL_UNALIGNED
Vineet Gupta2e651ea2013-01-23 16:30:36 +0530338 bool "Emulate unaligned memory access (userspace only)"
Vineet Gupta2e651ea2013-01-23 16:30:36 +0530339 select SYSCTL_ARCH_UNALIGN_NO_WARN
340 select SYSCTL_ARCH_UNALIGN_ALLOW
341 help
342 This enables misaligned 16 & 32 bit memory access from user space.
343 Use ONLY-IF-ABS-NECESSARY as it will be very slow and also can hide
344 potential bugs in code
345
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530346config HZ
347 int "Timer Frequency"
348 default 100
349
Vineet Guptacbe056f2013-01-18 15:12:25 +0530350config ARC_METAWARE_HLINK
351 bool "Support for Metaware debugger assisted Host access"
352 default n
353 help
354 This options allows a Linux userland apps to directly access
355 host file system (open/creat/read/write etc) with help from
356 Metaware Debugger. This can come in handy for Linux-host communication
357 when there is no real usable peripheral such as EMAC.
358
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530359menuconfig ARC_DBG
360 bool "ARC debugging"
361 default y
362
Vineet Gupta854a0d92013-01-22 17:03:19 +0530363config ARC_DW2_UNWIND
364 bool "Enable DWARF specific kernel stack unwind"
365 depends on ARC_DBG
366 default y
367 select KALLSYMS
368 help
369 Compiles the kernel with DWARF unwind information and can be used
370 to get stack backtraces.
371
372 If you say Y here the resulting kernel image will be slightly larger
373 but not slower, and it will give very useful debugging information.
374 If you don't debug the kernel, you can say N, but we may not be able
375 to solve problems without frame unwind information
376
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530377config ARC_DBG_TLB_PARANOIA
378 bool "Paranoia Checks in Low Level TLB Handlers"
Mischa Jonkerf46121b2013-01-18 15:12:24 +0530379 depends on ARC_DBG
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530380 default n
381
382config ARC_DBG_TLB_MISS_COUNT
383 bool "Profile TLB Misses"
384 default n
385 select DEBUG_FS
386 depends on ARC_DBG
387 help
388 Counts number of I and D TLB Misses and exports them via Debugfs
389 The counters can be cleared via Debugfs as well
390
Vineet Gupta036b2c52015-03-09 19:40:09 +0530391config ARC_UBOOT_SUPPORT
392 bool "Support uboot arg Handling"
393 default n
394 help
395 ARC Linux by default checks for uboot provided args as pointers to
396 external cmdline or DTB. This however breaks in absence of uboot,
397 when booting from Metaware debugger directly, as the registers are
398 not zeroed out on reset by mdb and/or ARCv2 based cores. The bogus
399 registers look like uboot args to kernel which then chokes.
400 So only enable the uboot arg checking/processing if users are sure
401 of uboot being in play.
402
Vineet Gupta999159a2013-01-22 17:00:52 +0530403config ARC_BUILTIN_DTB_NAME
404 string "Built in DTB"
405 help
406 Set the name of the DTB to embed in the vmlinux binary
407 Leaving it blank selects the minimal "skeleton" dtb
408
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530409source "kernel/Kconfig.preempt"
410
Vineet Gupta56288322013-04-06 14:16:20 +0530411menu "Executable file formats"
412source "fs/Kconfig.binfmt"
413endmenu
414
Vineet Guptacfdbc2e2013-01-18 15:12:20 +0530415endmenu # "ARC Architecture Configuration"
416
417source "mm/Kconfig"
418source "net/Kconfig"
419source "drivers/Kconfig"
420source "fs/Kconfig"
421source "arch/arc/Kconfig.debug"
422source "security/Kconfig"
423source "crypto/Kconfig"
424source "lib/Kconfig"
Alexey Brodkin996bad62014-10-29 15:26:25 +0300425source "kernel/power/Kconfig"