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) 230f623280SJagannadha 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 32*7ab35d92SJagannadha Sutradharudu Teki /** 33*7ab35d92SJagannadha Sutradharudu Teki * struct spi_flash - SPI flash structure 34*7ab35d92SJagannadha Sutradharudu Teki * 35*7ab35d92SJagannadha Sutradharudu Teki * @spi: SPI slave 36*7ab35d92SJagannadha Sutradharudu Teki * @name: Name of SPI flash 37*7ab35d92SJagannadha Sutradharudu Teki * @size: Total flash size 38*7ab35d92SJagannadha Sutradharudu Teki * @page_size: Write (page) size 39*7ab35d92SJagannadha Sutradharudu Teki * @sector_size: Sector size 40*7ab35d92SJagannadha Sutradharudu Teki * @erase_size: Erase size 41*7ab35d92SJagannadha Sutradharudu Teki * @bank_read_cmd: Bank read cmd 42*7ab35d92SJagannadha Sutradharudu Teki * @bank_write_cmd: Bank write cmd 43*7ab35d92SJagannadha Sutradharudu Teki * @bank_curr: Current flash bank 44*7ab35d92SJagannadha Sutradharudu Teki * @poll_cmd: Poll cmd - for flash erase/program 45*7ab35d92SJagannadha Sutradharudu Teki * @erase_cmd: Erase cmd 4K, 32K, 64K 46*7ab35d92SJagannadha Sutradharudu Teki * @memory_map: Address of read-only SPI flash access 47*7ab35d92SJagannadha Sutradharudu Teki * @read: Flash read ops: Read len bytes at offset into buf 48*7ab35d92SJagannadha Sutradharudu Teki * Supported cmds: Fast Array Read 49*7ab35d92SJagannadha Sutradharudu Teki * @write: Flash write ops: Write len bytes from buf into offeset 50*7ab35d92SJagannadha Sutradharudu Teki * Supported cmds: Page Program 51*7ab35d92SJagannadha Sutradharudu Teki * @erase: Flash erase ops: Erase len bytes from offset 52*7ab35d92SJagannadha Sutradharudu Teki * Supported cmds: Sector erase 4K, 32K, 64K 53*7ab35d92SJagannadha Sutradharudu Teki * return 0 - Sucess, 1 - Failure 54*7ab35d92SJagannadha Sutradharudu Teki */ 55d25ce7d2SHaavard Skinnemoen struct spi_flash { 56d25ce7d2SHaavard Skinnemoen struct spi_slave *spi; 57d25ce7d2SHaavard Skinnemoen const char *name; 58d25ce7d2SHaavard Skinnemoen 59d25ce7d2SHaavard Skinnemoen u32 size; 60d4aa5009SMike Frysinger u32 page_size; 614e6a5158SRichard Retanubun u32 sector_size; 62f4f51a8fSJagannadha Sutradharudu Teki u32 erase_size; 631dcd6d03SJagannadha Sutradharudu Teki #ifdef CONFIG_SPI_FLASH_BAR 64cf6b11dcSJagannadha Sutradharudu Teki u8 bank_read_cmd; 65cf6b11dcSJagannadha Sutradharudu Teki u8 bank_write_cmd; 66e612ddf5SJagannadha Sutradharudu Teki u8 bank_curr; 671dcd6d03SJagannadha Sutradharudu Teki #endif 68615a1561SJagannadha Sutradharudu Teki u8 poll_cmd; 69f4f51a8fSJagannadha Sutradharudu Teki u8 erase_cmd; 70615a1561SJagannadha Sutradharudu Teki 71*7ab35d92SJagannadha Sutradharudu Teki void *memory_map; 72*7ab35d92SJagannadha Sutradharudu Teki int (*read)(struct spi_flash *flash, u32 offset, size_t len, void *buf); 73*7ab35d92SJagannadha Sutradharudu Teki int (*write)(struct spi_flash *flash, u32 offset, size_t len, 74*7ab35d92SJagannadha Sutradharudu Teki const void *buf); 75*7ab35d92SJagannadha Sutradharudu Teki int (*erase)(struct spi_flash *flash, u32 offset, size_t len); 76d25ce7d2SHaavard Skinnemoen }; 77d25ce7d2SHaavard Skinnemoen 78b5aec142SSimon Glass /** 79b5aec142SSimon Glass * spi_flash_do_alloc - Allocate a new spi flash structure 80b5aec142SSimon Glass * 81b5aec142SSimon Glass * The structure is allocated and cleared with default values for 82b5aec142SSimon Glass * read, write and erase, which the caller can modify. The caller must set 83b5aec142SSimon Glass * up size, page_size and sector_size. 84b5aec142SSimon Glass * 85b5aec142SSimon Glass * Use the helper macro spi_flash_alloc() to call this. 86b5aec142SSimon Glass * 87b5aec142SSimon Glass * @offset: Offset of struct spi_slave within slave structure 88b5aec142SSimon Glass * @size: Size of slave structure 89b5aec142SSimon Glass * @spi: SPI slave 90b5aec142SSimon Glass * @name: Name of SPI flash device 91b5aec142SSimon Glass */ 92b5aec142SSimon Glass void *spi_flash_do_alloc(int offset, int size, struct spi_slave *spi, 93b5aec142SSimon Glass const char *name); 94b5aec142SSimon Glass 95b5aec142SSimon Glass /** 96b5aec142SSimon Glass * spi_flash_alloc - Allocate a new SPI flash structure 97b5aec142SSimon Glass * 98b5aec142SSimon Glass * @_struct: Name of structure to allocate (e.g. struct ramtron_spi_fram). This 99b5aec142SSimon Glass * structure must contain a member 'struct spi_flash *flash'. 100b5aec142SSimon Glass * @spi: SPI slave 101b5aec142SSimon Glass * @name: Name of SPI flash device 102b5aec142SSimon Glass */ 103b5aec142SSimon Glass #define spi_flash_alloc(_struct, spi, name) \ 104b5aec142SSimon Glass spi_flash_do_alloc(offsetof(_struct, flash), sizeof(_struct), \ 105b5aec142SSimon Glass spi, name) 106b5aec142SSimon Glass 107b5aec142SSimon Glass /** 108b5aec142SSimon Glass * spi_flash_alloc_base - Allocate a new SPI flash structure with no private data 109b5aec142SSimon Glass * 110b5aec142SSimon Glass * @spi: SPI slave 111b5aec142SSimon Glass * @name: Name of SPI flash device 112b5aec142SSimon Glass */ 113b5aec142SSimon Glass #define spi_flash_alloc_base(spi, name) \ 114b5aec142SSimon Glass spi_flash_do_alloc(0, sizeof(struct spi_flash), spi, name) 115b5aec142SSimon Glass 116d25ce7d2SHaavard Skinnemoen struct spi_flash *spi_flash_probe(unsigned int bus, unsigned int cs, 117d25ce7d2SHaavard Skinnemoen unsigned int max_hz, unsigned int spi_mode); 118d25ce7d2SHaavard Skinnemoen void spi_flash_free(struct spi_flash *flash); 119d25ce7d2SHaavard Skinnemoen 120d25ce7d2SHaavard Skinnemoen static inline int spi_flash_read(struct spi_flash *flash, u32 offset, 121d25ce7d2SHaavard Skinnemoen size_t len, void *buf) 122d25ce7d2SHaavard Skinnemoen { 123d25ce7d2SHaavard Skinnemoen return flash->read(flash, offset, len, buf); 124d25ce7d2SHaavard Skinnemoen } 125d25ce7d2SHaavard Skinnemoen 126d25ce7d2SHaavard Skinnemoen static inline int spi_flash_write(struct spi_flash *flash, u32 offset, 127d25ce7d2SHaavard Skinnemoen size_t len, const void *buf) 128d25ce7d2SHaavard Skinnemoen { 129d25ce7d2SHaavard Skinnemoen return flash->write(flash, offset, len, buf); 130d25ce7d2SHaavard Skinnemoen } 131d25ce7d2SHaavard Skinnemoen 132d25ce7d2SHaavard Skinnemoen static inline int spi_flash_erase(struct spi_flash *flash, u32 offset, 133d25ce7d2SHaavard Skinnemoen size_t len) 134d25ce7d2SHaavard Skinnemoen { 135d25ce7d2SHaavard Skinnemoen return flash->erase(flash, offset, len); 136d25ce7d2SHaavard Skinnemoen } 137d25ce7d2SHaavard Skinnemoen 13832b11273SChristian Riesch void spi_boot(void) __noreturn; 13932b11273SChristian Riesch 140d25ce7d2SHaavard Skinnemoen #endif /* _SPI_FLASH_H_ */ 141