d28b6eb1b122f569afa3f069e4ed2c664094c1d9
[linux-3.10.git] / arch / mn10300 / Kconfig
1 config MN10300
2         def_bool y
3         select HAVE_OPROFILE
4         select HAVE_GENERIC_HARDIRQS
5         select GENERIC_IRQ_SHOW
6         select HAVE_ARCH_TRACEHOOK
7         select HAVE_ARCH_KGDB
8         select HAVE_NMI_WATCHDOG if MN10300_WD_TIMER
9         select HAVE_GENERIC_INIT_TASK
10
11 config AM33_2
12         def_bool n
13
14 config AM33_3
15         def_bool n
16
17 config AM34_2
18         def_bool n
19         select MN10300_HAS_ATOMIC_OPS_UNIT
20         select MN10300_HAS_CACHE_SNOOP
21
22 config ERRATUM_NEED_TO_RELOAD_MMUCTR
23         def_bool y if AM33_3 || AM34_2
24
25 config MMU
26         def_bool y
27
28 config HIGHMEM
29         def_bool n
30
31 config NUMA
32         def_bool n
33
34 config UID16
35         def_bool y
36
37 config RWSEM_GENERIC_SPINLOCK
38         def_bool y
39
40 config RWSEM_XCHGADD_ALGORITHM
41         bool
42
43 config GENERIC_CALIBRATE_DELAY
44         def_bool y
45
46 config GENERIC_CMOS_UPDATE
47         def_bool n
48
49 config GENERIC_HWEIGHT
50         def_bool y
51
52 config GENERIC_CLOCKEVENTS
53         def_bool y
54
55 config GENERIC_BUG
56         def_bool y
57
58 config QUICKLIST
59         def_bool y
60
61 config ARCH_HAS_ILOG2_U32
62         def_bool y
63
64 config HOTPLUG_CPU
65         def_bool n
66
67 source "init/Kconfig"
68
69 source "kernel/Kconfig.freezer"
70
71
72 menu "Panasonic MN10300 system setup"
73
74 choice
75         prompt "Unit type"
76         default MN10300_UNIT_ASB2303
77         help
78           This option specifies board for which the kernel will be
79           compiled. It affects the external peripherals catered for.
80
81 config MN10300_UNIT_ASB2303
82         bool "ASB2303"
83
84 config MN10300_UNIT_ASB2305
85         bool "ASB2305"
86
87 config MN10300_UNIT_ASB2364
88         bool "ASB2364"
89         select SMSC911X_ARCH_HOOKS if SMSC911X
90
91 endchoice
92
93 choice
94         prompt "Processor support"
95         default MN10300_PROC_MN103E010
96         help
97           This option specifies the processor for which the kernel will be
98           compiled. It affects the on-chip peripherals catered for.
99
100 config MN10300_PROC_MN103E010
101         bool "MN103E010"
102         depends on MN10300_UNIT_ASB2303 || MN10300_UNIT_ASB2305
103         select AM33_2
104         select MN10300_PROC_HAS_TTYSM0
105         select MN10300_PROC_HAS_TTYSM1
106         select MN10300_PROC_HAS_TTYSM2
107
108 config MN10300_PROC_MN2WS0050
109         bool "MN2WS0050"
110         depends on MN10300_UNIT_ASB2364
111         select AM34_2
112         select MN10300_PROC_HAS_TTYSM0
113         select MN10300_PROC_HAS_TTYSM1
114         select MN10300_PROC_HAS_TTYSM2
115
116 endchoice
117
118 config MN10300_HAS_ATOMIC_OPS_UNIT
119         def_bool n
120         help
121           This should be enabled if the processor has an atomic ops unit
122           capable of doing LL/SC equivalent operations.
123
124 config FPU
125         bool "FPU present"
126         default y
127         depends on MN10300_PROC_MN103E010 || MN10300_PROC_MN2WS0050
128
129 config LAZY_SAVE_FPU
130         bool "Save FPU state lazily"
131         default y
132         depends on FPU && !SMP
133         help
134           Enable this to be lazy in the saving of the FPU state to the owning
135           task's thread struct.  This is useful if most tasks on the system
136           don't use the FPU as only those tasks that use it will pass it
137           between them, and the state needn't be saved for a task that isn't
138           using it.
139
140           This can't be so easily used on SMP as the process that owns the FPU
141           state on a CPU may be currently running on another CPU, so for the
142           moment, it is disabled.
143
144 source "arch/mn10300/mm/Kconfig.cache"
145
146 config MN10300_TLB_USE_PIDR
147         def_bool y
148
149 menu "Memory layout options"
150
151 config KERNEL_RAM_BASE_ADDRESS
152         hex "Base address of kernel RAM"
153         default "0x90000000"
154
155 config INTERRUPT_VECTOR_BASE
156         hex "Base address of vector table"
157         default "0x90000000"
158         help
159           The base address of the vector table will be programmed into
160           the TBR register. It must be on 16MiB address boundary.
161
162 config KERNEL_TEXT_ADDRESS
163         hex "Base address of kernel"
164         default "0x90001000"
165
166 config KERNEL_ZIMAGE_BASE_ADDRESS
167         hex "Base address of compressed vmlinux image"
168         default "0x50700000"
169
170 config BOOT_STACK_OFFSET
171         hex
172         default "0xF00" if SMP
173         default "0xFF0" if !SMP
174
175 config BOOT_STACK_SIZE
176         hex
177         depends on SMP
178         default "0x100"
179 endmenu
180
181 config SMP
182         bool "Symmetric multi-processing support"
183         default y
184         select USE_GENERIC_SMP_HELPERS
185         depends on MN10300_PROC_MN2WS0038 || MN10300_PROC_MN2WS0050
186         ---help---
187           This enables support for systems with more than one CPU. If you have
188           a system with only one CPU, like most personal computers, say N. If
189           you have a system with more than one CPU, say Y.
190
191           If you say N here, the kernel will run on single and multiprocessor
192           machines, but will use only one CPU of a multiprocessor machine. If
193           you say Y here, the kernel will run on many, but not all,
194           singleprocessor machines. On a singleprocessor machine, the kernel
195           will run faster if you say N here.
196
197           See also <file:Documentation/x86/i386/IO-APIC.txt>,
198           <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO available at
199           <http://www.tldp.org/docs.html#howto>.
200
201           If you don't know what to do here, say N.
202
203 config NR_CPUS
204         int
205         depends on SMP
206         default "2"
207
208 source "kernel/Kconfig.preempt"
209
210 config MN10300_CURRENT_IN_E2
211         bool "Hold current task address in E2 register"
212         depends on !SMP
213         default y
214         help
215           This option removes the E2/R2 register from the set available to gcc
216           for normal use and instead uses it to store the address of the
217           current process's task_struct whilst in the kernel.
218
219           This means the kernel doesn't need to calculate the address each time
220           "current" is used (take SP, AND with mask and dereference pointer
221           just to get the address), and instead can just use E2+offset
222           addressing each time.
223
224           This has no effect on userspace.
225
226 config MN10300_USING_JTAG
227         bool "Using JTAG to debug kernel"
228         default y
229         help
230           This options indicates that JTAG will be used to debug the kernel. It
231           suppresses the use of certain hardware debugging features, such as
232           single-stepping, which are taken over completely by the JTAG unit.
233
234 source "kernel/Kconfig.hz"
235 source "kernel/time/Kconfig"
236
237 config MN10300_RTC
238         bool "Using MN10300 RTC"
239         depends on MN10300_PROC_MN103E010 || MN10300_PROC_MN2WS0050
240         select GENERIC_CMOS_UPDATE
241         default n
242         help
243           This option enables support for the RTC, thus enabling time to be
244           tracked, even when system is powered down. This is available on-chip
245           on the MN103E010.
246
247 config MN10300_WD_TIMER
248         bool "Using MN10300 watchdog timer"
249         default y
250         help
251           This options indicates that the watchdog timer will be used.
252
253 config PCI
254         bool "Use PCI"
255         depends on MN10300_UNIT_ASB2305
256         default y
257         select GENERIC_PCI_IOMAP
258         help
259           Some systems (such as the ASB2305) have PCI onboard. If you have one
260           of these boards and you wish to use the PCI facilities, say Y here.
261
262           The PCI-HOWTO, available from
263           <http://www.tldp.org/docs.html#howto>, contains valuable
264           information about which PCI hardware does work under Linux and which
265           doesn't.
266
267 source "drivers/pci/Kconfig"
268
269 source "drivers/pcmcia/Kconfig"
270
271 menu "MN10300 internal serial options"
272
273 config MN10300_PROC_HAS_TTYSM0
274         bool
275         default n
276
277 config MN10300_PROC_HAS_TTYSM1
278         bool
279         default n
280
281 config MN10300_PROC_HAS_TTYSM2
282         bool
283         default n
284
285 config MN10300_TTYSM
286         bool "Support for ttySM serial ports"
287         depends on MN10300
288         default y
289         select SERIAL_CORE
290         help
291           This option enables support for the on-chip serial ports that the
292           MN10300 has available.
293
294 config MN10300_TTYSM_CONSOLE
295         bool "Support for console on ttySM serial ports"
296         depends on MN10300_TTYSM
297         select SERIAL_CORE_CONSOLE
298         help
299           This option enables support for a console on the on-chip serial ports
300           that the MN10300 has available.
301
302 #
303 # /dev/ttySM0
304 #
305 config MN10300_TTYSM0
306         bool "Enable SIF0 (/dev/ttySM0)"
307         depends on MN10300_TTYSM && MN10300_PROC_HAS_TTYSM0
308         help
309           Enable access to SIF0 through /dev/ttySM0 or gdb-stub
310
311 choice
312         prompt "Select the timer to supply the clock for SIF0"
313         default MN10300_TTYSM0_TIMER8
314         depends on MN10300_TTYSM0
315
316 config MN10300_TTYSM0_TIMER8
317         bool "Use timer 8 (16-bit)"
318
319 config MN10300_TTYSM0_TIMER2
320         bool "Use timer 2 (8-bit)"
321
322 endchoice
323
324 #
325 # /dev/ttySM1
326 #
327 config MN10300_TTYSM1
328         bool "Enable SIF1 (/dev/ttySM1)"
329         depends on MN10300_TTYSM && MN10300_PROC_HAS_TTYSM1
330         help
331           Enable access to SIF1 through /dev/ttySM1 or gdb-stub
332
333 choice
334         prompt "Select the timer to supply the clock for SIF1"
335         default MN10300_TTYSM1_TIMER12 \
336                 if !(AM33_2 || AM33_3)
337         default MN10300_TTYSM1_TIMER9 \
338                 if AM33_2 || AM33_3
339         depends on MN10300_TTYSM1
340
341 config MN10300_TTYSM1_TIMER12
342         bool "Use timer 12 (16-bit)"
343         depends on !(AM33_2 || AM33_3)
344
345 config MN10300_TTYSM1_TIMER9
346         bool "Use timer 9 (16-bit)"
347         depends on AM33_2 || AM33_3
348
349 config MN10300_TTYSM1_TIMER3
350         bool "Use timer 3 (8-bit)"
351         depends on AM33_2 || AM33_3
352
353 endchoice
354
355 #
356 # /dev/ttySM2
357 #
358 config MN10300_TTYSM2
359         bool "Enable SIF2 (/dev/ttySM2)"
360         depends on MN10300_TTYSM && MN10300_PROC_HAS_TTYSM2
361         help
362           Enable access to SIF2 through /dev/ttySM2 or gdb-stub
363
364 choice
365         prompt "Select the timer to supply the clock for SIF2"
366         default MN10300_TTYSM2_TIMER3 \
367                 if !(AM33_2 || AM33_3)
368         default MN10300_TTYSM2_TIMER10 \
369                 if AM33_2 || AM33_3
370         depends on MN10300_TTYSM2
371
372 config MN10300_TTYSM2_TIMER9
373         bool "Use timer 9 (16-bit)"
374         depends on !(AM33_2 || AM33_3)
375
376 config MN10300_TTYSM2_TIMER1
377         bool "Use timer 1 (8-bit)"
378         depends on !(AM33_2 || AM33_3)
379
380 config MN10300_TTYSM2_TIMER3
381         bool "Use timer 3 (8-bit)"
382         depends on !(AM33_2 || AM33_3)
383
384 config MN10300_TTYSM2_TIMER10
385         bool "Use timer 10 (16-bit)"
386         depends on AM33_2 || AM33_3
387
388 endchoice
389
390 config MN10300_TTYSM2_CTS
391         bool "Enable the use of the CTS line /dev/ttySM2"
392         depends on MN10300_TTYSM2 && AM33_2
393
394 endmenu
395
396 menu "Interrupt request priority options"
397
398 comment "[!] NOTE: A lower number/level indicates a higher priority (0 is highest, 6 is lowest)"
399
400 comment "____Non-maskable interrupt levels____"
401 comment "The following must be set to a higher priority than local_irq_disable() and on-chip serial"
402
403 config DEBUGGER_IRQ_LEVEL
404         int "DEBUGGER interrupt priority"
405         depends on KERNEL_DEBUGGER
406         range 0 1 if LINUX_CLI_LEVEL = 2
407         range 0 2 if LINUX_CLI_LEVEL = 3
408         range 0 3 if LINUX_CLI_LEVEL = 4
409         range 0 4 if LINUX_CLI_LEVEL = 5
410         range 0 5 if LINUX_CLI_LEVEL = 6
411         default 0
412
413 comment "The following must be set to a higher priority than local_irq_disable()"
414
415 config MN10300_SERIAL_IRQ_LEVEL
416         int "MN10300 on-chip serial interrupt priority"
417         depends on MN10300_TTYSM
418         range 1 1 if LINUX_CLI_LEVEL = 2
419         range 1 2 if LINUX_CLI_LEVEL = 3
420         range 1 3 if LINUX_CLI_LEVEL = 4
421         range 1 4 if LINUX_CLI_LEVEL = 5
422         range 1 5 if LINUX_CLI_LEVEL = 6
423         default 1
424
425 comment "-"
426 comment "____Maskable interrupt levels____"
427
428 config LINUX_CLI_LEVEL
429         int "The highest interrupt priority excluded by local_irq_disable() (2-6)"
430         range 2 6
431         default 2
432         help
433           local_irq_disable() doesn't actually disable maskable interrupts -
434           what it does is restrict the levels of interrupt which are permitted
435           (a lower level indicates a higher priority) by lowering the value in
436           EPSW.IM from 7.  Any interrupt is permitted for which the level is
437           lower than EPSW.IM.
438
439           Certain interrupts, such as DEBUGGER and virtual MN10300 on-chip
440           serial DMA interrupts are allowed to interrupt normal disabled
441           sections.
442
443 comment "The following must be set to a equal to or lower priority than LINUX_CLI_LEVEL"
444
445 config TIMER_IRQ_LEVEL
446         int "Kernel timer interrupt priority"
447         range LINUX_CLI_LEVEL 6
448         default 4
449
450 config PCI_IRQ_LEVEL
451         int "PCI interrupt priority"
452         depends on PCI
453         range LINUX_CLI_LEVEL 6
454         default 5
455
456 config ETHERNET_IRQ_LEVEL
457         int "Ethernet interrupt priority"
458         depends on SMC91X || SMC911X || SMSC911X
459         range LINUX_CLI_LEVEL 6
460         default 6
461
462 config EXT_SERIAL_IRQ_LEVEL
463         int "External serial port interrupt priority"
464         depends on SERIAL_8250
465         range LINUX_CLI_LEVEL 6
466         default 6
467
468 endmenu
469
470 source "mm/Kconfig"
471
472 menu "Power management options"
473 source kernel/power/Kconfig
474 endmenu
475
476 endmenu
477
478
479 menu "Executable formats"
480
481 source "fs/Kconfig.binfmt"
482
483 endmenu
484
485 source "net/Kconfig"
486
487 source "drivers/Kconfig"
488
489 source "fs/Kconfig"
490
491 source "arch/mn10300/Kconfig.debug"
492
493 source "security/Kconfig"
494
495 source "crypto/Kconfig"
496
497 source "lib/Kconfig"