Kconfig 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361
  1. menu "Self-contained MTD device drivers"
  2. depends on MTD!=n
  3. depends on HAS_IOMEM
  4. config MTD_PMC551
  5. tristate "Ramix PMC551 PCI Mezzanine RAM card support"
  6. depends on PCI
  7. ---help---
  8. This provides a MTD device driver for the Ramix PMC551 RAM PCI card
  9. from Ramix Inc. <http://www.ramix.com/products/memory/pmc551.html>.
  10. These devices come in memory configurations from 32M - 1G. If you
  11. have one, you probably want to enable this.
  12. If this driver is compiled as a module you get the ability to select
  13. the size of the aperture window pointing into the devices memory.
  14. What this means is that if you have a 1G card, normally the kernel
  15. will use a 1G memory map as its view of the device. As a module,
  16. you can select a 1M window into the memory and the driver will
  17. "slide" the window around the PMC551's memory. This was
  18. particularly useful on the 2.2 kernels on PPC architectures as there
  19. was limited kernel space to deal with.
  20. config MTD_PMC551_BUGFIX
  21. bool "PMC551 256M DRAM Bugfix"
  22. depends on MTD_PMC551
  23. help
  24. Some of Ramix's PMC551 boards with 256M configurations have invalid
  25. column and row mux values. This option will fix them, but will
  26. break other memory configurations. If unsure say N.
  27. config MTD_PMC551_DEBUG
  28. bool "PMC551 Debugging"
  29. depends on MTD_PMC551
  30. help
  31. This option makes the PMC551 more verbose during its operation and
  32. is only really useful if you are developing on this driver or
  33. suspect a possible hardware or driver bug. If unsure say N.
  34. config MTD_MS02NV
  35. tristate "DEC MS02-NV NVRAM module support"
  36. depends on MACH_DECSTATION
  37. help
  38. This is an MTD driver for the DEC's MS02-NV (54-20948-01) battery
  39. backed-up NVRAM module. The module was originally meant as an NFS
  40. accelerator. Say Y here if you have a DECstation 5000/2x0 or a
  41. DECsystem 5900 equipped with such a module.
  42. If you want to compile this driver as a module ( = code which can be
  43. inserted in and removed from the running kernel whenever you want),
  44. say M here and read <file:Documentation/kbuild/modules.txt>.
  45. The module will be called ms02-nv.
  46. config MTD_MSM_NAND
  47. tristate "MSM NAND Device Support"
  48. depends on MTD && ARCH_MSM
  49. select CRC16
  50. select BITREVERSE
  51. select MTD_NAND_IDS
  52. default y
  53. help
  54. Support for some NAND chips connected to the MSM NAND controller.
  55. config MTD_MSM_QPIC_NAND
  56. tristate "MSM QPIC NAND Device Support"
  57. depends on MTD && ARCH_MSM && !MTD_MSM_NAND
  58. select CRC16
  59. select BITREVERSE
  60. select MTD_NAND_IDS
  61. default n
  62. help
  63. Support for NAND controller in Qualcomm Parallel Interface
  64. controller (QPIC). This new controller supports BAM mode
  65. and BCH error correction mechanism. Based on the device
  66. capabilities either 4 bit or 8 bit BCH ECC will be used.
  67. config MTD_DATAFLASH
  68. tristate "Support for AT45xxx DataFlash"
  69. depends on SPI_MASTER && EXPERIMENTAL
  70. help
  71. This enables access to AT45xxx DataFlash chips, using SPI.
  72. Sometimes DataFlash chips are packaged inside MMC-format
  73. cards; at this writing, the MMC stack won't handle those.
  74. config MTD_DATAFLASH_WRITE_VERIFY
  75. bool "Verify DataFlash page writes"
  76. depends on MTD_DATAFLASH
  77. help
  78. This adds an extra check when data is written to the flash.
  79. It may help if you are verifying chip setup (timings etc) on
  80. your board. There is a rare possibility that even though the
  81. device thinks the write was successful, a bit could have been
  82. flipped accidentally due to device wear or something else.
  83. config MTD_DATAFLASH_OTP
  84. bool "DataFlash OTP support (Security Register)"
  85. depends on MTD_DATAFLASH
  86. select HAVE_MTD_OTP
  87. help
  88. Newer DataFlash chips (revisions C and D) support 128 bytes of
  89. one-time-programmable (OTP) data. The first half may be written
  90. (once) with up to 64 bytes of data, such as a serial number or
  91. other key product data. The second half is programmed with a
  92. unique-to-each-chip bit pattern at the factory.
  93. config MTD_M25P80
  94. tristate "Support most SPI Flash chips (AT26DF, M25P, W25X, ...)"
  95. depends on SPI_MASTER && EXPERIMENTAL
  96. help
  97. This enables access to most modern SPI flash chips, used for
  98. program and data storage. Series supported include Atmel AT26DF,
  99. Spansion S25SL, SST 25VF, ST M25P, and Winbond W25X. Other chips
  100. are supported as well. See the driver source for the current list,
  101. or to add other chips.
  102. Note that the original DataFlash chips (AT45 series, not AT26DF),
  103. need an entirely different driver.
  104. Set up your spi devices with the right board-specific platform data,
  105. if you want to specify device partitioning or to use a device which
  106. doesn't support the JEDEC ID instruction.
  107. config M25PXX_USE_FAST_READ
  108. bool "Use FAST_READ OPCode allowing SPI CLK <= 50MHz"
  109. depends on MTD_M25P80
  110. default y
  111. help
  112. This option enables FAST_READ access supported by ST M25Pxx.
  113. config MTD_SPEAR_SMI
  114. tristate "SPEAR MTD NOR Support through SMI controller"
  115. depends on PLAT_SPEAR
  116. default y
  117. help
  118. This enable SNOR support on SPEAR platforms using SMI controller
  119. config MTD_SST25L
  120. tristate "Support SST25L (non JEDEC) SPI Flash chips"
  121. depends on SPI_MASTER
  122. help
  123. This enables access to the non JEDEC SST25L SPI flash chips, used
  124. for program and data storage.
  125. Set up your spi devices with the right board-specific platform data,
  126. if you want to specify device partitioning.
  127. config MTD_SLRAM
  128. tristate "Uncached system RAM"
  129. help
  130. If your CPU cannot cache all of the physical memory in your machine,
  131. you can still use it for storage or swap by using this driver to
  132. present it to the system as a Memory Technology Device.
  133. config MTD_PHRAM
  134. tristate "Physical system RAM"
  135. help
  136. This is a re-implementation of the slram driver above.
  137. Use this driver to access physical memory that the kernel proper
  138. doesn't have access to, memory beyond the mem=xxx limit, nvram,
  139. memory on the video card, etc...
  140. config MTD_LART
  141. tristate "28F160xx flash driver for LART"
  142. depends on SA1100_LART
  143. help
  144. This enables the flash driver for LART. Please note that you do
  145. not need any mapping/chip driver for LART. This one does it all
  146. for you, so go disable all of those if you enabled some of them (:
  147. config MTD_MTDRAM
  148. tristate "Test driver using RAM"
  149. help
  150. This enables a test MTD device driver which uses vmalloc() to
  151. provide storage. You probably want to say 'N' unless you're
  152. testing stuff.
  153. config MTDRAM_TOTAL_SIZE
  154. int "MTDRAM device size in KiB"
  155. depends on MTD_MTDRAM
  156. default "4096"
  157. help
  158. This allows you to configure the total size of the MTD device
  159. emulated by the MTDRAM driver. If the MTDRAM driver is built
  160. as a module, it is also possible to specify this as a parameter when
  161. loading the module.
  162. config MTDRAM_ERASE_SIZE
  163. int "MTDRAM erase block size in KiB"
  164. depends on MTD_MTDRAM
  165. default "128"
  166. help
  167. This allows you to configure the size of the erase blocks in the
  168. device emulated by the MTDRAM driver. If the MTDRAM driver is built
  169. as a module, it is also possible to specify this as a parameter when
  170. loading the module.
  171. #If not a module (I don't want to test it as a module)
  172. config MTDRAM_ABS_POS
  173. hex "SRAM Hexadecimal Absolute position or 0"
  174. depends on MTD_MTDRAM=y
  175. default "0"
  176. help
  177. If you have system RAM accessible by the CPU but not used by Linux
  178. in normal operation, you can give the physical address at which the
  179. available RAM starts, and the MTDRAM driver will use it instead of
  180. allocating space from Linux's available memory. Otherwise, leave
  181. this set to zero. Most people will want to leave this as zero.
  182. config MTD_BLOCK2MTD
  183. tristate "MTD using block device"
  184. depends on BLOCK
  185. help
  186. This driver allows a block device to appear as an MTD. It would
  187. generally be used in the following cases:
  188. Using Compact Flash as an MTD, these usually present themselves to
  189. the system as an ATA drive.
  190. Testing MTD users (eg JFFS2) on large media and media that might
  191. be removed during a write (using the floppy drive).
  192. comment "Disk-On-Chip Device Drivers"
  193. config MTD_DOC2000
  194. tristate "M-Systems Disk-On-Chip 2000 and Millennium (DEPRECATED)"
  195. depends on MTD_NAND
  196. select MTD_DOCPROBE
  197. select MTD_NAND_IDS
  198. ---help---
  199. This provides an MTD device driver for the M-Systems DiskOnChip
  200. 2000 and Millennium devices. Originally designed for the DiskOnChip
  201. 2000, it also now includes support for the DiskOnChip Millennium.
  202. If you have problems with this driver and the DiskOnChip Millennium,
  203. you may wish to try the alternative Millennium driver below. To use
  204. the alternative driver, you will need to undefine DOC_SINGLE_DRIVER
  205. in the <file:drivers/mtd/devices/docprobe.c> source code.
  206. If you use this device, you probably also want to enable the NFTL
  207. 'NAND Flash Translation Layer' option below, which is used to
  208. emulate a block device by using a kind of file system on the flash
  209. chips.
  210. NOTE: This driver is deprecated and will probably be removed soon.
  211. Please try the new DiskOnChip driver under "NAND Flash Device
  212. Drivers".
  213. config MTD_DOC2001
  214. tristate "M-Systems Disk-On-Chip Millennium-only alternative driver (DEPRECATED)"
  215. depends on MTD_NAND
  216. select MTD_DOCPROBE
  217. select MTD_NAND_IDS
  218. ---help---
  219. This provides an alternative MTD device driver for the M-Systems
  220. DiskOnChip Millennium devices. Use this if you have problems with
  221. the combined DiskOnChip 2000 and Millennium driver above. To get
  222. the DiskOnChip probe code to load and use this driver instead of
  223. the other one, you will need to undefine DOC_SINGLE_DRIVER near
  224. the beginning of <file:drivers/mtd/devices/docprobe.c>.
  225. If you use this device, you probably also want to enable the NFTL
  226. 'NAND Flash Translation Layer' option below, which is used to
  227. emulate a block device by using a kind of file system on the flash
  228. chips.
  229. NOTE: This driver is deprecated and will probably be removed soon.
  230. Please try the new DiskOnChip driver under "NAND Flash Device
  231. Drivers".
  232. config MTD_DOC2001PLUS
  233. tristate "M-Systems Disk-On-Chip Millennium Plus"
  234. depends on MTD_NAND
  235. select MTD_DOCPROBE
  236. select MTD_NAND_IDS
  237. ---help---
  238. This provides an MTD device driver for the M-Systems DiskOnChip
  239. Millennium Plus devices.
  240. If you use this device, you probably also want to enable the INFTL
  241. 'Inverse NAND Flash Translation Layer' option below, which is used
  242. to emulate a block device by using a kind of file system on the
  243. flash chips.
  244. NOTE: This driver will soon be replaced by the new DiskOnChip driver
  245. under "NAND Flash Device Drivers" (currently that driver does not
  246. support all Millennium Plus devices).
  247. config MTD_DOCG3
  248. tristate "M-Systems Disk-On-Chip G3"
  249. select BCH
  250. select BCH_CONST_PARAMS
  251. ---help---
  252. This provides an MTD device driver for the M-Systems DiskOnChip
  253. G3 devices.
  254. The driver provides access to G3 DiskOnChip, distributed by
  255. M-Systems and now Sandisk. The support is very experimental,
  256. and doesn't give access to any write operations.
  257. if MTD_DOCG3
  258. config BCH_CONST_M
  259. default 14
  260. config BCH_CONST_T
  261. default 4
  262. endif
  263. config MTD_DOCPROBE
  264. tristate
  265. select MTD_DOCECC
  266. config MTD_DOCECC
  267. tristate
  268. config MTD_DOCPROBE_ADVANCED
  269. bool "Advanced detection options for DiskOnChip"
  270. depends on MTD_DOCPROBE
  271. help
  272. This option allows you to specify nonstandard address at which to
  273. probe for a DiskOnChip, or to change the detection options. You
  274. are unlikely to need any of this unless you are using LinuxBIOS.
  275. Say 'N'.
  276. config MTD_DOCPROBE_ADDRESS
  277. hex "Physical address of DiskOnChip" if MTD_DOCPROBE_ADVANCED
  278. depends on MTD_DOCPROBE
  279. default "0x0"
  280. ---help---
  281. By default, the probe for DiskOnChip devices will look for a
  282. DiskOnChip at every multiple of 0x2000 between 0xC8000 and 0xEE000.
  283. This option allows you to specify a single address at which to probe
  284. for the device, which is useful if you have other devices in that
  285. range which get upset when they are probed.
  286. (Note that on PowerPC, the normal probe will only check at
  287. 0xE4000000.)
  288. Normally, you should leave this set to zero, to allow the probe at
  289. the normal addresses.
  290. config MTD_DOCPROBE_HIGH
  291. bool "Probe high addresses"
  292. depends on MTD_DOCPROBE_ADVANCED
  293. help
  294. By default, the probe for DiskOnChip devices will look for a
  295. DiskOnChip at every multiple of 0x2000 between 0xC8000 and 0xEE000.
  296. This option changes to make it probe between 0xFFFC8000 and
  297. 0xFFFEE000. Unless you are using LinuxBIOS, this is unlikely to be
  298. useful to you. Say 'N'.
  299. config MTD_DOCPROBE_55AA
  300. bool "Probe for 0x55 0xAA BIOS Extension Signature"
  301. depends on MTD_DOCPROBE_ADVANCED
  302. help
  303. Check for the 0x55 0xAA signature of a DiskOnChip, and do not
  304. continue with probing if it is absent. The signature will always be
  305. present for a DiskOnChip 2000 or a normal DiskOnChip Millennium.
  306. Only if you have overwritten the first block of a DiskOnChip
  307. Millennium will it be absent. Enable this option if you are using
  308. LinuxBIOS or if you need to recover a DiskOnChip Millennium on which
  309. you have managed to wipe the first block.
  310. endmenu