blob: a0cfc623c6fcf849ffe951cbf44da363adb11fc4 [file] [log] [blame]
Jagan Teki9faaab82015-06-27 22:39:36 +05301menu "SPI Flash Support"
2
Simon Glassd8b771d2015-02-05 21:41:35 -07003config DM_SPI_FLASH
4 bool "Enable Driver Model for SPI flash"
Masahiro Yamada1260c382015-03-31 12:47:52 +09005 depends on DM && DM_SPI
Simon Glassd8b771d2015-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 Glass632310b2015-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 Teki9faaab82015-06-27 22:39:36 +053027
Jagan Tekiffc14542015-06-29 00:59:36 +053028config SPI_FLASH
Jagan Teki13d103b2019-02-09 17:45:42 +053029 bool "SPI Flash Core Interface support"
Vignesh R14510412019-02-05 11:29:23 +053030 select SPI_MEM
Jagan Tekiffc14542015-06-29 00:59:36 +053031 help
Jagan Teki13d103b2019-02-09 17:45:42 +053032 Enable the SPI flash Core support. This will include basic
Jagan Tekiffc14542015-06-29 00:59:36 +053033 standard support for things like probing, read / write, and
34 erasing through cmd_sf interface.
35
36 If unsure, say N
37
Patrick Delaunay0df81042019-02-27 15:20:36 +010038config SF_DEFAULT_BUS
39 int "SPI Flash default bus identifier"
40 depends on SPI_FLASH || DM_SPI_FLASH
41 default 0
42 help
43 The default bus may be provided by the platform
44 to handle the common case when only a single serial
45 flash is present on the system.
46
47config SF_DEFAULT_CS
48 int "SPI Flash default Chip-select"
49 depends on SPI_FLASH || DM_SPI_FLASH
50 default 0
51 help
52 The default chip select may be provided by the platform
53 to handle the common case when only a single serial
54 flash is present on the system.
55
56config SF_DEFAULT_MODE
57 hex "SPI Flash default mode (see include/spi.h)"
58 depends on SPI_FLASH || DM_SPI_FLASH
59 default 3
60 help
61 The default mode may be provided by the platform
62 to handle the common case when only a single serial
63 flash is present on the system.
Patrick Delaunayfa19c652019-02-27 15:36:44 +010064 Not used for boot with device tree; the SPI driver reads
65 speed and mode from platdata values computed from
66 available node.
Patrick Delaunay0df81042019-02-27 15:20:36 +010067
68config SF_DEFAULT_SPEED
69 int "SPI Flash default speed in Hz"
70 depends on SPI_FLASH || DM_SPI_FLASH
71 default 1000000
72 help
73 The default speed may be provided by the platform
74 to handle the common case when only a single serial
75 flash is present on the system.
Patrick Delaunayfa19c652019-02-27 15:36:44 +010076 Not used for boot with device tree; the SPI driver reads
77 speed and mode from platdata values computed from
78 available node.
Patrick Delaunay0df81042019-02-27 15:20:36 +010079
Vignesh R4d848c92019-02-05 11:29:20 +053080if SPI_FLASH
81
82config SPI_FLASH_SFDP_SUPPORT
83 bool "SFDP table parsing support for SPI NOR flashes"
84 depends on !SPI_FLASH_BAR
85 help
86 Enable support for parsing and auto discovery of parameters for
87 SPI NOR flashes using Serial Flash Discoverable Parameters (SFDP)
88 tables as per JESD216 standard.
89
Jagan Teki7a8fb0c2015-06-29 23:32:17 +053090config SPI_FLASH_BAR
91 bool "SPI flash Bank/Extended address register support"
Jagan Teki7a8fb0c2015-06-29 23:32:17 +053092 help
93 Enable the SPI flash Bank/Extended address register support.
94 Bank/Extended address registers are used to access the flash
95 which has size > 16MiB in 3-byte addressing.
96
Mike Looijmans4f1002d2017-06-07 07:42:37 +020097config SF_DUAL_FLASH
98 bool "SPI DUAL flash memory support"
Mike Looijmans4f1002d2017-06-07 07:42:37 +020099 help
100 Enable this option to support two flash memories connected to a single
101 controller. Currently Xilinx Zynq qspi supports this.
102
Nikita Kiryanovb577da62015-07-23 17:19:38 +0300103config SPI_FLASH_ATMEL
104 bool "Atmel SPI flash support"
105 help
106 Add support for various Atmel SPI flash chips (AT45xxx and AT25xxx)
107
108config SPI_FLASH_EON
109 bool "EON SPI flash support"
110 help
111 Add support for various EON SPI flash chips (EN25xxx)
112
113config SPI_FLASH_GIGADEVICE
114 bool "GigaDevice SPI flash support"
115 help
116 Add support for various GigaDevice SPI flash chips (GD25xxx)
117
Michal Simekf26b4c72016-01-25 15:39:26 +0100118config SPI_FLASH_ISSI
119 bool "ISSI SPI flash support"
120 help
121 Add support for various ISSI SPI flash chips (ISxxx)
122
Nikita Kiryanovb577da62015-07-23 17:19:38 +0300123config SPI_FLASH_MACRONIX
124 bool "Macronix SPI flash support"
125 help
126 Add support for various Macronix SPI flash chips (MX25Lxxx)
127
128config SPI_FLASH_SPANSION
129 bool "Spansion SPI flash support"
130 help
131 Add support for various Spansion SPI flash chips (S25FLxxx)
132
133config SPI_FLASH_STMICRO
134 bool "STMicro SPI flash support"
135 help
136 Add support for various STMicro SPI flash chips (M25Pxxx and N25Qxxx)
137
138config SPI_FLASH_SST
139 bool "SST SPI flash support"
140 help
141 Add support for various SST SPI flash chips (SST25xxx)
142
143config SPI_FLASH_WINBOND
144 bool "Winbond SPI flash support"
145 help
146 Add support for various Winbond SPI flash chips (W25xxx)
147
Stefan Roese72191c72018-08-06 16:33:19 +0200148config SPI_FLASH_XMC
149 bool "XMC SPI flash support"
150 help
151 Add support for various XMC (Wuhan Xinxin Semiconductor
152 Manufacturing Corp.) SPI flash chips (XM25xxx)
153
Nikita Kiryanovb577da62015-07-23 17:19:38 +0300154endif
155
Marek Vasute0bdcb82015-08-03 01:28:56 +0200156config SPI_FLASH_USE_4K_SECTORS
157 bool "Use small 4096 B erase sectors"
158 depends on SPI_FLASH
159 default y
160 help
161 Many flash memories support erasing small (4096 B) sectors. Depending
162 on the usage this feature may provide performance gain in comparison
163 to erasing whole blocks (32/64 KiB).
164 Changing a small part of the flash's contents is usually faster with
165 small sectors. On the other hand erasing should be faster when using
166 64 KiB block instead of 16 × 4 KiB sectors.
167
168 Please note that some tools/drivers/filesystems may not work with
169 4096 B erase size (e.g. UBIFS requires 15 KiB as a minimum).
170
Jagan Tekid6a56ae2015-07-01 21:22:19 +0530171config SPI_FLASH_DATAFLASH
172 bool "AT45xxx DataFlash support"
173 depends on SPI_FLASH && DM_SPI_FLASH
174 help
175 Enable the access for SPI-flash-based AT45xxx DataFlash chips.
176 DataFlash is a kind of SPI flash. Most AT45 chips have two buffers
177 in each chip, which may be used for double buffered I/O; but this
178 driver doesn't (yet) use these for any kind of i/o overlap or prefetching.
179
180 Sometimes DataFlash is packaged in MMC-format cards, although the
181 MMC stack can't (yet?) distinguish between MMC and DataFlash
182 protocols during enumeration.
183
184 If unsure, say N
185
Jagan Teki88c5b582015-06-27 22:42:35 +0530186config SPI_FLASH_MTD
187 bool "SPI Flash MTD support"
188 depends on SPI_FLASH
189 help
190 Enable the MTD support for spi flash layer, this adapter is for
191 translating mtd_read/mtd_write commands into spi_flash_read/write
192 commands. It is not intended to use it within sf_cmd or the SPI
193 flash subsystem. Such an adapter is needed for subsystems like
194 UBI which can only operate on top of the MTD layer.
195
196 If unsure, say N
197
Jagan Teki9faaab82015-06-27 22:39:36 +0530198endmenu # menu "SPI Flash Support"