blob: 63b0fd899fd81c3c55f89689930dcd4feb86aa7a [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"
Heinrich Schuchardt93b9cd72024-06-04 06:40:39 +02005 depends on DM_SPI
Jagan Teki77df1a92019-10-16 18:07:24 +05306 imply SPI_FLASH
Simon Glassf94a1be2015-02-05 21:41:35 -07007 help
8 Enable driver model for SPI flash. This SPI flash interface
9 (spi_flash_probe(), spi_flash_write(), etc.) is then
10 implemented by the SPI flash uclass. There is one standard
11 SPI flash driver which knows how to probe most chips
12 supported by U-Boot. The uclass interface is defined in
13 include/spi_flash.h, but is currently fully compatible
14 with the old interface to avoid confusion and duplication
15 during the transition parent. SPI and SPI flash must be
16 enabled together (it is not possible to use driver model
17 for one and not the other).
Simon Glass949dd812015-03-06 13:19:06 -070018
19config SPI_FLASH_SANDBOX
20 bool "Support sandbox SPI flash device"
21 depends on SANDBOX && DM_SPI_FLASH
22 help
23 Since sandbox cannot access real devices, an emulation mechanism is
24 provided instead. Drivers can be connected up to the sandbox SPI
25 bus (see CONFIG_SANDBOX_SPI) and SPI traffic will be routed to this
26 device. Typically the contents of the emulated SPI flash device is
27 stored in a file on the host filesystem.
Jagan Teki810fd692015-06-27 22:39:36 +053028
Jagan Teki2ce7e2b2015-06-29 00:59:36 +053029config SPI_FLASH
Jagan Teki989fd972019-02-09 17:45:42 +053030 bool "SPI Flash Core Interface support"
Vignesh Rc4e88622019-02-05 11:29:23 +053031 select SPI_MEM
Jagan Teki2ce7e2b2015-06-29 00:59:36 +053032 help
Jagan Teki989fd972019-02-09 17:45:42 +053033 Enable the SPI flash Core support. This will include basic
Jagan Teki2ce7e2b2015-06-29 00:59:36 +053034 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
Tom Rini7e6a6fd2021-12-11 14:55:48 -050060 default 0x0
Patrick Delaunay14453fb2019-02-27 15:20:36 +010061 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.
Patrick Delaunayb0cc1b82019-02-27 15:36:44 +010065 Not used for boot with device tree; the SPI driver reads
Simon Glasscaa4daa2020-12-03 16:55:18 -070066 speed and mode from plat values computed from
Patrick Delaunayb0cc1b82019-02-27 15:36:44 +010067 available node.
Patrick Delaunay14453fb2019-02-27 15:20:36 +010068
69config SF_DEFAULT_SPEED
70 int "SPI Flash default speed in Hz"
71 depends on SPI_FLASH || DM_SPI_FLASH
72 default 1000000
73 help
74 The default speed may be provided by the platform
75 to handle the common case when only a single serial
76 flash is present on the system.
Patrick Delaunayb0cc1b82019-02-27 15:36:44 +010077 Not used for boot with device tree; the SPI driver reads
Simon Glasscaa4daa2020-12-03 16:55:18 -070078 speed and mode from plat values computed from
Patrick Delaunayb0cc1b82019-02-27 15:36:44 +010079 available node.
Patrick Delaunay14453fb2019-02-27 15:20:36 +010080
Vignesh R0c6f1872019-02-05 11:29:20 +053081if SPI_FLASH
82
Simon Glass0c1f4a92023-01-17 10:48:03 -070083config BOOTDEV_SPI_FLASH
84 bool "SPI Flash bootdev support"
Heinrich Schuchardt073bf4a2023-08-28 20:49:59 +020085 depends on BOOTSTD
Simon Glass0c1f4a92023-01-17 10:48:03 -070086 help
87 Enable a boot device for SPI flash. This allows reading a script
88 from SPI flash so that it can be used to boot an Operating System.
89
90 If unsure, say N
91
Vignesh R0c6f1872019-02-05 11:29:20 +053092config SPI_FLASH_SFDP_SUPPORT
93 bool "SFDP table parsing support for SPI NOR flashes"
94 depends on !SPI_FLASH_BAR
95 help
96 Enable support for parsing and auto discovery of parameters for
97 SPI NOR flashes using Serial Flash Discoverable Parameters (SFDP)
98 tables as per JESD216 standard.
99
Pratyush Yadav71025f02021-06-26 00:47:14 +0530100config SPI_FLASH_SMART_HWCAPS
101 bool "Smart hardware capability detection based on SPI MEM supports_op() hook"
102 default y
103 help
104 Enable support for smart hardware capability detection based on SPI
105 MEM supports_op() hook that lets controllers express whether they
106 can support a type of operation in a much more refined way compared
107 to using flags like SPI_RX_DUAL, SPI_TX_QUAD, etc.
108
JaimeLiao68ad73b2022-07-04 14:12:40 +0800109config SPI_NOR_BOOT_SOFT_RESET_EXT_INVERT
110 bool "Command extension type is INVERT for Software Reset on boot"
JaimeLiao68ad73b2022-07-04 14:12:40 +0800111 help
112 Because of SFDP information can not be get before boot.
113 So define command extension type is INVERT when Software Reset on boot only.
114
Pratyush Yadav575caf42021-06-26 00:47:24 +0530115config SPI_FLASH_SOFT_RESET
116 bool "Software Reset support for SPI NOR flashes"
Pratyush Yadav575caf42021-06-26 00:47:24 +0530117 help
118 Enable support for xSPI Software Reset. It will be used to switch from
119 Octal DTR mode to legacy mode on shutdown and boot (if enabled).
120
Pratyush Yadav0be8ab12021-06-26 00:47:25 +0530121config SPI_FLASH_SOFT_RESET_ON_BOOT
122 bool "Perform a Software Reset on boot on flashes that boot in stateful mode"
123 depends on SPI_FLASH_SOFT_RESET
Pratyush Yadav0be8ab12021-06-26 00:47:25 +0530124 help
125 Perform a Software Reset on boot to allow detecting flashes that are
126 handed to us in Octal DTR mode. Do not enable this config on flashes
127 that are not supposed to be handed to U-Boot in Octal DTR mode, even
128 if they _do_ support the Soft Reset sequence.
129
Jagan Teki84d31b32015-06-29 23:32:17 +0530130config SPI_FLASH_BAR
131 bool "SPI flash Bank/Extended address register support"
Jagan Teki84d31b32015-06-29 23:32:17 +0530132 help
133 Enable the SPI flash Bank/Extended address register support.
134 Bank/Extended address registers are used to access the flash
135 which has size > 16MiB in 3-byte addressing.
136
Venkatesh Yadav Abbarapu188c8032023-10-03 08:47:13 +0530137config SPI_FLASH_LOCK
138 bool "Enable the Locking feature"
139 default y
140 help
141 Enable the SPI flash lock support. By default this is set to y.
142 If you intend not to use the lock support you should say n here.
143
Michael Walle5d867bc2020-12-09 10:53:25 +0100144config SPI_FLASH_UNLOCK_ALL
145 bool "Unlock the entire SPI flash on u-boot startup"
146 default y
147 help
148 Some flashes tend to power up with the software write protection
149 bits set. If this option is set, the whole flash will be unlocked.
150
151 For legacy reasons, this option default to y. But if you intend to
152 actually use the software protection bits you should say n here.
153
Nikita Kiryanovd5af9232015-07-23 17:19:38 +0300154config SPI_FLASH_ATMEL
155 bool "Atmel SPI flash support"
156 help
157 Add support for various Atmel SPI flash chips (AT45xxx and AT25xxx)
158
159config SPI_FLASH_EON
160 bool "EON SPI flash support"
161 help
162 Add support for various EON SPI flash chips (EN25xxx)
163
164config SPI_FLASH_GIGADEVICE
165 bool "GigaDevice SPI flash support"
166 help
167 Add support for various GigaDevice SPI flash chips (GD25xxx)
168
Michal Simek13f451b2016-01-25 15:39:26 +0100169config SPI_FLASH_ISSI
170 bool "ISSI SPI flash support"
171 help
172 Add support for various ISSI SPI flash chips (ISxxx)
173
Nikita Kiryanovd5af9232015-07-23 17:19:38 +0300174config SPI_FLASH_MACRONIX
175 bool "Macronix SPI flash support"
176 help
177 Add support for various Macronix SPI flash chips (MX25Lxxx)
178
Jonas Karlman791e2bf2023-07-26 21:44:03 +0000179config SPI_FLASH_SILICONKAISER
180 bool "Silicon Kaiser SPI flash support"
181 help
182 Add support for various Silicon Kaiser SPI flash chips (SK25Lxxx)
183
Nikita Kiryanovd5af9232015-07-23 17:19:38 +0300184config SPI_FLASH_SPANSION
185 bool "Spansion SPI flash support"
186 help
187 Add support for various Spansion SPI flash chips (S25FLxxx)
188
Takahiro Kuwanof422c4b2022-08-25 16:48:47 +0900189config SPI_FLASH_S28HX_T
190 bool "Cypress SEMPER Octal (S28) chip support"
Pratyush Yadavea9a22f2021-06-26 00:47:28 +0530191 depends on SPI_FLASH_SPANSION
192 help
Takahiro Kuwanof422c4b2022-08-25 16:48:47 +0900193 Add support for the Cypress S28HL-T and S28HS-T chip. This is a separate
194 config because the fixup hooks for this flash add extra size overhead.
195 Boards that don't use the flash can disable this to save space.
Pratyush Yadavea9a22f2021-06-26 00:47:28 +0530196
Nikita Kiryanovd5af9232015-07-23 17:19:38 +0300197config SPI_FLASH_STMICRO
198 bool "STMicro SPI flash support"
199 help
200 Add support for various STMicro SPI flash chips (M25Pxxx and N25Qxxx)
201
Pratyush Yadavf6adec12021-06-26 00:47:29 +0530202config SPI_FLASH_MT35XU
203 bool "Micron MT35XU chip support"
204 depends on SPI_FLASH_STMICRO
205 help
206 Add support for the Micron MT35XU chip. This is a separate config
207 because the fixup hooks for this flash add extra size overhead. Boards
208 that don't use the flash can disable this to save space.
209
Nikita Kiryanovd5af9232015-07-23 17:19:38 +0300210config SPI_FLASH_SST
211 bool "SST SPI flash support"
212 help
213 Add support for various SST SPI flash chips (SST25xxx)
214
215config SPI_FLASH_WINBOND
216 bool "Winbond SPI flash support"
217 help
218 Add support for various Winbond SPI flash chips (W25xxx)
219
Stefan Roese881e4fc2018-08-06 16:33:19 +0200220config SPI_FLASH_XMC
221 bool "XMC SPI flash support"
222 help
223 Add support for various XMC (Wuhan Xinxin Semiconductor
224 Manufacturing Corp.) SPI flash chips (XM25xxx)
225
Chris Morgan674a9482021-08-05 16:26:41 +0800226config SPI_FLASH_XTX
227 bool "XTX SPI flash support"
228 help
229 Add support for various XTX (XTX Technology Limited)
230 SPI flash chips (XT25xxx).
231
Andre Przywara9ac57fb2023-11-13 01:16:48 +0000232config SPI_FLASH_ZBIT
233 bool "ZBIT SPI flash support"
234 help
235 Add support for Zbit Semiconductor Inc. SPI flash chips (ZB25xxx).
236
Nikita Kiryanovd5af9232015-07-23 17:19:38 +0300237endif
238
Marek Vasut0a026552015-08-03 01:28:56 +0200239config SPI_FLASH_USE_4K_SECTORS
240 bool "Use small 4096 B erase sectors"
241 depends on SPI_FLASH
242 default y
243 help
244 Many flash memories support erasing small (4096 B) sectors. Depending
245 on the usage this feature may provide performance gain in comparison
246 to erasing whole blocks (32/64 KiB).
247 Changing a small part of the flash's contents is usually faster with
248 small sectors. On the other hand erasing should be faster when using
Michal Simek5a6cf7c2024-04-16 08:55:18 +0200249 64 KiB block instead of 16 x 4 KiB sectors.
Marek Vasut0a026552015-08-03 01:28:56 +0200250
251 Please note that some tools/drivers/filesystems may not work with
252 4096 B erase size (e.g. UBIFS requires 15 KiB as a minimum).
253
Jagan Tekicd9accd2015-07-01 21:22:19 +0530254config SPI_FLASH_DATAFLASH
255 bool "AT45xxx DataFlash support"
256 depends on SPI_FLASH && DM_SPI_FLASH
257 help
258 Enable the access for SPI-flash-based AT45xxx DataFlash chips.
259 DataFlash is a kind of SPI flash. Most AT45 chips have two buffers
260 in each chip, which may be used for double buffered I/O; but this
261 driver doesn't (yet) use these for any kind of i/o overlap or prefetching.
262
263 Sometimes DataFlash is packaged in MMC-format cards, although the
264 MMC stack can't (yet?) distinguish between MMC and DataFlash
265 protocols during enumeration.
266
267 If unsure, say N
268
Jagan Teki7678dd92015-06-27 22:42:35 +0530269config SPI_FLASH_MTD
270 bool "SPI Flash MTD support"
Miquel Raynal85f7e9d2019-10-03 19:50:24 +0200271 depends on SPI_FLASH && MTD
Jagan Teki7678dd92015-06-27 22:42:35 +0530272 help
273 Enable the MTD support for spi flash layer, this adapter is for
274 translating mtd_read/mtd_write commands into spi_flash_read/write
275 commands. It is not intended to use it within sf_cmd or the SPI
276 flash subsystem. Such an adapter is needed for subsystems like
277 UBI which can only operate on top of the MTD layer.
278
279 If unsure, say N
280
Frieder Schrempf64f736c2019-09-13 22:43:42 +0000281config SPL_SPI_FLASH_MTD
282 bool "SPI flash MTD support for SPL"
Tom Rinib3401992022-06-10 23:03:09 -0400283 depends on SPI_FLASH && SPL
Frieder Schrempf64f736c2019-09-13 22:43:42 +0000284 help
285 Enable the MTD support for the SPI flash layer in SPL.
286
287 If unsure, say N
288
Jagan Teki810fd692015-06-27 22:39:36 +0530289endmenu # menu "SPI Flash Support"