blob: 5671bca24a07e41200fd589ef31d4cc3a6acc462 [file] [log] [blame]
Jagan Teki810fd692015-06-27 22:39:36 +05301menu "SPI Flash Support"
2
Simon Glassf94a1be2015-02-05 21:41:35 -07003config DM_SPI_FLASH
4 bool "Enable Driver Model for SPI flash"
Masahiro Yamadab3d023b2015-03-31 12:47:52 +09005 depends on DM && DM_SPI
Simon Glassf94a1be2015-02-05 21:41:35 -07006 help
7 Enable driver model for SPI flash. This SPI flash interface
8 (spi_flash_probe(), spi_flash_write(), etc.) is then
9 implemented by the SPI flash uclass. There is one standard
10 SPI flash driver which knows how to probe most chips
11 supported by U-Boot. The uclass interface is defined in
12 include/spi_flash.h, but is currently fully compatible
13 with the old interface to avoid confusion and duplication
14 during the transition parent. SPI and SPI flash must be
15 enabled together (it is not possible to use driver model
16 for one and not the other).
Simon Glass949dd812015-03-06 13:19:06 -070017
18config SPI_FLASH_SANDBOX
19 bool "Support sandbox SPI flash device"
20 depends on SANDBOX && DM_SPI_FLASH
21 help
22 Since sandbox cannot access real devices, an emulation mechanism is
23 provided instead. Drivers can be connected up to the sandbox SPI
24 bus (see CONFIG_SANDBOX_SPI) and SPI traffic will be routed to this
25 device. Typically the contents of the emulated SPI flash device is
26 stored in a file on the host filesystem.
Jagan Teki810fd692015-06-27 22:39:36 +053027
Jagan Teki2ce7e2b2015-06-29 00:59:36 +053028config SPI_FLASH
29 bool "Legacy SPI Flash Interface support"
Vignesh Rc4e88622019-02-05 11:29:23 +053030 depends on SPI
31 select SPI_MEM
Jagan Teki2ce7e2b2015-06-29 00:59:36 +053032 help
33 Enable the legacy SPI flash support. This will include basic
34 standard support for things like probing, read / write, and
35 erasing through cmd_sf interface.
36
37 If unsure, say N
38
Patrick Delaunay14453fb2019-02-27 15:20:36 +010039config SF_DEFAULT_BUS
40 int "SPI Flash default bus identifier"
41 depends on SPI_FLASH || DM_SPI_FLASH
42 default 0
43 help
44 The default bus may be provided by the platform
45 to handle the common case when only a single serial
46 flash is present on the system.
47
48config SF_DEFAULT_CS
49 int "SPI Flash default Chip-select"
50 depends on SPI_FLASH || DM_SPI_FLASH
51 default 0
52 help
53 The default chip select may be provided by the platform
54 to handle the common case when only a single serial
55 flash is present on the system.
56
57config SF_DEFAULT_MODE
58 hex "SPI Flash default mode (see include/spi.h)"
59 depends on SPI_FLASH || DM_SPI_FLASH
60 default 3
61 help
62 The default mode may be provided by the platform
63 to handle the common case when only a single serial
64 flash is present on the system.
65
66config SF_DEFAULT_SPEED
67 int "SPI Flash default speed in Hz"
68 depends on SPI_FLASH || DM_SPI_FLASH
69 default 1000000
70 help
71 The default speed may be provided by the platform
72 to handle the common case when only a single serial
73 flash is present on the system.
74
Vignesh R0c6f1872019-02-05 11:29:20 +053075if SPI_FLASH
76
77config SPI_FLASH_SFDP_SUPPORT
78 bool "SFDP table parsing support for SPI NOR flashes"
79 depends on !SPI_FLASH_BAR
80 help
81 Enable support for parsing and auto discovery of parameters for
82 SPI NOR flashes using Serial Flash Discoverable Parameters (SFDP)
83 tables as per JESD216 standard.
84
Jagan Teki84d31b32015-06-29 23:32:17 +053085config SPI_FLASH_BAR
86 bool "SPI flash Bank/Extended address register support"
Jagan Teki84d31b32015-06-29 23:32:17 +053087 help
88 Enable the SPI flash Bank/Extended address register support.
89 Bank/Extended address registers are used to access the flash
90 which has size > 16MiB in 3-byte addressing.
91
Mike Looijmans988390b2017-06-07 07:42:37 +020092config SF_DUAL_FLASH
93 bool "SPI DUAL flash memory support"
Mike Looijmans988390b2017-06-07 07:42:37 +020094 help
95 Enable this option to support two flash memories connected to a single
96 controller. Currently Xilinx Zynq qspi supports this.
97
Nikita Kiryanovd5af9232015-07-23 17:19:38 +030098config SPI_FLASH_ATMEL
99 bool "Atmel SPI flash support"
100 help
101 Add support for various Atmel SPI flash chips (AT45xxx and AT25xxx)
102
103config SPI_FLASH_EON
104 bool "EON SPI flash support"
105 help
106 Add support for various EON SPI flash chips (EN25xxx)
107
108config SPI_FLASH_GIGADEVICE
109 bool "GigaDevice SPI flash support"
110 help
111 Add support for various GigaDevice SPI flash chips (GD25xxx)
112
Michal Simek13f451b2016-01-25 15:39:26 +0100113config SPI_FLASH_ISSI
114 bool "ISSI SPI flash support"
115 help
116 Add support for various ISSI SPI flash chips (ISxxx)
117
Nikita Kiryanovd5af9232015-07-23 17:19:38 +0300118config SPI_FLASH_MACRONIX
119 bool "Macronix SPI flash support"
120 help
121 Add support for various Macronix SPI flash chips (MX25Lxxx)
122
123config SPI_FLASH_SPANSION
124 bool "Spansion SPI flash support"
125 help
126 Add support for various Spansion SPI flash chips (S25FLxxx)
127
128config SPI_FLASH_STMICRO
129 bool "STMicro SPI flash support"
130 help
131 Add support for various STMicro SPI flash chips (M25Pxxx and N25Qxxx)
132
133config SPI_FLASH_SST
134 bool "SST SPI flash support"
135 help
136 Add support for various SST SPI flash chips (SST25xxx)
137
138config SPI_FLASH_WINBOND
139 bool "Winbond SPI flash support"
140 help
141 Add support for various Winbond SPI flash chips (W25xxx)
142
Stefan Roese881e4fc2018-08-06 16:33:19 +0200143config SPI_FLASH_XMC
144 bool "XMC SPI flash support"
145 help
146 Add support for various XMC (Wuhan Xinxin Semiconductor
147 Manufacturing Corp.) SPI flash chips (XM25xxx)
148
Nikita Kiryanovd5af9232015-07-23 17:19:38 +0300149endif
150
Marek Vasut0a026552015-08-03 01:28:56 +0200151config SPI_FLASH_USE_4K_SECTORS
152 bool "Use small 4096 B erase sectors"
153 depends on SPI_FLASH
154 default y
155 help
156 Many flash memories support erasing small (4096 B) sectors. Depending
157 on the usage this feature may provide performance gain in comparison
158 to erasing whole blocks (32/64 KiB).
159 Changing a small part of the flash's contents is usually faster with
160 small sectors. On the other hand erasing should be faster when using
161 64 KiB block instead of 16 × 4 KiB sectors.
162
163 Please note that some tools/drivers/filesystems may not work with
164 4096 B erase size (e.g. UBIFS requires 15 KiB as a minimum).
165
Jagan Tekicd9accd2015-07-01 21:22:19 +0530166config SPI_FLASH_DATAFLASH
167 bool "AT45xxx DataFlash support"
168 depends on SPI_FLASH && DM_SPI_FLASH
169 help
170 Enable the access for SPI-flash-based AT45xxx DataFlash chips.
171 DataFlash is a kind of SPI flash. Most AT45 chips have two buffers
172 in each chip, which may be used for double buffered I/O; but this
173 driver doesn't (yet) use these for any kind of i/o overlap or prefetching.
174
175 Sometimes DataFlash is packaged in MMC-format cards, although the
176 MMC stack can't (yet?) distinguish between MMC and DataFlash
177 protocols during enumeration.
178
179 If unsure, say N
180
Jagan Teki7678dd92015-06-27 22:42:35 +0530181config SPI_FLASH_MTD
182 bool "SPI Flash MTD support"
183 depends on SPI_FLASH
184 help
185 Enable the MTD support for spi flash layer, this adapter is for
186 translating mtd_read/mtd_write commands into spi_flash_read/write
187 commands. It is not intended to use it within sf_cmd or the SPI
188 flash subsystem. Such an adapter is needed for subsystems like
189 UBI which can only operate on top of the MTD layer.
190
191 If unsure, say N
192
Jagan Teki810fd692015-06-27 22:39:36 +0530193endmenu # menu "SPI Flash Support"