Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6
[cascardo/linux.git] / drivers / mtd / nand / Kconfig
1 menuconfig MTD_NAND
2         tristate "NAND Device Support"
3         depends on MTD
4         select MTD_NAND_IDS
5         help
6           This enables support for accessing all type of NAND flash
7           devices. For further information see
8           <http://www.linux-mtd.infradead.org/doc/nand.html>.
9
10 if MTD_NAND
11
12 config MTD_NAND_VERIFY_WRITE
13         bool "Verify NAND page writes"
14         help
15           This adds an extra check when data is written to the flash. The
16           NAND flash device internally checks only bits transitioning
17           from 1 to 0. There is a rare possibility that even though the
18           device thinks the write was successful, a bit could have been
19           flipped accidentally due to device wear or something else.
20
21 config MTD_NAND_ECC_SMC
22         bool "NAND ECC Smart Media byte order"
23         default n
24         help
25           Software ECC according to the Smart Media Specification.
26           The original Linux implementation had byte 0 and 1 swapped.
27
28 config MTD_SM_COMMON
29         tristate
30         default n
31
32 config MTD_NAND_MUSEUM_IDS
33         bool "Enable chip ids for obsolete ancient NAND devices"
34         depends on MTD_NAND
35         default n
36         help
37           Enable this option only when your board has first generation
38           NAND chips (page size 256 byte, erase size 4-8KiB). The IDs
39           of these chips were reused by later, larger chips.
40
41 config MTD_NAND_AUTCPU12
42         tristate "SmartMediaCard on autronix autcpu12 board"
43         depends on ARCH_AUTCPU12
44         help
45           This enables the driver for the autronix autcpu12 board to
46           access the SmartMediaCard.
47
48 config MTD_NAND_EDB7312
49         tristate "Support for Cirrus Logic EBD7312 evaluation board"
50         depends on ARCH_EDB7312
51         help
52           This enables the driver for the Cirrus Logic EBD7312 evaluation
53           board to access the onboard NAND Flash.
54
55 config MTD_NAND_H1900
56         tristate "iPAQ H1900 flash"
57         depends on ARCH_PXA && MTD_PARTITIONS
58         help
59           This enables the driver for the iPAQ h1900 flash.
60
61 config MTD_NAND_GPIO
62         tristate "GPIO NAND Flash driver"
63         depends on GENERIC_GPIO && ARM
64         help
65           This enables a GPIO based NAND flash driver.
66
67 config MTD_NAND_SPIA
68         tristate "NAND Flash device on SPIA board"
69         depends on ARCH_P720T
70         help
71           If you had to ask, you don't have one. Say 'N'.
72
73 config MTD_NAND_AMS_DELTA
74         tristate "NAND Flash device on Amstrad E3"
75         depends on MACH_AMS_DELTA
76         help
77           Support for NAND flash on Amstrad E3 (Delta).
78
79 config MTD_NAND_OMAP2
80         tristate "NAND Flash device on OMAP2 and OMAP3"
81         depends on ARM && MTD_NAND && (ARCH_OMAP2 || ARCH_OMAP3)
82         help
83           Support for NAND flash on Texas Instruments OMAP2 and OMAP3 platforms.
84
85 config MTD_NAND_OMAP_PREFETCH
86         bool "GPMC prefetch support for NAND Flash device"
87         depends on MTD_NAND && MTD_NAND_OMAP2
88         default y
89         help
90          The NAND device can be accessed for Read/Write using GPMC PREFETCH engine
91          to improve the performance.
92
93 config MTD_NAND_OMAP_PREFETCH_DMA
94         depends on MTD_NAND_OMAP_PREFETCH
95         bool "DMA mode"
96         default n
97         help
98          The GPMC PREFETCH engine can be configured eigther in MPU interrupt mode
99          or in DMA interrupt mode.
100          Say y for DMA mode or MPU mode will be used
101
102 config MTD_NAND_IDS
103         tristate
104
105 config MTD_NAND_AU1550
106         tristate "Au1550/1200 NAND support"
107         depends on SOC_AU1200 || SOC_AU1550
108         help
109           This enables the driver for the NAND flash controller on the
110           AMD/Alchemy 1550 SOC.
111
112 config MTD_NAND_BF5XX
113         tristate "Blackfin on-chip NAND Flash Controller driver"
114         depends on (BF54x || BF52x) && MTD_NAND
115         help
116           This enables the Blackfin on-chip NAND flash controller
117
118           No board specific support is done by this driver, each board
119           must advertise a platform_device for the driver to attach.
120
121           This driver can also be built as a module. If so, the module
122           will be called bf5xx-nand.
123
124 config MTD_NAND_BF5XX_HWECC
125         bool "BF5XX NAND Hardware ECC"
126         default y
127         depends on MTD_NAND_BF5XX
128         help
129           Enable the use of the BF5XX's internal ECC generator when
130           using NAND.
131
132 config MTD_NAND_BF5XX_BOOTROM_ECC
133         bool "Use Blackfin BootROM ECC Layout"
134         default n
135         depends on MTD_NAND_BF5XX_HWECC
136         help
137           If you wish to modify NAND pages and allow the Blackfin on-chip
138           BootROM to boot from them, say Y here.  This is only necessary
139           if you are booting U-Boot out of NAND and you wish to update
140           U-Boot from Linux' userspace.  Otherwise, you should say N here.
141
142           If unsure, say N.
143
144 config MTD_NAND_RTC_FROM4
145         tristate "Renesas Flash ROM 4-slot interface board (FROM_BOARD4)"
146         depends on SH_SOLUTION_ENGINE
147         select REED_SOLOMON
148         select REED_SOLOMON_DEC8
149         select BITREVERSE
150         help
151           This enables the driver for the Renesas Technology AG-AND
152           flash interface board (FROM_BOARD4)
153
154 config MTD_NAND_PPCHAMELEONEVB
155         tristate "NAND Flash device on PPChameleonEVB board"
156         depends on PPCHAMELEONEVB && BROKEN
157         help
158           This enables the NAND flash driver on the PPChameleon EVB Board.
159
160 config MTD_NAND_S3C2410
161         tristate "NAND Flash support for Samsung S3C SoCs"
162         depends on ARCH_S3C2410 || ARCH_S3C64XX
163         help
164           This enables the NAND flash controller on the S3C24xx and S3C64xx
165           SoCs
166
167           No board specific support is done by this driver, each board
168           must advertise a platform_device for the driver to attach.
169
170 config MTD_NAND_S3C2410_DEBUG
171         bool "Samsung S3C NAND driver debug"
172         depends on MTD_NAND_S3C2410
173         help
174           Enable debugging of the S3C NAND driver
175
176 config MTD_NAND_S3C2410_HWECC
177         bool "Samsung S3C NAND Hardware ECC"
178         depends on MTD_NAND_S3C2410
179         help
180           Enable the use of the controller's internal ECC generator when
181           using NAND. Early versions of the chips have had problems with
182           incorrect ECC generation, and if using these, the default of
183           software ECC is preferable.
184
185 config MTD_NAND_NDFC
186         tristate "NDFC NanD Flash Controller"
187         depends on 4xx
188         select MTD_NAND_ECC_SMC
189         help
190          NDFC Nand Flash Controllers are integrated in IBM/AMCC's 4xx SoCs
191
192 config MTD_NAND_S3C2410_CLKSTOP
193         bool "Samsung S3C NAND IDLE clock stop"
194         depends on MTD_NAND_S3C2410
195         default n
196         help
197           Stop the clock to the NAND controller when there is no chip
198           selected to save power. This will mean there is a small delay
199           when the is NAND chip selected or released, but will save
200           approximately 5mA of power when there is nothing happening.
201
202 config MTD_NAND_BCM_UMI
203         tristate "NAND Flash support for BCM Reference Boards"
204         depends on ARCH_BCMRING && MTD_NAND
205         help
206           This enables the NAND flash controller on the BCM UMI block.
207
208           No board specfic support is done by this driver, each board
209           must advertise a platform_device for the driver to attach.
210
211 config MTD_NAND_BCM_UMI_HWCS
212         bool "BCM UMI NAND Hardware CS"
213         depends on MTD_NAND_BCM_UMI
214         help
215           Enable the use of the BCM UMI block's internal CS using NAND.
216           This should only be used if you know the external NAND CS can toggle.
217
218 config MTD_NAND_DISKONCHIP
219         tristate "DiskOnChip 2000, Millennium and Millennium Plus (NAND reimplementation) (EXPERIMENTAL)"
220         depends on EXPERIMENTAL
221         select REED_SOLOMON
222         select REED_SOLOMON_DEC16
223         help
224           This is a reimplementation of M-Systems DiskOnChip 2000,
225           Millennium and Millennium Plus as a standard NAND device driver,
226           as opposed to the earlier self-contained MTD device drivers.
227           This should enable, among other things, proper JFFS2 operation on
228           these devices.
229
230 config MTD_NAND_DISKONCHIP_PROBE_ADVANCED
231         bool "Advanced detection options for DiskOnChip"
232         depends on MTD_NAND_DISKONCHIP
233         help
234           This option allows you to specify nonstandard address at which to
235           probe for a DiskOnChip, or to change the detection options.  You
236           are unlikely to need any of this unless you are using LinuxBIOS.
237           Say 'N'.
238
239 config MTD_NAND_DISKONCHIP_PROBE_ADDRESS
240         hex "Physical address of DiskOnChip" if MTD_NAND_DISKONCHIP_PROBE_ADVANCED
241         depends on MTD_NAND_DISKONCHIP
242         default "0"
243         ---help---
244         By default, the probe for DiskOnChip devices will look for a
245         DiskOnChip at every multiple of 0x2000 between 0xC8000 and 0xEE000.
246         This option allows you to specify a single address at which to probe
247         for the device, which is useful if you have other devices in that
248         range which get upset when they are probed.
249
250         (Note that on PowerPC, the normal probe will only check at
251         0xE4000000.)
252
253         Normally, you should leave this set to zero, to allow the probe at
254         the normal addresses.
255
256 config MTD_NAND_DISKONCHIP_PROBE_HIGH
257         bool "Probe high addresses"
258         depends on MTD_NAND_DISKONCHIP_PROBE_ADVANCED
259         help
260           By default, the probe for DiskOnChip devices will look for a
261           DiskOnChip at every multiple of 0x2000 between 0xC8000 and 0xEE000.
262           This option changes to make it probe between 0xFFFC8000 and
263           0xFFFEE000.  Unless you are using LinuxBIOS, this is unlikely to be
264           useful to you.  Say 'N'.
265
266 config MTD_NAND_DISKONCHIP_BBTWRITE
267         bool "Allow BBT writes on DiskOnChip Millennium and 2000TSOP"
268         depends on MTD_NAND_DISKONCHIP
269         help
270           On DiskOnChip devices shipped with the INFTL filesystem (Millennium
271           and 2000 TSOP/Alon), Linux reserves some space at the end of the
272           device for the Bad Block Table (BBT).  If you have existing INFTL
273           data on your device (created by non-Linux tools such as M-Systems'
274           DOS drivers), your data might overlap the area Linux wants to use for
275           the BBT.  If this is a concern for you, leave this option disabled and
276           Linux will not write BBT data into this area.
277           The downside of leaving this option disabled is that if bad blocks
278           are detected by Linux, they will not be recorded in the BBT, which
279           could cause future problems.
280           Once you enable this option, new filesystems (INFTL or others, created
281           in Linux or other operating systems) will not use the reserved area.
282           The only reason not to enable this option is to prevent damage to
283           preexisting filesystems.
284           Even if you leave this disabled, you can enable BBT writes at module
285           load time (assuming you build diskonchip as a module) with the module
286           parameter "inftl_bbt_write=1".
287
288 config MTD_NAND_SHARPSL
289         tristate "Support for NAND Flash on Sharp SL Series (C7xx + others)"
290         depends on ARCH_PXA
291
292 config MTD_NAND_CAFE
293         tristate "NAND support for OLPC CAFÉ chip"
294         depends on PCI
295         select REED_SOLOMON
296         select REED_SOLOMON_DEC16
297         help
298           Use NAND flash attached to the CAFÉ chip designed for the OLPC
299           laptop.
300
301 config MTD_NAND_CS553X
302         tristate "NAND support for CS5535/CS5536 (AMD Geode companion chip)"
303         depends on X86_32
304         help
305           The CS553x companion chips for the AMD Geode processor
306           include NAND flash controllers with built-in hardware ECC
307           capabilities; enabling this option will allow you to use
308           these. The driver will check the MSRs to verify that the
309           controller is enabled for NAND, and currently requires that
310           the controller be in MMIO mode.
311
312           If you say "m", the module will be called cs553x_nand.
313
314 config MTD_NAND_ATMEL
315         tristate "Support for NAND Flash / SmartMedia on AT91 and AVR32"
316         depends on ARCH_AT91 || AVR32
317         help
318           Enables support for NAND Flash / Smart Media Card interface
319           on Atmel AT91 and AVR32 processors.
320 choice
321         prompt "ECC management for NAND Flash / SmartMedia on AT91 / AVR32"
322         depends on MTD_NAND_ATMEL
323
324 config MTD_NAND_ATMEL_ECC_HW
325         bool "Hardware ECC"
326         depends on ARCH_AT91SAM9263 || ARCH_AT91SAM9260 || AVR32
327         help
328           Use hardware ECC instead of software ECC when the chip
329           supports it.
330
331           The hardware ECC controller is capable of single bit error
332           correction and 2-bit random detection per page.
333
334           NB : hardware and software ECC schemes are incompatible.
335           If you switch from one to another, you'll have to erase your
336           mtd partition.
337
338           If unsure, say Y
339
340 config MTD_NAND_ATMEL_ECC_SOFT
341         bool "Software ECC"
342         help
343           Use software ECC.
344
345           NB : hardware and software ECC schemes are incompatible.
346           If you switch from one to another, you'll have to erase your
347           mtd partition.
348
349 config MTD_NAND_ATMEL_ECC_NONE
350         bool "No ECC (testing only, DANGEROUS)"
351         depends on DEBUG_KERNEL
352         help
353           No ECC will be used.
354           It's not a good idea and it should be reserved for testing
355           purpose only.
356
357           If unsure, say N
358
359           endchoice
360
361 endchoice
362
363 config MTD_NAND_PXA3xx
364         tristate "Support for NAND flash devices on PXA3xx"
365         depends on MTD_NAND && (PXA3xx || ARCH_MMP)
366         help
367           This enables the driver for the NAND flash device found on
368           PXA3xx processors
369
370 config MTD_NAND_PXA3xx_BUILTIN
371         bool "Use builtin definitions for some NAND chips (deprecated)"
372         depends on MTD_NAND_PXA3xx
373         help
374           This enables builtin definitions for some NAND chips. This
375           is deprecated in favor of platform specific data.
376
377 config MTD_NAND_CM_X270
378         tristate "Support for NAND Flash on CM-X270 modules"
379         depends on MTD_NAND && MACH_ARMCORE
380
381 config MTD_NAND_PASEMI
382         tristate "NAND support for PA Semi PWRficient"
383         depends on MTD_NAND && PPC_PASEMI
384         help
385           Enables support for NAND Flash interface on PA Semi PWRficient
386           based boards
387
388 config MTD_NAND_TMIO
389         tristate "NAND Flash device on Toshiba Mobile IO Controller"
390         depends on MTD_NAND && MFD_TMIO
391         help
392           Support for NAND flash connected to a Toshiba Mobile IO
393           Controller in some PDAs, including the Sharp SL6000x.
394
395 config MTD_NAND_NANDSIM
396         tristate "Support for NAND Flash Simulator"
397         depends on MTD_PARTITIONS
398         help
399           The simulator may simulate various NAND flash chips for the
400           MTD nand layer.
401
402 config MTD_NAND_PLATFORM
403         tristate "Support for generic platform NAND driver"
404         depends on MTD_NAND
405         help
406           This implements a generic NAND driver for on-SOC platform
407           devices. You will need to provide platform-specific functions
408           via platform_data.
409
410 config MTD_ALAUDA
411         tristate "MTD driver for Olympus MAUSB-10 and Fujifilm DPC-R1"
412         depends on MTD_NAND && USB
413         help
414           These two (and possibly other) Alauda-based cardreaders for
415           SmartMedia and xD allow raw flash access.
416
417 config MTD_NAND_ORION
418         tristate "NAND Flash support for Marvell Orion SoC"
419         depends on PLAT_ORION && MTD_NAND
420         help
421           This enables the NAND flash controller on Orion machines.
422
423           No board specific support is done by this driver, each board
424           must advertise a platform_device for the driver to attach.
425
426 config MTD_NAND_FSL_ELBC
427         tristate "NAND support for Freescale eLBC controllers"
428         depends on MTD_NAND && PPC_OF
429         help
430           Various Freescale chips, including the 8313, include a NAND Flash
431           Controller Module with built-in hardware ECC capabilities.
432           Enabling this option will enable you to use this to control
433           external NAND devices.
434
435 config MTD_NAND_FSL_UPM
436         tristate "Support for NAND on Freescale UPM"
437         depends on MTD_NAND && (PPC_83xx || PPC_85xx)
438         select FSL_LBC
439         help
440           Enables support for NAND Flash chips wired onto Freescale PowerPC
441           processor localbus with User-Programmable Machine support.
442
443 config MTD_NAND_MPC5121_NFC
444         tristate "MPC5121 built-in NAND Flash Controller support"
445         depends on PPC_MPC512x
446         help
447           This enables the driver for the NAND flash controller on the
448           MPC5121 SoC.
449
450 config MTD_NAND_MXC
451         tristate "MXC NAND support"
452         depends on ARCH_MX2 || ARCH_MX3
453         help
454           This enables the driver for the NAND flash controller on the
455           MXC processors.
456
457 config MTD_NAND_NOMADIK
458         tristate "ST Nomadik 8815 NAND support"
459         depends on ARCH_NOMADIK
460         help
461           Driver for the NAND flash controller on the Nomadik, with ECC.
462
463 config MTD_NAND_SH_FLCTL
464         tristate "Support for NAND on Renesas SuperH FLCTL"
465         depends on MTD_NAND && SUPERH && CPU_SUBTYPE_SH7723
466         help
467           Several Renesas SuperH CPU has FLCTL. This option enables support
468           for NAND Flash using FLCTL. This driver support SH7723.
469
470 config MTD_NAND_DAVINCI
471         tristate "Support NAND on DaVinci SoC"
472         depends on ARCH_DAVINCI
473         help
474           Enable the driver for NAND flash chips on Texas Instruments
475           DaVinci processors.
476
477 config MTD_NAND_TXX9NDFMC
478         tristate "NAND Flash support for TXx9 SoC"
479         depends on SOC_TX4938 || SOC_TX4939
480         help
481           This enables the NAND flash controller on the TXx9 SoCs.
482
483 config MTD_NAND_SOCRATES
484         tristate "Support for NAND on Socrates board"
485         depends on MTD_NAND && SOCRATES
486         help
487           Enables support for NAND Flash chips wired onto Socrates board.
488
489 config MTD_NAND_NUC900
490         tristate "Support for NAND on Nuvoton NUC9xx/w90p910 evaluation boards."
491         depends on ARCH_W90X900 && MTD_PARTITIONS
492         help
493           This enables the driver for the NAND Flash on evaluation board based
494           on w90p910 / NUC9xx.
495
496 endif # MTD_NAND