mtd: spi-nor-core: Rework hwcaps selection
[platform/kernel/u-boot.git] / drivers / mtd / spi / Kconfig
1 menu "SPI Flash Support"
2
3 config DM_SPI_FLASH
4         bool "Enable Driver Model for SPI flash"
5         depends on DM && DM_SPI
6         imply SPI_FLASH
7         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).
18
19 config 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.
28
29 config SPI_FLASH
30         bool "SPI Flash Core Interface support"
31         select SPI_MEM
32         help
33           Enable the SPI flash Core 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
39 config 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
48 config 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
57 config 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           Not used for boot with device tree; the SPI driver reads
66           speed and mode from plat values computed from
67           available node.
68
69 config 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.
77           Not used for boot with device tree; the SPI driver reads
78           speed and mode from plat values computed from
79           available node.
80
81 if SPI_FLASH
82
83 config 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
91 config 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
100 config SPI_FLASH_BAR
101         bool "SPI flash Bank/Extended address register support"
102         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
107 config 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
117 config SF_DUAL_FLASH
118         bool "SPI DUAL flash memory support"
119         help
120           Enable this option to support two flash memories connected to a single
121           controller. Currently Xilinx Zynq qspi supports this.
122
123 config SPI_FLASH_ATMEL
124         bool "Atmel SPI flash support"
125         help
126           Add support for various Atmel SPI flash chips (AT45xxx and AT25xxx)
127
128 config SPI_FLASH_EON
129         bool "EON SPI flash support"
130         help
131           Add support for various EON SPI flash chips (EN25xxx)
132
133 config SPI_FLASH_GIGADEVICE
134         bool "GigaDevice SPI flash support"
135         help
136           Add support for various GigaDevice SPI flash chips (GD25xxx)
137
138 config SPI_FLASH_ISSI
139         bool "ISSI SPI flash support"
140         help
141           Add support for various ISSI SPI flash chips (ISxxx)
142
143 config SPI_FLASH_MACRONIX
144         bool "Macronix SPI flash support"
145         help
146           Add support for various Macronix SPI flash chips (MX25Lxxx)
147
148 config SPI_FLASH_SPANSION
149         bool "Spansion SPI flash support"
150         help
151           Add support for various Spansion SPI flash chips (S25FLxxx)
152
153 config SPI_FLASH_STMICRO
154         bool "STMicro SPI flash support"
155         help
156           Add support for various STMicro SPI flash chips (M25Pxxx and N25Qxxx)
157
158 config SPI_FLASH_SST
159         bool "SST SPI flash support"
160         help
161           Add support for various SST SPI flash chips (SST25xxx)
162
163 config SPI_FLASH_WINBOND
164         bool "Winbond SPI flash support"
165         help
166           Add support for various Winbond SPI flash chips (W25xxx)
167
168 config 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
174 endif
175
176 config 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
191 config 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
206 config SPI_FLASH_MTD
207         bool "SPI Flash MTD support"
208         depends on SPI_FLASH && MTD
209         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
218 config 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
226 endmenu # menu "SPI Flash Support"