mn10300: add the MN10300/AM33 architecture to the kernel
[deliverable/linux.git] / arch / mn10300 / Kconfig
1 #
2 # For a description of the syntax of this configuration file,
3 # see Documentation/kbuild/kconfig-language.txt.
4 #
5
6 mainmenu "Linux Kernel Configuration"
7
8 config MN10300
9 def_bool y
10
11 config AM33
12 def_bool y
13
14 config MMU
15 def_bool y
16
17 config HIGHMEM
18 def_bool n
19
20 config NUMA
21 def_bool n
22
23 config UID16
24 def_bool y
25
26 config RWSEM_GENERIC_SPINLOCK
27 def_bool y
28
29 config RWSEM_XCHGADD_ALGORITHM
30 bool
31
32 config GENERIC_HARDIRQS_NO__DO_IRQ
33 def_bool y
34
35 config GENERIC_CALIBRATE_DELAY
36 def_bool y
37
38 config GENERIC_FIND_NEXT_BIT
39 def_bool y
40
41 config GENERIC_HWEIGHT
42 def_bool y
43
44 config GENERIC_TIME
45 def_bool y
46
47 config GENERIC_BUG
48 def_bool y
49
50 config QUICKLIST
51 def_bool y
52
53 config ARCH_HAS_ILOG2_U32
54 def_bool y
55
56 config ARCH_SUPPORTS_AOUT
57 def_bool n
58
59 # Use the generic interrupt handling code in kernel/irq/
60 config GENERIC_HARDIRQS
61 def_bool y
62
63 config HOTPLUG_CPU
64 def_bool n
65
66 mainmenu "Matsushita MN10300/AM33 Kernel Configuration"
67
68 source "init/Kconfig"
69
70
71 menu "Matsushita MN10300 system setup"
72
73 choice
74 prompt "Unit type"
75 default MN10300_UNIT_ASB2303
76 help
77 This option specifies board for which the kernel will be
78 compiled. It affects the external peripherals catered for.
79
80 config MN10300_UNIT_ASB2303
81 bool "ASB2303"
82
83 config MN10300_UNIT_ASB2305
84 bool "ASB2305"
85
86 endchoice
87
88 choice
89 prompt "Processor support"
90 default MN10300_PROC_MN103E010
91 help
92 This option specifies the processor for which the kernel will be
93 compiled. It affects the on-chip peripherals catered for.
94
95 config MN10300_PROC_MN103E010
96 bool "MN103E010"
97 depends on MN10300_UNIT_ASB2303 || MN10300_UNIT_ASB2305
98 select MN10300_PROC_HAS_TTYSM0
99 select MN10300_PROC_HAS_TTYSM1
100 select MN10300_PROC_HAS_TTYSM2
101
102 endchoice
103
104 choice
105 prompt "Processor core support"
106 default MN10300_CPU_AM33V2
107 help
108 This option specifies the processor core for which the kernel will be
109 compiled. It affects the instruction set used.
110
111 config MN10300_CPU_AM33V2
112 bool "AM33v2"
113
114 endchoice
115
116 config FPU
117 bool "FPU present"
118 default y
119 depends on MN10300_PROC_MN103E010
120
121 choice
122 prompt "CPU Caching mode"
123 default MN10300_CACHE_WBACK
124 help
125 This option determines the caching mode for the kernel.
126
127 Write-Back caching mode involves the all reads and writes causing
128 the affected cacheline to be read into the cache first before being
129 operated upon. Memory is not then updated by a write until the cache
130 is filled and a cacheline needs to be displaced from the cache to
131 make room. Only at that point is it written back.
132
133 Write-Through caching only fetches cachelines from memory on a
134 read. Writes always get written directly to memory. If the affected
135 cacheline is also in cache, it will be updated too.
136
137 The final option is to turn of caching entirely.
138
139 config MN10300_CACHE_WBACK
140 bool "Write-Back"
141
142 config MN10300_CACHE_WTHRU
143 bool "Write-Through"
144
145 config MN10300_CACHE_DISABLED
146 bool "Disabled"
147
148 endchoice
149
150 menu "Memory layout options"
151
152 config KERNEL_RAM_BASE_ADDRESS
153 hex "Base address of kernel RAM"
154 default "0x90000000"
155
156 config INTERRUPT_VECTOR_BASE
157 hex "Base address of vector table"
158 default "0x90000000"
159 help
160 The base address of the vector table will be programmed into
161 the TBR register. It must be on 16MiB address boundary.
162
163 config KERNEL_TEXT_ADDRESS
164 hex "Base address of kernel"
165 default "0x90001000"
166
167 config KERNEL_ZIMAGE_BASE_ADDRESS
168 hex "Base address of compressed vmlinux image"
169 default "0x90700000"
170
171 endmenu
172
173 config PREEMPT
174 bool "Preemptible Kernel"
175 help
176 This option reduces the latency of the kernel when reacting to
177 real-time or interactive events by allowing a low priority process to
178 be preempted even if it is in kernel mode executing a system call.
179 This allows applications to run more reliably even when the system is
180 under load.
181
182 Say Y here if you are building a kernel for a desktop, embedded
183 or real-time system. Say N if you are unsure.
184
185 config PREEMPT_BKL
186 bool "Preempt The Big Kernel Lock"
187 depends on PREEMPT
188 default y
189 help
190 This option reduces the latency of the kernel by making the
191 big kernel lock preemptible.
192
193 Say Y here if you are building a kernel for a desktop system.
194 Say N if you are unsure.
195
196 config MN10300_CURRENT_IN_E2
197 bool "Hold current task address in E2 register"
198 default y
199 help
200 This option removes the E2/R2 register from the set available to gcc
201 for normal use and instead uses it to store the address of the
202 current process's task_struct whilst in the kernel.
203
204 This means the kernel doesn't need to calculate the address each time
205 "current" is used (take SP, AND with mask and dereference pointer
206 just to get the address), and instead can just use E2+offset
207 addressing each time.
208
209 This has no effect on userspace.
210
211 config MN10300_USING_JTAG
212 bool "Using JTAG to debug kernel"
213 default y
214 help
215 This options indicates that JTAG will be used to debug the kernel. It
216 suppresses the use of certain hardware debugging features, such as
217 single-stepping, which are taken over completely by the JTAG unit.
218
219 config MN10300_RTC
220 bool "Using MN10300 RTC"
221 depends on MN10300_PROC_MN103E010
222 default n
223 help
224
225 This option enables support for the RTC, thus enabling time to be
226 tracked, even when system is powered down. This is available on-chip
227 on the MN103E010.
228
229 config MN10300_WD_TIMER
230 bool "Using MN10300 watchdog timer"
231 default y
232 help
233 This options indicates that the watchdog timer will be used.
234
235 config PCI
236 bool "Use PCI"
237 depends on MN10300_UNIT_ASB2305
238 default y
239 help
240 Some systems (such as the ASB2305) have PCI onboard. If you have one
241 of these boards and you wish to use the PCI facilities, say Y here.
242
243 The PCI-HOWTO, available from
244 <http://www.tldp.org/docs.html#howto>, contains valuable
245 information about which PCI hardware does work under Linux and which
246 doesn't.
247
248 source "drivers/pci/Kconfig"
249
250 source "drivers/pcmcia/Kconfig"
251
252 menu "MN10300 internal serial options"
253
254 config MN10300_PROC_HAS_TTYSM0
255 bool
256 default n
257
258 config MN10300_PROC_HAS_TTYSM1
259 bool
260 default n
261
262 config MN10300_PROC_HAS_TTYSM2
263 bool
264 default n
265
266 config MN10300_TTYSM
267 bool "Support for ttySM serial ports"
268 depends on MN10300
269 default y
270 select SERIAL_CORE
271 help
272 This option enables support for the on-chip serial ports that the
273 MN10300 has available.
274
275 config MN10300_TTYSM_CONSOLE
276 bool "Support for console on ttySM serial ports"
277 depends on MN10300_TTYSM
278 select SERIAL_CORE_CONSOLE
279 help
280 This option enables support for a console on the on-chip serial ports
281 that the MN10300 has available.
282
283 #
284 # /dev/ttySM0
285 #
286 config MN10300_TTYSM0
287 bool "Enable SIF0 (/dev/ttySM0)"
288 depends on MN10300_TTYSM && MN10300_PROC_HAS_TTYSM0
289 help
290 Enable access to SIF0 through /dev/ttySM0 or gdb-stub
291
292 choice
293 prompt "Select the timer to supply the clock for SIF0"
294 default MN10300_TTYSM0_TIMER8
295 depends on MN10300_TTYSM0
296
297 config MN10300_TTYSM0_TIMER8
298 bool "Use timer 8 (16-bit)"
299
300 config MN10300_TTYSM0_TIMER2
301 bool "Use timer 2 (8-bit)"
302
303 endchoice
304
305 #
306 # /dev/ttySM1
307 #
308 config MN10300_TTYSM1
309 bool "Enable SIF1 (/dev/ttySM1)"
310 depends on MN10300_TTYSM && MN10300_PROC_HAS_TTYSM1
311 help
312 Enable access to SIF1 through /dev/ttySM1 or gdb-stub
313
314 choice
315 prompt "Select the timer to supply the clock for SIF1"
316 default MN10300_TTYSM0_TIMER9
317 depends on MN10300_TTYSM1
318
319 config MN10300_TTYSM1_TIMER9
320 bool "Use timer 9 (16-bit)"
321
322 config MN10300_TTYSM1_TIMER3
323 bool "Use timer 3 (8-bit)"
324
325 endchoice
326
327 #
328 # /dev/ttySM2
329 #
330 config MN10300_TTYSM2
331 bool "Enable SIF2 (/dev/ttySM2)"
332 depends on MN10300_TTYSM && MN10300_PROC_HAS_TTYSM2
333 help
334 Enable access to SIF2 through /dev/ttySM2 or gdb-stub
335
336 choice
337 prompt "Select the timer to supply the clock for SIF2"
338 default MN10300_TTYSM0_TIMER10
339 depends on MN10300_TTYSM2
340
341 config MN10300_TTYSM2_TIMER10
342 bool "Use timer 10 (16-bit)"
343
344 endchoice
345
346 config MN10300_TTYSM2_CTS
347 bool "Enable the use of the CTS line /dev/ttySM2"
348 depends on MN10300_TTYSM2
349
350 endmenu
351
352 source "mm/Kconfig"
353
354 menu "Power management options"
355 source kernel/power/Kconfig
356 endmenu
357
358 endmenu
359
360
361 menu "Executable formats"
362
363 source "fs/Kconfig.binfmt"
364
365 endmenu
366
367 source "net/Kconfig"
368
369 source "drivers/Kconfig"
370
371 source "fs/Kconfig"
372
373 source "arch/mn10300/Kconfig.debug"
374
375 source "security/Kconfig"
376
377 source "crypto/Kconfig"
378
379 source "lib/Kconfig"
380
381 source "arch/mn10300/oprofile/Kconfig"
This page took 0.04009 seconds and 5 git commands to generate.