blob: 92623818a1fe0ecb6147ceed0ebeb900a79df49e [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001config M32R
2 bool
3 default y
Sam Ravnborgec7748b2008-02-09 10:46:40 +01004 select HAVE_IDE
Mathieu Desnoyers42d4b832008-02-02 15:10:34 -05005 select HAVE_OPROFILE
Rusty Russell98a79d62008-12-13 21:19:41 +10306 select INIT_ALL_POSSIBLE
Hirokazu Takata337214e2009-10-15 09:21:56 +09007 select HAVE_KERNEL_GZIP
8 select HAVE_KERNEL_BZIP2
9 select HAVE_KERNEL_LZMA
Will Deaconc1d7e012012-07-30 14:42:46 -070010 select ARCH_WANT_IPC_PARSE_VERSION
Catalin Marinas9b2a60c2012-10-08 16:28:13 -070011 select HAVE_DEBUG_BUGVERBOSE
Thomas Gleixner0e155b22011-01-19 19:17:10 +010012 select HAVE_GENERIC_HARDIRQS
Stephen Rothwell887cbce02013-02-27 17:05:48 -080013 select HAVE_VIRT_TO_BUS
Thomas Gleixner0e155b22011-01-19 19:17:10 +010014 select GENERIC_IRQ_PROBE
Thomas Gleixner4bdab7e2011-03-24 19:24:55 +010015 select GENERIC_IRQ_SHOW
Steven Rostedtabcefec2011-10-13 10:40:16 -040016 select GENERIC_ATOMIC64
Anna-Maria Gleixner97a1c1e2012-05-18 16:45:48 +000017 select ARCH_USES_GETTIMEOFFSET
David Howells786d35d2012-09-28 14:31:03 +093018 select MODULES_USE_ELF_RELA
Linus Torvalds1da177e2005-04-16 15:20:36 -070019
20config SBUS
21 bool
22
Linus Torvalds1da177e2005-04-16 15:20:36 -070023config GENERIC_ISA_DMA
24 bool
25 default y
26
Christoph Lameter5ac6da62007-02-10 01:43:14 -080027config ZONE_DMA
28 bool
29 default y
30
Al Viro5ea81762007-02-11 15:41:31 +000031config NO_IOPORT
32 def_bool y
33
Dan Williams1b0fac42007-07-15 23:40:26 -070034config NO_DMA
35 def_bool y
36
H. Peter Anvinbdc80782008-02-08 04:21:26 -080037config HZ
38 int
39 default 100
40
Linus Torvalds1da177e2005-04-16 15:20:36 -070041source "init/Kconfig"
42
Matt Helsleydc52ddc2008-10-18 20:27:21 -070043source "kernel/Kconfig.freezer"
44
Linus Torvalds1da177e2005-04-16 15:20:36 -070045
46menu "Processor type and features"
47
48choice
49 prompt "Platform Type"
50 default PLAT_MAPPI
51
52config PLAT_MAPPI
53 bool "Mappi-I"
54 help
55 The Mappi-I is an FPGA board for SOC (System-On-a-Chip) prototyping.
56 You can operate a Linux system on this board by using an M32R
57 softmacro core, which is a fully-synthesizable functional model
58 described in Verilog-HDL.
59
60 The Mappi-I board was the first platform, which had been used
61 to port and develop a Linux system for the M32R processor.
62 Currently, the Mappi-II, an heir to the Mappi-I, is available.
63
64config PLAT_USRV
65 bool "uServer"
Hirokazu Takatae070fb742007-08-17 17:22:15 +090066 select PLAT_HAS_INT1ICU
Linus Torvalds1da177e2005-04-16 15:20:36 -070067
68config PLAT_M32700UT
69 bool "M32700UT"
Hirokazu Takatae070fb742007-08-17 17:22:15 +090070 select PLAT_HAS_INT0ICU
71 select PLAT_HAS_INT1ICU
72 select PLAT_HAS_INT2ICU
Linus Torvalds1da177e2005-04-16 15:20:36 -070073 help
74 The M3T-M32700UT is an evaluation board based on uT-Engine
75 specification. This board has an M32700 (Chaos) evaluation chip.
76 You can say Y for SMP, because the M32700 is a single chip
77 multiprocessor.
78
79config PLAT_OPSPUT
80 bool "OPSPUT"
Hirokazu Takatae070fb742007-08-17 17:22:15 +090081 select PLAT_HAS_INT0ICU
82 select PLAT_HAS_INT1ICU
83 select PLAT_HAS_INT2ICU
Linus Torvalds1da177e2005-04-16 15:20:36 -070084 help
85 The OPSPUT is an evaluation board based on uT-Engine
86 specification. This board has a OPSP-REP chip.
87
88config PLAT_OAKS32R
89 bool "OAKS32R"
90 help
91 The OAKS32R is a tiny, inexpensive evaluation board.
92 Please note that if you say Y here and choose chip "M32102",
93 say N for MMU and select a no-MMU version kernel, otherwise
94 a kernel with MMU support will not work, because the M32102
95 is a microcontroller for embedded systems and it has no MMU.
96
97config PLAT_MAPPI2
98 bool "Mappi-II(M3A-ZA36/M3A-ZA52)"
99
Hirokazu Takata23680862005-06-21 17:16:10 -0700100config PLAT_MAPPI3
101 bool "Mappi-III(M3A-2170)"
102
Hirokazu Takata9287d952006-01-06 00:18:41 -0800103config PLAT_M32104UT
104 bool "M32104UT"
Hirokazu Takatae070fb742007-08-17 17:22:15 +0900105 select PLAT_HAS_INT1ICU
Hirokazu Takata9287d952006-01-06 00:18:41 -0800106 help
107 The M3T-M32104UT is an reference board based on uT-Engine
108 specification. This board has a M32104 chip.
109
Linus Torvalds1da177e2005-04-16 15:20:36 -0700110endchoice
111
112choice
113 prompt "Processor family"
114 default CHIP_M32700
115
116config CHIP_M32700
117 bool "M32700 (Chaos)"
118
119config CHIP_M32102
120 bool "M32102"
121
Hirokazu Takata9287d952006-01-06 00:18:41 -0800122config CHIP_M32104
123 bool "M32104"
124 depends on PLAT_M32104UT
125
Linus Torvalds1da177e2005-04-16 15:20:36 -0700126config CHIP_VDEC2
127 bool "VDEC2"
128
129config CHIP_OPSP
130 bool "OPSP"
131
132endchoice
133
134config MMU
135 bool "Support for memory management hardware"
136 depends on CHIP_M32700 || CHIP_VDEC2 || CHIP_OPSP
137 default y
138
139config TLB_ENTRIES
140 int "TLB Entries"
141 depends on CHIP_M32700 || CHIP_VDEC2 || CHIP_OPSP
142 default 32 if CHIP_M32700 || CHIP_OPSP
143 default 16 if CHIP_VDEC2
144
145
146config ISA_M32R
147 bool
Hirokazu Takata9287d952006-01-06 00:18:41 -0800148 depends on CHIP_M32102 || CHIP_M32104
Linus Torvalds1da177e2005-04-16 15:20:36 -0700149 default y
150
151config ISA_M32R2
152 bool
153 depends on CHIP_M32700 || CHIP_VDEC2 || CHIP_OPSP
154 default y
155
156config ISA_DSP_LEVEL2
157 bool
158 depends on CHIP_M32700 || CHIP_OPSP
159 default y
160
161config ISA_DUAL_ISSUE
162 bool
163 depends on CHIP_M32700 || CHIP_OPSP
164 default y
165
Hirokazu Takatae070fb742007-08-17 17:22:15 +0900166config PLAT_HAS_INT0ICU
167 bool
168 default n
169
170config PLAT_HAS_INT1ICU
171 bool
172 default n
173
174config PLAT_HAS_INT2ICU
175 bool
176 default n
177
Linus Torvalds1da177e2005-04-16 15:20:36 -0700178config BUS_CLOCK
179 int "Bus Clock [Hz] (integer)"
180 default "70000000" if PLAT_MAPPI
181 default "25000000" if PLAT_USRV
Hirokazu Takata23680862005-06-21 17:16:10 -0700182 default "50000000" if PLAT_MAPPI3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700183 default "50000000" if PLAT_M32700UT
184 default "50000000" if PLAT_OPSPUT
Hirokazu Takata9287d952006-01-06 00:18:41 -0800185 default "54000000" if PLAT_M32104UT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700186 default "33333333" if PLAT_OAKS32R
187 default "20000000" if PLAT_MAPPI2
188
189config TIMER_DIVIDE
190 int "Timer divider (integer)"
191 default "128"
192
193config CPU_LITTLE_ENDIAN
194 bool "Generate little endian code"
195 default n
196
197config MEMORY_START
198 hex "Physical memory start address (hex)"
Hirokazu Takata23680862005-06-21 17:16:10 -0700199 default "08000000" if PLAT_MAPPI || PLAT_MAPPI2 || PLAT_MAPPI3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700200 default "08000000" if PLAT_USRV
201 default "08000000" if PLAT_M32700UT
202 default "08000000" if PLAT_OPSPUT
Hirokazu Takata9287d952006-01-06 00:18:41 -0800203 default "04000000" if PLAT_M32104UT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700204 default "01000000" if PLAT_OAKS32R
205
206config MEMORY_SIZE
207 hex "Physical memory size (hex)"
Hirokazu Takata23680862005-06-21 17:16:10 -0700208 default "08000000" if PLAT_MAPPI3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700209 default "04000000" if PLAT_MAPPI || PLAT_MAPPI2
210 default "02000000" if PLAT_USRV
211 default "01000000" if PLAT_M32700UT
212 default "01000000" if PLAT_OPSPUT
Hirokazu Takata9287d952006-01-06 00:18:41 -0800213 default "01000000" if PLAT_M32104UT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700214 default "00800000" if PLAT_OAKS32R
215
Dave Hansen3f22ab22005-06-23 00:07:43 -0700216config ARCH_DISCONTIGMEM_ENABLE
Linus Torvalds1da177e2005-04-16 15:20:36 -0700217 bool "Internal RAM Support"
Hirokazu Takata9287d952006-01-06 00:18:41 -0800218 depends on CHIP_M32700 || CHIP_M32102 || CHIP_VDEC2 || CHIP_OPSP || CHIP_M32104
Linus Torvalds1da177e2005-04-16 15:20:36 -0700219 default y
220
Dave Hansen3f22ab22005-06-23 00:07:43 -0700221source "mm/Kconfig"
222
Linus Torvalds1da177e2005-04-16 15:20:36 -0700223config IRAM_START
224 hex "Internal memory start address (hex)"
Hirokazu Takata9287d952006-01-06 00:18:41 -0800225 default "00f00000" if !CHIP_M32104
226 default "00700000" if CHIP_M32104
227 depends on (CHIP_M32700 || CHIP_M32102 || CHIP_VDEC2 || CHIP_OPSP || CHIP_M32104) && DISCONTIGMEM
Linus Torvalds1da177e2005-04-16 15:20:36 -0700228
229config IRAM_SIZE
230 hex "Internal memory size (hex)"
Hirokazu Takata9287d952006-01-06 00:18:41 -0800231 depends on (CHIP_M32700 || CHIP_M32102 || CHIP_VDEC2 || CHIP_OPSP || CHIP_M32104) && DISCONTIGMEM
Linus Torvalds1da177e2005-04-16 15:20:36 -0700232 default "00080000" if CHIP_M32700
Hirokazu Takata9287d952006-01-06 00:18:41 -0800233 default "00010000" if CHIP_M32102 || CHIP_OPSP || CHIP_M32104
Linus Torvalds1da177e2005-04-16 15:20:36 -0700234 default "00008000" if CHIP_VDEC2
235
236#
237# Define implied options from the CPU selection here
238#
239
Nick Piggin95c354f2008-01-30 13:31:20 +0100240config GENERIC_LOCKBREAK
241 bool
242 default y
243 depends on SMP && PREEMPT
244
Linus Torvalds1da177e2005-04-16 15:20:36 -0700245config RWSEM_GENERIC_SPINLOCK
246 bool
247 depends on M32R
248 default y
249
250config RWSEM_XCHGADD_ALGORITHM
251 bool
252 default n
253
David Howellsf0d1b0b2006-12-08 02:37:49 -0800254config ARCH_HAS_ILOG2_U32
255 bool
256 default n
257
258config ARCH_HAS_ILOG2_U64
259 bool
260 default n
261
Akinobu Mita6d9f9372006-03-26 01:39:26 -0800262config GENERIC_HWEIGHT
263 bool
264 default y
265
Linus Torvalds1da177e2005-04-16 15:20:36 -0700266config GENERIC_CALIBRATE_DELAY
267 bool
268 default y
269
Ingo Molnarae1e9132008-11-11 09:05:16 +0100270config SCHED_OMIT_FRAME_POINTER
Hirokazu Takata43c09ce2007-05-10 22:22:25 -0700271 bool
272 default y
273
Frederic Weisbeckerdab16ae2011-07-05 16:29:40 +0200274source "kernel/Kconfig.preempt"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700275
Linus Torvalds1da177e2005-04-16 15:20:36 -0700276config SMP
277 bool "Symmetric multi-processing support"
Jens Axboe7b7426c2008-06-10 20:49:30 +0200278 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700279 ---help---
280 This enables support for systems with more than one CPU. If you have
281 a system with only one CPU, like most personal computers, say N. If
282 you have a system with more than one CPU, say Y.
283
284 If you say N here, the kernel will run on single and multiprocessor
285 machines, but will use only one CPU of a multiprocessor machine. If
286 you say Y here, the kernel will run on many, but not all,
287 singleprocessor machines. On a singleprocessor machine, the kernel
288 will run faster if you say N here.
289
290 People using multiprocessor machines who say Y here should also say
291 Y to "Enhanced Real Time Clock Support", below. The "Advanced Power
292 Management" code will be disabled if you say Y here.
293
Adrian Bunk03502fa2008-02-03 15:50:21 +0200294 See also the SMP-HOWTO available at
Justin P. Mattock50a23e62010-10-16 10:36:23 -0700295 <http://tldp.org/HOWTO/SMP-HOWTO.html>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700296
297 If you don't know what to do here, say N.
298
299config CHIP_M32700_TS1
300 bool "Workaround code for the M32700 TS1 chip's bug"
301 depends on (CHIP_M32700 && SMP)
302 default n
303
304config NR_CPUS
305 int "Maximum number of CPUs (2-32)"
306 range 2 32
307 depends on SMP
308 default "2"
309 help
310 This allows you to specify the maximum number of CPUs which this
311 kernel will support. The maximum supported value is 32 and the
312 minimum value which makes sense is 2.
313
314 This is purely to save memory - each supported CPU adds
315 approximately eight kilobytes to the kernel image.
316
317# Common NUMA Features
318config NUMA
319 bool "Numa Memory Allocation Support"
Al Viroc5596b22005-08-23 22:45:11 +0100320 depends on SMP && BROKEN
Linus Torvalds1da177e2005-04-16 15:20:36 -0700321 default n
322
Yasunori Gotoc80d79d2006-04-10 22:53:53 -0700323config NODES_SHIFT
324 int
325 default "1"
326 depends on NEED_MULTIPLE_NODES
327
Linus Torvalds1da177e2005-04-16 15:20:36 -0700328endmenu
329
330
331menu "Bus options (PCI, PCMCIA, EISA, MCA, ISA)"
332
333config PCI
334 bool "PCI support"
Al Viroc3a0f772005-08-23 22:45:31 +0100335 depends on BROKEN
Linus Torvalds1da177e2005-04-16 15:20:36 -0700336 default n
337 help
338 Find out whether you have a PCI motherboard. PCI is the name of a
339 bus system, i.e. the way the CPU talks to the other stuff inside
340 your box. Other bus systems are ISA, EISA, MicroChannel (MCA) or
341 VESA. If you have PCI, say Y, otherwise N.
342
Linus Torvalds1da177e2005-04-16 15:20:36 -0700343choice
344 prompt "PCI access mode"
345 depends on PCI
346 default PCI_GOANY
347
348config PCI_GOBIOS
349 bool "BIOS"
350 ---help---
351 On PCI systems, the BIOS can be used to detect the PCI devices and
352 determine their configuration. However, some old PCI motherboards
353 have BIOS bugs and may crash if this is done. Also, some embedded
354 PCI-based systems don't have any BIOS at all. Linux can also try to
355 detect the PCI hardware directly without using the BIOS.
356
357 With this option, you can specify how Linux should detect the PCI
358 devices. If you choose "BIOS", the BIOS will be used, if you choose
359 "Direct", the BIOS won't be used, and if you choose "Any", the
360 kernel will try the direct access method and falls back to the BIOS
361 if that doesn't work. If unsure, go with the default, which is
362 "Any".
363
364config PCI_GODIRECT
365 bool "Direct"
366
367config PCI_GOANY
368 bool "Any"
369
370endchoice
371
372config PCI_BIOS
373 bool
374 depends on PCI && (PCI_GOBIOS || PCI_GOANY)
375 default y
376
377config PCI_DIRECT
378 bool
379 depends on PCI && (PCI_GODIRECT || PCI_GOANY)
380 default y
381
382source "drivers/pci/Kconfig"
383
384config ISA
Adrian Bunk1b20b092008-09-24 14:58:54 +0900385 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -0700386
387source "drivers/pcmcia/Kconfig"
388
389source "drivers/pci/hotplug/Kconfig"
390
391endmenu
392
393
394menu "Executable file formats"
395
396source "fs/Kconfig.binfmt"
397
398endmenu
399
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700400source "net/Kconfig"
401
Linus Torvalds1da177e2005-04-16 15:20:36 -0700402source "drivers/Kconfig"
403
404source "fs/Kconfig"
405
Linus Torvalds1da177e2005-04-16 15:20:36 -0700406source "arch/m32r/Kconfig.debug"
407
408source "security/Kconfig"
409
410source "crypto/Kconfig"
411
412source "lib/Kconfig"