1# SPDX-License-Identifier: GPL-2.0-only
2menu "Mapping drivers for chip access"
3	depends on MTD!=n
4	depends on HAS_IOMEM
5
6config MTD_COMPLEX_MAPPINGS
7	bool "Support non-linear mappings of flash chips"
8	help
9	  This causes the chip drivers to allow for complicated
10	  paged mappings of flash chips.
11
12config MTD_PHYSMAP
13	tristate "Flash device in physical memory map"
14	depends on MTD_CFI || MTD_JEDECPROBE || MTD_ROM || MTD_RAM || MTD_LPDDR
15	help
16	  This provides a 'mapping' driver which allows the NOR Flash and
17	  ROM driver code to communicate with chips which are mapped
18	  physically into the CPU's memory. You will need to configure
19	  the physical address and size of the flash chips on your
20	  particular board as well as the bus width, either statically
21	  with config options or at run-time.
22
23	  To compile this driver as a module, choose M here: the
24	  module will be called physmap.
25
26config MTD_PHYSMAP_COMPAT
27	bool "Physmap compat support"
28	depends on MTD_PHYSMAP
29	default n
30	help
31	  Setup a simple mapping via the Kconfig options.  Normally the
32	  physmap configuration options are done via your board's
33	  resource file.
34
35	  If unsure, say N here.
36
37config MTD_PHYSMAP_START
38	hex "Physical start address of flash mapping"
39	depends on MTD_PHYSMAP_COMPAT
40	default "0x8000000"
41	help
42	  This is the physical memory location at which the flash chips
43	  are mapped on your particular target board. Refer to the
44	  memory map which should hopefully be in the documentation for
45	  your board.
46
47config MTD_PHYSMAP_LEN
48	hex "Physical length of flash mapping"
49	depends on MTD_PHYSMAP_COMPAT
50	default "0"
51	help
52	  This is the total length of the mapping of the flash chips on
53	  your particular board. If there is space, or aliases, in the
54	  physical memory map between the chips, this could be larger
55	  than the total amount of flash present. Refer to the memory
56	  map which should hopefully be in the documentation for your
57	  board.
58
59config MTD_PHYSMAP_BANKWIDTH
60	int "Bank width in octets"
61	depends on MTD_PHYSMAP_COMPAT
62	default "2"
63	help
64	  This is the total width of the data bus of the flash devices
65	  in octets. For example, if you have a data bus width of 32
66	  bits, you would set the bus width octet value to 4. This is
67	  used internally by the CFI drivers.
68
69config MTD_PHYSMAP_OF
70	bool "Memory device in physical memory map based on OF description"
71	depends on OF && MTD_PHYSMAP
72	help
73	  This provides a 'mapping' driver which allows the NOR Flash, ROM
74	  and RAM driver code to communicate with chips which are mapped
75	  physically into the CPU's memory. The mapping description here is
76	  taken from OF device tree.
77
78config MTD_PHYSMAP_BT1_ROM
79	bool "Baikal-T1 Boot ROMs OF-based physical memory map handling"
80	depends on MTD_PHYSMAP_OF
81	depends on MIPS_BAIKAL_T1 || COMPILE_TEST
82	select MTD_COMPLEX_MAPPINGS
83	select MULTIPLEXER
84	select MUX_MMIO
85	help
86	  This provides some extra DT physmap parsing for the Baikal-T1
87	  platforms, some detection and setting up ROMs-specific accessors.
88
89config MTD_PHYSMAP_VERSATILE
90	bool "ARM Versatile OF-based physical memory map handling"
91	depends on MTD_PHYSMAP_OF
92	depends on MFD_SYSCON
93	default y if (ARCH_INTEGRATOR || ARCH_VERSATILE || ARCH_REALVIEW)
94	help
95	  This provides some extra DT physmap parsing for the ARM Versatile
96	  platforms, basically to add a VPP (write protection) callback so
97	  the flash can be taken out of write protection.
98
99config MTD_PHYSMAP_GEMINI
100	bool "Cortina Gemini OF-based physical memory map handling"
101	depends on MTD_PHYSMAP_OF
102	depends on MFD_SYSCON
103	select MTD_COMPLEX_MAPPINGS
104	default ARCH_GEMINI
105	help
106	  This provides some extra DT physmap parsing for the Gemini
107	  platforms, some detection and setting up parallel mode on the
108	  external interface.
109
110config MTD_PHYSMAP_IXP4XX
111	bool "Intel IXP4xx OF-based physical memory map handling"
112	depends on MTD_PHYSMAP_OF
113	depends on ARM
114	select MTD_COMPLEX_MAPPINGS
115	select MTD_CFI_BE_BYTE_SWAP if CPU_BIG_ENDIAN
116	default ARCH_IXP4XX
117	help
118	  This provides some extra DT physmap parsing for the Intel IXP4xx
119	  platforms, some elaborate endianness handling in particular.
120
121config MTD_PHYSMAP_GPIO_ADDR
122	bool "GPIO-assisted Flash Chip Support"
123	depends on MTD_PHYSMAP
124	depends on GPIOLIB || COMPILE_TEST
125	depends on MTD_COMPLEX_MAPPINGS
126	help
127	  Extend the physmap driver to allow flashes to be partially
128	  physically addressed and assisted by GPIOs.
129
130config MTD_PMC_MSP_EVM
131	tristate "CFI Flash device mapped on PMC-Sierra MSP"
132	depends on PMC_MSP && MTD_CFI
133	help
134	  This provides a 'mapping' driver which supports the way
135	  in which user-programmable flash chips are connected on the
136	  PMC-Sierra MSP eval/demo boards.
137
138choice
139	prompt "Maximum mappable memory available for flash IO"
140	depends on MTD_PMC_MSP_EVM
141	default MSP_FLASH_MAP_LIMIT_32M
142
143config MSP_FLASH_MAP_LIMIT_32M
144	bool "32M"
145
146endchoice
147
148config MSP_FLASH_MAP_LIMIT
149	hex
150	default "0x02000000"
151	depends on MSP_FLASH_MAP_LIMIT_32M
152
153config MTD_SUN_UFLASH
154	tristate "Sun Microsystems userflash support"
155	depends on SPARC && MTD_CFI && PCI
156	help
157	  This provides a 'mapping' driver which supports the way in
158	  which user-programmable flash chips are connected on various
159	  Sun Microsystems boardsets.  This driver will require CFI support
160	  in the kernel, so if you did not enable CFI previously, do that now.
161
162config MTD_SC520CDP
163	tristate "CFI Flash device mapped on AMD SC520 CDP"
164	depends on (MELAN || COMPILE_TEST) && MTD_CFI
165	help
166	  The SC520 CDP board has two banks of CFI-compliant chips and one
167	  Dual-in-line JEDEC chip. This 'mapping' driver supports that
168	  arrangement, implementing three MTD devices.
169
170config MTD_NETSC520
171	tristate "CFI Flash device mapped on AMD NetSc520"
172	depends on (MELAN || COMPILE_TEST) && MTD_CFI
173	help
174	  This enables access routines for the flash chips on the AMD NetSc520
175	  demonstration board. If you have one of these boards and would like
176	  to use the flash chips on it, say 'Y'.
177
178config MTD_TS5500
179	tristate "JEDEC Flash device mapped on Technologic Systems TS-5500"
180	depends on TS5500 || COMPILE_TEST
181	select MTD_JEDECPROBE
182	select MTD_CFI_AMDSTD
183	help
184	  This provides a driver for the on-board flash of the Technologic
185	  System's TS-5500 board. The 2MB flash is split into 3 partitions
186	  which are accessed as separate MTD devices.
187
188	  mtd0 and mtd2 are the two BIOS drives, which use the resident
189	  flash disk (RFD) flash translation layer.
190
191	  mtd1 allows you to reprogram your BIOS. BE VERY CAREFUL.
192
193	  Note that jumper 3 ("Write Enable Drive A") must be set
194	  otherwise detection won't succeed.
195
196config MTD_SBC_GXX
197	tristate "CFI Flash device mapped on Arcom SBC-GXx boards"
198	depends on X86 && MTD_CFI_INTELEXT && MTD_COMPLEX_MAPPINGS
199	help
200	  This provides a driver for the on-board flash of Arcom Control
201	  Systems' SBC-GXn family of boards, formerly known as SBC-MediaGX.
202	  By default the flash is split into 3 partitions which are accessed
203	  as separate MTD devices. This board utilizes Intel StrataFlash.
204	  More info at
205	  <http://www.arcomcontrols.com/products/icp/pc104/processors/SBC_GX1.htm>.
206
207config MTD_PXA2XX
208	tristate "CFI Flash device mapped on Intel XScale PXA2xx based boards"
209	depends on (PXA25x || PXA27x) && MTD_CFI_INTELEXT
210	help
211	  This provides a driver for the NOR flash attached to a PXA2xx chip.
212
213config MTD_SCx200_DOCFLASH
214	tristate "Flash device mapped with DOCCS on NatSemi SCx200"
215	depends on SCx200 && MTD_CFI
216	help
217	  Enable support for a flash chip mapped using the DOCCS signal on a
218	  National Semiconductor SCx200 processor.
219
220	  If you don't know what to do here, say N.
221
222	  If compiled as a module, it will be called scx200_docflash.
223
224config MTD_AMD76XROM
225	tristate "BIOS flash chip on AMD76x southbridge"
226	depends on X86 && MTD_JEDECPROBE
227	help
228	  Support for treating the BIOS flash chip on AMD76x motherboards
229	  as an MTD device - with this you can reprogram your BIOS.
230
231	  BE VERY CAREFUL.
232
233config MTD_ICHXROM
234	tristate "BIOS flash chip on Intel Controller Hub 2/3/4/5"
235	depends on X86 && MTD_JEDECPROBE
236	help
237	  Support for treating the BIOS flash chip on ICHX motherboards
238	  as an MTD device - with this you can reprogram your BIOS.
239
240	  BE VERY CAREFUL.
241
242config MTD_ESB2ROM
243	tristate "BIOS flash chip on Intel ESB Controller Hub 2"
244	depends on X86 && MTD_JEDECPROBE && PCI
245	help
246	  Support for treating the BIOS flash chip on ESB2 motherboards
247	  as an MTD device - with this you can reprogram your BIOS.
248
249	  BE VERY CAREFUL.
250
251config MTD_CK804XROM
252	tristate "BIOS flash chip on Nvidia CK804"
253	depends on X86 && MTD_JEDECPROBE && PCI
254	help
255	  Support for treating the BIOS flash chip on nvidia motherboards
256	  as an MTD device - with this you can reprogram your BIOS.
257
258	  BE VERY CAREFUL.
259
260config MTD_SCB2_FLASH
261	tristate "BIOS flash chip on Intel SCB2 boards"
262	depends on X86 && MTD_JEDECPROBE && PCI
263	help
264	  Support for treating the BIOS flash chip on Intel SCB2 boards
265	  as an MTD device - with this you can reprogram your BIOS.
266
267	  BE VERY CAREFUL.
268
269config MTD_TSUNAMI
270	tristate "Flash chips on Tsunami TIG bus"
271	depends on ALPHA_TSUNAMI && MTD_COMPLEX_MAPPINGS
272	help
273	  Support for the flash chip on Tsunami TIG bus.
274
275config MTD_NETtel
276	tristate "CFI flash device on SnapGear/SecureEdge"
277	depends on X86 && MTD_JEDECPROBE
278	help
279	  Support for flash chips on NETtel/SecureEdge/SnapGear boards.
280
281config MTD_LANTIQ
282	tristate "Lantiq SoC NOR support"
283	depends on LANTIQ
284	help
285	  Support for NOR flash attached to the Lantiq SoC's External Bus Unit.
286
287config MTD_L440GX
288	tristate "BIOS flash chip on Intel L440GX boards"
289	depends on X86 && MTD_JEDECPROBE
290	help
291	  Support for treating the BIOS flash chip on Intel L440GX motherboards
292	  as an MTD device - with this you can reprogram your BIOS.
293
294	  BE VERY CAREFUL.
295
296config MTD_CFI_FLAGADM
297	tristate "CFI Flash device mapping on FlagaDM"
298	depends on PPC_8xx && MTD_CFI
299	help
300	  Mapping for the Flaga digital module. If you don't have one, ignore
301	  this setting.
302
303config MTD_SOLUTIONENGINE
304	tristate "CFI Flash device mapped on Hitachi SolutionEngine"
305	depends on SOLUTION_ENGINE && MTD_CFI && MTD_REDBOOT_PARTS
306	help
307	  This enables access to the flash chips on the Hitachi SolutionEngine and
308	  similar boards. Say 'Y' if you are building a kernel for such a board.
309
310config MTD_SA1100
311	tristate "CFI Flash device mapped on StrongARM SA11x0"
312	depends on MTD_CFI && ARCH_SA1100
313	help
314	  This enables access to the flash chips on most platforms based on
315	  the SA1100 and SA1110, including the Assabet and the Compaq iPAQ.
316	  If you have such a board, say 'Y'.
317
318config MTD_DC21285
319	tristate "CFI Flash device mapped on DC21285 Footbridge"
320	depends on MTD_CFI && ARCH_FOOTBRIDGE && MTD_COMPLEX_MAPPINGS
321	help
322	  This provides a driver for the flash accessed using Intel's
323	  21285 bridge used with Intel's StrongARM processors. More info at
324	  <https://www.intel.com/design/bridge/docs/21285_documentation.htm>.
325
326config MTD_IXP4XX
327	tristate "CFI Flash device mapped on Intel IXP4xx based systems"
328	depends on MTD_CFI && MTD_COMPLEX_MAPPINGS && ARCH_IXP4XX
329	help
330	  This enables MTD access to flash devices on platforms based
331	  on Intel's IXP4xx family of network processors such as the
332	  IXDP425 and Coyote. If you have an IXP4xx based board and
333	  would like to use the flash chips on it, say 'Y'.
334
335config MTD_IMPA7
336	tristate "JEDEC Flash device mapped on impA7"
337	depends on ARM && MTD_JEDECPROBE
338	help
339	  This enables access to the NOR Flash on the impA7 board of
340	  implementa GmbH. If you have such a board, say 'Y' here.
341
342# This needs CFI or JEDEC, depending on the cards found.
343config MTD_PCI
344	tristate "PCI MTD driver"
345	depends on PCI && MTD_COMPLEX_MAPPINGS
346	help
347	  Mapping for accessing flash devices on add-in cards like the Intel XScale
348	  IQ80310 card, and the Intel EBSA285 card in blank ROM programming mode
349	  (please see the manual for the link settings).
350
351	  If you are not sure, say N.
352
353config MTD_PCMCIA
354	tristate "PCMCIA MTD driver"
355	depends on PCMCIA && MTD_COMPLEX_MAPPINGS
356	help
357	  Map driver for accessing PCMCIA linear flash memory cards. These
358	  cards are usually around 4-16MiB in size. This does not include
359	  Compact Flash cards which are treated as IDE devices.
360
361config MTD_PCMCIA_ANONYMOUS
362	bool "Use PCMCIA MTD drivers for anonymous PCMCIA cards"
363	depends on MTD_PCMCIA
364	help
365	  If this option is enabled, PCMCIA cards which do not report
366	  anything about themselves are assumed to be MTD cards.
367
368	  If unsure, say N.
369
370config MTD_UCLINUX
371	bool "Generic uClinux RAM/ROM filesystem support"
372	depends on (MTD_RAM=y || MTD_ROM=y) && (!MMU || COLDFIRE)
373	help
374	  Map driver to support image based filesystems for uClinux.
375
376config MTD_INTEL_VR_NOR
377	tristate "NOR flash on Intel Vermilion Range Expansion Bus CS0"
378	depends on PCI
379	help
380	  Map driver for a NOR flash bank located on the Expansion Bus of the
381	  Intel Vermilion Range chipset.
382
383config MTD_RBTX4939
384	tristate "Map driver for RBTX4939 board"
385	depends on TOSHIBA_RBTX4939 && MTD_CFI && MTD_COMPLEX_MAPPINGS
386	help
387	  Map driver for NOR flash chips on RBTX4939 board.
388
389config MTD_PLATRAM
390	tristate "Map driver for platform device RAM (mtd-ram)"
391	select MTD_RAM
392	help
393	  Map driver for RAM areas described via the platform device
394	  system.
395
396	  This selection automatically selects the map_ram driver.
397
398config MTD_VMU
399	tristate "Map driver for Dreamcast VMU"
400	depends on MAPLE
401	help
402	  This driver enables access to the Dreamcast Visual Memory Unit (VMU).
403
404	  Most Dreamcast users will want to say Y here.
405
406	  To build this as a module select M here, the module will be called
407	  vmu-flash.
408
409config MTD_PISMO
410	tristate "MTD discovery driver for PISMO modules"
411	depends on I2C
412	depends on ARCH_VERSATILE
413	help
414	  This driver allows for discovery of PISMO modules - see
415	  <http://www.pismoworld.org/>.  These are small modules containing
416	  up to five memory devices (eg, SRAM, flash, DOC) described by an
417	  I2C EEPROM.
418
419	  This driver does not create any MTD maps itself; instead it
420	  creates MTD physmap and MTD SRAM platform devices.  If you
421	  enable this option, you should consider enabling MTD_PHYSMAP
422	  and/or MTD_PLATRAM according to the devices on your module.
423
424	  When built as a module, it will be called pismo.ko
425
426endmenu
427