Merge with git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git
[linux-2.6] / arch / mips / Kconfig
1 config MIPS
2         bool
3         default y
4         # Horrible source of confusion.  Die, die, die ...
5         select EMBEDDED
6
7 mainmenu "Linux/MIPS Kernel Configuration"
8
9 menu "Machine selection"
10
11 choice
12         prompt "System type"
13         default SGI_IP22
14
15 config MIPS_MTX1
16         bool "Support for 4G Systems MTX-1 board"
17         select DMA_NONCOHERENT
18         select HW_HAS_PCI
19         select SOC_AU1500
20         select SYS_HAS_CPU_MIPS32_R1
21         select SYS_SUPPORTS_LITTLE_ENDIAN
22
23 config MIPS_BOSPORUS
24         bool "AMD Alchemy Bosporus board"
25         select SOC_AU1500
26         select DMA_NONCOHERENT
27         select SYS_HAS_CPU_MIPS32_R1
28         select SYS_SUPPORTS_LITTLE_ENDIAN
29
30 config MIPS_PB1000
31         bool "AMD Alchemy PB1000 board"
32         select SOC_AU1000
33         select DMA_NONCOHERENT
34         select HW_HAS_PCI
35         select SWAP_IO_SPACE
36         select SYS_HAS_CPU_MIPS32_R1
37         select SYS_SUPPORTS_LITTLE_ENDIAN
38
39 config MIPS_PB1100
40         bool "AMD Alchemy PB1100 board"
41         select SOC_AU1100
42         select DMA_NONCOHERENT
43         select HW_HAS_PCI
44         select SWAP_IO_SPACE
45         select SYS_HAS_CPU_MIPS32_R1
46         select SYS_SUPPORTS_LITTLE_ENDIAN
47
48 config MIPS_PB1500
49         bool "AMD Alchemy PB1500 board"
50         select SOC_AU1500
51         select DMA_NONCOHERENT
52         select HW_HAS_PCI
53         select SYS_HAS_CPU_MIPS32_R1
54         select SYS_SUPPORTS_LITTLE_ENDIAN
55
56 config MIPS_PB1550
57         bool "AMD Alchemy PB1550 board"
58         select SOC_AU1550
59         select DMA_NONCOHERENT
60         select HW_HAS_PCI
61         select MIPS_DISABLE_OBSOLETE_IDE
62         select SYS_HAS_CPU_MIPS32_R1
63         select SYS_SUPPORTS_LITTLE_ENDIAN
64
65 config MIPS_PB1200
66         bool "AMD Alchemy PB1200 board"
67         select SOC_AU1200
68         select DMA_NONCOHERENT
69         select MIPS_DISABLE_OBSOLETE_IDE
70         select SYS_HAS_CPU_MIPS32_R1
71         select SYS_SUPPORTS_LITTLE_ENDIAN
72
73 config MIPS_DB1000
74         bool "AMD Alchemy DB1000 board"
75         select SOC_AU1000
76         select DMA_NONCOHERENT
77         select HW_HAS_PCI
78         select SYS_HAS_CPU_MIPS32_R1
79         select SYS_SUPPORTS_LITTLE_ENDIAN
80
81 config MIPS_DB1100
82         bool "AMD Alchemy DB1100 board"
83         select SOC_AU1100
84         select DMA_NONCOHERENT
85         select SYS_HAS_CPU_MIPS32_R1
86         select SYS_SUPPORTS_LITTLE_ENDIAN
87
88 config MIPS_DB1500
89         bool "AMD Alchemy DB1500 board"
90         select SOC_AU1500
91         select DMA_NONCOHERENT
92         select HW_HAS_PCI
93         select MIPS_DISABLE_OBSOLETE_IDE
94         select SYS_HAS_CPU_MIPS32_R1
95         select SYS_SUPPORTS_BIG_ENDIAN
96         select SYS_SUPPORTS_LITTLE_ENDIAN
97
98 config MIPS_DB1550
99         bool "AMD Alchemy DB1550 board"
100         select SOC_AU1550
101         select HW_HAS_PCI
102         select DMA_NONCOHERENT
103         select MIPS_DISABLE_OBSOLETE_IDE
104         select SYS_HAS_CPU_MIPS32_R1
105         select SYS_SUPPORTS_LITTLE_ENDIAN
106
107 config MIPS_DB1200
108         bool "AMD Alchemy DB1200 board"
109         select SOC_AU1200
110         select DMA_COHERENT
111         select MIPS_DISABLE_OBSOLETE_IDE
112         select SYS_HAS_CPU_MIPS32_R1
113         select SYS_SUPPORTS_LITTLE_ENDIAN
114
115 config MIPS_MIRAGE
116         bool "AMD Alchemy Mirage board"
117         select DMA_NONCOHERENT
118         select SOC_AU1500
119         select SYS_HAS_CPU_MIPS32_R1
120         select SYS_SUPPORTS_LITTLE_ENDIAN
121
122 config MIPS_COBALT
123         bool "Support for Cobalt Server"
124         select DMA_NONCOHERENT
125         select HW_HAS_PCI
126         select I8259
127         select IRQ_CPU
128         select MIPS_GT64111
129         select SYS_HAS_CPU_NEVADA
130         select SYS_SUPPORTS_32BIT_KERNEL
131         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
132         select SYS_SUPPORTS_LITTLE_ENDIAN
133
134 config MACH_DECSTATION
135         bool "Support for DECstations"
136         select BOOT_ELF32
137         select DMA_NONCOHERENT
138         select EARLY_PRINTK
139         select IRQ_CPU
140         select SYS_HAS_CPU_R3000
141         select SYS_HAS_CPU_R4X00
142         select SYS_SUPPORTS_32BIT_KERNEL
143         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
144         select SYS_SUPPORTS_LITTLE_ENDIAN
145         help
146           This enables support for DEC's MIPS based workstations.  For details
147           see the Linux/MIPS FAQ on <http://www.linux-mips.org/> and the
148           DECstation porting pages on <http://decstation.unix-ag.org/>.
149
150           If you have one of the following DECstation Models you definitely
151           want to choose R4xx0 for the CPU Type:
152
153                 DECstation 5000/50
154                 DECstation 5000/150
155                 DECstation 5000/260
156                 DECsystem 5900/260
157
158           otherwise choose R3000.
159
160 config MIPS_EV64120
161         bool "Support for Galileo EV64120 Evaluation board (EXPERIMENTAL)"
162         depends on EXPERIMENTAL
163         select DMA_NONCOHERENT
164         select HW_HAS_PCI
165         select MIPS_GT64120
166         select SYS_HAS_CPU_R5000
167         select SYS_SUPPORTS_32BIT_KERNEL
168         select SYS_SUPPORTS_64BIT_KERNEL
169         select SYS_SUPPORTS_BIG_ENDIAN
170         help
171           This is an evaluation board based on the Galileo GT-64120
172           single-chip system controller that contains a MIPS R5000 compatible
173           core running at 75/100MHz.  Their website is located at
174           <http://www.marvell.com/>.  Say Y here if you wish to build a
175           kernel for this platform.
176
177 config MIPS_EV96100
178         bool "Support for Galileo EV96100 Evaluation board (EXPERIMENTAL)"
179         depends on EXPERIMENTAL
180         select DMA_NONCOHERENT
181         select HW_HAS_PCI
182         select IRQ_CPU
183         select MIPS_GT96100
184         select RM7000_CPU_SCACHE
185         select SWAP_IO_SPACE
186         select SYS_HAS_CPU_R5000
187         select SYS_HAS_CPU_RM7000
188         select SYS_SUPPORTS_32BIT_KERNEL
189         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
190         select SYS_SUPPORTS_BIG_ENDIAN
191         help
192           This is an evaluation board based on the Galileo GT-96100 LAN/WAN
193           communications controllers containing a MIPS R5000 compatible core
194           running at 83MHz. Their website is <http://www.marvell.com/>. Say Y
195           here if you wish to build a kernel for this platform.
196
197 config MIPS_IVR
198         bool "Support for Globespan IVR board"
199         select DMA_NONCOHERENT
200         select HW_HAS_PCI
201         select ITE_BOARD_GEN
202         select SYS_HAS_CPU_NEVADA
203         select SYS_SUPPORTS_32BIT_KERNEL
204         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
205         select SYS_SUPPORTS_LITTLE_ENDIAN
206         help
207           This is an evaluation board built by Globespan to showcase thir
208           iVR (Internet Video Recorder) design. It utilizes a QED RM5231
209           R5000 MIPS core. More information can be found out their website
210           located at <http://www.globespan.net/>. Say Y here if you wish to
211           build a kernel for this platform.
212
213 config MIPS_ITE8172
214         bool "Support for ITE 8172G board"
215         select DMA_NONCOHERENT
216         select HW_HAS_PCI
217         select ITE_BOARD_GEN
218         select SYS_HAS_CPU_R5432
219         select SYS_HAS_CPU_NEVADA
220         select SYS_SUPPORTS_32BIT_KERNEL
221         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
222         select SYS_SUPPORTS_LITTLE_ENDIAN
223         help
224           Ths is an evaluation board made by ITE <http://www.ite.com.tw/>
225           with ATX form factor that utilizes a MIPS R5000 to work with its
226           ITE8172G companion internet appliance chip. The MIPS core can be
227           either a NEC Vr5432 or QED RM5231. Say Y here if you wish to build
228           a kernel for this platform.
229
230 config MACH_JAZZ
231         bool "Support for the Jazz family of machines"
232         select ARC
233         select ARC32
234         select ARCH_MAY_HAVE_PC_FDC
235         select GENERIC_ISA_DMA
236         select I8259
237         select ISA
238         select SYS_HAS_CPU_R4X00
239         select SYS_SUPPORTS_32BIT_KERNEL
240         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
241         help
242          This a family of machines based on the MIPS R4030 chipset which was
243          used by several vendors to build RISC/os and Windows NT workstations.
244          Members include the Acer PICA, MIPS Magnum 4000, MIPS Millenium and
245          Olivetti M700-10 workstations.
246
247 config LASAT
248         bool "Support for LASAT Networks platforms"
249         select DMA_NONCOHERENT
250         select HW_HAS_PCI
251         select MIPS_GT64120
252         select MIPS_NILE4
253         select R5000_CPU_SCACHE
254         select SYS_HAS_CPU_R5000
255         select SYS_SUPPORTS_32BIT_KERNEL
256         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
257         select SYS_SUPPORTS_LITTLE_ENDIAN
258
259 config MIPS_ATLAS
260         bool "Support for MIPS Atlas board"
261         select BOOT_ELF32
262         select DMA_NONCOHERENT
263         select IRQ_CPU
264         select HW_HAS_PCI
265         select MIPS_BOARDS_GEN
266         select MIPS_BONITO64
267         select MIPS_GT64120
268         select MIPS_MSC
269         select RM7000_CPU_SCACHE
270         select SWAP_IO_SPACE
271         select SYS_HAS_CPU_MIPS32_R1
272         select SYS_HAS_CPU_MIPS32_R2
273         select SYS_HAS_CPU_MIPS64_R1
274         select SYS_HAS_CPU_NEVADA
275         select SYS_HAS_CPU_RM7000
276         select SYS_SUPPORTS_32BIT_KERNEL
277         select SYS_SUPPORTS_64BIT_KERNEL
278         select SYS_SUPPORTS_BIG_ENDIAN
279         select SYS_SUPPORTS_LITTLE_ENDIAN
280         help
281           This enables support for the MIPS Technologies Atlas evaluation
282           board.
283
284 config MIPS_MALTA
285         bool "Support for MIPS Malta board"
286         select ARCH_MAY_HAVE_PC_FDC
287         select BOOT_ELF32
288         select HAVE_STD_PC_SERIAL_PORT
289         select DMA_NONCOHERENT
290         select IRQ_CPU
291         select GENERIC_ISA_DMA
292         select HW_HAS_PCI
293         select I8259
294         select MIPS_BOARDS_GEN
295         select MIPS_BONITO64
296         select MIPS_GT64120
297         select MIPS_MSC
298         select SWAP_IO_SPACE
299         select SYS_HAS_CPU_MIPS32_R1
300         select SYS_HAS_CPU_MIPS32_R2
301         select SYS_HAS_CPU_MIPS64_R1
302         select SYS_HAS_CPU_NEVADA
303         select SYS_HAS_CPU_RM7000
304         select SYS_SUPPORTS_32BIT_KERNEL
305         select SYS_SUPPORTS_64BIT_KERNEL
306         select SYS_SUPPORTS_BIG_ENDIAN
307         select SYS_SUPPORTS_LITTLE_ENDIAN
308         help
309           This enables support for the MIPS Technologies Malta evaluation
310           board.
311
312 config MIPS_SEAD
313         bool "Support for MIPS SEAD board (EXPERIMENTAL)"
314         depends on EXPERIMENTAL
315         select IRQ_CPU
316         select DMA_NONCOHERENT
317         select MIPS_BOARDS_GEN
318         select SYS_HAS_CPU_MIPS32_R1
319         select SYS_HAS_CPU_MIPS32_R2
320         select SYS_HAS_CPU_MIPS64_R1
321         select SYS_SUPPORTS_32BIT_KERNEL
322         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
323         select SYS_SUPPORTS_BIG_ENDIAN
324         select SYS_SUPPORTS_LITTLE_ENDIAN
325         help
326           This enables support for the MIPS Technologies SEAD evaluation
327           board.
328
329 config MIPS_SIM
330         bool 'Support for MIPS simulator (MIPSsim)'
331         select DMA_NONCOHERENT
332         select IRQ_CPU
333         select SYS_HAS_CPU_MIPS32_R1
334         select SYS_HAS_CPU_MIPS32_R2
335         select SYS_SUPPORTS_32BIT_KERNEL
336         select SYS_SUPPORTS_BIG_ENDIAN
337         select SYS_SUPPORTS_LITTLE_ENDIAN
338         help
339           This option enables support for MIPS Technologies MIPSsim software
340           emulator.
341
342 config MOMENCO_JAGUAR_ATX
343         bool "Support for Momentum Jaguar board"
344         select BOOT_ELF32
345         select DMA_NONCOHERENT
346         select HW_HAS_PCI
347         select IRQ_CPU
348         select IRQ_CPU_RM7K
349         select IRQ_MV64340
350         select LIMITED_DMA
351         select PCI_MARVELL
352         select RM7000_CPU_SCACHE
353         select SWAP_IO_SPACE
354         select SYS_HAS_CPU_RM9000
355         select SYS_SUPPORTS_32BIT_KERNEL
356         select SYS_SUPPORTS_64BIT_KERNEL
357         select SYS_SUPPORTS_BIG_ENDIAN
358         help
359           The Jaguar ATX is a MIPS-based Single Board Computer (SBC) made by
360           Momentum Computer <http://www.momenco.com/>.
361
362 config MOMENCO_OCELOT
363         bool "Support for Momentum Ocelot board"
364         select DMA_NONCOHERENT
365         select HW_HAS_PCI
366         select IRQ_CPU
367         select IRQ_CPU_RM7K
368         select MIPS_GT64120
369         select RM7000_CPU_SCACHE
370         select SWAP_IO_SPACE
371         select SYS_HAS_CPU_RM7000
372         select SYS_SUPPORTS_32BIT_KERNEL
373         select SYS_SUPPORTS_64BIT_KERNEL
374         select SYS_SUPPORTS_BIG_ENDIAN
375         help
376           The Ocelot is a MIPS-based Single Board Computer (SBC) made by
377           Momentum Computer <http://www.momenco.com/>.
378
379 config MOMENCO_OCELOT_3
380         bool "Support for Momentum Ocelot-3 board"
381         select BOOT_ELF32
382         select DMA_NONCOHERENT
383         select HW_HAS_PCI
384         select IRQ_CPU
385         select IRQ_CPU_RM7K
386         select IRQ_MV64340
387         select PCI_MARVELL
388         select RM7000_CPU_SCACHE
389         select SWAP_IO_SPACE
390         select SYS_HAS_CPU_RM9000
391         select SYS_SUPPORTS_32BIT_KERNEL
392         select SYS_SUPPORTS_64BIT_KERNEL
393         select SYS_SUPPORTS_BIG_ENDIAN
394         help
395           The Ocelot-3 is based off Discovery III System Controller and
396           PMC-Sierra Rm79000 core.
397
398 config MOMENCO_OCELOT_C
399         bool "Support for Momentum Ocelot-C board"
400         select DMA_NONCOHERENT
401         select HW_HAS_PCI
402         select IRQ_CPU
403         select IRQ_MV64340
404         select PCI_MARVELL
405         select RM7000_CPU_SCACHE
406         select SWAP_IO_SPACE
407         select SYS_HAS_CPU_RM7000
408         select SYS_SUPPORTS_32BIT_KERNEL
409         select SYS_SUPPORTS_64BIT_KERNEL
410         select SYS_SUPPORTS_BIG_ENDIAN
411         help
412           The Ocelot is a MIPS-based Single Board Computer (SBC) made by
413           Momentum Computer <http://www.momenco.com/>.
414
415 config MOMENCO_OCELOT_G
416         bool "Support for Momentum Ocelot-G board"
417         select DMA_NONCOHERENT
418         select HW_HAS_PCI
419         select IRQ_CPU
420         select IRQ_CPU_RM7K
421         select PCI_MARVELL
422         select RM7000_CPU_SCACHE
423         select SWAP_IO_SPACE
424         select SYS_HAS_CPU_RM7000
425         select SYS_SUPPORTS_32BIT_KERNEL
426         select SYS_SUPPORTS_64BIT_KERNEL
427         select SYS_SUPPORTS_BIG_ENDIAN
428         help
429           The Ocelot is a MIPS-based Single Board Computer (SBC) made by
430           Momentum Computer <http://www.momenco.com/>.
431
432 config MIPS_XXS1500
433         bool "Support for MyCable XXS1500 board"
434         select DMA_NONCOHERENT
435         select SOC_AU1500
436         select SYS_SUPPORTS_LITTLE_ENDIAN
437
438 config PNX8550_V2PCI
439         bool "Support for Philips PNX8550 based Viper2-PCI board"
440         select PNX8550
441         select SYS_SUPPORTS_LITTLE_ENDIAN
442
443 config PNX8550_JBS
444         bool "Support for Philips PNX8550 based JBS board"
445         select PNX8550
446         select SYS_SUPPORTS_LITTLE_ENDIAN
447
448 config DDB5074
449         bool "Support for NEC DDB Vrc-5074 (EXPERIMENTAL)"
450         depends on EXPERIMENTAL
451         select DDB5XXX_COMMON
452         select DMA_NONCOHERENT
453         select HAVE_STD_PC_SERIAL_PORT
454         select HW_HAS_PCI
455         select IRQ_CPU
456         select I8259
457         select ISA
458         select SYS_HAS_CPU_R5000
459         select SYS_SUPPORTS_32BIT_KERNEL
460         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
461         select SYS_SUPPORTS_LITTLE_ENDIAN
462         help
463           This enables support for the VR5000-based NEC DDB Vrc-5074
464           evaluation board.
465
466 config DDB5476
467         bool "Support for NEC DDB Vrc-5476"
468         select DDB5XXX_COMMON
469         select DMA_NONCOHERENT
470         select HAVE_STD_PC_SERIAL_PORT
471         select HW_HAS_PCI
472         select IRQ_CPU
473         select I8259
474         select ISA
475         select SYS_HAS_CPU_R5432
476         select SYS_SUPPORTS_32BIT_KERNEL
477         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
478         select SYS_SUPPORTS_LITTLE_ENDIAN
479         help
480           This enables support for the R5432-based NEC DDB Vrc-5476
481           evaluation board.
482
483           Features : kernel debugging, serial terminal, NFS root fs, on-board
484           ether port USB, AC97, PCI, PCI VGA card & framebuffer console,
485           IDE controller, PS2 keyboard, PS2 mouse, etc.
486
487 config DDB5477
488         bool "Support for NEC DDB Vrc-5477"
489         select DDB5XXX_COMMON
490         select DMA_NONCOHERENT
491         select HW_HAS_PCI
492         select I8259
493         select IRQ_CPU
494         select SYS_HAS_CPU_R5432
495         select SYS_SUPPORTS_32BIT_KERNEL
496         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
497         select SYS_SUPPORTS_LITTLE_ENDIAN
498         help
499           This enables support for the R5432-based NEC DDB Vrc-5477,
500           or Rockhopper/SolutionGear boards with R5432/R5500 CPUs.
501
502           Features : kernel debugging, serial terminal, NFS root fs, on-board
503           ether port USB, AC97, PCI, etc.
504
505 config MACH_VR41XX
506         bool "Support for NEC VR4100 series based machines"
507         select SYS_HAS_CPU_VR41XX
508         select SYS_SUPPORTS_32BIT_KERNEL
509         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
510
511 config PMC_YOSEMITE
512         bool "Support for PMC-Sierra Yosemite eval board"
513         select DMA_COHERENT
514         select HW_HAS_PCI
515         select IRQ_CPU
516         select IRQ_CPU_RM7K
517         select IRQ_CPU_RM9K
518         select SWAP_IO_SPACE
519         select SYS_HAS_CPU_RM9000
520         select SYS_SUPPORTS_32BIT_KERNEL
521         select SYS_SUPPORTS_64BIT_KERNEL
522         select SYS_SUPPORTS_BIG_ENDIAN
523         select SYS_SUPPORTS_HIGHMEM
524         help
525           Yosemite is an evaluation board for the RM9000x2 processor
526           manufactured by PMC-Sierra.
527
528 config QEMU
529         bool "Support for Qemu"
530         select DMA_COHERENT
531         select GENERIC_ISA_DMA
532         select HAVE_STD_PC_SERIAL_PORT
533         select I8259
534         select ISA
535         select SWAP_IO_SPACE
536         select SYS_HAS_CPU_MIPS32_R1
537         select SYS_SUPPORTS_32BIT_KERNEL
538         select SYS_SUPPORTS_BIG_ENDIAN
539         help
540           Qemu is a software emulator which among other architectures also
541           can simulate a MIPS32 4Kc system.  This patch adds support for the
542           system architecture that currently is being simulated by Qemu.  It
543           will eventually be removed again when Qemu has the capability to
544           simulate actual MIPS hardware platforms.  More information on Qemu
545           can be found at http://www.linux-mips.org/wiki/Qemu.
546
547 config SGI_IP22
548         bool "Support for SGI IP22 (Indy/Indigo2)"
549         select ARC
550         select ARC32
551         select BOOT_ELF32
552         select DMA_NONCOHERENT
553         select HW_HAS_EISA
554         select IP22_CPU_SCACHE
555         select IRQ_CPU
556         select SWAP_IO_SPACE
557         select SYS_HAS_CPU_R4X00
558         select SYS_HAS_CPU_R5000
559         select SYS_SUPPORTS_32BIT_KERNEL
560         select SYS_SUPPORTS_64BIT_KERNEL
561         select SYS_SUPPORTS_BIG_ENDIAN
562         help
563           This are the SGI Indy, Challenge S and Indigo2, as well as certain
564           OEM variants like the Tandem CMN B006S. To compile a Linux kernel
565           that runs on these, say Y here.
566
567 config SGI_IP27
568         bool "Support for SGI IP27 (Origin200/2000)"
569         select ARC
570         select ARC64
571         select BOOT_ELF64
572         select DMA_IP27
573         select HW_HAS_PCI
574         select PCI_DOMAINS
575         select SYS_HAS_CPU_R10000
576         select SYS_SUPPORTS_64BIT_KERNEL
577         select SYS_SUPPORTS_BIG_ENDIAN
578         help
579           This are the SGI Origin 200, Origin 2000 and Onyx 2 Graphics
580           workstations.  To compile a Linux kernel that runs on these, say Y
581           here.
582
583 config SGI_IP32
584         bool "Support for SGI IP32 (O2) (EXPERIMENTAL)"
585         depends on EXPERIMENTAL
586         select ARC
587         select ARC32
588         select BOOT_ELF32
589         select OWN_DMA
590         select DMA_IP32
591         select DMA_NONCOHERENT
592         select HW_HAS_PCI
593         select R5000_CPU_SCACHE
594         select RM7000_CPU_SCACHE
595         select SYS_HAS_CPU_R5000
596         select SYS_HAS_CPU_R10000 if BROKEN
597         select SYS_HAS_CPU_RM7000
598         select SYS_HAS_CPU_NEVADA
599         select SYS_SUPPORTS_64BIT_KERNEL
600         select SYS_SUPPORTS_BIG_ENDIAN
601         help
602           If you want this kernel to run on SGI O2 workstation, say Y here.
603
604 config SIBYTE_BIGSUR
605         bool "Support for Sibyte BigSur"
606         select BOOT_ELF32
607         select DMA_COHERENT
608         select PCI_DOMAINS
609         select SIBYTE_BCM1x80
610         select SWAP_IO_SPACE
611         select SYS_HAS_CPU_SB1
612         select SYS_SUPPORTS_BIG_ENDIAN
613         select SYS_SUPPORTS_LITTLE_ENDIAN
614
615 config SIBYTE_SWARM
616         bool "Support for Sibyte BCM91250A-SWARM"
617         select BOOT_ELF32
618         select DMA_COHERENT
619         select SIBYTE_SB1250
620         select SWAP_IO_SPACE
621         select SYS_HAS_CPU_SB1
622         select SYS_SUPPORTS_BIG_ENDIAN
623         select SYS_SUPPORTS_HIGHMEM
624         select SYS_SUPPORTS_LITTLE_ENDIAN
625
626 config SIBYTE_SENTOSA
627         bool "Support for Sibyte BCM91250E-Sentosa"
628         depends on EXPERIMENTAL
629         select BOOT_ELF32
630         select DMA_COHERENT
631         select SIBYTE_SB1250
632         select SWAP_IO_SPACE
633         select SYS_HAS_CPU_SB1
634         select SYS_SUPPORTS_BIG_ENDIAN
635         select SYS_SUPPORTS_LITTLE_ENDIAN
636
637 config SIBYTE_RHONE
638         bool "Support for Sibyte BCM91125E-Rhone"
639         depends on EXPERIMENTAL
640         select BOOT_ELF32
641         select DMA_COHERENT
642         select SIBYTE_BCM1125H
643         select SWAP_IO_SPACE
644         select SYS_HAS_CPU_SB1
645         select SYS_SUPPORTS_BIG_ENDIAN
646         select SYS_SUPPORTS_LITTLE_ENDIAN
647
648 config SIBYTE_CARMEL
649         bool "Support for Sibyte BCM91120x-Carmel"
650         depends on EXPERIMENTAL
651         select BOOT_ELF32
652         select DMA_COHERENT
653         select SIBYTE_BCM1120
654         select SWAP_IO_SPACE
655         select SYS_HAS_CPU_SB1
656         select SYS_SUPPORTS_BIG_ENDIAN
657         select SYS_SUPPORTS_LITTLE_ENDIAN
658
659 config SIBYTE_PTSWARM
660         bool "Support for Sibyte BCM91250PT-PTSWARM"
661         depends on EXPERIMENTAL
662         select BOOT_ELF32
663         select DMA_COHERENT
664         select SIBYTE_SB1250
665         select SWAP_IO_SPACE
666         select SYS_HAS_CPU_SB1
667         select SYS_SUPPORTS_BIG_ENDIAN
668         select SYS_SUPPORTS_HIGHMEM
669         select SYS_SUPPORTS_LITTLE_ENDIAN
670
671 config SIBYTE_LITTLESUR
672         bool "Support for Sibyte BCM91250C2-LittleSur"
673         depends on EXPERIMENTAL
674         select BOOT_ELF32
675         select DMA_COHERENT
676         select SIBYTE_SB1250
677         select SWAP_IO_SPACE
678         select SYS_HAS_CPU_SB1
679         select SYS_SUPPORTS_BIG_ENDIAN
680         select SYS_SUPPORTS_HIGHMEM
681         select SYS_SUPPORTS_LITTLE_ENDIAN
682
683 config SIBYTE_CRHINE
684         bool "Support for Sibyte BCM91120C-CRhine"
685         depends on EXPERIMENTAL
686         select BOOT_ELF32
687         select DMA_COHERENT
688         select SIBYTE_BCM1120
689         select SWAP_IO_SPACE
690         select SYS_HAS_CPU_SB1
691         select SYS_SUPPORTS_BIG_ENDIAN
692         select SYS_SUPPORTS_LITTLE_ENDIAN
693
694 config SIBYTE_CRHONE
695         bool "Support for Sibyte BCM91125C-CRhone"
696         depends on EXPERIMENTAL
697         select BOOT_ELF32
698         select DMA_COHERENT
699         select SIBYTE_BCM1125
700         select SWAP_IO_SPACE
701         select SYS_HAS_CPU_SB1
702         select SYS_SUPPORTS_BIG_ENDIAN
703         select SYS_SUPPORTS_HIGHMEM
704         select SYS_SUPPORTS_LITTLE_ENDIAN
705
706 config SNI_RM200_PCI
707         bool "Support for SNI RM200 PCI"
708         select ARC
709         select ARC32
710         select ARCH_MAY_HAVE_PC_FDC
711         select BOOT_ELF32
712         select DMA_NONCOHERENT
713         select GENERIC_ISA_DMA
714         select HAVE_STD_PC_SERIAL_PORT
715         select HW_HAS_EISA
716         select HW_HAS_PCI
717         select I8259
718         select ISA
719         select SYS_HAS_CPU_R4X00
720         select SYS_SUPPORTS_32BIT_KERNEL
721         select SYS_SUPPORTS_64BIT_KERNEL if EXPERIMENTAL
722         select SYS_SUPPORTS_BIG_ENDIAN if EXPERIMENTAL
723         select SYS_SUPPORTS_HIGHMEM
724         select SYS_SUPPORTS_LITTLE_ENDIAN
725         help
726           The SNI RM200 PCI was a MIPS-based platform manufactured by Siemens
727           Nixdorf Informationssysteme (SNI), parent company of Pyramid
728           Technology and now in turn merged with Fujitsu.  Say Y here to
729           support this machine type.
730
731 config TOSHIBA_JMR3927
732         bool "Support for Toshiba JMR-TX3927 board"
733         select DMA_NONCOHERENT
734         select HW_HAS_PCI
735         select MIPS_TX3927
736         select SWAP_IO_SPACE
737         select SYS_HAS_CPU_TX39XX
738         select SYS_SUPPORTS_32BIT_KERNEL
739         select SYS_SUPPORTS_BIG_ENDIAN
740         select TOSHIBA_BOARDS
741
742 config TOSHIBA_RBTX4927
743         bool "Support for Toshiba TBTX49[23]7 board"
744         select DMA_NONCOHERENT
745         select HAS_TXX9_SERIAL
746         select HW_HAS_PCI
747         select I8259
748         select ISA
749         select SWAP_IO_SPACE
750         select SYS_HAS_CPU_TX49XX
751         select SYS_SUPPORTS_32BIT_KERNEL
752         select SYS_SUPPORTS_64BIT_KERNEL
753         select SYS_SUPPORTS_BIG_ENDIAN
754         select TOSHIBA_BOARDS
755         help
756           This Toshiba board is based on the TX4927 processor. Say Y here to
757           support this machine type
758
759 config TOSHIBA_RBTX4938
760         bool "Support for Toshiba RBTX4938 board"
761         select HAVE_STD_PC_SERIAL_PORT
762         select DMA_NONCOHERENT
763         select GENERIC_ISA_DMA
764         select HAS_TXX9_SERIAL
765         select HW_HAS_PCI
766         select I8259
767         select ISA
768         select SWAP_IO_SPACE
769         select SYS_HAS_CPU_TX49XX
770         select SYS_SUPPORTS_32BIT_KERNEL
771         select SYS_SUPPORTS_LITTLE_ENDIAN
772         select SYS_SUPPORTS_BIG_ENDIAN
773         select TOSHIBA_BOARDS
774         help
775           This Toshiba board is based on the TX4938 processor. Say Y here to
776           support this machine type
777
778 endchoice
779
780 source "arch/mips/ddb5xxx/Kconfig"
781 source "arch/mips/gt64120/ev64120/Kconfig"
782 source "arch/mips/jazz/Kconfig"
783 source "arch/mips/ite-boards/Kconfig"
784 source "arch/mips/lasat/Kconfig"
785 source "arch/mips/momentum/Kconfig"
786 source "arch/mips/pmc-sierra/Kconfig"
787 source "arch/mips/sgi-ip27/Kconfig"
788 source "arch/mips/sibyte/Kconfig"
789 source "arch/mips/tx4927/Kconfig"
790 source "arch/mips/tx4938/Kconfig"
791 source "arch/mips/vr41xx/Kconfig"
792 source "arch/mips/philips/pnx8550/common/Kconfig"
793
794 endmenu
795
796 config RWSEM_GENERIC_SPINLOCK
797         bool
798         default y
799
800 config RWSEM_XCHGADD_ALGORITHM
801         bool
802
803 config GENERIC_CALIBRATE_DELAY
804         bool
805         default y
806
807 #
808 # Select some configuration options automatically based on user selections.
809 #
810 config ARC
811         bool
812
813 config ARCH_MAY_HAVE_PC_FDC
814         bool
815
816 config DMA_COHERENT
817         bool
818
819 config DMA_IP27
820         bool
821
822 config DMA_IP32
823         bool
824         select DMA_NEED_PCI_MAP_STATE
825
826 config DMA_NONCOHERENT
827         bool
828         select DMA_NEED_PCI_MAP_STATE
829
830 config DMA_NEED_PCI_MAP_STATE
831         bool
832
833 config OWN_DMA
834         bool
835
836 config EARLY_PRINTK
837         bool
838
839 config GENERIC_ISA_DMA
840         bool
841
842 config I8259
843         bool
844
845 config LIMITED_DMA
846         bool
847         select HIGHMEM
848         select SYS_SUPPORTS_HIGHMEM
849
850 config MIPS_BONITO64
851         bool
852
853 config MIPS_MSC
854         bool
855
856 config MIPS_NILE4
857         bool
858
859 config MIPS_DISABLE_OBSOLETE_IDE
860         bool
861
862 #
863 # Endianess selection.  Suffiently obscure so many users don't know what to
864 # answer,so we try hard to limit the available choices.  Also the use of a
865 # choice statement should be more obvious to the user.
866 #
867 choice
868         prompt "Endianess selection"
869         help
870           Some MIPS machines can be configured for either little or big endian
871           byte order. These modes require different kernels and a different
872           Linux distribution.  In general there is one prefered byteorder for a
873           particular system but some systems are just as commonly used in the
874           one or the other endianess.
875
876 config CPU_BIG_ENDIAN
877         bool "Big endian"
878         depends on SYS_SUPPORTS_BIG_ENDIAN
879
880 config CPU_LITTLE_ENDIAN
881         bool "Little endian"
882         depends on SYS_SUPPORTS_LITTLE_ENDIAN
883         help
884
885 endchoice
886
887 config SYS_SUPPORTS_BIG_ENDIAN
888         bool
889
890 config SYS_SUPPORTS_LITTLE_ENDIAN
891         bool
892
893 config IRQ_CPU
894         bool
895
896 config IRQ_CPU_RM7K
897         bool
898
899 config IRQ_CPU_RM9K
900         bool
901
902 config IRQ_MV64340
903         bool
904
905 config DDB5XXX_COMMON
906         bool
907
908 config MIPS_BOARDS_GEN
909         bool
910
911 config MIPS_GT64111
912         bool
913
914 config MIPS_GT64120
915         bool
916
917 config MIPS_TX3927
918         bool
919         select HAS_TXX9_SERIAL
920
921 config PCI_MARVELL
922         bool
923
924 config ITE_BOARD_GEN
925         bool
926
927 config SOC_AU1000
928         bool
929         select SOC_AU1X00
930
931 config SOC_AU1100
932         bool
933         select SOC_AU1X00
934
935 config SOC_AU1500
936         bool
937         select SOC_AU1X00
938
939 config SOC_AU1550
940         bool
941         select SOC_AU1X00
942
943 config SOC_AU1200
944         bool
945         select SOC_AU1X00
946
947 config SOC_AU1X00
948         bool
949         select SYS_HAS_CPU_MIPS32_R1
950         select SYS_SUPPORTS_32BIT_KERNEL
951
952 config PNX8550
953         bool
954         select SOC_PNX8550
955
956 config SOC_PNX8550
957         bool
958         select DMA_NONCOHERENT
959         select HW_HAS_PCI
960         select SYS_HAS_CPU_MIPS32_R1
961         select SYS_SUPPORTS_32BIT_KERNEL
962
963 config SWAP_IO_SPACE
964         bool
965
966 #
967 # Unfortunately not all GT64120 systems run the chip at the same clock.
968 # As the user for the clock rate and try to minimize the available options.
969 #
970 choice
971         prompt "Galileo Chip Clock"
972         #default SYSCLK_83 if MIPS_EV64120
973         depends on MIPS_EV64120 || MOMENCO_OCELOT || MOMENCO_OCELOT_G
974         default SYSCLK_83 if MIPS_EV64120
975         default SYSCLK_100 if MOMENCO_OCELOT || MOMENCO_OCELOT_G
976
977 config SYSCLK_75
978         bool "75" if MIPS_EV64120
979
980 config SYSCLK_83
981         bool "83.3" if MIPS_EV64120
982
983 config SYSCLK_100
984         bool "100" if MIPS_EV64120 || MOMENCO_OCELOT || MOMENCO_OCELOT_G
985
986 endchoice
987
988 config ARC32
989         bool
990
991 config AU1X00_USB_DEVICE
992         bool
993         depends on MIPS_PB1500 || MIPS_PB1100 || MIPS_PB1000
994         default n
995
996 config MIPS_GT96100
997         bool
998         select MIPS_GT64120
999
1000 config IT8172_CIR
1001         bool
1002         depends on MIPS_ITE8172 || MIPS_IVR
1003         default y
1004
1005 config IT8712
1006         bool
1007         depends on MIPS_ITE8172
1008         default y
1009
1010 config BOOT_ELF32
1011         bool
1012
1013 config MIPS_L1_CACHE_SHIFT
1014         int
1015         default "4" if MACH_DECSTATION
1016         default "7" if SGI_IP27
1017         default "5"
1018
1019 config HAVE_STD_PC_SERIAL_PORT
1020         bool
1021
1022 config ARC_CONSOLE
1023         bool "ARC console support"
1024         depends on SGI_IP22 || SNI_RM200_PCI
1025
1026 config ARC_MEMORY
1027         bool
1028         depends on MACH_JAZZ || SNI_RM200_PCI || SGI_IP32
1029         default y
1030
1031 config ARC_PROMLIB
1032         bool
1033         depends on MACH_JAZZ || SNI_RM200_PCI || SGI_IP22 || SGI_IP32
1034         default y
1035
1036 config ARC64
1037         bool
1038
1039 config BOOT_ELF64
1040         bool
1041
1042 config TOSHIBA_BOARDS
1043         bool
1044
1045 menu "CPU selection"
1046
1047 choice
1048         prompt "CPU type"
1049         default CPU_R4X00
1050
1051 config CPU_MIPS32_R1
1052         bool "MIPS32 Release 1"
1053         depends on SYS_HAS_CPU_MIPS32_R1
1054         select CPU_HAS_PREFETCH
1055         select CPU_SUPPORTS_32BIT_KERNEL
1056         select CPU_SUPPORTS_HIGHMEM
1057         help
1058           Choose this option to build a kernel for release 1 or later of the
1059           MIPS32 architecture.  Most modern embedded systems with a 32-bit
1060           MIPS processor are based on a MIPS32 processor.  If you know the
1061           specific type of processor in your system, choose those that one
1062           otherwise CPU_MIPS32_R1 is a safe bet for any MIPS32 system.
1063           Release 2 of the MIPS32 architecture is available since several
1064           years so chances are you even have a MIPS32 Release 2 processor
1065           in which case you should choose CPU_MIPS32_R2 instead for better
1066           performance.
1067
1068 config CPU_MIPS32_R2
1069         bool "MIPS32 Release 2"
1070         depends on SYS_HAS_CPU_MIPS32_R2
1071         select CPU_HAS_PREFETCH
1072         select CPU_SUPPORTS_32BIT_KERNEL
1073         select CPU_SUPPORTS_HIGHMEM
1074         help
1075           Choose this option to build a kernel for release 2 or later of the
1076           MIPS32 architecture.  Most modern embedded systems with a 32-bit
1077           MIPS processor are based on a MIPS32 processor.  If you know the
1078           specific type of processor in your system, choose those that one
1079           otherwise CPU_MIPS32_R1 is a safe bet for any MIPS32 system.
1080
1081 config CPU_MIPS64_R1
1082         bool "MIPS64 Release 1"
1083         depends on SYS_HAS_CPU_MIPS64_R1
1084         select CPU_HAS_PREFETCH
1085         select CPU_SUPPORTS_32BIT_KERNEL
1086         select CPU_SUPPORTS_64BIT_KERNEL
1087         select CPU_SUPPORTS_HIGHMEM
1088         help
1089           Choose this option to build a kernel for release 1 or later of the
1090           MIPS64 architecture.  Many modern embedded systems with a 64-bit
1091           MIPS processor are based on a MIPS64 processor.  If you know the
1092           specific type of processor in your system, choose those that one
1093           otherwise CPU_MIPS64_R1 is a safe bet for any MIPS64 system.
1094           Release 2 of the MIPS64 architecture is available since several
1095           years so chances are you even have a MIPS64 Release 2 processor
1096           in which case you should choose CPU_MIPS64_R2 instead for better
1097           performance.
1098
1099 config CPU_MIPS64_R2
1100         bool "MIPS64 Release 2"
1101         depends on SYS_HAS_CPU_MIPS64_R2
1102         select CPU_HAS_PREFETCH
1103         select CPU_SUPPORTS_32BIT_KERNEL
1104         select CPU_SUPPORTS_64BIT_KERNEL
1105         select CPU_SUPPORTS_HIGHMEM
1106         help
1107           Choose this option to build a kernel for release 2 or later of the
1108           MIPS64 architecture.  Many modern embedded systems with a 64-bit
1109           MIPS processor are based on a MIPS64 processor.  If you know the
1110           specific type of processor in your system, choose those that one
1111           otherwise CPU_MIPS64_R1 is a safe bet for any MIPS64 system.
1112
1113 config CPU_R3000
1114         bool "R3000"
1115         depends on SYS_HAS_CPU_R3000
1116         select CPU_SUPPORTS_32BIT_KERNEL
1117         select CPU_SUPPORTS_HIGHMEM
1118         help
1119           Please make sure to pick the right CPU type. Linux/MIPS is not
1120           designed to be generic, i.e. Kernels compiled for R3000 CPUs will
1121           *not* work on R4000 machines and vice versa.  However, since most
1122           of the supported machines have an R4000 (or similar) CPU, R4x00
1123           might be a safe bet.  If the resulting kernel does not work,
1124           try to recompile with R3000.
1125
1126 config CPU_TX39XX
1127         bool "R39XX"
1128         depends on SYS_HAS_CPU_TX39XX
1129         select CPU_SUPPORTS_32BIT_KERNEL
1130
1131 config CPU_VR41XX
1132         bool "R41xx"
1133         depends on SYS_HAS_CPU_VR41XX
1134         select CPU_SUPPORTS_32BIT_KERNEL
1135         select CPU_SUPPORTS_64BIT_KERNEL
1136         help
1137           The options selects support for the NEC VR4100 series of processors.
1138           Only choose this option if you have one of these processors as a
1139           kernel built with this option will not run on any other type of
1140           processor or vice versa.
1141
1142 config CPU_R4300
1143         bool "R4300"
1144         depends on SYS_HAS_CPU_R4300
1145         select CPU_SUPPORTS_32BIT_KERNEL
1146         select CPU_SUPPORTS_64BIT_KERNEL
1147         help
1148           MIPS Technologies R4300-series processors.
1149
1150 config CPU_R4X00
1151         bool "R4x00"
1152         depends on SYS_HAS_CPU_R4X00
1153         select CPU_SUPPORTS_32BIT_KERNEL
1154         select CPU_SUPPORTS_64BIT_KERNEL
1155         help
1156           MIPS Technologies R4000-series processors other than 4300, including
1157           the R4000, R4400, R4600, and 4700.
1158
1159 config CPU_TX49XX
1160         bool "R49XX"
1161         depends on SYS_HAS_CPU_TX49XX
1162         select CPU_SUPPORTS_32BIT_KERNEL
1163         select CPU_SUPPORTS_64BIT_KERNEL
1164
1165 config CPU_R5000
1166         bool "R5000"
1167         depends on SYS_HAS_CPU_R5000
1168         select CPU_SUPPORTS_32BIT_KERNEL
1169         select CPU_SUPPORTS_64BIT_KERNEL
1170         help
1171           MIPS Technologies R5000-series processors other than the Nevada.
1172
1173 config CPU_R5432
1174         bool "R5432"
1175         depends on SYS_HAS_CPU_R5432
1176         select CPU_SUPPORTS_32BIT_KERNEL
1177         select CPU_SUPPORTS_64BIT_KERNEL
1178
1179 config CPU_R6000
1180         bool "R6000"
1181         depends on EXPERIMENTAL
1182         depends on SYS_HAS_CPU_R6000
1183         select CPU_SUPPORTS_32BIT_KERNEL
1184         help
1185           MIPS Technologies R6000 and R6000A series processors.  Note these
1186           processors are extremly rare and the support for them is incomplete.
1187
1188 config CPU_NEVADA
1189         bool "RM52xx"
1190         depends on SYS_HAS_CPU_NEVADA
1191         select CPU_SUPPORTS_32BIT_KERNEL
1192         select CPU_SUPPORTS_64BIT_KERNEL
1193         help
1194           QED / PMC-Sierra RM52xx-series ("Nevada") processors.
1195
1196 config CPU_R8000
1197         bool "R8000"
1198         depends on EXPERIMENTAL
1199         depends on SYS_HAS_CPU_R8000
1200         select CPU_HAS_PREFETCH
1201         select CPU_SUPPORTS_64BIT_KERNEL
1202         help
1203           MIPS Technologies R8000 processors.  Note these processors are
1204           uncommon and the support for them is incomplete.
1205
1206 config CPU_R10000
1207         bool "R10000"
1208         depends on SYS_HAS_CPU_R10000
1209         select CPU_HAS_PREFETCH
1210         select CPU_SUPPORTS_32BIT_KERNEL
1211         select CPU_SUPPORTS_64BIT_KERNEL
1212         select CPU_SUPPORTS_HIGHMEM
1213         help
1214           MIPS Technologies R10000-series processors.
1215
1216 config CPU_RM7000
1217         bool "RM7000"
1218         depends on SYS_HAS_CPU_RM7000
1219         select CPU_HAS_PREFETCH
1220         select CPU_SUPPORTS_32BIT_KERNEL
1221         select CPU_SUPPORTS_64BIT_KERNEL
1222         select CPU_SUPPORTS_HIGHMEM
1223
1224 config CPU_RM9000
1225         bool "RM9000"
1226         depends on SYS_HAS_CPU_RM9000
1227         select CPU_HAS_PREFETCH
1228         select CPU_SUPPORTS_32BIT_KERNEL
1229         select CPU_SUPPORTS_64BIT_KERNEL
1230         select CPU_SUPPORTS_HIGHMEM
1231
1232 config CPU_SB1
1233         bool "SB1"
1234         depends on SYS_HAS_CPU_SB1
1235         select CPU_SUPPORTS_32BIT_KERNEL
1236         select CPU_SUPPORTS_64BIT_KERNEL
1237         select CPU_SUPPORTS_HIGHMEM
1238
1239 endchoice
1240
1241 config SYS_HAS_CPU_MIPS32_R1
1242         bool
1243
1244 config SYS_HAS_CPU_MIPS32_R2
1245         bool
1246
1247 config SYS_HAS_CPU_MIPS64_R1
1248         bool
1249
1250 config SYS_HAS_CPU_MIPS64_R2
1251         bool
1252
1253 config SYS_HAS_CPU_R3000
1254         bool
1255
1256 config SYS_HAS_CPU_TX39XX
1257         bool
1258
1259 config SYS_HAS_CPU_VR41XX
1260         bool
1261
1262 config SYS_HAS_CPU_R4300
1263         bool
1264
1265 config SYS_HAS_CPU_R4X00
1266         bool
1267
1268 config SYS_HAS_CPU_TX49XX
1269         bool
1270
1271 config SYS_HAS_CPU_R5000
1272         bool
1273
1274 config SYS_HAS_CPU_R5432
1275         bool
1276
1277 config SYS_HAS_CPU_R6000
1278         bool
1279
1280 config SYS_HAS_CPU_NEVADA
1281         bool
1282
1283 config SYS_HAS_CPU_R8000
1284         bool
1285
1286 config SYS_HAS_CPU_R10000
1287         bool
1288
1289 config SYS_HAS_CPU_RM7000
1290         bool
1291
1292 config SYS_HAS_CPU_RM9000
1293         bool
1294
1295 config SYS_HAS_CPU_SB1
1296         bool
1297
1298 endmenu
1299
1300 #
1301 # These two indicate any levelof the MIPS32 and MIPS64 architecture
1302 #
1303 config CPU_MIPS32
1304         bool
1305         default y if CPU_MIPS32_R1 || CPU_MIPS32_R2
1306
1307 config CPU_MIPS64
1308         bool
1309         default y if CPU_MIPS64_R1 || CPU_MIPS64_R2
1310
1311 #
1312 # These two indicate the revision of the architecture, either 32 bot 64 bit.
1313 #
1314 config CPU_MIPSR1
1315         bool
1316         default y if CPU_MIPS32_R1 || CPU_MIPS64_R1
1317
1318 config CPU_MIPSR2
1319         bool
1320         default y if CPU_MIPS32_R2 || CPU_MIPS64_R2
1321
1322 config SYS_SUPPORTS_32BIT_KERNEL
1323         bool
1324 config SYS_SUPPORTS_64BIT_KERNEL
1325         bool
1326 config CPU_SUPPORTS_32BIT_KERNEL
1327         bool
1328 config CPU_SUPPORTS_64BIT_KERNEL
1329         bool
1330
1331 menu "Kernel type"
1332
1333 choice
1334
1335         prompt "Kernel code model"
1336         help
1337           You should only select this option if you have a workload that
1338           actually benefits from 64-bit processing or if your machine has
1339           large memory.  You will only be presented a single option in this
1340           menu if your system does not support both 32-bit and 64-bit kernels.
1341
1342 config 32BIT
1343         bool "32-bit kernel"
1344         depends on CPU_SUPPORTS_32BIT_KERNEL && SYS_SUPPORTS_32BIT_KERNEL
1345         select TRAD_SIGNALS
1346         help
1347           Select this option if you want to build a 32-bit kernel.
1348 config 64BIT
1349         bool "64-bit kernel"
1350         depends on CPU_SUPPORTS_64BIT_KERNEL && SYS_SUPPORTS_64BIT_KERNEL
1351         help
1352           Select this option if you want to build a 64-bit kernel.
1353
1354 endchoice
1355
1356 choice
1357         prompt "Kernel page size"
1358         default PAGE_SIZE_4KB
1359
1360 config PAGE_SIZE_4KB
1361         bool "4kB"
1362         help
1363          This option select the standard 4kB Linux page size.  On some
1364          R3000-family processors this is the only available page size.  Using
1365          4kB page size will minimize memory consumption and is therefore
1366          recommended for low memory systems.
1367
1368 config PAGE_SIZE_8KB
1369         bool "8kB"
1370         depends on EXPERIMENTAL && CPU_R8000
1371         help
1372           Using 8kB page size will result in higher performance kernel at
1373           the price of higher memory consumption.  This option is available
1374           only on the R8000 processor.  Not that at the time of this writing
1375           this option is still high experimental; there are also issues with
1376           compatibility of user applications.
1377
1378 config PAGE_SIZE_16KB
1379         bool "16kB"
1380         depends on EXPERIMENTAL && !CPU_R3000 && !CPU_TX39XX
1381         help
1382           Using 16kB page size will result in higher performance kernel at
1383           the price of higher memory consumption.  This option is available on
1384           all non-R3000 family processor.  Not that at the time of this
1385           writing this option is still high experimental; there are also
1386           issues with compatibility of user applications.
1387
1388 config PAGE_SIZE_64KB
1389         bool "64kB"
1390         depends on EXPERIMENTAL && !CPU_R3000 && !CPU_TX39XX
1391         help
1392           Using 64kB page size will result in higher performance kernel at
1393           the price of higher memory consumption.  This option is available on
1394           all non-R3000 family processor.  Not that at the time of this
1395           writing this option is still high experimental; there are also
1396           issues with compatibility of user applications.
1397
1398 endchoice
1399
1400 config BOARD_SCACHE
1401         bool
1402
1403 config IP22_CPU_SCACHE
1404         bool
1405         select BOARD_SCACHE
1406
1407 config R5000_CPU_SCACHE
1408         bool
1409         select BOARD_SCACHE
1410
1411 config RM7000_CPU_SCACHE
1412         bool
1413         select BOARD_SCACHE
1414
1415 config SIBYTE_DMA_PAGEOPS
1416         bool "Use DMA to clear/copy pages"
1417         depends on CPU_SB1
1418         help
1419           Instead of using the CPU to zero and copy pages, use a Data Mover
1420           channel.  These DMA channels are otherwise unused by the standard
1421           SiByte Linux port.  Seems to give a small performance benefit.
1422
1423 config CPU_HAS_PREFETCH
1424         bool
1425
1426 config MIPS_MT
1427         bool "Enable MIPS MT"
1428
1429 choice
1430         prompt "MIPS MT options"
1431         depends on MIPS_MT
1432
1433 config MIPS_MT_SMP
1434         bool "Use 1 TC on each available VPE for SMP"
1435         select SMP
1436
1437 config MIPS_VPE_LOADER
1438         bool "VPE loader support."
1439         depends on MIPS_MT
1440         help
1441           Includes a loader for loading an elf relocatable object
1442           onto another VPE and running it.
1443
1444 endchoice
1445
1446 config MIPS_VPE_LOADER_TOM
1447         bool "Load VPE program into memory hidden from linux"
1448         depends on MIPS_VPE_LOADER
1449         default y
1450         help
1451           The loader can use memory that is present but has been hidden from
1452           Linux using the kernel command line option "mem=xxMB". It's up to
1453           you to ensure the amount you put in the option and the space your
1454           program requires is less or equal to the amount physically present.
1455
1456 # this should possibly be in drivers/char, but it is rather cpu related. Hmmm
1457 config MIPS_VPE_APSP_API
1458         bool "Enable support for AP/SP API (RTLX)"
1459         depends on MIPS_VPE_LOADER
1460         help
1461
1462 config SB1_PASS_1_WORKAROUNDS
1463         bool
1464         depends on CPU_SB1_PASS_1
1465         default y
1466
1467 config SB1_PASS_2_WORKAROUNDS
1468         bool
1469         depends on CPU_SB1 && (CPU_SB1_PASS_2_2 || CPU_SB1_PASS_2)
1470         default y
1471
1472 config SB1_PASS_2_1_WORKAROUNDS
1473         bool
1474         depends on CPU_SB1 && CPU_SB1_PASS_2
1475         default y
1476
1477 config 64BIT_PHYS_ADDR
1478         bool "Support for 64-bit physical address space"
1479         depends on (CPU_R4X00 || CPU_R5000 || CPU_RM7000 || CPU_RM9000 || CPU_R10000 || CPU_SB1 || CPU_MIPS32 || CPU_MIPS64) && 32BIT
1480
1481 config CPU_ADVANCED
1482         bool "Override CPU Options"
1483         depends on 32BIT
1484         help
1485           Saying yes here allows you to select support for various features
1486           your CPU may or may not have.  Most people should say N here.
1487
1488 config CPU_HAS_LLSC
1489         bool "ll/sc Instructions available" if CPU_ADVANCED
1490         default y if !CPU_ADVANCED && !CPU_R3000 && !CPU_VR41XX && !CPU_TX39XX
1491         help
1492           MIPS R4000 series and later provide the Load Linked (ll)
1493           and Store Conditional (sc) instructions. More information is
1494           available at <http://www.go-ecs.com/mips/miptek1.htm>.
1495
1496           Say Y here if your CPU has the ll and sc instructions.  Say Y here
1497           for better performance, N if you don't know.  You must say Y here
1498           for multiprocessor machines.
1499
1500 config CPU_HAS_WB
1501         bool "Writeback Buffer available" if CPU_ADVANCED
1502         default y if !CPU_ADVANCED && CPU_R3000 && MACH_DECSTATION
1503         help
1504           Say N here for slightly better performance.  You must say Y here for
1505           machines which require flushing of write buffers in software.  Saying
1506           Y is the safe option; N may result in kernel malfunction and crashes.
1507
1508 menu "MIPSR2 Interrupt handling"
1509         depends on CPU_MIPSR2 && CPU_ADVANCED
1510
1511 config CPU_MIPSR2_IRQ_VI
1512         bool "Vectored interrupt mode"
1513         help
1514            Vectored interrupt mode allowing faster dispatching of interrupts.
1515            The board support code needs to be written to take advantage of this
1516            mode.  Compatibility code is included to allow the kernel to run on
1517            a CPU that does not support vectored interrupts.  It's safe to
1518            say Y here.
1519
1520 config CPU_MIPSR2_IRQ_EI
1521         bool "External interrupt controller mode"
1522         help
1523            Extended interrupt mode takes advantage of an external interrupt
1524            controller to allow fast dispatching from many possible interrupt
1525            sources. Say N unless you know that external interrupt support is
1526            required.
1527
1528 config CPU_MIPSR2_SRS
1529         bool "Make shadow set registers available for interrupt handlers"
1530         depends on CPU_MIPSR2_IRQ_VI || CPU_MIPSR2_IRQ_EI
1531         help
1532            Allow the kernel to use shadow register sets for fast interrupts.
1533            Interrupt handlers must be specially written to use shadow sets.
1534            Say N unless you know that shadow register set upport is needed.
1535 endmenu
1536
1537 config CPU_HAS_SYNC
1538         bool
1539         depends on !CPU_R3000
1540         default y
1541
1542 #
1543 # Use the generic interrupt handling code in kernel/irq/:
1544 #
1545 config GENERIC_HARDIRQS
1546         bool
1547         default y
1548
1549 config GENERIC_IRQ_PROBE
1550         bool
1551         default y
1552
1553 #
1554 # - Highmem only makes sense for the 32-bit kernel.
1555 # - The current highmem code will only work properly on physically indexed
1556 #   caches such as R3000, SB1, R7000 or those that look like they're virtually
1557 #   indexed such as R4000/R4400 SC and MC versions or R10000.  So for the
1558 #   moment we protect the user and offer the highmem option only on machines
1559 #   where it's known to be safe.  This will not offer highmem on a few systems
1560 #   such as MIPS32 and MIPS64 CPUs which may have virtual and physically
1561 #   indexed CPUs but we're playing safe.
1562 # - We use SYS_SUPPORTS_HIGHMEM to offer highmem only for systems where we
1563 #   know they might have memory configurations that could make use of highmem
1564 #   support.
1565 #
1566 config HIGHMEM
1567         bool "High Memory Support"
1568         depends on 32BIT && CPU_SUPPORTS_HIGHMEM && SYS_SUPPORTS_HIGHMEM
1569
1570 config CPU_SUPPORTS_HIGHMEM
1571         bool
1572
1573 config SYS_SUPPORTS_HIGHMEM
1574         bool
1575
1576 config ARCH_FLATMEM_ENABLE
1577         def_bool y
1578         depends on !NUMA
1579
1580 source "mm/Kconfig"
1581
1582 config SMP
1583         bool "Multi-Processing support"
1584         depends on CPU_RM9000 || ((SIBYTE_BCM1x80 || SIBYTE_BCM1x55 || SIBYTE_SB1250) && !SIBYTE_STANDALONE) || SGI_IP27 || MIPS_MT_SMP
1585         ---help---
1586           This enables support for systems with more than one CPU. If you have
1587           a system with only one CPU, like most personal computers, say N. If
1588           you have a system with more than one CPU, say Y.
1589
1590           If you say N here, the kernel will run on single and multiprocessor
1591           machines, but will use only one CPU of a multiprocessor machine. If
1592           you say Y here, the kernel will run on many, but not all,
1593           singleprocessor machines. On a singleprocessor machine, the kernel
1594           will run faster if you say N here.
1595
1596           People using multiprocessor machines who say Y here should also say
1597           Y to "Enhanced Real Time Clock Support", below.
1598
1599           See also the <file:Documentation/smp.txt> and the SMP-HOWTO
1600           available at <http://www.tldp.org/docs.html#howto>.
1601
1602           If you don't know what to do here, say N.
1603
1604 config NR_CPUS
1605         int "Maximum number of CPUs (2-64)"
1606         range 2 64
1607         depends on SMP
1608         default "64" if SGI_IP27
1609         default "2"
1610         help
1611           This allows you to specify the maximum number of CPUs which this
1612           kernel will support.  The maximum supported value is 32 for 32-bit
1613           kernel and 64 for 64-bit kernels; the minimum value which makes
1614           sense is 2.
1615
1616           This is purely to save memory - each supported CPU adds
1617           approximately eight kilobytes to the kernel image.
1618
1619 source "kernel/Kconfig.preempt"
1620
1621 config RTC_DS1742
1622         bool "DS1742 BRAM/RTC support"
1623         depends on TOSHIBA_JMR3927 || TOSHIBA_RBTX4927
1624
1625 config MIPS_INSANE_LARGE
1626         bool "Support for large 64-bit configurations"
1627         depends on CPU_R10000 && 64BIT
1628         help
1629           MIPS R10000 does support a 44 bit / 16TB address space as opposed to
1630           previous 64-bit processors which only supported 40 bit / 1TB. If you
1631           need processes of more than 1TB virtual address space, say Y here.
1632           This will result in additional memory usage, so it is not
1633           recommended for normal users.
1634
1635 endmenu
1636
1637 config RWSEM_GENERIC_SPINLOCK
1638         bool
1639         default y
1640
1641 source "init/Kconfig"
1642
1643 menu "Bus options (PCI, PCMCIA, EISA, ISA, TC)"
1644
1645 config HW_HAS_EISA
1646         bool
1647 config HW_HAS_PCI
1648         bool
1649
1650 config PCI
1651         bool "Support for PCI controller"
1652         depends on HW_HAS_PCI
1653         help
1654           Find out whether you have a PCI motherboard. PCI is the name of a
1655           bus system, i.e. the way the CPU talks to the other stuff inside
1656           your box. Other bus systems are ISA, EISA, or VESA. If you have PCI,
1657           say Y, otherwise N.
1658
1659           The PCI-HOWTO, available from
1660           <http://www.tldp.org/docs.html#howto>, contains valuable
1661           information about which PCI hardware does work under Linux and which
1662           doesn't.
1663
1664 config PCI_DOMAINS
1665         bool
1666         depends on PCI
1667
1668 source "drivers/pci/Kconfig"
1669
1670 #
1671 # ISA support is now enabled via select.  Too many systems still have the one
1672 # or other ISA chip on the board that users don't know about so don't expect
1673 # users to choose the right thing ...
1674 #
1675 config ISA
1676         bool
1677
1678 config EISA
1679         bool "EISA support"
1680         depends on HW_HAS_EISA
1681         select ISA
1682         ---help---
1683           The Extended Industry Standard Architecture (EISA) bus was
1684           developed as an open alternative to the IBM MicroChannel bus.
1685
1686           The EISA bus provided some of the features of the IBM MicroChannel
1687           bus while maintaining backward compatibility with cards made for
1688           the older ISA bus.  The EISA bus saw limited use between 1988 and
1689           1995 when it was made obsolete by the PCI bus.
1690
1691           Say Y here if you are building a kernel for an EISA-based machine.
1692
1693           Otherwise, say N.
1694
1695 source "drivers/eisa/Kconfig"
1696
1697 config TC
1698         bool "TURBOchannel support"
1699         depends on MACH_DECSTATION
1700         help
1701           TurboChannel is a DEC (now Compaq (now HP)) bus for Alpha and MIPS
1702           processors.  Documentation on writing device drivers for TurboChannel
1703           is available at:
1704           <http://www.cs.arizona.edu/computer.help/policy/DIGITAL_unix/AA-PS3HD-TET1_html/TITLE.html>.
1705
1706 #config ACCESSBUS
1707 #       bool "Access.Bus support"
1708 #       depends on TC
1709
1710 config MMU
1711         bool
1712         default y
1713
1714 source "drivers/pcmcia/Kconfig"
1715
1716 source "drivers/pci/hotplug/Kconfig"
1717
1718 endmenu
1719
1720 menu "Executable file formats"
1721
1722 source "fs/Kconfig.binfmt"
1723
1724 config TRAD_SIGNALS
1725         bool
1726
1727 config BUILD_ELF64
1728         bool "Use 64-bit ELF format for building"
1729         depends on 64BIT
1730         help
1731           A 64-bit kernel is usually built using the 64-bit ELF binary object
1732           format as it's one that allows arbitrary 64-bit constructs.  For
1733           kernels that are loaded within the KSEG compatibility segments the
1734           32-bit ELF format can optionally be used resulting in a somewhat
1735           smaller binary, but this option is not explicitly supported by the
1736           toolchain and since binutils 2.14 it does not even work at all.
1737
1738           Say Y to use the 64-bit format or N to use the 32-bit one.
1739
1740           If unsure say Y.
1741
1742 config BINFMT_IRIX
1743         bool "Include IRIX binary compatibility"
1744         depends on CPU_BIG_ENDIAN && 32BIT && BROKEN
1745
1746 config MIPS32_COMPAT
1747         bool "Kernel support for Linux/MIPS 32-bit binary compatibility"
1748         depends on 64BIT
1749         help
1750           Select this option if you want Linux/MIPS 32-bit binary
1751           compatibility. Since all software available for Linux/MIPS is
1752           currently 32-bit you should say Y here.
1753
1754 config COMPAT
1755         bool
1756         depends on MIPS32_COMPAT
1757         default y
1758
1759 config MIPS32_O32
1760         bool "Kernel support for o32 binaries"
1761         depends on MIPS32_COMPAT
1762         help
1763           Select this option if you want to run o32 binaries.  These are pure
1764           32-bit binaries as used by the 32-bit Linux/MIPS port.  Most of
1765           existing binaries are in this format.
1766
1767           If unsure, say Y.
1768
1769 config MIPS32_N32
1770         bool "Kernel support for n32 binaries"
1771         depends on MIPS32_COMPAT
1772         help
1773           Select this option if you want to run n32 binaries.  These are
1774           64-bit binaries using 32-bit quantities for addressing and certain
1775           data that would normally be 64-bit.  They are used in special
1776           cases.
1777
1778           If unsure, say N.
1779
1780 config BINFMT_ELF32
1781         bool
1782         default y if MIPS32_O32 || MIPS32_N32
1783
1784 config SECCOMP
1785         bool "Enable seccomp to safely compute untrusted bytecode"
1786         depends on PROC_FS && BROKEN
1787         default y
1788         help
1789           This kernel feature is useful for number crunching applications
1790           that may need to compute untrusted bytecode during their
1791           execution. By using pipes or other transports made available to
1792           the process as file descriptors supporting the read/write
1793           syscalls, it's possible to isolate those applications in
1794           their own address space using seccomp. Once seccomp is
1795           enabled via /proc/<pid>/seccomp, it cannot be disabled
1796           and the task is only allowed to execute a few safe syscalls
1797           defined by each seccomp mode.
1798
1799           If unsure, say Y. Only embedded should say N here.
1800
1801 config PM
1802         bool "Power Management support (EXPERIMENTAL)"
1803         depends on EXPERIMENTAL && SOC_AU1X00
1804
1805 endmenu
1806
1807 source "net/Kconfig"
1808
1809 source "drivers/Kconfig"
1810
1811 source "fs/Kconfig"
1812
1813 source "arch/mips/oprofile/Kconfig"
1814
1815 source "arch/mips/Kconfig.debug"
1816
1817 source "security/Kconfig"
1818
1819 source "crypto/Kconfig"
1820
1821 source "lib/Kconfig"