vexpress64: fvp: add distro_boot support
[u-boot.git] / include / spi_flash.h
CommitLineData
83d290c5 1/* SPDX-License-Identifier: GPL-2.0 */
d25ce7d2 2/*
a5e8199a 3 * Common SPI flash Interface
d25ce7d2
HS
4 *
5 * Copyright (C) 2008 Atmel Corporation
a5e8199a 6 * Copyright (C) 2013 Jagannadha Sutradharudu Teki, Xilinx Inc.
d25ce7d2 7 */
a5e8199a 8
d25ce7d2
HS
9#ifndef _SPI_FLASH_H_
10#define _SPI_FLASH_H_
11
e06ab654 12#include <linux/types.h>
c4e88623 13#include <linux/mtd/spi-nor.h>
d25ce7d2 14
a00867b4
SG
15struct udevice;
16
ff0960f9 17struct spi_slave;
33adfb5f 18
4c2dbefd
SG
19struct dm_spi_flash_ops {
20 int (*read)(struct udevice *dev, u32 offset, size_t len, void *buf);
21 int (*write)(struct udevice *dev, u32 offset, size_t len,
22 const void *buf);
23 int (*erase)(struct udevice *dev, u32 offset, size_t len);
b3b60f59
SG
24 /**
25 * get_sw_write_prot() - Check state of software write-protect feature
26 *
27 * SPI flash chips can lock a region of the flash defined by a
28 * 'protected area'. This function checks if this protected area is
29 * defined.
30 *
31 * @dev: SPI flash device
32 * @return 0 if no region is write-protected, 1 if a region is
33 * write-protected, -ENOSYS if the driver does not implement this,
34 * other -ve value on error
35 */
36 int (*get_sw_write_prot)(struct udevice *dev);
d25ce7d2
HS
37};
38
4c2dbefd
SG
39/* Access the serial operations for a device */
40#define sf_get_ops(dev) ((struct dm_spi_flash_ops *)(dev)->driver->ops)
41
56c40460 42#if CONFIG_IS_ENABLED(DM_SPI_FLASH)
8d987abc
SG
43/**
44 * spi_flash_read_dm() - Read data from SPI flash
45 *
46 * @dev: SPI flash device
47 * @offset: Offset into device in bytes to read from
48 * @len: Number of bytes to read
49 * @buf: Buffer to put the data that is read
185f812c 50 * Return: 0 if OK, -ve on error
8d987abc
SG
51 */
52int spi_flash_read_dm(struct udevice *dev, u32 offset, size_t len, void *buf);
53
54/**
55 * spi_flash_write_dm() - Write data to SPI flash
56 *
57 * @dev: SPI flash device
58 * @offset: Offset into device in bytes to write to
59 * @len: Number of bytes to write
60 * @buf: Buffer containing bytes to write
185f812c 61 * Return: 0 if OK, -ve on error
8d987abc
SG
62 */
63int spi_flash_write_dm(struct udevice *dev, u32 offset, size_t len,
64 const void *buf);
65
66/**
67 * spi_flash_erase_dm() - Erase blocks of the SPI flash
68 *
69 * Note that @len must be a muiltiple of the flash sector size.
70 *
71 * @dev: SPI flash device
72 * @offset: Offset into device in bytes to start erasing
73 * @len: Number of bytes to erase
185f812c 74 * Return: 0 if OK, -ve on error
8d987abc
SG
75 */
76int spi_flash_erase_dm(struct udevice *dev, u32 offset, size_t len);
77
b3b60f59
SG
78/**
79 * spl_flash_get_sw_write_prot() - Check state of software write-protect feature
80 *
81 * SPI flash chips can lock a region of the flash defined by a
82 * 'protected area'. This function checks if this protected area is
83 * defined.
84 *
85 * @dev: SPI flash device
185f812c 86 * Return: 0 if no region is write-protected, 1 if a region is
b3b60f59
SG
87 * write-protected, -ENOSYS if the driver does not implement this,
88 * other -ve value on error
89 */
90int spl_flash_get_sw_write_prot(struct udevice *dev);
91
4806fcea
SG
92/**
93 * spi_flash_std_probe() - Probe a SPI flash device
94 *
95 * This is the standard internal method for probing a SPI flash device to
96 * determine its type. It can be used in chip-specific drivers which need to
97 * do this, typically with of-platdata
98 *
99 * @dev: SPI-flash device to probe
185f812c 100 * Return: 0 if OK, -ve on error
4806fcea
SG
101 */
102int spi_flash_std_probe(struct udevice *dev);
103
4c2dbefd
SG
104int spi_flash_probe_bus_cs(unsigned int busnum, unsigned int cs,
105 unsigned int max_hz, unsigned int spi_mode,
106 struct udevice **devp);
107
108/* Compatibility function - this is the old U-Boot API */
109struct spi_flash *spi_flash_probe(unsigned int bus, unsigned int cs,
110 unsigned int max_hz, unsigned int spi_mode);
111
112/* Compatibility function - this is the old U-Boot API */
b09c74f6
HS
113static inline void spi_flash_free(struct spi_flash *flash)
114{
115}
4c2dbefd 116
4c2dbefd 117static inline int spi_flash_read(struct spi_flash *flash, u32 offset,
8d987abc 118 size_t len, void *buf)
4c2dbefd 119{
8d987abc 120 return spi_flash_read_dm(flash->dev, offset, len, buf);
4c2dbefd
SG
121}
122
123static inline int spi_flash_write(struct spi_flash *flash, u32 offset,
8d987abc 124 size_t len, const void *buf)
4c2dbefd 125{
8d987abc 126 return spi_flash_write_dm(flash->dev, offset, len, buf);
4c2dbefd
SG
127}
128
129static inline int spi_flash_erase(struct spi_flash *flash, u32 offset,
8d987abc 130 size_t len)
4c2dbefd 131{
8d987abc 132 return spi_flash_erase_dm(flash->dev, offset, len);
4c2dbefd
SG
133}
134
135struct sandbox_state;
136
137int sandbox_sf_bind_emul(struct sandbox_state *state, int busnum, int cs,
008dcddf 138 struct udevice *bus, ofnode node, const char *spec);
4c2dbefd
SG
139
140void sandbox_sf_unbind_emul(struct sandbox_state *state, int busnum, int cs);
141
142#else
d25ce7d2
HS
143struct spi_flash *spi_flash_probe(unsigned int bus, unsigned int cs,
144 unsigned int max_hz, unsigned int spi_mode);
0efc0249 145
d25ce7d2
HS
146void spi_flash_free(struct spi_flash *flash);
147
148static inline int spi_flash_read(struct spi_flash *flash, u32 offset,
149 size_t len, void *buf)
150{
c4e88623
V
151 struct mtd_info *mtd = &flash->mtd;
152 size_t retlen;
153
a67b3719
MB
154 if (!len)
155 return 0;
156
c4e88623 157 return mtd->_read(mtd, offset, len, &retlen, buf);
d25ce7d2
HS
158}
159
160static inline int spi_flash_write(struct spi_flash *flash, u32 offset,
161 size_t len, const void *buf)
162{
c4e88623
V
163 struct mtd_info *mtd = &flash->mtd;
164 size_t retlen;
165
a67b3719
MB
166 if (!len)
167 return 0;
168
c4e88623 169 return mtd->_write(mtd, offset, len, &retlen, buf);
d25ce7d2
HS
170}
171
172static inline int spi_flash_erase(struct spi_flash *flash, u32 offset,
173 size_t len)
174{
c4e88623
V
175 struct mtd_info *mtd = &flash->mtd;
176 struct erase_info instr;
177
178 if (offset % mtd->erasesize || len % mtd->erasesize) {
179 printf("SF: Erase offset/length not multiple of erase size\n");
180 return -EINVAL;
181 }
182
a67b3719
MB
183 if (!len)
184 return 0;
185
c4e88623
V
186 memset(&instr, 0, sizeof(instr));
187 instr.addr = offset;
188 instr.len = len;
189
190 return mtd->_erase(mtd, &instr);
d25ce7d2 191}
4c2dbefd 192#endif
d25ce7d2 193
c3c016cf
FE
194static inline int spi_flash_protect(struct spi_flash *flash, u32 ofs, u32 len,
195 bool prot)
196{
439fcb9b 197 if (!flash->flash_lock || !flash->flash_unlock)
c3c016cf
FE
198 return -EOPNOTSUPP;
199
200 if (prot)
201 return flash->flash_lock(flash, ofs, len);
202 else
203 return flash->flash_unlock(flash, ofs, len);
204}
205
d25ce7d2 206#endif /* _SPI_FLASH_H_ */
This page took 0.659974 seconds and 4 git commands to generate.