xref: /rk3399_rockchip-uboot/include/spi_flash.h (revision f2313133c8b63b9260aea9eee872e725fcacbdcf)
1d25ce7d2SHaavard Skinnemoen /*
2a5e8199aSJagannadha Sutradharudu Teki  * Common SPI flash Interface
3d25ce7d2SHaavard Skinnemoen  *
4d25ce7d2SHaavard Skinnemoen  * Copyright (C) 2008 Atmel Corporation
5a5e8199aSJagannadha Sutradharudu Teki  * Copyright (C) 2013 Jagannadha Sutradharudu Teki, Xilinx Inc.
6d25ce7d2SHaavard Skinnemoen  *
75b8031ccSTom Rini  * SPDX-License-Identifier:	GPL-2.0
8d25ce7d2SHaavard Skinnemoen  */
9a5e8199aSJagannadha Sutradharudu Teki 
10d25ce7d2SHaavard Skinnemoen #ifndef _SPI_FLASH_H_
11d25ce7d2SHaavard Skinnemoen #define _SPI_FLASH_H_
12d25ce7d2SHaavard Skinnemoen 
134c2dbefdSSimon Glass #include <dm.h>	/* Because we dereference struct udevice here */
14e06ab654SMike Frysinger #include <linux/types.h>
15*f2313133SVignesh R #include <linux/mtd/spi-nor.h>
16d25ce7d2SHaavard Skinnemoen 
1788e34e5fSNikita Kiryanov #ifndef CONFIG_SF_DEFAULT_SPEED
1888e34e5fSNikita Kiryanov # define CONFIG_SF_DEFAULT_SPEED	1000000
1988e34e5fSNikita Kiryanov #endif
2088e34e5fSNikita Kiryanov #ifndef CONFIG_SF_DEFAULT_MODE
2188e34e5fSNikita Kiryanov # define CONFIG_SF_DEFAULT_MODE		SPI_MODE_3
2288e34e5fSNikita Kiryanov #endif
2388e34e5fSNikita Kiryanov #ifndef CONFIG_SF_DEFAULT_CS
2488e34e5fSNikita Kiryanov # define CONFIG_SF_DEFAULT_CS		0
2588e34e5fSNikita Kiryanov #endif
2688e34e5fSNikita Kiryanov #ifndef CONFIG_SF_DEFAULT_BUS
2788e34e5fSNikita Kiryanov # define CONFIG_SF_DEFAULT_BUS		0
2888e34e5fSNikita Kiryanov #endif
2988e34e5fSNikita Kiryanov 
30ff0960f9SSimon Glass struct spi_slave;
3133adfb5fSJagannadha Sutradharudu Teki 
324c2dbefdSSimon Glass struct dm_spi_flash_ops {
334c2dbefdSSimon Glass 	int (*read)(struct udevice *dev, u32 offset, size_t len, void *buf);
344c2dbefdSSimon Glass 	int (*write)(struct udevice *dev, u32 offset, size_t len,
354c2dbefdSSimon Glass 		     const void *buf);
364c2dbefdSSimon Glass 	int (*erase)(struct udevice *dev, u32 offset, size_t len);
37b6e92505SSimon Glass 	/**
38b6e92505SSimon Glass 	 * get_sw_write_prot() - Check state of software write-protect feature
39b6e92505SSimon Glass 	 *
40b6e92505SSimon Glass 	 * SPI flash chips can lock a region of the flash defined by a
41b6e92505SSimon Glass 	 * 'protected area'. This function checks if this protected area is
42b6e92505SSimon Glass 	 * defined.
43b6e92505SSimon Glass 	 *
44b6e92505SSimon Glass 	 * @dev:	SPI flash device
45b6e92505SSimon Glass 	 * @return 0 if no region is write-protected, 1 if a region is
46b6e92505SSimon Glass 	 *	write-protected, -ENOSYS if the driver does not implement this,
47b6e92505SSimon Glass 	 *	other -ve value on error
48b6e92505SSimon Glass 	 */
49b6e92505SSimon Glass 	int (*get_sw_write_prot)(struct udevice *dev);
504c2dbefdSSimon Glass };
514c2dbefdSSimon Glass 
524c2dbefdSSimon Glass /* Access the serial operations for a device */
534c2dbefdSSimon Glass #define sf_get_ops(dev) ((struct dm_spi_flash_ops *)(dev)->driver->ops)
544c2dbefdSSimon Glass 
554c2dbefdSSimon Glass #ifdef CONFIG_DM_SPI_FLASH
568d987abcSSimon Glass /**
578d987abcSSimon Glass  * spi_flash_read_dm() - Read data from SPI flash
588d987abcSSimon Glass  *
598d987abcSSimon Glass  * @dev:	SPI flash device
608d987abcSSimon Glass  * @offset:	Offset into device in bytes to read from
618d987abcSSimon Glass  * @len:	Number of bytes to read
628d987abcSSimon Glass  * @buf:	Buffer to put the data that is read
638d987abcSSimon Glass  * @return 0 if OK, -ve on error
648d987abcSSimon Glass  */
658d987abcSSimon Glass int spi_flash_read_dm(struct udevice *dev, u32 offset, size_t len, void *buf);
668d987abcSSimon Glass 
678d987abcSSimon Glass /**
688d987abcSSimon Glass  * spi_flash_write_dm() - Write data to SPI flash
698d987abcSSimon Glass  *
708d987abcSSimon Glass  * @dev:	SPI flash device
718d987abcSSimon Glass  * @offset:	Offset into device in bytes to write to
728d987abcSSimon Glass  * @len:	Number of bytes to write
738d987abcSSimon Glass  * @buf:	Buffer containing bytes to write
748d987abcSSimon Glass  * @return 0 if OK, -ve on error
758d987abcSSimon Glass  */
768d987abcSSimon Glass int spi_flash_write_dm(struct udevice *dev, u32 offset, size_t len,
778d987abcSSimon Glass 		       const void *buf);
788d987abcSSimon Glass 
798d987abcSSimon Glass /**
808d987abcSSimon Glass  * spi_flash_erase_dm() - Erase blocks of the SPI flash
818d987abcSSimon Glass  *
828d987abcSSimon Glass  * Note that @len must be a muiltiple of the flash sector size.
838d987abcSSimon Glass  *
848d987abcSSimon Glass  * @dev:	SPI flash device
858d987abcSSimon Glass  * @offset:	Offset into device in bytes to start erasing
868d987abcSSimon Glass  * @len:	Number of bytes to erase
878d987abcSSimon Glass  * @return 0 if OK, -ve on error
888d987abcSSimon Glass  */
898d987abcSSimon Glass int spi_flash_erase_dm(struct udevice *dev, u32 offset, size_t len);
908d987abcSSimon Glass 
91b6e92505SSimon Glass /**
92b6e92505SSimon Glass  * spl_flash_get_sw_write_prot() - Check state of software write-protect feature
93b6e92505SSimon Glass  *
94b6e92505SSimon Glass  * SPI flash chips can lock a region of the flash defined by a
95b6e92505SSimon Glass  * 'protected area'. This function checks if this protected area is
96b6e92505SSimon Glass  * defined.
97b6e92505SSimon Glass  *
98b6e92505SSimon Glass  * @dev:	SPI flash device
99b6e92505SSimon Glass  * @return 0 if no region is write-protected, 1 if a region is
100b6e92505SSimon Glass  *	write-protected, -ENOSYS if the driver does not implement this,
101b6e92505SSimon Glass  *	other -ve value on error
102b6e92505SSimon Glass  */
103b6e92505SSimon Glass int spl_flash_get_sw_write_prot(struct udevice *dev);
104b6e92505SSimon Glass 
1054c2dbefdSSimon Glass int spi_flash_probe_bus_cs(unsigned int busnum, unsigned int cs,
1064c2dbefdSSimon Glass 			   unsigned int max_hz, unsigned int spi_mode,
1074c2dbefdSSimon Glass 			   struct udevice **devp);
1084c2dbefdSSimon Glass 
1094c2dbefdSSimon Glass /* Compatibility function - this is the old U-Boot API */
1104c2dbefdSSimon Glass struct spi_flash *spi_flash_probe(unsigned int bus, unsigned int cs,
1114c2dbefdSSimon Glass 				  unsigned int max_hz, unsigned int spi_mode);
1124c2dbefdSSimon Glass 
1134c2dbefdSSimon Glass /* Compatibility function - this is the old U-Boot API */
1144c2dbefdSSimon Glass void spi_flash_free(struct spi_flash *flash);
1154c2dbefdSSimon Glass 
spi_flash_read(struct spi_flash * flash,u32 offset,size_t len,void * buf)1164c2dbefdSSimon Glass static inline int spi_flash_read(struct spi_flash *flash, u32 offset,
1174c2dbefdSSimon Glass 				 size_t len, void *buf)
1184c2dbefdSSimon Glass {
1198d987abcSSimon Glass 	return spi_flash_read_dm(flash->dev, offset, len, buf);
1204c2dbefdSSimon Glass }
1214c2dbefdSSimon Glass 
spi_flash_write(struct spi_flash * flash,u32 offset,size_t len,const void * buf)1224c2dbefdSSimon Glass static inline int spi_flash_write(struct spi_flash *flash, u32 offset,
1234c2dbefdSSimon Glass 				  size_t len, const void *buf)
1244c2dbefdSSimon Glass {
1258d987abcSSimon Glass 	return spi_flash_write_dm(flash->dev, offset, len, buf);
1264c2dbefdSSimon Glass }
1274c2dbefdSSimon Glass 
spi_flash_erase(struct spi_flash * flash,u32 offset,size_t len)1284c2dbefdSSimon Glass static inline int spi_flash_erase(struct spi_flash *flash, u32 offset,
1294c2dbefdSSimon Glass 				  size_t len)
1304c2dbefdSSimon Glass {
1318d987abcSSimon Glass 	return spi_flash_erase_dm(flash->dev, offset, len);
1324c2dbefdSSimon Glass }
1334c2dbefdSSimon Glass 
1344c2dbefdSSimon Glass struct sandbox_state;
1354c2dbefdSSimon Glass 
1364c2dbefdSSimon Glass int sandbox_sf_bind_emul(struct sandbox_state *state, int busnum, int cs,
1374d9cacbfSSimon Glass 			 struct udevice *bus, ofnode node, const char *spec);
1384c2dbefdSSimon Glass 
1394c2dbefdSSimon Glass void sandbox_sf_unbind_emul(struct sandbox_state *state, int busnum, int cs);
1404c2dbefdSSimon Glass 
1414c2dbefdSSimon Glass #else
142d25ce7d2SHaavard Skinnemoen struct spi_flash *spi_flash_probe(unsigned int bus, unsigned int cs,
143d25ce7d2SHaavard Skinnemoen 		unsigned int max_hz, unsigned int spi_mode);
1440efc0249SSimon Glass 
145d25ce7d2SHaavard Skinnemoen void spi_flash_free(struct spi_flash *flash);
146d25ce7d2SHaavard Skinnemoen 
spi_flash_read(struct spi_flash * flash,u32 offset,size_t len,void * buf)147d25ce7d2SHaavard Skinnemoen static inline int spi_flash_read(struct spi_flash *flash, u32 offset,
148d25ce7d2SHaavard Skinnemoen 		size_t len, void *buf)
149d25ce7d2SHaavard Skinnemoen {
150*f2313133SVignesh R 	struct mtd_info *mtd = &flash->mtd;
151*f2313133SVignesh R 	size_t retlen;
152*f2313133SVignesh R 
153*f2313133SVignesh R 	return mtd->_read(mtd, offset, len, &retlen, buf);
154d25ce7d2SHaavard Skinnemoen }
155d25ce7d2SHaavard Skinnemoen 
spi_flash_write(struct spi_flash * flash,u32 offset,size_t len,const void * buf)156d25ce7d2SHaavard Skinnemoen static inline int spi_flash_write(struct spi_flash *flash, u32 offset,
157d25ce7d2SHaavard Skinnemoen 		size_t len, const void *buf)
158d25ce7d2SHaavard Skinnemoen {
159*f2313133SVignesh R 	struct mtd_info *mtd = &flash->mtd;
160*f2313133SVignesh R 	size_t retlen;
161*f2313133SVignesh R 
162*f2313133SVignesh R 	return mtd->_write(mtd, offset, len, &retlen, buf);
163d25ce7d2SHaavard Skinnemoen }
164d25ce7d2SHaavard Skinnemoen 
spi_flash_erase(struct spi_flash * flash,u32 offset,size_t len)165d25ce7d2SHaavard Skinnemoen static inline int spi_flash_erase(struct spi_flash *flash, u32 offset,
166d25ce7d2SHaavard Skinnemoen 		size_t len)
167d25ce7d2SHaavard Skinnemoen {
168*f2313133SVignesh R 	struct mtd_info *mtd = &flash->mtd;
169*f2313133SVignesh R 	struct erase_info instr;
170*f2313133SVignesh R 
171*f2313133SVignesh R 	if (offset % mtd->erasesize || len % mtd->erasesize) {
172*f2313133SVignesh R 		printf("SF: Erase offset/length not multiple of erase size\n");
173*f2313133SVignesh R 		return -EINVAL;
174*f2313133SVignesh R 	}
175*f2313133SVignesh R 
176*f2313133SVignesh R 	memset(&instr, 0, sizeof(instr));
177*f2313133SVignesh R 	instr.addr = offset;
178*f2313133SVignesh R 	instr.len = len;
179*f2313133SVignesh R 
180*f2313133SVignesh R 	return mtd->_erase(mtd, &instr);
181d25ce7d2SHaavard Skinnemoen }
1824c2dbefdSSimon Glass #endif
183d25ce7d2SHaavard Skinnemoen 
spi_flash_protect(struct spi_flash * flash,u32 ofs,u32 len,bool prot)184c3c016cfSFabio Estevam static inline int spi_flash_protect(struct spi_flash *flash, u32 ofs, u32 len,
185c3c016cfSFabio Estevam 					bool prot)
186c3c016cfSFabio Estevam {
187439fcb9bSBin Meng 	if (!flash->flash_lock || !flash->flash_unlock)
188c3c016cfSFabio Estevam 		return -EOPNOTSUPP;
189c3c016cfSFabio Estevam 
190c3c016cfSFabio Estevam 	if (prot)
191c3c016cfSFabio Estevam 		return flash->flash_lock(flash, ofs, len);
192c3c016cfSFabio Estevam 	else
193c3c016cfSFabio Estevam 		return flash->flash_unlock(flash, ofs, len);
194c3c016cfSFabio Estevam }
195c3c016cfSFabio Estevam 
196d25ce7d2SHaavard Skinnemoen #endif /* _SPI_FLASH_H_ */
197