blob: 368bc7fe167e70c1400b38e30188dda6b87baa00 [file] [log] [blame]
Bryan Wu1394f032007-05-06 14:50:22 -07001#
2# For a description of the syntax of this configuration file,
3# see Documentation/kbuild/kconfig-language.txt.
4#
5
Mike Frysinger53f8a252007-11-15 15:48:01 +08006mainmenu "Blackfin Kernel Configuration"
Bryan Wu1394f032007-05-06 14:50:22 -07007
8config MMU
9 bool
10 default n
11
12config FPU
13 bool
14 default n
15
16config RWSEM_GENERIC_SPINLOCK
17 bool
18 default y
19
20config RWSEM_XCHGADD_ALGORITHM
21 bool
22 default n
23
24config BLACKFIN
25 bool
26 default y
Mathieu Desnoyers42d4b832008-02-02 15:10:34 -050027 select HAVE_OPROFILE
Bryan Wu1394f032007-05-06 14:50:22 -070028
Aubrey Lie3defff2007-05-21 18:09:11 +080029config ZONE_DMA
30 bool
31 default y
32
Bryan Wu1394f032007-05-06 14:50:22 -070033config SEMAPHORE_SLEEPERS
34 bool
35 default y
36
37config GENERIC_FIND_NEXT_BIT
38 bool
39 default y
40
41config GENERIC_HWEIGHT
42 bool
43 default y
44
45config GENERIC_HARDIRQS
46 bool
47 default y
48
49config GENERIC_IRQ_PROBE
Mike Frysingere4e9a7a2007-11-15 20:39:34 +080050 bool
Bryan Wu1394f032007-05-06 14:50:22 -070051 default y
52
53config GENERIC_TIME
54 bool
55 default n
56
Michael Hennerichb2d15832007-07-24 15:46:36 +080057config GENERIC_GPIO
Bryan Wu1394f032007-05-06 14:50:22 -070058 bool
59 default y
60
61config FORCE_MAX_ZONEORDER
62 int
63 default "14"
64
65config GENERIC_CALIBRATE_DELAY
66 bool
67 default y
68
Mathieu Desnoyers7d2284b2008-01-15 12:42:02 -050069config HARDWARE_PM
70 def_bool y
71 depends on OPROFILE
72
Bryan Wu1394f032007-05-06 14:50:22 -070073source "init/Kconfig"
74source "kernel/Kconfig.preempt"
75
76menu "Blackfin Processor Options"
77
78comment "Processor and Board Settings"
79
80choice
81 prompt "CPU"
82 default BF533
83
Michael Hennerich59003142007-10-21 16:54:27 +080084config BF522
85 bool "BF522"
86 help
87 BF522 Processor Support.
88
Mike Frysinger1545a112007-12-24 16:54:48 +080089config BF523
90 bool "BF523"
91 help
92 BF523 Processor Support.
93
94config BF524
95 bool "BF524"
96 help
97 BF524 Processor Support.
98
Michael Hennerich59003142007-10-21 16:54:27 +080099config BF525
100 bool "BF525"
101 help
102 BF525 Processor Support.
103
Mike Frysinger1545a112007-12-24 16:54:48 +0800104config BF526
105 bool "BF526"
106 help
107 BF526 Processor Support.
108
Michael Hennerich59003142007-10-21 16:54:27 +0800109config BF527
110 bool "BF527"
111 help
112 BF527 Processor Support.
113
Bryan Wu1394f032007-05-06 14:50:22 -0700114config BF531
115 bool "BF531"
116 help
117 BF531 Processor Support.
118
119config BF532
120 bool "BF532"
121 help
122 BF532 Processor Support.
123
124config BF533
125 bool "BF533"
126 help
127 BF533 Processor Support.
128
129config BF534
130 bool "BF534"
131 help
132 BF534 Processor Support.
133
134config BF536
135 bool "BF536"
136 help
137 BF536 Processor Support.
138
139config BF537
140 bool "BF537"
141 help
142 BF537 Processor Support.
143
Roy Huang24a07a12007-07-12 22:41:45 +0800144config BF542
145 bool "BF542"
146 help
147 BF542 Processor Support.
148
149config BF544
150 bool "BF544"
151 help
152 BF544 Processor Support.
153
Mike Frysinger7c7fd172007-11-15 21:10:21 +0800154config BF547
155 bool "BF547"
156 help
157 BF547 Processor Support.
158
Roy Huang24a07a12007-07-12 22:41:45 +0800159config BF548
160 bool "BF548"
161 help
162 BF548 Processor Support.
163
164config BF549
165 bool "BF549"
166 help
167 BF549 Processor Support.
168
Bryan Wu1394f032007-05-06 14:50:22 -0700169config BF561
170 bool "BF561"
171 help
172 Not Supported Yet - Work in progress - BF561 Processor Support.
173
174endchoice
175
176choice
177 prompt "Silicon Rev"
Michael Hennerich59003142007-10-21 16:54:27 +0800178 default BF_REV_0_1 if BF527
Bryan Wu1394f032007-05-06 14:50:22 -0700179 default BF_REV_0_2 if BF537
180 default BF_REV_0_3 if BF533
Roy Huang24a07a12007-07-12 22:41:45 +0800181 default BF_REV_0_0 if BF549
182
183config BF_REV_0_0
184 bool "0.0"
Mike Frysingerd07f4382007-11-15 15:49:17 +0800185 depends on (BF52x || BF54x)
Michael Hennerich59003142007-10-21 16:54:27 +0800186
187config BF_REV_0_1
Mike Frysingerd07f4382007-11-15 15:49:17 +0800188 bool "0.1"
189 depends on (BF52x || BF54x)
Bryan Wu1394f032007-05-06 14:50:22 -0700190
191config BF_REV_0_2
192 bool "0.2"
193 depends on (BF537 || BF536 || BF534)
194
195config BF_REV_0_3
196 bool "0.3"
197 depends on (BF561 || BF537 || BF536 || BF534 || BF533 || BF532 || BF531)
198
199config BF_REV_0_4
200 bool "0.4"
201 depends on (BF561 || BF533 || BF532 || BF531)
202
203config BF_REV_0_5
204 bool "0.5"
205 depends on (BF561 || BF533 || BF532 || BF531)
206
Jie Zhangde3025f2007-06-25 18:04:12 +0800207config BF_REV_ANY
208 bool "any"
209
210config BF_REV_NONE
211 bool "none"
212
Bryan Wu1394f032007-05-06 14:50:22 -0700213endchoice
214
Michael Hennerich59003142007-10-21 16:54:27 +0800215config BF52x
216 bool
Mike Frysinger1545a112007-12-24 16:54:48 +0800217 depends on (BF522 || BF523 || BF524 || BF525 || BF526 || BF527)
Michael Hennerich59003142007-10-21 16:54:27 +0800218 default y
219
Roy Huang24a07a12007-07-12 22:41:45 +0800220config BF53x
221 bool
222 depends on (BF531 || BF532 || BF533 || BF534 || BF536 || BF537)
223 default y
224
225config BF54x
226 bool
Mike Frysinger7c7fd172007-11-15 21:10:21 +0800227 depends on (BF542 || BF544 || BF547 || BF548 || BF549)
Roy Huang24a07a12007-07-12 22:41:45 +0800228 default y
229
Bryan Wu1394f032007-05-06 14:50:22 -0700230config BFIN_DUAL_CORE
231 bool
232 depends on (BF561)
233 default y
234
235config BFIN_SINGLE_CORE
236 bool
237 depends on !BFIN_DUAL_CORE
238 default y
239
Bryan Wu1394f032007-05-06 14:50:22 -0700240config MEM_GENERIC_BOARD
241 bool
242 depends on GENERIC_BOARD
243 default y
244
245config MEM_MT48LC64M4A2FB_7E
246 bool
247 depends on (BFIN533_STAMP)
248 default y
249
250config MEM_MT48LC16M16A2TG_75
251 bool
252 depends on (BFIN533_EZKIT || BFIN561_EZKIT \
Javier Herreroab472a02007-10-29 16:14:44 +0800253 || BFIN533_BLUETECHNIX_CM || BFIN537_BLUETECHNIX_CM \
254 || H8606_HVSISTEMAS)
Bryan Wu1394f032007-05-06 14:50:22 -0700255 default y
256
257config MEM_MT48LC32M8A2_75
258 bool
259 depends on (BFIN537_STAMP || PNAV10)
260 default y
261
262config MEM_MT48LC8M32B2B5_7
263 bool
264 depends on (BFIN561_BLUETECHNIX_CM)
265 default y
266
Michael Hennerich59003142007-10-21 16:54:27 +0800267config MEM_MT48LC32M16A2TG_75
268 bool
269 depends on (BFIN527_EZKIT)
270 default y
271
Michael Hennerich59003142007-10-21 16:54:27 +0800272source "arch/blackfin/mach-bf527/Kconfig"
Bryan Wu1394f032007-05-06 14:50:22 -0700273source "arch/blackfin/mach-bf533/Kconfig"
274source "arch/blackfin/mach-bf561/Kconfig"
275source "arch/blackfin/mach-bf537/Kconfig"
Roy Huang24a07a12007-07-12 22:41:45 +0800276source "arch/blackfin/mach-bf548/Kconfig"
Bryan Wu1394f032007-05-06 14:50:22 -0700277
278menu "Board customizations"
279
280config CMDLINE_BOOL
281 bool "Default bootloader kernel arguments"
282
283config CMDLINE
284 string "Initial kernel command string"
285 depends on CMDLINE_BOOL
286 default "console=ttyBF0,57600"
287 help
288 If you don't have a boot loader capable of passing a command line string
289 to the kernel, you may specify one here. As a minimum, you should specify
290 the memory size and the root device (e.g., mem=8M, root=/dev/nfs).
291
Robin Getzf16295e2007-08-03 18:07:17 +0800292comment "Clock/PLL Setup"
Bryan Wu1394f032007-05-06 14:50:22 -0700293
294config CLKIN_HZ
295 int "Crystal Frequency in Hz"
296 default "11059200" if BFIN533_STAMP
297 default "27000000" if BFIN533_EZKIT
Javier Herreroab472a02007-10-29 16:14:44 +0800298 default "25000000" if (BFIN537_STAMP || BFIN527_EZKIT || H8606_HVSISTEMAS)
Bryan Wu1394f032007-05-06 14:50:22 -0700299 default "30000000" if BFIN561_EZKIT
300 default "24576000" if PNAV10
301 help
302 The frequency of CLKIN crystal oscillator on the board in Hz.
303
Robin Getzf16295e2007-08-03 18:07:17 +0800304config BFIN_KERNEL_CLOCK
305 bool "Re-program Clocks while Kernel boots?"
306 default n
307 help
308 This option decides if kernel clocks are re-programed from the
309 bootloader settings. If the clocks are not set, the SDRAM settings
310 are also not changed, and the Bootloader does 100% of the hardware
311 configuration.
312
313config PLL_BYPASS
Mike Frysingere4e9a7a2007-11-15 20:39:34 +0800314 bool "Bypass PLL"
315 depends on BFIN_KERNEL_CLOCK
316 default n
Robin Getzf16295e2007-08-03 18:07:17 +0800317
318config CLKIN_HALF
319 bool "Half Clock In"
320 depends on BFIN_KERNEL_CLOCK && (! PLL_BYPASS)
321 default n
322 help
323 If this is set the clock will be divided by 2, before it goes to the PLL.
324
325config VCO_MULT
326 int "VCO Multiplier"
327 depends on BFIN_KERNEL_CLOCK && (! PLL_BYPASS)
328 range 1 64
329 default "22" if BFIN533_EZKIT
330 default "45" if BFIN533_STAMP
Sonic Zhang971d5bc2008-01-27 16:32:31 +0800331 default "20" if (BFIN537_STAMP || BFIN527_EZKIT || BFIN548_EZKIT)
Robin Getzf16295e2007-08-03 18:07:17 +0800332 default "22" if BFIN533_BLUETECHNIX_CM
333 default "20" if BFIN537_BLUETECHNIX_CM
334 default "20" if BFIN561_BLUETECHNIX_CM
335 default "20" if BFIN561_EZKIT
Javier Herreroab472a02007-10-29 16:14:44 +0800336 default "16" if H8606_HVSISTEMAS
Robin Getzf16295e2007-08-03 18:07:17 +0800337 help
338 This controls the frequency of the on-chip PLL. This can be between 1 and 64.
339 PLL Frequency = (Crystal Frequency) * (this setting)
340
341choice
342 prompt "Core Clock Divider"
343 depends on BFIN_KERNEL_CLOCK
344 default CCLK_DIV_1
345 help
346 This sets the frequency of the core. It can be 1, 2, 4 or 8
347 Core Frequency = (PLL frequency) / (this setting)
348
349config CCLK_DIV_1
350 bool "1"
351
352config CCLK_DIV_2
353 bool "2"
354
355config CCLK_DIV_4
356 bool "4"
357
358config CCLK_DIV_8
359 bool "8"
360endchoice
361
362config SCLK_DIV
363 int "System Clock Divider"
364 depends on BFIN_KERNEL_CLOCK
365 range 1 15
366 default 5 if BFIN533_EZKIT
367 default 5 if BFIN533_STAMP
Sonic Zhang971d5bc2008-01-27 16:32:31 +0800368 default 4 if (BFIN537_STAMP || BFIN527_EZKIT || BFIN548_EZKIT)
Robin Getzf16295e2007-08-03 18:07:17 +0800369 default 5 if BFIN533_BLUETECHNIX_CM
370 default 4 if BFIN537_BLUETECHNIX_CM
371 default 4 if BFIN561_BLUETECHNIX_CM
372 default 5 if BFIN561_EZKIT
Javier Herreroab472a02007-10-29 16:14:44 +0800373 default 3 if H8606_HVSISTEMAS
Robin Getzf16295e2007-08-03 18:07:17 +0800374 help
375 This sets the frequency of the system clock (including SDRAM or DDR).
376 This can be between 1 and 15
377 System Clock = (PLL frequency) / (this setting)
378
379#
380# Max & Min Speeds for various Chips
381#
382config MAX_VCO_HZ
383 int
384 default 600000000 if BF522
Mike Frysinger1545a112007-12-24 16:54:48 +0800385 default 400000000 if BF523
386 default 400000000 if BF524
Robin Getzf16295e2007-08-03 18:07:17 +0800387 default 600000000 if BF525
Mike Frysinger1545a112007-12-24 16:54:48 +0800388 default 400000000 if BF526
Robin Getzf16295e2007-08-03 18:07:17 +0800389 default 600000000 if BF527
390 default 400000000 if BF531
391 default 400000000 if BF532
392 default 750000000 if BF533
393 default 500000000 if BF534
394 default 400000000 if BF536
395 default 600000000 if BF537
Robin Getzf72eecb2007-11-21 16:29:20 +0800396 default 533333333 if BF538
397 default 533333333 if BF539
Robin Getzf16295e2007-08-03 18:07:17 +0800398 default 600000000 if BF542
Robin Getzf72eecb2007-11-21 16:29:20 +0800399 default 533333333 if BF544
Mike Frysinger1545a112007-12-24 16:54:48 +0800400 default 600000000 if BF547
401 default 600000000 if BF548
Robin Getzf72eecb2007-11-21 16:29:20 +0800402 default 533333333 if BF549
Robin Getzf16295e2007-08-03 18:07:17 +0800403 default 600000000 if BF561
404
405config MIN_VCO_HZ
406 int
407 default 50000000
408
409config MAX_SCLK_HZ
410 int
Robin Getzf72eecb2007-11-21 16:29:20 +0800411 default 133333333
Robin Getzf16295e2007-08-03 18:07:17 +0800412
413config MIN_SCLK_HZ
414 int
415 default 27000000
416
417comment "Kernel Timer/Scheduler"
418
419source kernel/Kconfig.hz
420
421comment "Memory Setup"
422
Bryan Wu1394f032007-05-06 14:50:22 -0700423config MEM_SIZE
424 int "SDRAM Memory Size in MBytes"
425 default 32 if BFIN533_EZKIT
Michael Hennerich59003142007-10-21 16:54:27 +0800426 default 64 if BFIN527_EZKIT
Bryan Wu1394f032007-05-06 14:50:22 -0700427 default 64 if BFIN537_STAMP
Sonic Zhang971d5bc2008-01-27 16:32:31 +0800428 default 64 if BFIN548_EZKIT
Bryan Wu1394f032007-05-06 14:50:22 -0700429 default 64 if BFIN561_EZKIT
430 default 128 if BFIN533_STAMP
431 default 64 if PNAV10
Javier Herreroab472a02007-10-29 16:14:44 +0800432 default 32 if H8606_HVSISTEMAS
Bryan Wu1394f032007-05-06 14:50:22 -0700433
434config MEM_ADD_WIDTH
435 int "SDRAM Memory Address Width"
Sonic Zhang971d5bc2008-01-27 16:32:31 +0800436 depends on (!BF54x)
Bryan Wu1394f032007-05-06 14:50:22 -0700437 default 9 if BFIN533_EZKIT
438 default 9 if BFIN561_EZKIT
Javier Herreroab472a02007-10-29 16:14:44 +0800439 default 9 if H8606_HVSISTEMAS
Michael Hennerich59003142007-10-21 16:54:27 +0800440 default 10 if BFIN527_EZKIT
Bryan Wu1394f032007-05-06 14:50:22 -0700441 default 10 if BFIN537_STAMP
442 default 11 if BFIN533_STAMP
443 default 10 if PNAV10
444
Sonic Zhang971d5bc2008-01-27 16:32:31 +0800445
446choice
447 prompt "DDR SDRAM Chip Type"
448 depends on BFIN548_EZKIT
449 default MEM_MT46V32M16_5B
450
451config MEM_MT46V32M16_6T
452 bool "MT46V32M16_6T"
453
454config MEM_MT46V32M16_5B
455 bool "MT46V32M16_5B"
456endchoice
457
Bryan Wu1394f032007-05-06 14:50:22 -0700458config ENET_FLASH_PIN
459 int "PF port/pin used for flash and ethernet sharing"
460 depends on (BFIN533_STAMP)
461 default 0
462 help
463 PF port/pin used for flash and ethernet sharing to allow other PF
464 pins to be used on other platforms without having to touch common
465 code.
466 For example: PF0 --> 0,PF1 --> 1,PF2 --> 2, etc.
467
468config BOOT_LOAD
469 hex "Kernel load address for booting"
470 default "0x1000"
Mike Frysinger2d8f1612007-08-05 14:06:16 +0800471 range 0x1000 0x20000000
Bryan Wu1394f032007-05-06 14:50:22 -0700472 help
473 This option allows you to set the load address of the kernel.
474 This can be useful if you are on a board which has a small amount
475 of memory or you wish to reserve some memory at the beginning of
476 the address space.
477
Mike Frysinger2d8f1612007-08-05 14:06:16 +0800478 Note that you need to keep this value above 4k (0x1000) as this
479 memory region is used to capture NULL pointer references as well
480 as some core kernel functions.
Bryan Wu1394f032007-05-06 14:50:22 -0700481
Mike Frysingerf0b5d122007-08-05 17:03:59 +0800482choice
483 prompt "Blackfin Exception Scratch Register"
484 default BFIN_SCRATCH_REG_RETN
485 help
486 Select the resource to reserve for the Exception handler:
487 - RETN: Non-Maskable Interrupt (NMI)
488 - RETE: Exception Return (JTAG/ICE)
489 - CYCLES: Performance counter
490
491 If you are unsure, please select "RETN".
492
493config BFIN_SCRATCH_REG_RETN
494 bool "RETN"
495 help
496 Use the RETN register in the Blackfin exception handler
497 as a stack scratch register. This means you cannot
498 safely use NMI on the Blackfin while running Linux, but
499 you can debug the system with a JTAG ICE and use the
500 CYCLES performance registers.
501
502 If you are unsure, please select "RETN".
503
504config BFIN_SCRATCH_REG_RETE
505 bool "RETE"
506 help
507 Use the RETE register in the Blackfin exception handler
508 as a stack scratch register. This means you cannot
509 safely use a JTAG ICE while debugging a Blackfin board,
510 but you can safely use the CYCLES performance registers
511 and the NMI.
512
513 If you are unsure, please select "RETN".
514
515config BFIN_SCRATCH_REG_CYCLES
516 bool "CYCLES"
517 help
518 Use the CYCLES register in the Blackfin exception handler
519 as a stack scratch register. This means you cannot
520 safely use the CYCLES performance registers on a Blackfin
521 board at anytime, but you can debug the system with a JTAG
522 ICE and use the NMI.
523
524 If you are unsure, please select "RETN".
525
526endchoice
527
Bryan Wu1394f032007-05-06 14:50:22 -0700528endmenu
529
530
531menu "Blackfin Kernel Optimizations"
532
Bryan Wu1394f032007-05-06 14:50:22 -0700533comment "Memory Optimizations"
534
535config I_ENTRY_L1
536 bool "Locate interrupt entry code in L1 Memory"
537 default y
538 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200539 If enabled, interrupt entry code (STORE/RESTORE CONTEXT) is linked
540 into L1 instruction memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700541
542config EXCPT_IRQ_SYSC_L1
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200543 bool "Locate entire ASM lowlevel exception / interrupt - Syscall and CPLB handler code in L1 Memory"
Bryan Wu1394f032007-05-06 14:50:22 -0700544 default y
545 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200546 If enabled, the entire ASM lowlevel exception and interrupt entry code
Michael Hennerichcfefe3c2008-02-09 04:12:37 +0800547 (STORE/RESTORE CONTEXT) is linked into L1 instruction memory.
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200548 (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700549
550config DO_IRQ_L1
551 bool "Locate frequently called do_irq dispatcher function in L1 Memory"
552 default y
553 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200554 If enabled, the frequently called do_irq dispatcher function is linked
555 into L1 instruction memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700556
557config CORE_TIMER_IRQ_L1
558 bool "Locate frequently called timer_interrupt() function in L1 Memory"
559 default y
560 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200561 If enabled, the frequently called timer_interrupt() function is linked
562 into L1 instruction memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700563
564config IDLE_L1
565 bool "Locate frequently idle function in L1 Memory"
566 default y
567 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200568 If enabled, the frequently called idle function is linked
569 into L1 instruction memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700570
571config SCHEDULE_L1
572 bool "Locate kernel schedule function in L1 Memory"
573 default y
574 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200575 If enabled, the frequently called kernel schedule is linked
576 into L1 instruction memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700577
578config ARITHMETIC_OPS_L1
579 bool "Locate kernel owned arithmetic functions in L1 Memory"
580 default y
581 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200582 If enabled, arithmetic functions are linked
583 into L1 instruction memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700584
585config ACCESS_OK_L1
586 bool "Locate access_ok function in L1 Memory"
587 default y
588 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200589 If enabled, the access_ok function is linked
590 into L1 instruction memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700591
592config MEMSET_L1
593 bool "Locate memset function in L1 Memory"
594 default y
595 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200596 If enabled, the memset function is linked
597 into L1 instruction memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700598
599config MEMCPY_L1
600 bool "Locate memcpy function in L1 Memory"
601 default y
602 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200603 If enabled, the memcpy function is linked
604 into L1 instruction memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700605
606config SYS_BFIN_SPINLOCK_L1
607 bool "Locate sys_bfin_spinlock function in L1 Memory"
608 default y
609 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200610 If enabled, sys_bfin_spinlock function is linked
611 into L1 instruction memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700612
613config IP_CHECKSUM_L1
614 bool "Locate IP Checksum function in L1 Memory"
615 default n
616 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200617 If enabled, the IP Checksum function is linked
618 into L1 instruction memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700619
620config CACHELINE_ALIGNED_L1
621 bool "Locate cacheline_aligned data to L1 Data Memory"
Michael Hennerich157cc5a2007-07-12 16:20:21 +0800622 default y if !BF54x
623 default n if BF54x
Bryan Wu1394f032007-05-06 14:50:22 -0700624 depends on !BF531
625 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200626 If enabled, cacheline_anligned data is linked
627 into L1 data memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700628
629config SYSCALL_TAB_L1
630 bool "Locate Syscall Table L1 Data Memory"
631 default n
632 depends on !BF531
633 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200634 If enabled, the Syscall LUT is linked
635 into L1 data memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700636
637config CPLB_SWITCH_TAB_L1
638 bool "Locate CPLB Switch Tables L1 Data Memory"
639 default n
640 depends on !BF531
641 help
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200642 If enabled, the CPLB Switch Tables are linked
643 into L1 data memory. (less latency)
Bryan Wu1394f032007-05-06 14:50:22 -0700644
645endmenu
646
647
648choice
649 prompt "Kernel executes from"
650 help
651 Choose the memory type that the kernel will be running in.
652
653config RAMKERNEL
654 bool "RAM"
655 help
656 The kernel will be resident in RAM when running.
657
658config ROMKERNEL
659 bool "ROM"
660 help
661 The kernel will be resident in FLASH/ROM when running.
662
663endchoice
664
665source "mm/Kconfig"
666
Bryan Wudb0fa202007-07-12 14:55:05 +0800667config LARGE_ALLOCS
668 bool "Allow allocating large blocks (> 1MB) of memory"
669 help
670 Allow the slab memory allocator to keep chains for very large
671 memory sizes - upto 32MB. You may need this if your system has
672 a lot of RAM, and you need to able to allocate very large
673 contiguous chunks. If unsure, say N.
674
Mike Frysinger780431e2007-10-21 23:37:54 +0800675config BFIN_GPTIMERS
676 tristate "Enable Blackfin General Purpose Timers API"
677 default n
678 help
679 Enable support for the General Purpose Timers API. If you
680 are unsure, say N.
681
682 To compile this driver as a module, choose M here: the module
683 will be called gptimers.ko.
684
Bryan Wu1394f032007-05-06 14:50:22 -0700685config BFIN_DMA_5XX
686 bool "Enable DMA Support"
Michael Hennerich59003142007-10-21 16:54:27 +0800687 depends on (BF52x || BF53x || BF561 || BF54x)
Bryan Wu1394f032007-05-06 14:50:22 -0700688 default y
689 help
690 DMA driver for BF5xx.
691
692choice
693 prompt "Uncached SDRAM region"
694 default DMA_UNCACHED_1M
Adrian Bunk247537b2007-09-26 20:02:52 +0200695 depends on BFIN_DMA_5XX
Bryan Wu1394f032007-05-06 14:50:22 -0700696config DMA_UNCACHED_2M
697 bool "Enable 2M DMA region"
698config DMA_UNCACHED_1M
699 bool "Enable 1M DMA region"
700config DMA_UNCACHED_NONE
701 bool "Disable DMA region"
702endchoice
703
704
705comment "Cache Support"
Robin Getz3bebca22007-10-10 23:55:26 +0800706config BFIN_ICACHE
Bryan Wu1394f032007-05-06 14:50:22 -0700707 bool "Enable ICACHE"
Robin Getz3bebca22007-10-10 23:55:26 +0800708config BFIN_DCACHE
Bryan Wu1394f032007-05-06 14:50:22 -0700709 bool "Enable DCACHE"
Robin Getz3bebca22007-10-10 23:55:26 +0800710config BFIN_DCACHE_BANKA
Bryan Wu1394f032007-05-06 14:50:22 -0700711 bool "Enable only 16k BankA DCACHE - BankB is SRAM"
Robin Getz3bebca22007-10-10 23:55:26 +0800712 depends on BFIN_DCACHE && !BF531
Bryan Wu1394f032007-05-06 14:50:22 -0700713 default n
Robin Getz3bebca22007-10-10 23:55:26 +0800714config BFIN_ICACHE_LOCK
715 bool "Enable Instruction Cache Locking"
Bryan Wu1394f032007-05-06 14:50:22 -0700716
717choice
718 prompt "Policy"
Robin Getz3bebca22007-10-10 23:55:26 +0800719 depends on BFIN_DCACHE
720 default BFIN_WB
721config BFIN_WB
Bryan Wu1394f032007-05-06 14:50:22 -0700722 bool "Write back"
723 help
724 Write Back Policy:
725 Cached data will be written back to SDRAM only when needed.
726 This can give a nice increase in performance, but beware of
727 broken drivers that do not properly invalidate/flush their
728 cache.
729
730 Write Through Policy:
731 Cached data will always be written back to SDRAM when the
732 cache is updated. This is a completely safe setting, but
733 performance is worse than Write Back.
734
735 If you are unsure of the options and you want to be safe,
736 then go with Write Through.
737
Robin Getz3bebca22007-10-10 23:55:26 +0800738config BFIN_WT
Bryan Wu1394f032007-05-06 14:50:22 -0700739 bool "Write through"
740 help
741 Write Back Policy:
742 Cached data will be written back to SDRAM only when needed.
743 This can give a nice increase in performance, but beware of
744 broken drivers that do not properly invalidate/flush their
745 cache.
746
747 Write Through Policy:
748 Cached data will always be written back to SDRAM when the
749 cache is updated. This is a completely safe setting, but
750 performance is worse than Write Back.
751
752 If you are unsure of the options and you want to be safe,
753 then go with Write Through.
754
755endchoice
756
757config L1_MAX_PIECE
758 int "Set the max L1 SRAM pieces"
759 default 16
760 help
761 Set the max memory pieces for the L1 SRAM allocation algorithm.
762 Min value is 16. Max value is 1024.
763
Bernd Schmidtb97b8a92008-01-27 18:39:16 +0800764
765config MPU
766 bool "Enable the memory protection unit (EXPERIMENTAL)"
767 default n
768 help
769 Use the processor's MPU to protect applications from accessing
770 memory they do not own. This comes at a performance penalty
771 and is recommended only for debugging.
772
Bryan Wu1394f032007-05-06 14:50:22 -0700773comment "Asynchonous Memory Configuration"
774
Mike Frysingerddf416b2007-10-10 18:06:47 +0800775menu "EBIU_AMGCTL Global Control"
Bryan Wu1394f032007-05-06 14:50:22 -0700776config C_AMCKEN
777 bool "Enable CLKOUT"
778 default y
779
780config C_CDPRIO
781 bool "DMA has priority over core for ext. accesses"
782 default n
783
784config C_B0PEN
785 depends on BF561
786 bool "Bank 0 16 bit packing enable"
787 default y
788
789config C_B1PEN
790 depends on BF561
791 bool "Bank 1 16 bit packing enable"
792 default y
793
794config C_B2PEN
795 depends on BF561
796 bool "Bank 2 16 bit packing enable"
797 default y
798
799config C_B3PEN
800 depends on BF561
801 bool "Bank 3 16 bit packing enable"
802 default n
803
804choice
805 prompt"Enable Asynchonous Memory Banks"
806 default C_AMBEN_ALL
807
808config C_AMBEN
809 bool "Disable All Banks"
810
811config C_AMBEN_B0
812 bool "Enable Bank 0"
813
814config C_AMBEN_B0_B1
815 bool "Enable Bank 0 & 1"
816
817config C_AMBEN_B0_B1_B2
818 bool "Enable Bank 0 & 1 & 2"
819
820config C_AMBEN_ALL
821 bool "Enable All Banks"
822endchoice
823endmenu
824
825menu "EBIU_AMBCTL Control"
826config BANK_0
827 hex "Bank 0"
828 default 0x7BB0
829
830config BANK_1
831 hex "Bank 1"
832 default 0x7BB0
833
834config BANK_2
835 hex "Bank 2"
836 default 0x7BB0
837
838config BANK_3
839 hex "Bank 3"
840 default 0x99B3
841endmenu
842
Sonic Zhange40540b2007-11-21 23:49:52 +0800843config EBIU_MBSCTLVAL
844 hex "EBIU Bank Select Control Register"
845 depends on BF54x
846 default 0
847
848config EBIU_MODEVAL
849 hex "Flash Memory Mode Control Register"
850 depends on BF54x
851 default 1
852
853config EBIU_FCTLVAL
854 hex "Flash Memory Bank Control Register"
855 depends on BF54x
856 default 6
Bryan Wu1394f032007-05-06 14:50:22 -0700857endmenu
858
859#############################################################################
860menu "Bus options (PCI, PCMCIA, EISA, MCA, ISA)"
861
862config PCI
863 bool "PCI support"
864 help
865 Support for PCI bus.
866
867source "drivers/pci/Kconfig"
868
869config HOTPLUG
870 bool "Support for hot-pluggable device"
871 help
872 Say Y here if you want to plug devices into your computer while
873 the system is running, and be able to use them quickly. In many
874 cases, the devices can likewise be unplugged at any time too.
875
876 One well known example of this is PCMCIA- or PC-cards, credit-card
877 size devices such as network cards, modems or hard drives which are
878 plugged into slots found on all modern laptop computers. Another
879 example, used on modern desktops as well as laptops, is USB.
880
881 Enable HOTPLUG and KMOD, and build a modular kernel. Get agent
882 software (at <http://linux-hotplug.sourceforge.net/>) and install it.
883 Then your kernel will automatically call out to a user mode "policy
884 agent" (/sbin/hotplug) to load modules and set up software needed
885 to use devices as you hotplug them.
886
887source "drivers/pcmcia/Kconfig"
888
889source "drivers/pci/hotplug/Kconfig"
890
891endmenu
892
893menu "Executable file formats"
894
895source "fs/Kconfig.binfmt"
896
897endmenu
898
899menu "Power management options"
900source "kernel/power/Kconfig"
901
Johannes Bergf4cb5702007-12-08 02:14:00 +0100902config ARCH_SUSPEND_POSSIBLE
903 def_bool y
904 depends on !SMP
905
Bryan Wu1394f032007-05-06 14:50:22 -0700906choice
Michael Hennerichcfefe3c2008-02-09 04:12:37 +0800907 prompt "Default Power Saving Mode"
Bryan Wu1394f032007-05-06 14:50:22 -0700908 depends on PM
Michael Hennerichcfefe3c2008-02-09 04:12:37 +0800909 default PM_BFIN_SLEEP_DEEPER
910config PM_BFIN_SLEEP_DEEPER
911 bool "Sleep Deeper"
Bryan Wu1394f032007-05-06 14:50:22 -0700912 help
Michael Hennerichcfefe3c2008-02-09 04:12:37 +0800913 Sleep "Deeper" Mode (High Power Savings) - This mode reduces dynamic
914 power dissipation by disabling the clock to the processor core (CCLK).
915 Furthermore, Standby sets the internal power supply voltage (VDDINT)
916 to 0.85 V to provide the greatest power savings, while preserving the
917 processor state.
918 The PLL and system clock (SCLK) continue to operate at a very low
919 frequency of about 3.3 MHz. To preserve data integrity in the SDRAM,
920 the SDRAM is put into Self Refresh Mode. Typically an external event
921 such as GPIO interrupt or RTC activity wakes up the processor.
922 Various Peripherals such as UART, SPORT, PPI may not function as
923 normal during Sleep Deeper, due to the reduced SCLK frequency.
924 When in the sleep mode, system DMA access to L1 memory is not supported.
Bryan Wu1394f032007-05-06 14:50:22 -0700925
Michael Hennerichcfefe3c2008-02-09 04:12:37 +0800926config PM_BFIN_SLEEP
927 bool "Sleep"
928 help
929 Sleep Mode (High Power Savings) - The sleep mode reduces power
930 dissipation by disabling the clock to the processor core (CCLK).
931 The PLL and system clock (SCLK), however, continue to operate in
932 this mode. Typically an external event or RTC activity will wake
933 up the processor. When in the sleep mode,
934 system DMA access to L1 memory is not supported.
Bryan Wu1394f032007-05-06 14:50:22 -0700935endchoice
936
Michael Hennerichcfefe3c2008-02-09 04:12:37 +0800937config PM_WAKEUP_BY_GPIO
938 bool "Cause Wakeup Event by GPIO"
Bryan Wu1394f032007-05-06 14:50:22 -0700939
940config PM_WAKEUP_GPIO_NUMBER
941 int "Wakeup GPIO number"
942 range 0 47
943 depends on PM_WAKEUP_BY_GPIO
944 default 2 if BFIN537_STAMP
945
946choice
947 prompt "GPIO Polarity"
948 depends on PM_WAKEUP_BY_GPIO
949 default PM_WAKEUP_GPIO_POLAR_H
950config PM_WAKEUP_GPIO_POLAR_H
951 bool "Active High"
952config PM_WAKEUP_GPIO_POLAR_L
953 bool "Active Low"
954config PM_WAKEUP_GPIO_POLAR_EDGE_F
955 bool "Falling EDGE"
956config PM_WAKEUP_GPIO_POLAR_EDGE_R
957 bool "Rising EDGE"
958config PM_WAKEUP_GPIO_POLAR_EDGE_B
959 bool "Both EDGE"
960endchoice
961
962endmenu
963
Roy Huang24a07a12007-07-12 22:41:45 +0800964if (BF537 || BF533 || BF54x)
Bryan Wu1394f032007-05-06 14:50:22 -0700965
966menu "CPU Frequency scaling"
967
968source "drivers/cpufreq/Kconfig"
969
970config CPU_FREQ
971 bool
972 default n
973 help
974 If you want to enable this option, you should select the
975 DPMC driver from Character Devices.
976endmenu
977
978endif
979
980source "net/Kconfig"
981
982source "drivers/Kconfig"
983
984source "fs/Kconfig"
985
Mike Frysinger74ce8322007-11-21 23:50:49 +0800986source "arch/blackfin/Kconfig.debug"
Bryan Wu1394f032007-05-06 14:50:22 -0700987
988source "security/Kconfig"
989
990source "crypto/Kconfig"
991
992source "lib/Kconfig"