blob: a701167dccf9f4c86a790d0dcd7def6741b3cb3b [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
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
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.
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
83config SPI_FLASH_SFDP_SUPPORT
84 bool "SFDP table parsing support for SPI NOR flashes"
85 depends on !SPI_FLASH_BAR
86 help
87 Enable support for parsing and auto discovery of parameters for
88 SPI NOR flashes using Serial Flash Discoverable Parameters (SFDP)
89 tables as per JESD216 standard.
90
Pratyush Yadav71025f02021-06-26 00:47:14 +053091config SPI_FLASH_SMART_HWCAPS
92 bool "Smart hardware capability detection based on SPI MEM supports_op() hook"
93 default y
94 help
95 Enable support for smart hardware capability detection based on SPI
96 MEM supports_op() hook that lets controllers express whether they
97 can support a type of operation in a much more refined way compared
98 to using flags like SPI_RX_DUAL, SPI_TX_QUAD, etc.
99
Jagan Teki84d31b32015-06-29 23:32:17 +0530100config SPI_FLASH_BAR
101 bool "SPI flash Bank/Extended address register support"
Jagan Teki84d31b32015-06-29 23:32:17 +0530102 help
103 Enable the SPI flash Bank/Extended address register support.
104 Bank/Extended address registers are used to access the flash
105 which has size > 16MiB in 3-byte addressing.
106
Michael Walle5d867bc2020-12-09 10:53:25 +0100107config SPI_FLASH_UNLOCK_ALL
108 bool "Unlock the entire SPI flash on u-boot startup"
109 default y
110 help
111 Some flashes tend to power up with the software write protection
112 bits set. If this option is set, the whole flash will be unlocked.
113
114 For legacy reasons, this option default to y. But if you intend to
115 actually use the software protection bits you should say n here.
116
Mike Looijmans988390b2017-06-07 07:42:37 +0200117config SF_DUAL_FLASH
118 bool "SPI DUAL flash memory support"
Mike Looijmans988390b2017-06-07 07:42:37 +0200119 help
120 Enable this option to support two flash memories connected to a single
121 controller. Currently Xilinx Zynq qspi supports this.
122
Nikita Kiryanovd5af9232015-07-23 17:19:38 +0300123config SPI_FLASH_ATMEL
124 bool "Atmel SPI flash support"
125 help
126 Add support for various Atmel SPI flash chips (AT45xxx and AT25xxx)
127
128config SPI_FLASH_EON
129 bool "EON SPI flash support"
130 help
131 Add support for various EON SPI flash chips (EN25xxx)
132
133config SPI_FLASH_GIGADEVICE
134 bool "GigaDevice SPI flash support"
135 help
136 Add support for various GigaDevice SPI flash chips (GD25xxx)
137
Michal Simek13f451b2016-01-25 15:39:26 +0100138config SPI_FLASH_ISSI
139 bool "ISSI SPI flash support"
140 help
141 Add support for various ISSI SPI flash chips (ISxxx)
142
Nikita Kiryanovd5af9232015-07-23 17:19:38 +0300143config SPI_FLASH_MACRONIX
144 bool "Macronix SPI flash support"
145 help
146 Add support for various Macronix SPI flash chips (MX25Lxxx)
147
148config SPI_FLASH_SPANSION
149 bool "Spansion SPI flash support"
150 help
151 Add support for various Spansion SPI flash chips (S25FLxxx)
152
153config SPI_FLASH_STMICRO
154 bool "STMicro SPI flash support"
155 help
156 Add support for various STMicro SPI flash chips (M25Pxxx and N25Qxxx)
157
158config SPI_FLASH_SST
159 bool "SST SPI flash support"
160 help
161 Add support for various SST SPI flash chips (SST25xxx)
162
163config SPI_FLASH_WINBOND
164 bool "Winbond SPI flash support"
165 help
166 Add support for various Winbond SPI flash chips (W25xxx)
167
Stefan Roese881e4fc2018-08-06 16:33:19 +0200168config SPI_FLASH_XMC
169 bool "XMC SPI flash support"
170 help
171 Add support for various XMC (Wuhan Xinxin Semiconductor
172 Manufacturing Corp.) SPI flash chips (XM25xxx)
173
Nikita Kiryanovd5af9232015-07-23 17:19:38 +0300174endif
175
Marek Vasut0a026552015-08-03 01:28:56 +0200176config SPI_FLASH_USE_4K_SECTORS
177 bool "Use small 4096 B erase sectors"
178 depends on SPI_FLASH
179 default y
180 help
181 Many flash memories support erasing small (4096 B) sectors. Depending
182 on the usage this feature may provide performance gain in comparison
183 to erasing whole blocks (32/64 KiB).
184 Changing a small part of the flash's contents is usually faster with
185 small sectors. On the other hand erasing should be faster when using
186 64 KiB block instead of 16 × 4 KiB sectors.
187
188 Please note that some tools/drivers/filesystems may not work with
189 4096 B erase size (e.g. UBIFS requires 15 KiB as a minimum).
190
Jagan Tekicd9accd2015-07-01 21:22:19 +0530191config SPI_FLASH_DATAFLASH
192 bool "AT45xxx DataFlash support"
193 depends on SPI_FLASH && DM_SPI_FLASH
194 help
195 Enable the access for SPI-flash-based AT45xxx DataFlash chips.
196 DataFlash is a kind of SPI flash. Most AT45 chips have two buffers
197 in each chip, which may be used for double buffered I/O; but this
198 driver doesn't (yet) use these for any kind of i/o overlap or prefetching.
199
200 Sometimes DataFlash is packaged in MMC-format cards, although the
201 MMC stack can't (yet?) distinguish between MMC and DataFlash
202 protocols during enumeration.
203
204 If unsure, say N
205
Jagan Teki7678dd92015-06-27 22:42:35 +0530206config SPI_FLASH_MTD
207 bool "SPI Flash MTD support"
Miquel Raynal85f7e9d2019-10-03 19:50:24 +0200208 depends on SPI_FLASH && MTD
Jagan Teki7678dd92015-06-27 22:42:35 +0530209 help
210 Enable the MTD support for spi flash layer, this adapter is for
211 translating mtd_read/mtd_write commands into spi_flash_read/write
212 commands. It is not intended to use it within sf_cmd or the SPI
213 flash subsystem. Such an adapter is needed for subsystems like
214 UBI which can only operate on top of the MTD layer.
215
216 If unsure, say N
217
Frieder Schrempf64f736c2019-09-13 22:43:42 +0000218config SPL_SPI_FLASH_MTD
219 bool "SPI flash MTD support for SPL"
220 depends on SPI_FLASH
221 help
222 Enable the MTD support for the SPI flash layer in SPL.
223
224 If unsure, say N
225
Jagan Teki810fd692015-06-27 22:39:36 +0530226endmenu # menu "SPI Flash Support"