Loading...
1config M32R
2 bool
3 default y
4 select HAVE_IDE
5 select HAVE_OPROFILE
6 select INIT_ALL_POSSIBLE
7 select HAVE_KERNEL_GZIP
8 select HAVE_KERNEL_BZIP2
9 select HAVE_KERNEL_LZMA
10 select HAVE_GENERIC_HARDIRQS
11 select GENERIC_IRQ_PROBE
12 select GENERIC_IRQ_SHOW
13
14config SBUS
15 bool
16
17config GENERIC_ISA_DMA
18 bool
19 default y
20
21config ZONE_DMA
22 bool
23 default y
24
25config NO_IOPORT
26 def_bool y
27
28config NO_DMA
29 def_bool y
30
31config HZ
32 int
33 default 100
34
35config ARCH_USES_GETTIMEOFFSET
36 def_bool y
37
38source "init/Kconfig"
39
40source "kernel/Kconfig.freezer"
41
42
43menu "Processor type and features"
44
45choice
46 prompt "Platform Type"
47 default PLAT_MAPPI
48
49config PLAT_MAPPI
50 bool "Mappi-I"
51 help
52 The Mappi-I is an FPGA board for SOC (System-On-a-Chip) prototyping.
53 You can operate a Linux system on this board by using an M32R
54 softmacro core, which is a fully-synthesizable functional model
55 described in Verilog-HDL.
56
57 The Mappi-I board was the first platform, which had been used
58 to port and develop a Linux system for the M32R processor.
59 Currently, the Mappi-II, an heir to the Mappi-I, is available.
60
61config PLAT_USRV
62 bool "uServer"
63 select PLAT_HAS_INT1ICU
64
65config PLAT_M32700UT
66 bool "M32700UT"
67 select PLAT_HAS_INT0ICU
68 select PLAT_HAS_INT1ICU
69 select PLAT_HAS_INT2ICU
70 help
71 The M3T-M32700UT is an evaluation board based on uT-Engine
72 specification. This board has an M32700 (Chaos) evaluation chip.
73 You can say Y for SMP, because the M32700 is a single chip
74 multiprocessor.
75
76config PLAT_OPSPUT
77 bool "OPSPUT"
78 select PLAT_HAS_INT0ICU
79 select PLAT_HAS_INT1ICU
80 select PLAT_HAS_INT2ICU
81 help
82 The OPSPUT is an evaluation board based on uT-Engine
83 specification. This board has a OPSP-REP chip.
84
85config PLAT_OAKS32R
86 bool "OAKS32R"
87 help
88 The OAKS32R is a tiny, inexpensive evaluation board.
89 Please note that if you say Y here and choose chip "M32102",
90 say N for MMU and select a no-MMU version kernel, otherwise
91 a kernel with MMU support will not work, because the M32102
92 is a microcontroller for embedded systems and it has no MMU.
93
94config PLAT_MAPPI2
95 bool "Mappi-II(M3A-ZA36/M3A-ZA52)"
96
97config PLAT_MAPPI3
98 bool "Mappi-III(M3A-2170)"
99
100config PLAT_M32104UT
101 bool "M32104UT"
102 select PLAT_HAS_INT1ICU
103 help
104 The M3T-M32104UT is an reference board based on uT-Engine
105 specification. This board has a M32104 chip.
106
107endchoice
108
109choice
110 prompt "Processor family"
111 default CHIP_M32700
112
113config CHIP_M32700
114 bool "M32700 (Chaos)"
115
116config CHIP_M32102
117 bool "M32102"
118
119config CHIP_M32104
120 bool "M32104"
121 depends on PLAT_M32104UT
122
123config CHIP_VDEC2
124 bool "VDEC2"
125
126config CHIP_OPSP
127 bool "OPSP"
128
129endchoice
130
131config MMU
132 bool "Support for memory management hardware"
133 depends on CHIP_M32700 || CHIP_VDEC2 || CHIP_OPSP
134 default y
135
136config TLB_ENTRIES
137 int "TLB Entries"
138 depends on CHIP_M32700 || CHIP_VDEC2 || CHIP_OPSP
139 default 32 if CHIP_M32700 || CHIP_OPSP
140 default 16 if CHIP_VDEC2
141
142
143config ISA_M32R
144 bool
145 depends on CHIP_M32102 || CHIP_M32104
146 default y
147
148config ISA_M32R2
149 bool
150 depends on CHIP_M32700 || CHIP_VDEC2 || CHIP_OPSP
151 default y
152
153config ISA_DSP_LEVEL2
154 bool
155 depends on CHIP_M32700 || CHIP_OPSP
156 default y
157
158config ISA_DUAL_ISSUE
159 bool
160 depends on CHIP_M32700 || CHIP_OPSP
161 default y
162
163config PLAT_HAS_INT0ICU
164 bool
165 default n
166
167config PLAT_HAS_INT1ICU
168 bool
169 default n
170
171config PLAT_HAS_INT2ICU
172 bool
173 default n
174
175config BUS_CLOCK
176 int "Bus Clock [Hz] (integer)"
177 default "70000000" if PLAT_MAPPI
178 default "25000000" if PLAT_USRV
179 default "50000000" if PLAT_MAPPI3
180 default "50000000" if PLAT_M32700UT
181 default "50000000" if PLAT_OPSPUT
182 default "54000000" if PLAT_M32104UT
183 default "33333333" if PLAT_OAKS32R
184 default "20000000" if PLAT_MAPPI2
185
186config TIMER_DIVIDE
187 int "Timer divider (integer)"
188 default "128"
189
190config CPU_LITTLE_ENDIAN
191 bool "Generate little endian code"
192 default n
193
194config MEMORY_START
195 hex "Physical memory start address (hex)"
196 default "08000000" if PLAT_MAPPI || PLAT_MAPPI2 || PLAT_MAPPI3
197 default "08000000" if PLAT_USRV
198 default "08000000" if PLAT_M32700UT
199 default "08000000" if PLAT_OPSPUT
200 default "04000000" if PLAT_M32104UT
201 default "01000000" if PLAT_OAKS32R
202
203config MEMORY_SIZE
204 hex "Physical memory size (hex)"
205 default "08000000" if PLAT_MAPPI3
206 default "04000000" if PLAT_MAPPI || PLAT_MAPPI2
207 default "02000000" if PLAT_USRV
208 default "01000000" if PLAT_M32700UT
209 default "01000000" if PLAT_OPSPUT
210 default "01000000" if PLAT_M32104UT
211 default "00800000" if PLAT_OAKS32R
212
213config ARCH_DISCONTIGMEM_ENABLE
214 bool "Internal RAM Support"
215 depends on CHIP_M32700 || CHIP_M32102 || CHIP_VDEC2 || CHIP_OPSP || CHIP_M32104
216 default y
217
218source "mm/Kconfig"
219
220config IRAM_START
221 hex "Internal memory start address (hex)"
222 default "00f00000" if !CHIP_M32104
223 default "00700000" if CHIP_M32104
224 depends on (CHIP_M32700 || CHIP_M32102 || CHIP_VDEC2 || CHIP_OPSP || CHIP_M32104) && DISCONTIGMEM
225
226config IRAM_SIZE
227 hex "Internal memory size (hex)"
228 depends on (CHIP_M32700 || CHIP_M32102 || CHIP_VDEC2 || CHIP_OPSP || CHIP_M32104) && DISCONTIGMEM
229 default "00080000" if CHIP_M32700
230 default "00010000" if CHIP_M32102 || CHIP_OPSP || CHIP_M32104
231 default "00008000" if CHIP_VDEC2
232
233#
234# Define implied options from the CPU selection here
235#
236
237config GENERIC_LOCKBREAK
238 bool
239 default y
240 depends on SMP && PREEMPT
241
242config RWSEM_GENERIC_SPINLOCK
243 bool
244 depends on M32R
245 default y
246
247config RWSEM_XCHGADD_ALGORITHM
248 bool
249 default n
250
251config ARCH_HAS_ILOG2_U32
252 bool
253 default n
254
255config ARCH_HAS_ILOG2_U64
256 bool
257 default n
258
259config GENERIC_HWEIGHT
260 bool
261 default y
262
263config GENERIC_CALIBRATE_DELAY
264 bool
265 default y
266
267config SCHED_OMIT_FRAME_POINTER
268 bool
269 default y
270
271source "kernel/Kconfig.preempt"
272
273config SMP
274 bool "Symmetric multi-processing support"
275 select USE_GENERIC_SMP_HELPERS
276 ---help---
277 This enables support for systems with more than one CPU. If you have
278 a system with only one CPU, like most personal computers, say N. If
279 you have a system with more than one CPU, say Y.
280
281 If you say N here, the kernel will run on single and multiprocessor
282 machines, but will use only one CPU of a multiprocessor machine. If
283 you say Y here, the kernel will run on many, but not all,
284 singleprocessor machines. On a singleprocessor machine, the kernel
285 will run faster if you say N here.
286
287 People using multiprocessor machines who say Y here should also say
288 Y to "Enhanced Real Time Clock Support", below. The "Advanced Power
289 Management" code will be disabled if you say Y here.
290
291 See also the SMP-HOWTO available at
292 <http://tldp.org/HOWTO/SMP-HOWTO.html>.
293
294 If you don't know what to do here, say N.
295
296config CHIP_M32700_TS1
297 bool "Workaround code for the M32700 TS1 chip's bug"
298 depends on (CHIP_M32700 && SMP)
299 default n
300
301config NR_CPUS
302 int "Maximum number of CPUs (2-32)"
303 range 2 32
304 depends on SMP
305 default "2"
306 help
307 This allows you to specify the maximum number of CPUs which this
308 kernel will support. The maximum supported value is 32 and the
309 minimum value which makes sense is 2.
310
311 This is purely to save memory - each supported CPU adds
312 approximately eight kilobytes to the kernel image.
313
314# Common NUMA Features
315config NUMA
316 bool "Numa Memory Allocation Support"
317 depends on SMP && BROKEN
318 default n
319
320config NODES_SHIFT
321 int
322 default "1"
323 depends on NEED_MULTIPLE_NODES
324
325# turning this on wastes a bunch of space.
326# Summit needs it only when NUMA is on
327config BOOT_IOREMAP
328 bool
329 depends on NUMA
330 default n
331
332endmenu
333
334
335menu "Bus options (PCI, PCMCIA, EISA, MCA, ISA)"
336
337config PCI
338 bool "PCI support"
339 depends on BROKEN
340 default n
341 help
342 Find out whether you have a PCI motherboard. PCI is the name of a
343 bus system, i.e. the way the CPU talks to the other stuff inside
344 your box. Other bus systems are ISA, EISA, MicroChannel (MCA) or
345 VESA. If you have PCI, say Y, otherwise N.
346
347choice
348 prompt "PCI access mode"
349 depends on PCI
350 default PCI_GOANY
351
352config PCI_GOBIOS
353 bool "BIOS"
354 ---help---
355 On PCI systems, the BIOS can be used to detect the PCI devices and
356 determine their configuration. However, some old PCI motherboards
357 have BIOS bugs and may crash if this is done. Also, some embedded
358 PCI-based systems don't have any BIOS at all. Linux can also try to
359 detect the PCI hardware directly without using the BIOS.
360
361 With this option, you can specify how Linux should detect the PCI
362 devices. If you choose "BIOS", the BIOS will be used, if you choose
363 "Direct", the BIOS won't be used, and if you choose "Any", the
364 kernel will try the direct access method and falls back to the BIOS
365 if that doesn't work. If unsure, go with the default, which is
366 "Any".
367
368config PCI_GODIRECT
369 bool "Direct"
370
371config PCI_GOANY
372 bool "Any"
373
374endchoice
375
376config PCI_BIOS
377 bool
378 depends on PCI && (PCI_GOBIOS || PCI_GOANY)
379 default y
380
381config PCI_DIRECT
382 bool
383 depends on PCI && (PCI_GODIRECT || PCI_GOANY)
384 default y
385
386source "drivers/pci/Kconfig"
387
388config ISA
389 bool
390
391source "drivers/pcmcia/Kconfig"
392
393source "drivers/pci/hotplug/Kconfig"
394
395endmenu
396
397
398menu "Executable file formats"
399
400source "fs/Kconfig.binfmt"
401
402endmenu
403
404source "net/Kconfig"
405
406source "drivers/Kconfig"
407
408source "fs/Kconfig"
409
410source "arch/m32r/Kconfig.debug"
411
412source "security/Kconfig"
413
414source "crypto/Kconfig"
415
416source "lib/Kconfig"
1config M32R
2 bool
3 default y
4 select HAVE_IDE
5 select HAVE_OPROFILE
6 select INIT_ALL_POSSIBLE
7 select HAVE_KERNEL_GZIP
8 select HAVE_KERNEL_BZIP2
9 select HAVE_KERNEL_LZMA
10 select ARCH_WANT_IPC_PARSE_VERSION
11 select HAVE_DEBUG_BUGVERBOSE
12 select VIRT_TO_BUS
13 select GENERIC_IRQ_PROBE
14 select GENERIC_IRQ_SHOW
15 select GENERIC_ATOMIC64
16 select ARCH_HAS_DEVMEM_IS_ALLOWED
17 select ARCH_USES_GETTIMEOFFSET
18 select MODULES_USE_ELF_RELA
19 select HAVE_DEBUG_STACKOVERFLOW
20
21config SBUS
22 bool
23
24config GENERIC_ISA_DMA
25 bool
26 default y
27
28config ZONE_DMA
29 bool
30 default y
31
32config NO_IOPORT_MAP
33 def_bool y
34
35config NO_DMA
36 def_bool y
37
38config HZ
39 int
40 default 100
41
42source "init/Kconfig"
43
44source "kernel/Kconfig.freezer"
45
46
47menu "Processor type and features"
48
49choice
50 prompt "Platform Type"
51 default PLAT_MAPPI
52
53config PLAT_MAPPI
54 bool "Mappi-I"
55 help
56 The Mappi-I is an FPGA board for SOC (System-On-a-Chip) prototyping.
57 You can operate a Linux system on this board by using an M32R
58 softmacro core, which is a fully-synthesizable functional model
59 described in Verilog-HDL.
60
61 The Mappi-I board was the first platform, which had been used
62 to port and develop a Linux system for the M32R processor.
63 Currently, the Mappi-II, an heir to the Mappi-I, is available.
64
65config PLAT_USRV
66 bool "uServer"
67 select PLAT_HAS_INT1ICU
68
69config PLAT_M32700UT
70 bool "M32700UT"
71 select PLAT_HAS_INT0ICU
72 select PLAT_HAS_INT1ICU
73 select PLAT_HAS_INT2ICU
74 help
75 The M3T-M32700UT is an evaluation board based on uT-Engine
76 specification. This board has an M32700 (Chaos) evaluation chip.
77 You can say Y for SMP, because the M32700 is a single chip
78 multiprocessor.
79
80config PLAT_OPSPUT
81 bool "OPSPUT"
82 select PLAT_HAS_INT0ICU
83 select PLAT_HAS_INT1ICU
84 select PLAT_HAS_INT2ICU
85 help
86 The OPSPUT is an evaluation board based on uT-Engine
87 specification. This board has a OPSP-REP chip.
88
89config PLAT_OAKS32R
90 bool "OAKS32R"
91 help
92 The OAKS32R is a tiny, inexpensive evaluation board.
93 Please note that if you say Y here and choose chip "M32102",
94 say N for MMU and select a no-MMU version kernel, otherwise
95 a kernel with MMU support will not work, because the M32102
96 is a microcontroller for embedded systems and it has no MMU.
97
98config PLAT_MAPPI2
99 bool "Mappi-II(M3A-ZA36/M3A-ZA52)"
100
101config PLAT_MAPPI3
102 bool "Mappi-III(M3A-2170)"
103
104config PLAT_M32104UT
105 bool "M32104UT"
106 select PLAT_HAS_INT1ICU
107 help
108 The M3T-M32104UT is an reference board based on uT-Engine
109 specification. This board has a M32104 chip.
110
111endchoice
112
113choice
114 prompt "Processor family"
115 default CHIP_M32700
116
117config CHIP_M32700
118 bool "M32700 (Chaos)"
119
120config CHIP_M32102
121 bool "M32102"
122
123config CHIP_M32104
124 bool "M32104"
125 depends on PLAT_M32104UT
126
127config CHIP_VDEC2
128 bool "VDEC2"
129
130config CHIP_OPSP
131 bool "OPSP"
132
133endchoice
134
135config MMU
136 bool "Support for memory management hardware"
137 depends on CHIP_M32700 || CHIP_VDEC2 || CHIP_OPSP
138 default y
139
140config TLB_ENTRIES
141 int "TLB Entries"
142 depends on CHIP_M32700 || CHIP_VDEC2 || CHIP_OPSP
143 default 32 if CHIP_M32700 || CHIP_OPSP
144 default 16 if CHIP_VDEC2
145
146
147config ISA_M32R
148 bool
149 depends on CHIP_M32102 || CHIP_M32104
150 default y
151
152config ISA_M32R2
153 bool
154 depends on CHIP_M32700 || CHIP_VDEC2 || CHIP_OPSP
155 default y
156
157config ISA_DSP_LEVEL2
158 bool
159 depends on CHIP_M32700 || CHIP_OPSP
160 default y
161
162config ISA_DUAL_ISSUE
163 bool
164 depends on CHIP_M32700 || CHIP_OPSP
165 default y
166
167config PLAT_HAS_INT0ICU
168 bool
169 default n
170
171config PLAT_HAS_INT1ICU
172 bool
173 default n
174
175config PLAT_HAS_INT2ICU
176 bool
177 default n
178
179config BUS_CLOCK
180 int "Bus Clock [Hz] (integer)"
181 default "70000000" if PLAT_MAPPI
182 default "25000000" if PLAT_USRV
183 default "50000000" if PLAT_MAPPI3
184 default "50000000" if PLAT_M32700UT
185 default "50000000" if PLAT_OPSPUT
186 default "54000000" if PLAT_M32104UT
187 default "33333333" if PLAT_OAKS32R
188 default "20000000" if PLAT_MAPPI2
189
190config TIMER_DIVIDE
191 int "Timer divider (integer)"
192 default "128"
193
194config CPU_LITTLE_ENDIAN
195 bool "Generate little endian code"
196 default n
197
198config MEMORY_START
199 hex "Physical memory start address (hex)"
200 default "08000000" if PLAT_MAPPI || PLAT_MAPPI2 || PLAT_MAPPI3
201 default "08000000" if PLAT_USRV
202 default "08000000" if PLAT_M32700UT
203 default "08000000" if PLAT_OPSPUT
204 default "04000000" if PLAT_M32104UT
205 default "01000000" if PLAT_OAKS32R
206
207config MEMORY_SIZE
208 hex "Physical memory size (hex)"
209 default "08000000" if PLAT_MAPPI3
210 default "04000000" if PLAT_MAPPI || PLAT_MAPPI2
211 default "02000000" if PLAT_USRV
212 default "01000000" if PLAT_M32700UT
213 default "01000000" if PLAT_OPSPUT
214 default "01000000" if PLAT_M32104UT
215 default "00800000" if PLAT_OAKS32R
216
217config ARCH_DISCONTIGMEM_ENABLE
218 bool "Internal RAM Support"
219 depends on CHIP_M32700 || CHIP_M32102 || CHIP_VDEC2 || CHIP_OPSP || CHIP_M32104
220 default y
221
222source "mm/Kconfig"
223
224config IRAM_START
225 hex "Internal memory start address (hex)"
226 default "00f00000" if !CHIP_M32104
227 default "00700000" if CHIP_M32104
228 depends on (CHIP_M32700 || CHIP_M32102 || CHIP_VDEC2 || CHIP_OPSP || CHIP_M32104) && DISCONTIGMEM
229
230config IRAM_SIZE
231 hex "Internal memory size (hex)"
232 depends on (CHIP_M32700 || CHIP_M32102 || CHIP_VDEC2 || CHIP_OPSP || CHIP_M32104) && DISCONTIGMEM
233 default "00080000" if CHIP_M32700
234 default "00010000" if CHIP_M32102 || CHIP_OPSP || CHIP_M32104
235 default "00008000" if CHIP_VDEC2
236
237#
238# Define implied options from the CPU selection here
239#
240
241config GENERIC_LOCKBREAK
242 bool
243 default y
244 depends on SMP && PREEMPT
245
246config RWSEM_GENERIC_SPINLOCK
247 bool
248 depends on M32R
249 default y
250
251config RWSEM_XCHGADD_ALGORITHM
252 bool
253 default n
254
255config ARCH_HAS_ILOG2_U32
256 bool
257 default n
258
259config ARCH_HAS_ILOG2_U64
260 bool
261 default n
262
263config GENERIC_HWEIGHT
264 bool
265 default y
266
267config GENERIC_CALIBRATE_DELAY
268 bool
269 default y
270
271config SCHED_OMIT_FRAME_POINTER
272 bool
273 default y
274
275source "kernel/Kconfig.preempt"
276
277config SMP
278 bool "Symmetric multi-processing support"
279 depends on MMU
280 ---help---
281 This enables support for systems with more than one CPU. If you have
282 a system with only one CPU, say N. If you have a system with more
283 than one CPU, say Y.
284
285 If you say N here, the kernel will run on uni- and multiprocessor
286 machines, but will use only one CPU of a multiprocessor machine. If
287 you say Y here, the kernel will run on many, but not all,
288 uniprocessor machines. On a uniprocessor machine, the kernel
289 will run faster if you say N here.
290
291 People using multiprocessor machines who say Y here should also say
292 Y to "Enhanced Real Time Clock Support", below. The "Advanced Power
293 Management" code will be disabled if you say Y here.
294
295 See also the SMP-HOWTO available at
296 <http://tldp.org/HOWTO/SMP-HOWTO.html>.
297
298 If you don't know what to do here, say N.
299
300config CHIP_M32700_TS1
301 bool "Workaround code for the M32700 TS1 chip's bug"
302 depends on (CHIP_M32700 && SMP)
303 default n
304
305config NR_CPUS
306 int "Maximum number of CPUs (2-32)"
307 range 2 32
308 depends on SMP
309 default "2"
310 help
311 This allows you to specify the maximum number of CPUs which this
312 kernel will support. The maximum supported value is 32 and the
313 minimum value which makes sense is 2.
314
315 This is purely to save memory - each supported CPU adds
316 approximately eight kilobytes to the kernel image.
317
318# Common NUMA Features
319config NUMA
320 bool "Numa Memory Allocation Support"
321 depends on SMP && BROKEN
322 default n
323
324config NODES_SHIFT
325 int
326 default "1"
327 depends on NEED_MULTIPLE_NODES
328
329endmenu
330
331
332menu "Bus options (PCI, PCMCIA, EISA, MCA, ISA)"
333
334config PCI
335 bool "PCI support"
336 depends on BROKEN
337 default n
338 help
339 Find out whether you have a PCI motherboard. PCI is the name of a
340 bus system, i.e. the way the CPU talks to the other stuff inside
341 your box. Other bus systems are ISA, EISA, MicroChannel (MCA) or
342 VESA. If you have PCI, say Y, otherwise N.
343
344choice
345 prompt "PCI access mode"
346 depends on PCI
347 default PCI_GOANY
348
349config PCI_GOBIOS
350 bool "BIOS"
351 ---help---
352 On PCI systems, the BIOS can be used to detect the PCI devices and
353 determine their configuration. However, some old PCI motherboards
354 have BIOS bugs and may crash if this is done. Also, some embedded
355 PCI-based systems don't have any BIOS at all. Linux can also try to
356 detect the PCI hardware directly without using the BIOS.
357
358 With this option, you can specify how Linux should detect the PCI
359 devices. If you choose "BIOS", the BIOS will be used, if you choose
360 "Direct", the BIOS won't be used, and if you choose "Any", the
361 kernel will try the direct access method and falls back to the BIOS
362 if that doesn't work. If unsure, go with the default, which is
363 "Any".
364
365config PCI_GODIRECT
366 bool "Direct"
367
368config PCI_GOANY
369 bool "Any"
370
371endchoice
372
373config PCI_BIOS
374 bool
375 depends on PCI && (PCI_GOBIOS || PCI_GOANY)
376 default y
377
378config PCI_DIRECT
379 bool
380 depends on PCI && (PCI_GODIRECT || PCI_GOANY)
381 default y
382
383source "drivers/pci/Kconfig"
384
385config ISA
386 bool
387
388source "drivers/pcmcia/Kconfig"
389
390endmenu
391
392
393menu "Executable file formats"
394
395source "fs/Kconfig.binfmt"
396
397endmenu
398
399source "net/Kconfig"
400
401source "drivers/Kconfig"
402
403source "fs/Kconfig"
404
405source "arch/m32r/Kconfig.debug"
406
407source "security/Kconfig"
408
409source "crypto/Kconfig"
410
411source "lib/Kconfig"