Merge branch 'audit.b43' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/audit...
[linux-2.6.git] / arch / blackfin / Kconfig
1 #
2 # For a description of the syntax of this configuration file,
3 # see Documentation/kbuild/kconfig-language.txt.
4 #
5
6 mainmenu "uClinux/Blackfin (w/o MMU) Kernel Configuration"
7
8 config MMU
9         bool
10         default n
11
12 config FPU
13         bool
14         default n
15
16 config RWSEM_GENERIC_SPINLOCK
17         bool
18         default y
19
20 config RWSEM_XCHGADD_ALGORITHM
21         bool
22         default n
23
24 config BLACKFIN
25         bool
26         default y
27
28 config ZONE_DMA
29         bool
30         default y
31
32 config BFIN
33         bool
34         default y
35
36 config SEMAPHORE_SLEEPERS
37         bool
38         default y
39
40 config GENERIC_FIND_NEXT_BIT
41         bool
42         default y
43
44 config GENERIC_HWEIGHT
45         bool
46         default y
47
48 config GENERIC_HARDIRQS
49         bool
50         default y
51
52 config GENERIC_IRQ_PROBE
53         bool
54         default y
55
56 config GENERIC_TIME
57         bool
58         default n
59
60 config GENERIC_GPIO
61         bool
62         default y
63
64 config FORCE_MAX_ZONEORDER
65         int
66         default "14"
67
68 config GENERIC_CALIBRATE_DELAY
69         bool
70         default y
71
72 config IRQCHIP_DEMUX_GPIO
73         bool
74         depends on (BF53x || BF561 || BF54x)
75         default y
76
77 source "init/Kconfig"
78 source "kernel/Kconfig.preempt"
79
80 menu "Blackfin Processor Options"
81
82 comment "Processor and Board Settings"
83
84 choice
85         prompt "CPU"
86         default BF533
87
88 config BF531
89         bool "BF531"
90         help
91           BF531 Processor Support.
92
93 config BF532
94         bool "BF532"
95         help
96           BF532 Processor Support.
97
98 config BF533
99         bool "BF533"
100         help
101           BF533 Processor Support.
102
103 config BF534
104         bool "BF534"
105         help
106           BF534 Processor Support.
107
108 config BF536
109         bool "BF536"
110         help
111           BF536 Processor Support.
112
113 config BF537
114         bool "BF537"
115         help
116           BF537 Processor Support.
117
118 config BF542
119         bool "BF542"
120         help
121           BF542 Processor Support.
122
123 config BF544
124         bool "BF544"
125         help
126           BF544 Processor Support.
127
128 config BF548
129         bool "BF548"
130         help
131           BF548 Processor Support.
132
133 config BF549
134         bool "BF549"
135         help
136           BF549 Processor Support.
137
138 config BF561
139         bool "BF561"
140         help
141           Not Supported Yet - Work in progress - BF561 Processor Support.
142
143 endchoice
144
145 choice
146         prompt "Silicon Rev"
147         default BF_REV_0_2 if BF537
148         default BF_REV_0_3 if BF533
149         default BF_REV_0_0 if BF549
150
151 config BF_REV_0_0
152         bool "0.0"
153         depends on (BF549)
154
155 config BF_REV_0_2
156         bool "0.2"
157         depends on (BF537 || BF536 || BF534)
158
159 config BF_REV_0_3
160         bool "0.3"
161         depends on (BF561 || BF537 || BF536 || BF534 || BF533 || BF532 || BF531)
162
163 config BF_REV_0_4
164         bool "0.4"
165         depends on (BF561 || BF533 || BF532 || BF531)
166
167 config BF_REV_0_5
168         bool "0.5"
169         depends on (BF561 || BF533 || BF532 || BF531)
170
171 config BF_REV_ANY
172         bool "any"
173
174 config BF_REV_NONE
175         bool "none"
176
177 endchoice
178
179 config BF53x
180         bool
181         depends on (BF531 || BF532 || BF533 || BF534 || BF536 || BF537)
182         default y
183
184 config BF54x
185         bool
186         depends on (BF542 || BF544 || BF548 || BF549)
187         default y
188
189 config BFIN_DUAL_CORE
190         bool
191         depends on (BF561)
192         default y
193
194 config BFIN_SINGLE_CORE
195         bool
196         depends on !BFIN_DUAL_CORE
197         default y
198
199 choice
200         prompt "System type"
201         default BFIN533_STAMP
202         help
203           Do NOT change the board here.  Please use the top level
204           configuration to ensure that all the other settings are
205           correct.
206
207 config BFIN533_EZKIT
208         bool "BF533-EZKIT"
209         depends on (BF533 || BF532 || BF531)
210         help
211           BF533-EZKIT-LITE board Support.
212
213 config  BFIN533_STAMP
214         bool "BF533-STAMP"
215         depends on (BF533 || BF532 || BF531)
216         help
217           BF533-STAMP board Support.
218
219 config BFIN537_STAMP
220         bool "BF537-STAMP"
221         depends on (BF537 || BF536 || BF534)
222         help
223           BF537-STAMP board Support.
224
225 config BFIN533_BLUETECHNIX_CM
226         bool "Bluetechnix CM-BF533"
227         depends on (BF533)
228         help
229           CM-BF533 support for EVAL- and DEV-Board.
230
231 config BFIN537_BLUETECHNIX_CM
232         bool "Bluetechnix CM-BF537"
233         depends on (BF537)
234         help
235           CM-BF537 support for EVAL- and DEV-Board.
236
237 config BFIN548_EZKIT
238         bool "BF548-EZKIT"
239         depends on (BF548 || BF549)
240           help
241           BFIN548-EZKIT board Support.
242
243 config BFIN561_BLUETECHNIX_CM
244         bool "Bluetechnix CM-BF561"
245         depends on (BF561)
246         help
247           CM-BF561 support for EVAL- and DEV-Board.
248
249 config BFIN561_EZKIT
250         bool "BF561-EZKIT"
251         depends on (BF561)
252         help
253           BF561-EZKIT-LITE board Support.
254
255 config BFIN561_TEPLA
256         bool "BF561-TEPLA"
257         depends on (BF561)
258         help
259          BF561-TEPLA board Support.
260
261 config PNAV10
262         bool "PNAV 1.0 board"
263         depends on (BF537)
264         help
265           PNAV 1.0 board Support.
266
267 config GENERIC_BOARD
268         bool "Custom"
269         depends on (BF537 || BF536 \
270                 || BF534 || BF561 || BF535 || BF533 || BF532 || BF531)
271         help
272           GENERIC or Custom board Support.
273
274 endchoice
275
276 config MEM_GENERIC_BOARD
277         bool
278         depends on GENERIC_BOARD
279         default y
280
281 config MEM_MT48LC64M4A2FB_7E
282         bool
283         depends on (BFIN533_STAMP)
284         default y
285
286 config MEM_MT48LC16M16A2TG_75
287         bool
288         depends on (BFIN533_EZKIT || BFIN561_EZKIT \
289                 || BFIN533_BLUETECHNIX_CM || BFIN537_BLUETECHNIX_CM)
290         default y
291
292 config MEM_MT48LC32M8A2_75
293         bool
294         depends on (BFIN537_STAMP || PNAV10)
295         default y
296
297 config MEM_MT48LC8M32B2B5_7
298         bool
299         depends on (BFIN561_BLUETECHNIX_CM)
300         default y
301
302 config BFIN_SHARED_FLASH_ENET
303         bool
304         depends on (BFIN533_STAMP)
305         default y
306
307 source "arch/blackfin/mach-bf533/Kconfig"
308 source "arch/blackfin/mach-bf561/Kconfig"
309 source "arch/blackfin/mach-bf537/Kconfig"
310 source "arch/blackfin/mach-bf548/Kconfig"
311
312 menu "Board customizations"
313
314 config CMDLINE_BOOL
315         bool "Default bootloader kernel arguments"
316
317 config CMDLINE
318         string "Initial kernel command string"
319         depends on CMDLINE_BOOL
320         default "console=ttyBF0,57600"
321         help
322           If you don't have a boot loader capable of passing a command line string
323           to the kernel, you may specify one here. As a minimum, you should specify
324           the memory size and the root device (e.g., mem=8M, root=/dev/nfs).
325
326 comment "Clock/PLL Setup"
327
328 config CLKIN_HZ
329         int "Crystal Frequency in Hz"
330         default "11059200" if BFIN533_STAMP
331         default "27000000" if BFIN533_EZKIT
332         default "25000000" if BFIN537_STAMP
333         default "30000000" if BFIN561_EZKIT
334         default "24576000" if PNAV10
335         help
336           The frequency of CLKIN crystal oscillator on the board in Hz.
337
338 config BFIN_KERNEL_CLOCK
339         bool "Re-program Clocks while Kernel boots?"
340         default n
341         help
342           This option decides if kernel clocks are re-programed from the
343           bootloader settings. If the clocks are not set, the SDRAM settings
344           are also not changed, and the Bootloader does 100% of the hardware
345           configuration.
346
347 config PLL_BYPASS
348         bool "Bypass PLL"
349         depends on BFIN_KERNEL_CLOCK
350         default n
351
352 config CLKIN_HALF
353         bool "Half Clock In"
354         depends on BFIN_KERNEL_CLOCK && (! PLL_BYPASS)
355         default n
356         help
357           If this is set the clock will be divided by 2, before it goes to the PLL.
358
359 config VCO_MULT
360         int "VCO Multiplier"
361         depends on BFIN_KERNEL_CLOCK && (! PLL_BYPASS)
362         range 1 64
363         default "22" if BFIN533_EZKIT
364         default "45" if BFIN533_STAMP
365         default "20" if BFIN537_STAMP
366         default "22" if BFIN533_BLUETECHNIX_CM
367         default "20" if BFIN537_BLUETECHNIX_CM
368         default "20" if BFIN561_BLUETECHNIX_CM
369         default "20" if BFIN561_EZKIT
370         help
371           This controls the frequency of the on-chip PLL. This can be between 1 and 64.
372           PLL Frequency = (Crystal Frequency) * (this setting)
373
374 choice
375         prompt "Core Clock Divider"
376         depends on BFIN_KERNEL_CLOCK
377         default CCLK_DIV_1
378         help
379           This sets the frequency of the core. It can be 1, 2, 4 or 8
380           Core Frequency = (PLL frequency) / (this setting)
381
382 config CCLK_DIV_1
383         bool "1"
384
385 config CCLK_DIV_2
386         bool "2"
387
388 config CCLK_DIV_4
389         bool "4"
390
391 config CCLK_DIV_8
392         bool "8"
393 endchoice
394
395 config SCLK_DIV
396         int "System Clock Divider"
397         depends on BFIN_KERNEL_CLOCK
398         range 1 15
399         default 5 if BFIN533_EZKIT
400         default 5 if BFIN533_STAMP
401         default 4 if BFIN537_STAMP
402         default 5 if BFIN533_BLUETECHNIX_CM
403         default 4 if BFIN537_BLUETECHNIX_CM
404         default 4 if BFIN561_BLUETECHNIX_CM
405         default 5 if BFIN561_EZKIT
406         help
407           This sets the frequency of the system clock (including SDRAM or DDR).
408           This can be between 1 and 15
409           System Clock = (PLL frequency) / (this setting)
410
411 #
412 # Max & Min Speeds for various Chips
413 #
414 config MAX_VCO_HZ
415         int
416         default 600000000 if BF522
417         default 600000000 if BF525
418         default 600000000 if BF527
419         default 400000000 if BF531
420         default 400000000 if BF532
421         default 750000000 if BF533
422         default 500000000 if BF534
423         default 400000000 if BF536
424         default 600000000 if BF537
425         default 533000000 if BF538
426         default 533000000 if BF539
427         default 600000000 if BF542
428         default 533000000 if BF544
429         default 533000000 if BF549
430         default 600000000 if BF561
431
432 config MIN_VCO_HZ
433         int
434         default 50000000
435
436 config MAX_SCLK_HZ
437         int
438         default 133000000
439
440 config MIN_SCLK_HZ
441         int
442         default 27000000
443
444 comment "Kernel Timer/Scheduler"
445
446 source kernel/Kconfig.hz
447
448 comment "Memory Setup"
449
450 config MEM_SIZE
451         int "SDRAM Memory Size in MBytes"
452         default  32 if BFIN533_EZKIT
453         default  64 if BFIN537_STAMP
454         default  64 if BFIN561_EZKIT
455         default 128 if BFIN533_STAMP
456         default  64 if PNAV10
457
458 config MEM_ADD_WIDTH
459         int "SDRAM Memory Address Width"
460         default  9 if BFIN533_EZKIT
461         default  9 if BFIN561_EZKIT
462         default 10 if BFIN537_STAMP
463         default 11 if BFIN533_STAMP
464         default 10 if PNAV10
465
466 config ENET_FLASH_PIN
467         int "PF port/pin used for flash and ethernet sharing"
468         depends on (BFIN533_STAMP)
469         default  0
470         help
471           PF port/pin used for flash and ethernet sharing to allow other PF
472           pins to be used on other platforms without having to touch common
473           code.
474           For example: PF0 --> 0,PF1 --> 1,PF2 --> 2, etc.
475
476 config BOOT_LOAD
477         hex "Kernel load address for booting"
478         default "0x1000"
479         range 0x1000 0x20000000
480         help
481           This option allows you to set the load address of the kernel.
482           This can be useful if you are on a board which has a small amount
483           of memory or you wish to reserve some memory at the beginning of
484           the address space.
485
486           Note that you need to keep this value above 4k (0x1000) as this
487           memory region is used to capture NULL pointer references as well
488           as some core kernel functions.
489
490 comment "LED Status Indicators"
491         depends on (BFIN533_STAMP || BFIN533_BLUETECHNIX_CM)
492
493 config BFIN_ALIVE_LED
494         bool "Enable Board Alive"
495         depends on (BFIN533_STAMP || BFIN533_BLUETECHNIX_CM)
496         default n
497         help
498           Blink the LEDs you select when the kernel is running.  Helps detect
499           a hung kernel.
500
501 config BFIN_ALIVE_LED_NUM
502         int "LED"
503         depends on BFIN_ALIVE_LED
504         range 1 3 if BFIN533_STAMP
505         default "3" if BFIN533_STAMP
506         help
507           Select the LED (marked on the board) for you to blink.
508
509 config BFIN_IDLE_LED
510         bool "Enable System Load/Idle LED"
511         depends on (BFIN533_STAMP || BFIN533_BLUETECHNIX_CM)
512         default n
513         help
514           Blinks the LED you select when to determine kernel load.
515
516 config BFIN_IDLE_LED_NUM
517         int "LED"
518         depends on BFIN_IDLE_LED
519         range 1 3 if BFIN533_STAMP
520         default "2" if BFIN533_STAMP
521         help
522           Select the LED (marked on the board) for you to blink.
523
524 choice
525         prompt "Blackfin Exception Scratch Register"
526         default BFIN_SCRATCH_REG_RETN
527         help
528           Select the resource to reserve for the Exception handler:
529             - RETN: Non-Maskable Interrupt (NMI)
530             - RETE: Exception Return (JTAG/ICE)
531             - CYCLES: Performance counter
532
533           If you are unsure, please select "RETN".
534
535 config BFIN_SCRATCH_REG_RETN
536         bool "RETN"
537         help
538           Use the RETN register in the Blackfin exception handler
539           as a stack scratch register.  This means you cannot
540           safely use NMI on the Blackfin while running Linux, but
541           you can debug the system with a JTAG ICE and use the
542           CYCLES performance registers.
543
544           If you are unsure, please select "RETN".
545
546 config BFIN_SCRATCH_REG_RETE
547         bool "RETE"
548         help
549           Use the RETE register in the Blackfin exception handler
550           as a stack scratch register.  This means you cannot
551           safely use a JTAG ICE while debugging a Blackfin board,
552           but you can safely use the CYCLES performance registers
553           and the NMI.
554
555           If you are unsure, please select "RETN".
556
557 config BFIN_SCRATCH_REG_CYCLES
558         bool "CYCLES"
559         help
560           Use the CYCLES register in the Blackfin exception handler
561           as a stack scratch register.  This means you cannot
562           safely use the CYCLES performance registers on a Blackfin
563           board at anytime, but you can debug the system with a JTAG
564           ICE and use the NMI.
565
566           If you are unsure, please select "RETN".
567
568 endchoice
569
570 #
571 # Sorry - but you need to put the hex address here -
572 #
573
574 # Flag Data register
575 config BFIN_ALIVE_LED_PORT
576         hex
577         default 0xFFC00700 if (BFIN533_STAMP)
578
579 # Peripheral Flag Direction Register
580 config BFIN_ALIVE_LED_DPORT
581         hex
582         default 0xFFC00730 if (BFIN533_STAMP)
583
584 config BFIN_ALIVE_LED_PIN
585         hex
586         default 0x04 if (BFIN533_STAMP && BFIN_ALIVE_LED_NUM = 1)
587         default 0x08 if (BFIN533_STAMP && BFIN_ALIVE_LED_NUM = 2)
588         default 0x10 if (BFIN533_STAMP && BFIN_ALIVE_LED_NUM = 3)
589
590 config BFIN_IDLE_LED_PORT
591         hex
592         default 0xFFC00700 if (BFIN533_STAMP)
593
594 # Peripheral Flag Direction Register
595 config BFIN_IDLE_LED_DPORT
596         hex
597         default 0xFFC00730 if (BFIN533_STAMP)
598
599 config BFIN_IDLE_LED_PIN
600         hex
601         default 0x04 if (BFIN533_STAMP && BFIN_IDLE_LED_NUM = 1)
602         default 0x08 if (BFIN533_STAMP && BFIN_IDLE_LED_NUM = 2)
603         default 0x10 if (BFIN533_STAMP && BFIN_IDLE_LED_NUM = 3)
604
605 endmenu
606
607
608 menu "Blackfin Kernel Optimizations"
609
610 comment "Memory Optimizations"
611
612 config I_ENTRY_L1
613         bool "Locate interrupt entry code in L1 Memory"
614         default y
615         help
616           If enabled, interrupt entry code (STORE/RESTORE CONTEXT) is linked
617           into L1 instruction memory. (less latency)
618
619 config EXCPT_IRQ_SYSC_L1
620         bool "Locate entire ASM lowlevel exception / interrupt - Syscall and CPLB handler code in L1 Memory"
621         default y
622         help
623           If enabled, the entire ASM lowlevel exception and interrupt entry code
624           (STORE/RESTORE CONTEXT) is linked into L1 instruction memory. 
625           (less latency)
626
627 config DO_IRQ_L1
628         bool "Locate frequently called do_irq dispatcher function in L1 Memory"
629         default y
630         help
631           If enabled, the frequently called do_irq dispatcher function is linked
632           into L1 instruction memory. (less latency)
633
634 config CORE_TIMER_IRQ_L1
635         bool "Locate frequently called timer_interrupt() function in L1 Memory"
636         default y
637         help
638           If enabled, the frequently called timer_interrupt() function is linked
639           into L1 instruction memory. (less latency)
640
641 config IDLE_L1
642         bool "Locate frequently idle function in L1 Memory"
643         default y
644         help
645           If enabled, the frequently called idle function is linked
646           into L1 instruction memory. (less latency)
647
648 config SCHEDULE_L1
649         bool "Locate kernel schedule function in L1 Memory"
650         default y
651         help
652           If enabled, the frequently called kernel schedule is linked
653           into L1 instruction memory. (less latency)
654
655 config ARITHMETIC_OPS_L1
656         bool "Locate kernel owned arithmetic functions in L1 Memory"
657         default y
658         help
659           If enabled, arithmetic functions are linked
660           into L1 instruction memory. (less latency)
661
662 config ACCESS_OK_L1
663         bool "Locate access_ok function in L1 Memory"
664         default y
665         help
666           If enabled, the access_ok function is linked
667           into L1 instruction memory. (less latency)
668
669 config MEMSET_L1
670         bool "Locate memset function in L1 Memory"
671         default y
672         help
673           If enabled, the memset function is linked
674           into L1 instruction memory. (less latency)
675
676 config MEMCPY_L1
677         bool "Locate memcpy function in L1 Memory"
678         default y
679         help
680           If enabled, the memcpy function is linked
681           into L1 instruction memory. (less latency)
682
683 config SYS_BFIN_SPINLOCK_L1
684         bool "Locate sys_bfin_spinlock function in L1 Memory"
685         default y
686         help
687           If enabled, sys_bfin_spinlock function is linked
688           into L1 instruction memory. (less latency)
689
690 config IP_CHECKSUM_L1
691         bool "Locate IP Checksum function in L1 Memory"
692         default n
693         help
694           If enabled, the IP Checksum function is linked
695           into L1 instruction memory. (less latency)
696
697 config CACHELINE_ALIGNED_L1
698         bool "Locate cacheline_aligned data to L1 Data Memory"
699         default y if !BF54x
700         default n if BF54x
701         depends on !BF531
702         help
703           If enabled, cacheline_anligned data is linked
704           into L1 data memory. (less latency)
705
706 config SYSCALL_TAB_L1
707         bool "Locate Syscall Table L1 Data Memory"
708         default n
709         depends on !BF531
710         help
711           If enabled, the Syscall LUT is linked
712           into L1 data memory. (less latency)
713
714 config CPLB_SWITCH_TAB_L1
715         bool "Locate CPLB Switch Tables L1 Data Memory"
716         default n
717         depends on !BF531
718         help
719           If enabled, the CPLB Switch Tables are linked
720           into L1 data memory. (less latency)
721
722 endmenu
723
724
725 choice
726         prompt "Kernel executes from"
727         help
728           Choose the memory type that the kernel will be running in.
729
730 config RAMKERNEL
731         bool "RAM"
732         help
733           The kernel will be resident in RAM when running.
734
735 config ROMKERNEL
736         bool "ROM"
737         help
738           The kernel will be resident in FLASH/ROM when running.
739
740 endchoice
741
742 source "mm/Kconfig"
743
744 config LARGE_ALLOCS
745         bool "Allow allocating large blocks (> 1MB) of memory"
746         help
747           Allow the slab memory allocator to keep chains for very large
748           memory sizes - upto 32MB. You may need this if your system has
749           a lot of RAM, and you need to able to allocate very large
750           contiguous chunks. If unsure, say N.
751
752 config BFIN_DMA_5XX
753         bool "Enable DMA Support"
754         depends on (BF533 || BF532 || BF531 || BF537 || BF536 || BF534 || BF561 || BF54x)
755         default y
756         help
757           DMA driver for BF5xx.
758
759 choice
760         prompt "Uncached SDRAM region"
761         default DMA_UNCACHED_1M
762         depends on BFIN_DMA_5XX
763 config DMA_UNCACHED_2M
764         bool "Enable 2M DMA region"
765 config DMA_UNCACHED_1M
766         bool "Enable 1M DMA region"
767 config DMA_UNCACHED_NONE
768         bool "Disable DMA region"
769 endchoice
770
771
772 comment "Cache Support"
773 config BFIN_ICACHE
774         bool "Enable ICACHE"
775 config BFIN_DCACHE
776         bool "Enable DCACHE"
777 config BFIN_DCACHE_BANKA
778         bool "Enable only 16k BankA DCACHE - BankB is SRAM"
779         depends on BFIN_DCACHE && !BF531
780         default n
781 config BFIN_ICACHE_LOCK
782         bool "Enable Instruction Cache Locking"
783
784 choice
785         prompt "Policy"
786         depends on BFIN_DCACHE
787         default BFIN_WB
788 config BFIN_WB
789         bool "Write back"
790         help
791           Write Back Policy:
792             Cached data will be written back to SDRAM only when needed.
793             This can give a nice increase in performance, but beware of
794             broken drivers that do not properly invalidate/flush their
795             cache.
796
797           Write Through Policy:
798             Cached data will always be written back to SDRAM when the
799             cache is updated.  This is a completely safe setting, but
800             performance is worse than Write Back.
801
802           If you are unsure of the options and you want to be safe,
803           then go with Write Through.
804
805 config BFIN_WT
806         bool "Write through"
807         help
808           Write Back Policy:
809             Cached data will be written back to SDRAM only when needed.
810             This can give a nice increase in performance, but beware of
811             broken drivers that do not properly invalidate/flush their
812             cache.
813
814           Write Through Policy:
815             Cached data will always be written back to SDRAM when the
816             cache is updated.  This is a completely safe setting, but
817             performance is worse than Write Back.
818
819           If you are unsure of the options and you want to be safe,
820           then go with Write Through.
821
822 endchoice
823
824 config L1_MAX_PIECE
825         int "Set the max L1 SRAM pieces"
826         default 16
827         help
828           Set the max memory pieces for the L1 SRAM allocation algorithm.
829           Min value is 16. Max value is 1024.
830
831 comment "Asynchonous Memory Configuration"
832
833 menu "EBIU_AMGCTL Global Control"
834 config C_AMCKEN
835         bool "Enable CLKOUT"
836         default y
837
838 config C_CDPRIO
839         bool "DMA has priority over core for ext. accesses"
840         depends on !BF54x
841         default n
842
843 config C_B0PEN
844         depends on BF561
845         bool "Bank 0 16 bit packing enable"
846         default y
847
848 config C_B1PEN
849         depends on BF561
850         bool "Bank 1 16 bit packing enable"
851         default y
852
853 config C_B2PEN
854         depends on BF561
855         bool "Bank 2 16 bit packing enable"
856         default y
857
858 config C_B3PEN
859         depends on BF561
860         bool "Bank 3 16 bit packing enable"
861         default n
862
863 choice
864         prompt"Enable Asynchonous Memory Banks"
865         default C_AMBEN_ALL
866
867 config C_AMBEN
868         bool "Disable All Banks"
869
870 config C_AMBEN_B0
871         bool "Enable Bank 0"
872
873 config C_AMBEN_B0_B1
874         bool "Enable Bank 0 & 1"
875
876 config C_AMBEN_B0_B1_B2
877         bool "Enable Bank 0 & 1 & 2"
878
879 config C_AMBEN_ALL
880         bool "Enable All Banks"
881 endchoice
882 endmenu
883
884 menu "EBIU_AMBCTL Control"
885 config BANK_0
886         hex "Bank 0"
887         default 0x7BB0
888
889 config BANK_1
890         hex "Bank 1"
891         default 0x7BB0
892
893 config BANK_2
894         hex "Bank 2"
895         default 0x7BB0
896
897 config BANK_3
898         hex "Bank 3"
899         default 0x99B3
900 endmenu
901
902 endmenu
903
904 #############################################################################
905 menu "Bus options (PCI, PCMCIA, EISA, MCA, ISA)"
906
907 config PCI
908         bool "PCI support"
909         help
910           Support for PCI bus.
911
912 source "drivers/pci/Kconfig"
913
914 config HOTPLUG
915         bool "Support for hot-pluggable device"
916           help
917           Say Y here if you want to plug devices into your computer while
918           the system is running, and be able to use them quickly.  In many
919           cases, the devices can likewise be unplugged at any time too.
920
921           One well known example of this is PCMCIA- or PC-cards, credit-card
922           size devices such as network cards, modems or hard drives which are
923           plugged into slots found on all modern laptop computers.  Another
924           example, used on modern desktops as well as laptops, is USB.
925
926           Enable HOTPLUG and KMOD, and build a modular kernel.  Get agent
927           software (at <http://linux-hotplug.sourceforge.net/>) and install it.
928           Then your kernel will automatically call out to a user mode "policy
929           agent" (/sbin/hotplug) to load modules and set up software needed
930           to use devices as you hotplug them.
931
932 source "drivers/pcmcia/Kconfig"
933
934 source "drivers/pci/hotplug/Kconfig"
935
936 endmenu
937
938 menu "Executable file formats"
939
940 source "fs/Kconfig.binfmt"
941
942 endmenu
943
944 menu "Power management options"
945 source "kernel/power/Kconfig"
946
947 choice
948         prompt "Select PM Wakeup Event Source"
949         default PM_WAKEUP_GPIO_BY_SIC_IWR
950         depends on PM
951         help
952           If you have a GPIO already configured as input with the corresponding PORTx_MASK
953           bit set - "Specify Wakeup Event by SIC_IWR value"
954
955 config PM_WAKEUP_GPIO_BY_SIC_IWR
956         bool "Specify Wakeup Event by SIC_IWR value"
957 config PM_WAKEUP_BY_GPIO
958         bool "Cause Wakeup Event by GPIO"
959 config PM_WAKEUP_GPIO_API
960         bool "Configure Wakeup Event by PM GPIO API"
961
962 endchoice
963
964 config PM_WAKEUP_SIC_IWR
965         hex "Wakeup Events (SIC_IWR)"
966         depends on PM_WAKEUP_GPIO_BY_SIC_IWR
967         default 0x80000000 if (BF537 || BF536 || BF534)
968         default 0x100000 if (BF533 || BF532 || BF531)
969
970 config PM_WAKEUP_GPIO_NUMBER
971         int "Wakeup GPIO number"
972         range 0 47
973         depends on PM_WAKEUP_BY_GPIO
974         default 2 if BFIN537_STAMP
975
976 choice
977         prompt "GPIO Polarity"
978         depends on PM_WAKEUP_BY_GPIO
979         default PM_WAKEUP_GPIO_POLAR_H
980 config  PM_WAKEUP_GPIO_POLAR_H
981         bool "Active High"
982 config  PM_WAKEUP_GPIO_POLAR_L
983         bool "Active Low"
984 config  PM_WAKEUP_GPIO_POLAR_EDGE_F
985         bool "Falling EDGE"
986 config  PM_WAKEUP_GPIO_POLAR_EDGE_R
987         bool "Rising EDGE"
988 config  PM_WAKEUP_GPIO_POLAR_EDGE_B
989         bool "Both EDGE"
990 endchoice
991
992 endmenu
993
994 if (BF537 || BF533 || BF54x)
995
996 menu "CPU Frequency scaling"
997
998 source "drivers/cpufreq/Kconfig"
999
1000 config CPU_FREQ
1001         bool
1002         default n
1003         help
1004           If you want to enable this option, you should select the
1005           DPMC driver from Character Devices.
1006 endmenu
1007
1008 endif
1009
1010 source "net/Kconfig"
1011
1012 source "drivers/Kconfig"
1013
1014 source "fs/Kconfig"
1015
1016 source "kernel/Kconfig.instrumentation"
1017
1018 menu "Kernel hacking"
1019
1020 source "lib/Kconfig.debug"
1021
1022 config DEBUG_HWERR
1023         bool "Hardware error interrupt debugging"
1024         depends on DEBUG_KERNEL
1025         help
1026           When enabled, the hardware error interrupt is never disabled, and
1027           will happen immediately when an error condition occurs.  This comes
1028           at a slight cost in code size, but is necessary if you are getting
1029           hardware error interrupts and need to know where they are coming
1030           from.
1031
1032 config DEBUG_ICACHE_CHECK
1033         bool "Check Instruction cache coherency"
1034         depends on DEBUG_KERNEL
1035         depends on DEBUG_HWERR
1036         help
1037           Say Y here if you are getting weird unexplained errors. This will
1038           ensure that icache is what SDRAM says it should be by doing a
1039           byte wise comparison between SDRAM and instruction cache. This
1040           also relocates the irq_panic() function to L1 memory, (which is
1041           un-cached).
1042
1043 config DEBUG_HUNT_FOR_ZERO
1044         bool "Catch NULL pointer reads/writes"
1045         default y
1046         help
1047           Say Y here to catch reads/writes to anywhere in the memory range
1048           from 0x0000 - 0x0FFF (the first 4k) of memory.  This is useful in
1049           catching common programming errors such as NULL pointer dereferences.
1050
1051           Misbehaving applications will be killed (generate a SEGV) while the
1052           kernel will trigger a panic.
1053
1054           Enabling this option will take up an extra entry in CPLB table.
1055           Otherwise, there is no extra overhead.
1056
1057 config DEBUG_BFIN_HWTRACE_ON
1058         bool "Turn on Blackfin's Hardware Trace"
1059         default y
1060         help
1061           All Blackfins include a Trace Unit which stores a history of the last
1062           16 changes in program flow taken by the program sequencer. The history
1063           allows the user to recreate the program sequencer’s recent path. This
1064           can be handy when an application dies - we print out the execution
1065           path of how it got to the offending instruction.
1066
1067           By turning this off, you may save a tiny amount of power.
1068
1069 choice
1070         prompt "Omit loop Tracing"
1071         default DEBUG_BFIN_HWTRACE_COMPRESSION_OFF
1072         depends on DEBUG_BFIN_HWTRACE_ON
1073         help
1074           The trace buffer can be configured to omit recording of changes in
1075           program flow that match either the last entry or one of the last
1076           two entries. Omitting one of these entries from the record prevents
1077           the trace buffer from overflowing because of any sort of loop (for, do
1078           while, etc) in the program.
1079
1080           Because zero-overhead Hardware loops are not recorded in the trace buffer,
1081           this feature can be used to prevent trace overflow from loops that
1082           are nested four deep.
1083
1084 config DEBUG_BFIN_HWTRACE_COMPRESSION_OFF
1085         bool "Trace all Loops"
1086         help
1087           The trace buffer records all changes of flow 
1088
1089 config DEBUG_BFIN_HWTRACE_COMPRESSION_ONE
1090         bool "Compress single-level loops"
1091         help
1092           The trace buffer does not record single loops - helpful if trace 
1093           is spinning on a while or do loop.
1094
1095 config DEBUG_BFIN_HWTRACE_COMPRESSION_TWO
1096         bool "Compress two-level loops"
1097         help
1098           The trace buffer does not record loops two levels deep. Helpful if
1099           the trace is spinning in a nested loop
1100
1101 endchoice
1102
1103 config DEBUG_BFIN_HWTRACE_COMPRESSION
1104         int
1105         depends on DEBUG_BFIN_HWTRACE_ON
1106         default 0 if DEBUG_BFIN_HWTRACE_COMPRESSION_OFF
1107         default 1 if DEBUG_BFIN_HWTRACE_COMPRESSION_ONE
1108         default 2 if DEBUG_BFIN_HWTRACE_COMPRESSION_TWO
1109
1110
1111 config DEBUG_BFIN_HWTRACE_EXPAND
1112         bool "Expand Trace Buffer greater than 16 entries"
1113         depends on DEBUG_BFIN_HWTRACE_ON
1114         default n
1115         help
1116           By selecting this option, every time the 16 hardware entries in
1117           the Blackfin's HW Trace buffer are full, the kernel will move them
1118           into a software buffer, for dumping when there is an issue. This 
1119           has a great impact on performance, (an interrupt every 16 change of 
1120           flows) and should normally be turned off, except in those nasty
1121           debugging sessions
1122
1123 config DEBUG_BFIN_HWTRACE_EXPAND_LEN
1124         int "Size of Trace buffer (in power of 2k)"
1125         range 0 4
1126         depends on DEBUG_BFIN_HWTRACE_EXPAND
1127         default 1
1128         help
1129           This sets the size of the software buffer that the trace information
1130           is kept in.
1131           0 for (2^0)  1k, or 256 entries,
1132           1 for (2^1)  2k, or 512 entries,
1133           2 for (2^2)  4k, or 1024 entries,
1134           3 for (2^3)  8k, or 2048 entries,
1135           4 for (2^4) 16k, or 4096 entries
1136
1137 config DEBUG_BFIN_NO_KERN_HWTRACE
1138         bool "Trace user apps (turn off hwtrace in kernel)"
1139         depends on DEBUG_BFIN_HWTRACE_ON
1140         default n
1141         help
1142           Some pieces of the kernel contain a lot of flow changes which can
1143           quickly fill up the hardware trace buffer.  When debugging crashes,
1144           the hardware trace may indicate that the problem lies in kernel
1145           space when in reality an application is buggy.
1146
1147           Say Y here to disable hardware tracing in some known "jumpy" pieces
1148           of code so that the trace buffer will extend further back.
1149
1150 config EARLY_PRINTK
1151         bool "Early printk" 
1152         default n
1153         help
1154           This option enables special console drivers which allow the kernel
1155           to print messages very early in the bootup process.
1156
1157           This is useful for kernel debugging when your machine crashes very
1158           early before the console code is initialized. After enabling this
1159           feature, you must add "earlyprintk=serial,uart0,57600" to the
1160           command line (bootargs). It is safe to say Y here in all cases, as
1161           all of this lives in the init section and is thrown away after the
1162           kernel boots completely.
1163
1164 config DUAL_CORE_TEST_MODULE
1165         tristate "Dual Core Test Module"
1166         depends on (BF561)
1167         default n
1168         help
1169           Say Y here to build-in dual core test module for dual core test.
1170
1171 config CPLB_INFO
1172         bool "Display the CPLB information"
1173         help
1174           Display the CPLB information.
1175
1176 config ACCESS_CHECK
1177         bool "Check the user pointer address"
1178         default y
1179         help
1180           Usually the pointer transfer from user space is checked to see if its
1181           address is in the kernel space.
1182
1183           Say N here to disable that check to improve the performance.
1184
1185 endmenu
1186
1187 source "security/Kconfig"
1188
1189 source "crypto/Kconfig"
1190
1191 source "lib/Kconfig"