/* $NetBSD: spiflash.h,v 1.4 2009/05/12 14:45:08 cegger Exp $ */ /*- * Copyright (c) 2006 Urbana-Champaign Independent Media Center. * Copyright (c) 2006 Garrett D'Amore. * All rights reserved. * * Portions of this code were written by Garrett D'Amore for the * Champaign-Urbana Community Wireless Network Project. * * Redistribution and use in source and binary forms, with or * without modification, are permitted provided that the following * conditions are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following * disclaimer in the documentation and/or other materials provided * with the distribution. * 3. All advertising materials mentioning features or use of this * software must display the following acknowledgements: * This product includes software developed by the Urbana-Champaign * Independent Media Center. * This product includes software developed by Garrett D'Amore. * 4. Urbana-Champaign Independent Media Center's name and Garrett * D'Amore's name may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE URBANA-CHAMPAIGN INDEPENDENT * MEDIA CENTER AND GARRETT D'AMORE ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE URBANA-CHAMPAIGN INDEPENDENT * MEDIA CENTER OR GARRETT D'AMORE BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef _DEV_SPI_SPIFLASH_H_ #define _DEV_SPI_SPIFLASH_H_ #define SPIFLASH_CMD_RDSR 0x05 /* read status register */ #define SPIFLASH_CMD_WRSR 0x01 /* write status register */ #define SPIFLASH_CMD_WREN 0x06 /* enable WRSR */ #define SPIFLASH_CMD_WRDI 0x04 /* disable WRSR */ /* * Different chips offer different ways to read a device ID, although * newer parts should all offer the standard JEDEC variant. * Additionally, many parts have a faster read, though how to make use * of this sometimes requires special hacks. E.g. some parts use an * extra data pin, and some crank the clock rate up. */ #define SPIFLASH_CMD_READ 0x03 /* read data (normal) */ #define SPIFLASH_CMD_RDID 0xab /* read id */ #define SPIFLASH_CMD_RDID2 0x90 /* read id (alternate) */ #define SPIFLASH_CMD_RDJI 0x9f /* read JEDEC id */ #define SPIFLASH_CMD_READFAST 0x0b /* fast read */ /* * Different chips offer different variations on the sector erase. * E.g. SST parts offer 4k, 32k, and 64k erase sizes on the same part, * with just different cmds. However, at least SST, AMD, and Winbond * all offer at least the main (0xd8) variant. */ #define SPIFLASH_CMD_ERASE 0xd8 /* sector erase */ #define SPIFLASH_CMD_ERASE2 0x52 /* sector erase (alternate) */ #define SPIFLASH_CMD_ERASE3 0x20 /* sector erase (alternate) */ #define SPIFLASH_CMD_ERASE4 0x81 /* page erase */ #define SPIFLASH_CMD_CHIPERASE 0xc7 /* chip erase */ /* * Some parts can stream bytes with the program command, whereas others require * a separate command sequence for each byte. */ #define SPIFLASH_CMD_PROGRAM 0x02 /* page or byte program */ #define SPIFLASH_CMD_PROGRAM_AA 0xad /* program (autoincrement) */ /* * Some additional commands. Again, mostly device specific. */ #define SPIFLASH_CMD_EBSY 0x70 /* output busy signal (SST) */ #define SPIFLASH_CMD_DBSY 0x80 /* disable busy signal (SST) */ /* * Status register bits. Not all devices implement all bits. In * addition, the meanings of the BP bits seem to vary from device to * device. */ #define SPIFLASH_SR_BUSY 0x01 /* program in progress */ #define SPIFLASH_SR_WEL 0x02 /* write enable latch */ #define SPIFLASH_SR_BP0 0x04 /* block protect bits */ #define SPIFLASH_SR_BP1 0x08 #define SPIFLASH_SR_BP2 0x10 #define SPIFLASH_SR_BP3 0x20 #define SPIFLASH_SR_AAI 0x40 /* auto-increment mode */ #define SPIFLASH_SR_SRP 0x80 /* SR write protected */ /* * This needs to change to accommodate boot-sectored devices. */ typedef struct spiflash_softc *spiflash_handle_t; struct spiflash_hw_if { /* * Driver MUST provide these. */ const char *(*sf_getname)(void *); struct spi_handle *(*sf_gethandle)(void *); int (*sf_getflags)(void *); int (*sf_getsize)(void *, int); /* * SPI framework will provide these if the driver does not. */ int (*sf_erase)(spiflash_handle_t, size_t, size_t); int (*sf_write)(spiflash_handle_t, size_t, size_t, const uint8_t *); int (*sf_read)(spiflash_handle_t, size_t, size_t, uint8_t *); /* * Not implemented yet. */ int (*sf_getstatus)(spiflash_handle_t, int, int); int (*sf_setstatus)(spiflash_handle_t, int, int, int); }; #define SPIFLASH_SIZE_DEVICE 0 #define SPIFLASH_SIZE_ERASE 1 #define SPIFLASH_SIZE_WRITE 2 /* return -1 for unlimited */ #define SPIFLASH_SIZE_READ 3 /* return -1 for unlimited */ #define SPIFLASH_SIZE_COUNT 4 #define SPIFLASH_FLAG_FAST_READ 0x0004 /* use fast read sequence */ spiflash_handle_t spiflash_attach_mi(const struct spiflash_hw_if *, void *, device_t); void spiflash_set_private(spiflash_handle_t, void *); void *spiflash_get_private(spiflash_handle_t); int spiflash_read_status(spiflash_handle_t, uint8_t *); int spiflash_write_disable(spiflash_handle_t); int spiflash_write_enable(spiflash_handle_t); int spiflash_cmd(spiflash_handle_t, uint8_t, size_t, uint32_t, size_t, const uint8_t *, uint8_t *); int spiflash_wait(spiflash_handle_t, int); #endif /* _DEV_SPI_SPIFLASH_H_ */