@@ -63,3 +63,205 @@ The main API is spi_nor_scan(). Before you call the hook, a driver should
6363initialize the necessary fields for spi_nor{}. Please see
6464drivers/mtd/spi-nor/spi-nor.c for detail. Please also refer to spi-fsl-qspi.c
6565when you want to write a new driver for a SPI NOR controller.
66+
67+ How to propose a new flash addition
68+ -----------------------------------
69+
70+ Most SPI NOR flashes comply with the JEDEC JESD216
71+ Serial Flash Discoverable Parameter (SFDP) standard. SFDP describes
72+ the functional and feature capabilities of serial flash devices in a
73+ standard set of internal read-only parameter tables.
74+
75+ The SPI NOR driver queries the SFDP tables in order to determine the
76+ flash's parameters and settings. If the flash defines the SFDP tables
77+ it's likely that you won't need a flash entry at all, and instead
78+ rely on the generic flash driver which probes the flash solely based
79+ on its SFDP data. All one has to do is to specify the "jedec,spi-nor"
80+ compatible in the device tree.
81+
82+ There are cases however where you need to define an explicit flash
83+ entry. This typically happens when the flash has settings or support
84+ that is not covered by the SFDP tables (e.g. Block Protection), or
85+ when the flash contains mangled SFDP data. If the later, one needs
86+ to implement the ``spi_nor_fixups `` hooks in order to amend the SFDP
87+ parameters with the correct values.
88+
89+ Minimum testing requirements
90+ -----------------------------
91+
92+ Do all the tests from below and paste them in the commit's comments
93+ section, after the ``--- `` marker.
94+
95+ 1) Specify the controller that you used to test the flash and specify
96+ the frequency at which the flash was operated, e.g.::
97+
98+ This flash is populated on the X board and was tested at Y
99+ frequency using the Z (put compatible) SPI controller.
100+
101+ 2) Dump the sysfs entries and print the md5/sha1/sha256 SFDP checksum::
102+
103+ root@1:~# cat /sys/bus/spi/devices/spi0.0/spi-nor/partname
104+ sst26vf064b
105+ root@1:~# cat /sys/bus/spi/devices/spi0.0/spi-nor/jedec_id
106+ bf2643
107+ root@1:~# cat /sys/bus/spi/devices/spi0.0/spi-nor/manufacturer
108+ sst
109+ root@1:~# xxd -p /sys/bus/spi/devices/spi0.0/spi-nor/sfdp
110+ 53464450060102ff00060110300000ff81000106000100ffbf0001180002
111+ 0001fffffffffffffffffffffffffffffffffd20f1ffffffff0344eb086b
112+ 083b80bbfeffffffffff00ffffff440b0c200dd80fd810d820914824806f
113+ 1d81ed0f773830b030b0f7ffffff29c25cfff030c080ffffffffffffffff
114+ ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
115+ ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
116+ ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
117+ ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
118+ ffffffffffffffffffffffffffffffffff0004fff37f0000f57f0000f9ff
119+ 7d00f57f0000f37f0000ffffffffffffffffffffffffffffffffffffffff
120+ ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
121+ ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
122+ ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
123+ ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
124+ ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
125+ ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
126+ ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
127+ ffffbf2643ffb95ffdff30f260f332ff0a122346ff0f19320f1919ffffff
128+ ffffffff00669938ff05013506040232b03072428de89888a585c09faf5a
129+ ffff06ec060c0003080bffffffffff07ffff0202ff060300fdfd040700fc
130+ 0300fefe0202070e
131+ root@1:~# sha256sum /sys/bus/spi/devices/spi0.0/spi-nor/sfdp
132+ 428f34d0461876f189ac97f93e68a05fa6428c6650b3b7baf736a921e5898ed1 /sys/bus/spi/devices/spi0.0/spi-nor/sfdp
133+
134+ Please dump the SFDP tables using ``xxd -p``. It enables us to do
135+ the reverse operation and convert the hexdump to binary with
136+ ``xxd -rp``. Dumping the SFDP data with ``hexdump -Cv`` is accepted,
137+ but less desirable.
138+
139+ 3) Dump debugfs data::
140+
141+ root@1:~# cat /sys/kernel/debug/spi-nor/spi0.0/capabilities
142+ Supported read modes by the flash
143+ 1S-1S-1S
144+ opcode 0x03
145+ mode cycles 0
146+ dummy cycles 0
147+ 1S-1S-1S (fast read)
148+ opcode 0x0b
149+ mode cycles 0
150+ dummy cycles 8
151+ 1S-1S-2S
152+ opcode 0x3b
153+ mode cycles 0
154+ dummy cycles 8
155+ 1S-2S-2S
156+ opcode 0xbb
157+ mode cycles 4
158+ dummy cycles 0
159+ 1S-1S-4S
160+ opcode 0x6b
161+ mode cycles 0
162+ dummy cycles 8
163+ 1S-4S-4S
164+ opcode 0xeb
165+ mode cycles 2
166+ dummy cycles 4
167+ 4S-4S-4S
168+ opcode 0x0b
169+ mode cycles 2
170+ dummy cycles 4
171+
172+ Supported page program modes by the flash
173+ 1S-1S-1S
174+ opcode 0x02
175+
176+ root@1:~# cat /sys/kernel/debug/spi-nor/spi0.0/params
177+ name sst26vf064b
178+ id bf 26 43 bf 26 43
179+ size 8.00 MiB
180+ write size 1
181+ page size 256
182+ address nbytes 3
183+ flags HAS_LOCK | HAS_16BIT_SR | SOFT_RESET | SWP_IS_VOLATILE
184+
185+ opcodes
186+ read 0xeb
187+ dummy cycles 6
188+ erase 0x20
189+ program 0x02
190+ 8D extension none
191+
192+ protocols
193+ read 1S-4S-4S
194+ write 1S-1S-1S
195+ register 1S-1S-1S
196+
197+ erase commands
198+ 20 (4.00 KiB) [0]
199+ d8 (8.00 KiB) [1]
200+ d8 (32.0 KiB) [2]
201+ d8 (64.0 KiB) [3]
202+ c7 (8.00 MiB)
203+
204+ sector map
205+ region (in hex) | erase mask | flags
206+ ------------------+------------+----------
207+ 00000000-00007fff | [01 ] |
208+ 00008000-0000ffff | [0 2 ] |
209+ 00010000-007effff | [0 3] |
210+ 007f0000-007f7fff | [0 2 ] |
211+ 007f8000-007fffff | [01 ] |
212+
213+ 4) Use `mtd-utils <https://git.infradead.org/mtd-utils.git >`__
214+ and verify that erase, read and page program operations work fine::
215+
216+ root@1:~# dd if=/dev/urandom of=./spi_test bs=1M count=2
217+ 2+0 records in
218+ 2+0 records out
219+ 2097152 bytes (2.1 MB, 2.0 MiB) copied, 0.848566 s, 2.5 MB/s
220+
221+ root@1:~# mtd_debug erase /dev/mtd0 0 2097152
222+ Erased 2097152 bytes from address 0x00000000 in flash
223+
224+ root@1:~# mtd_debug read /dev/mtd0 0 2097152 spi_read
225+ Copied 2097152 bytes from address 0x00000000 in flash to spi_read
226+
227+ root@1:~# hexdump spi_read
228+ 0000000 ffff ffff ffff ffff ffff ffff ffff ffff
229+ *
230+ 0200000
231+
232+ root@1:~# sha256sum spi_read
233+ 4bda3a28f4ffe603c0ec1258c0034d65a1a0d35ab7bd523a834608adabf03cc5 spi_read
234+
235+ root@1:~# mtd_debug write /dev/mtd0 0 2097152 spi_test
236+ Copied 2097152 bytes from spi_test to address 0x00000000 in flash
237+
238+ root@1:~# mtd_debug read /dev/mtd0 0 2097152 spi_read
239+ Copied 2097152 bytes from address 0x00000000 in flash to spi_read
240+
241+ root@1:~# sha256sum spi*
242+ c444216a6ba2a4a66cccd60a0dd062bce4b865dd52b200ef5e21838c4b899ac8 spi_read
243+ c444216a6ba2a4a66cccd60a0dd062bce4b865dd52b200ef5e21838c4b899ac8 spi_test
244+
245+ If the flash comes erased by default and the previous erase was ignored,
246+ we won't catch it, thus test the erase again::
247+
248+ root@1:~# mtd_debug erase /dev/mtd0 0 2097152
249+ Erased 2097152 bytes from address 0x00000000 in flash
250+
251+ root@1:~# mtd_debug read /dev/mtd0 0 2097152 spi_read
252+ Copied 2097152 bytes from address 0x00000000 in flash to spi_read
253+
254+ root@1:~# sha256sum spi*
255+ 4bda3a28f4ffe603c0ec1258c0034d65a1a0d35ab7bd523a834608adabf03cc5 spi_read
256+ c444216a6ba2a4a66cccd60a0dd062bce4b865dd52b200ef5e21838c4b899ac8 spi_test
257+
258+ Dump some other relevant data::
259+
260+ root@1:~# mtd_debug info /dev/mtd0
261+ mtd.type = MTD_NORFLASH
262+ mtd.flags = MTD_CAP_NORFLASH
263+ mtd.size = 8388608 (8M)
264+ mtd.erasesize = 4096 (4K)
265+ mtd.writesize = 1
266+ mtd.oobsize = 0
267+ regions = 0
0 commit comments