1d25ce7d2SHaavard Skinnemoen /* 2d25ce7d2SHaavard Skinnemoen * Interface to SPI flash 3d25ce7d2SHaavard Skinnemoen * 4d25ce7d2SHaavard Skinnemoen * Copyright (C) 2008 Atmel Corporation 5d25ce7d2SHaavard Skinnemoen * 6d25ce7d2SHaavard Skinnemoen * See file CREDITS for list of people who contributed to this 7d25ce7d2SHaavard Skinnemoen * project. 8d25ce7d2SHaavard Skinnemoen * 9d25ce7d2SHaavard Skinnemoen * This program is free software; you can redistribute it and/or 10d25ce7d2SHaavard Skinnemoen * modify it under the terms of the GNU General Public License 11d25ce7d2SHaavard Skinnemoen * version 2 as published by the Free Software Foundation. 12d25ce7d2SHaavard Skinnemoen */ 13d25ce7d2SHaavard Skinnemoen #ifndef _SPI_FLASH_H_ 14d25ce7d2SHaavard Skinnemoen #define _SPI_FLASH_H_ 15d25ce7d2SHaavard Skinnemoen 16d25ce7d2SHaavard Skinnemoen #include <spi.h> 17e06ab654SMike Frysinger #include <linux/types.h> 1832b11273SChristian Riesch #include <linux/compiler.h> 19d25ce7d2SHaavard Skinnemoen 20f4f51a8fSJagannadha Sutradharudu Teki /* SECT flags */ 21f4f51a8fSJagannadha Sutradharudu Teki #define SECT_4K (1 << 1) 22f4f51a8fSJagannadha Sutradharudu Teki #define SECT_32K (1 << 2) 23*0f623280SJagannadha Sutradharudu Teki #define E_FSR (1 << 3) 24f4f51a8fSJagannadha Sutradharudu Teki 2510ca45d0SJagannadha Sutradharudu Teki /* SST specific macros */ 2610ca45d0SJagannadha Sutradharudu Teki #ifdef CONFIG_SPI_FLASH_SST 2710ca45d0SJagannadha Sutradharudu Teki # define SST_WP 0x01 /* Supports AAI word program */ 2810ca45d0SJagannadha Sutradharudu Teki # define CMD_SST_BP 0x02 /* Byte Program */ 2910ca45d0SJagannadha Sutradharudu Teki # define CMD_SST_AAI_WP 0xAD /* Auto Address Incr Word Program */ 3010ca45d0SJagannadha Sutradharudu Teki #endif 3110ca45d0SJagannadha Sutradharudu Teki 32d25ce7d2SHaavard Skinnemoen struct spi_flash { 33d25ce7d2SHaavard Skinnemoen struct spi_slave *spi; 34d25ce7d2SHaavard Skinnemoen 35d25ce7d2SHaavard Skinnemoen const char *name; 36d25ce7d2SHaavard Skinnemoen 37d4aa5009SMike Frysinger /* Total flash size */ 38d25ce7d2SHaavard Skinnemoen u32 size; 39d4aa5009SMike Frysinger /* Write (page) size */ 40d4aa5009SMike Frysinger u32 page_size; 41f4f51a8fSJagannadha Sutradharudu Teki /* Sector size */ 424e6a5158SRichard Retanubun u32 sector_size; 43f4f51a8fSJagannadha Sutradharudu Teki /* Erase size */ 44f4f51a8fSJagannadha Sutradharudu Teki u32 erase_size; 451dcd6d03SJagannadha Sutradharudu Teki #ifdef CONFIG_SPI_FLASH_BAR 46cf6b11dcSJagannadha Sutradharudu Teki /* Bank read cmd */ 47cf6b11dcSJagannadha Sutradharudu Teki u8 bank_read_cmd; 48cf6b11dcSJagannadha Sutradharudu Teki /* Bank write cmd */ 49cf6b11dcSJagannadha Sutradharudu Teki u8 bank_write_cmd; 50e612ddf5SJagannadha Sutradharudu Teki /* Current flash bank */ 51e612ddf5SJagannadha Sutradharudu Teki u8 bank_curr; 521dcd6d03SJagannadha Sutradharudu Teki #endif 53615a1561SJagannadha Sutradharudu Teki /* Poll cmd - for flash erase/program */ 54615a1561SJagannadha Sutradharudu Teki u8 poll_cmd; 55f4f51a8fSJagannadha Sutradharudu Teki /* Erase cmd 4K, 32K, 64K */ 56f4f51a8fSJagannadha Sutradharudu Teki u8 erase_cmd; 57615a1561SJagannadha Sutradharudu Teki 58bb8215f4SSimon Glass void *memory_map; /* Address of read-only SPI flash access */ 59d25ce7d2SHaavard Skinnemoen int (*read)(struct spi_flash *flash, u32 offset, 60d25ce7d2SHaavard Skinnemoen size_t len, void *buf); 61d25ce7d2SHaavard Skinnemoen int (*write)(struct spi_flash *flash, u32 offset, 62d25ce7d2SHaavard Skinnemoen size_t len, const void *buf); 63d25ce7d2SHaavard Skinnemoen int (*erase)(struct spi_flash *flash, u32 offset, 64d25ce7d2SHaavard Skinnemoen size_t len); 65d25ce7d2SHaavard Skinnemoen }; 66d25ce7d2SHaavard Skinnemoen 67b5aec142SSimon Glass /** 68b5aec142SSimon Glass * spi_flash_do_alloc - Allocate a new spi flash structure 69b5aec142SSimon Glass * 70b5aec142SSimon Glass * The structure is allocated and cleared with default values for 71b5aec142SSimon Glass * read, write and erase, which the caller can modify. The caller must set 72b5aec142SSimon Glass * up size, page_size and sector_size. 73b5aec142SSimon Glass * 74b5aec142SSimon Glass * Use the helper macro spi_flash_alloc() to call this. 75b5aec142SSimon Glass * 76b5aec142SSimon Glass * @offset: Offset of struct spi_slave within slave structure 77b5aec142SSimon Glass * @size: Size of slave structure 78b5aec142SSimon Glass * @spi: SPI slave 79b5aec142SSimon Glass * @name: Name of SPI flash device 80b5aec142SSimon Glass */ 81b5aec142SSimon Glass void *spi_flash_do_alloc(int offset, int size, struct spi_slave *spi, 82b5aec142SSimon Glass const char *name); 83b5aec142SSimon Glass 84b5aec142SSimon Glass /** 85b5aec142SSimon Glass * spi_flash_alloc - Allocate a new SPI flash structure 86b5aec142SSimon Glass * 87b5aec142SSimon Glass * @_struct: Name of structure to allocate (e.g. struct ramtron_spi_fram). This 88b5aec142SSimon Glass * structure must contain a member 'struct spi_flash *flash'. 89b5aec142SSimon Glass * @spi: SPI slave 90b5aec142SSimon Glass * @name: Name of SPI flash device 91b5aec142SSimon Glass */ 92b5aec142SSimon Glass #define spi_flash_alloc(_struct, spi, name) \ 93b5aec142SSimon Glass spi_flash_do_alloc(offsetof(_struct, flash), sizeof(_struct), \ 94b5aec142SSimon Glass spi, name) 95b5aec142SSimon Glass 96b5aec142SSimon Glass /** 97b5aec142SSimon Glass * spi_flash_alloc_base - Allocate a new SPI flash structure with no private data 98b5aec142SSimon Glass * 99b5aec142SSimon Glass * @spi: SPI slave 100b5aec142SSimon Glass * @name: Name of SPI flash device 101b5aec142SSimon Glass */ 102b5aec142SSimon Glass #define spi_flash_alloc_base(spi, name) \ 103b5aec142SSimon Glass spi_flash_do_alloc(0, sizeof(struct spi_flash), spi, name) 104b5aec142SSimon Glass 105d25ce7d2SHaavard Skinnemoen struct spi_flash *spi_flash_probe(unsigned int bus, unsigned int cs, 106d25ce7d2SHaavard Skinnemoen unsigned int max_hz, unsigned int spi_mode); 107d25ce7d2SHaavard Skinnemoen void spi_flash_free(struct spi_flash *flash); 108d25ce7d2SHaavard Skinnemoen 109d25ce7d2SHaavard Skinnemoen static inline int spi_flash_read(struct spi_flash *flash, u32 offset, 110d25ce7d2SHaavard Skinnemoen size_t len, void *buf) 111d25ce7d2SHaavard Skinnemoen { 112d25ce7d2SHaavard Skinnemoen return flash->read(flash, offset, len, buf); 113d25ce7d2SHaavard Skinnemoen } 114d25ce7d2SHaavard Skinnemoen 115d25ce7d2SHaavard Skinnemoen static inline int spi_flash_write(struct spi_flash *flash, u32 offset, 116d25ce7d2SHaavard Skinnemoen size_t len, const void *buf) 117d25ce7d2SHaavard Skinnemoen { 118d25ce7d2SHaavard Skinnemoen return flash->write(flash, offset, len, buf); 119d25ce7d2SHaavard Skinnemoen } 120d25ce7d2SHaavard Skinnemoen 121d25ce7d2SHaavard Skinnemoen static inline int spi_flash_erase(struct spi_flash *flash, u32 offset, 122d25ce7d2SHaavard Skinnemoen size_t len) 123d25ce7d2SHaavard Skinnemoen { 124d25ce7d2SHaavard Skinnemoen return flash->erase(flash, offset, len); 125d25ce7d2SHaavard Skinnemoen } 126d25ce7d2SHaavard Skinnemoen 12732b11273SChristian Riesch void spi_boot(void) __noreturn; 12832b11273SChristian Riesch 129d25ce7d2SHaavard Skinnemoen #endif /* _SPI_FLASH_H_ */ 130