MySensors Library & Examples  2.3.2-62-ge298769
Classes | Macros
SPIFlash.h File Reference

Detailed Description

SPIFlash provides access to a SPI Flash IC for OTA update or storing data.

IMPORTANT: NAND FLASH memory requires erase before write, because it can only transition from 1s to 0s and only the erase command can reset all 0s to 1s See http://en.wikipedia.org/wiki/Flash_memory The smallest range that can be erased is a sector (4K, 32K, 64K); there is also a chip erase command

Standard SPI flash commands
Assuming the WP pin is pulled up (to disable hardware write protection).
To use any write commands the WEL bit in the status register must be set to 1.
This is accomplished by sending a 0x06 command before any such write/erase command.
The WEL bit in the status register resets to the logical ?0? state after a device power-up or reset. In addition, the WEL bit will be reset to the logical ?0? state automatically under the following conditions:

Definition in file SPIFlash.h.

#include <wiring.h>
#include "pins_arduino.h"
#include <SPI.h>
+ Include dependency graph for SPIFlash.h:
+ This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Classes

class  SPIFlash
 

Macros

#define SPIFLASH_WRITEENABLE   0x06
 write enable
 
#define SPIFLASH_WRITEDISABLE   0x04
 write disable
 
#define SPIFLASH_BLOCKERASE_4K   0x20
 erase one 4K block of flash memory
 
#define SPIFLASH_BLOCKERASE_32K   0x52
 erase one 32K block of flash memory
 
#define SPIFLASH_BLOCKERASE_64K   0xD8
 erase one 64K block of flash memory
 
#define SPIFLASH_CHIPERASE   0x60
 chip erase (may take several seconds depending on size) More...
 
#define SPIFLASH_STATUSREAD   0x05
 read status register
 
#define SPIFLASH_STATUSWRITE   0x01
 write status register
 
#define SPIFLASH_ARRAYREAD   0x0B
 read array (fast, need to add 1 dummy byte after 3 address bytes)
 
#define SPIFLASH_ARRAYREADLOWFREQ   0x03
 read array (low frequency)
 
#define SPIFLASH_SLEEP   0xB9
 deep power down
 
#define SPIFLASH_WAKE   0xAB
 deep power wake up
 
#define SPIFLASH_BYTEPAGEPROGRAM   0x02
 write (1 to 256bytes). Writing more than one Byte is not supported on all devices (e.g. SST25 Series)
 
#define SPIFLASH_AAIWORDPROGRAM   0xAD
 Auto Address Increment Programming on Microchip SST Family Devices which do not support page program.
More...
 
#define SPIFLASH_IDREAD   0x9F
 read JEDEC manufacturer and device ID (2 bytes, specific bytes for each manufacturer and device) More...
 
#define SPIFLASH_MACREAD   0x4B
 read unique ID number (MAC)
 
#define MY_SPIFLASH_SST25TYPE
 If set AAI Word Programming is used to support SST25 Family SPI Flash. More...
 

Macro Definition Documentation

◆ MY_SPIFLASH_SST25TYPE

#define MY_SPIFLASH_SST25TYPE

If set AAI Word Programming is used to support SST25 Family SPI Flash.

SST25 Family Flash does not support programming multiple Bytes with opcode 0x02 SPIFLASH_BYTEPAGEPROGRAM.
If SPIFLASH_SST25TYPE is set and writeBytes is called, it will use opcode 0xAD SPIFLASH_AAIWORDPROGRAM and care for Byte alignment.
Note: AAI Wordprogramming is independent of Pages, so pagebreaking is not an issue when using AAI Wordprogramming.

Definition at line 157 of file SPIFlash.h.

◆ SPIFLASH_AAIWORDPROGRAM

#define SPIFLASH_AAIWORDPROGRAM   0xAD

Auto Address Increment Programming on Microchip SST Family Devices which do not support page program.

Use define MY_SPIFLASH_SST25TYPE to use AAI prog instead of Bytepageprogram which does not work on SST Family Chips tested with SST25PF020B80 http://ww1.microchip.com/downloads/en/DeviceDoc/20005135B.pdf

Definition at line 133 of file SPIFlash.h.

◆ SPIFLASH_CHIPERASE

#define SPIFLASH_CHIPERASE   0x60

chip erase (may take several seconds depending on size)

Chip is erased but not actually waited for completion (instead need to check the status register BUSY bit)

Definition at line 100 of file SPIFlash.h.

◆ SPIFLASH_IDREAD

#define SPIFLASH_IDREAD   0x9F

read JEDEC manufacturer and device ID (2 bytes, specific bytes for each manufacturer and device)

Example for Atmel-Adesto 4Mbit AT25DF041A: 0x1F44 (page 27: http://www.adestotech.com/sites/default/files/datasheets/doc3668.pdf) Example for Winbond 4Mbit W25X40CL: 0xEF30 (page 14: http://www.winbond.com/NR/rdonlyres/6E25084C-0BFE-4B25-903D-AE10221A0929/0/W25X40CL.pdf)

Definition at line 139 of file SPIFlash.h.