Serial Flash Memory Programmer Schematic
Programming the SPI flash memory. First, the FPGA is programmed with a circuit that can program the SPI ROM. Serial Flash memory. FLASH Memory Programming Specification for PIC16F72. In-Circuit Serial Programming™ for PIC16C433 OTP MCUs. USB BIOS EEPROM SPI FLASH Programmer CH341A 24 25 series. (7, the operation results of re-instruction: software interface shows that light flashing.
I'm working on an audio application where instead of storing audio data on an SD card (Waveshield on Arduino) I'm storing it on an SPI flash memory IC and rolling my own board with MCU, DAC, and amp.
I am using a Winbond W25Q80BVSSIG.
I'm pretty familiar with programming AVR using the AVRISP mkII or the USBTiny, is writing data to flash done with the same programmer? I haven't been able to find anything when looking for SPI flash memory programmers specifically.
This question is a follow up to this one.
7 Answers
$begingroup$If you are simply looking for a way to program the Winbond SPI flash with 'pre-loaded' data that your microcontroller would read for use when it is running then what you will want to look into is a programmer that can do in-circuit programming of the SPI Flash chip. This also known as in-system-programming (ISP).
One choice is the programmer from DediProg. This USB connected device can program in circuit if you design your board correctly. They even sell an adapter clip that can attach into the SOW-16 package without having to design in a separate programming header on your board. DediProg has application information bulletins available to help with correct design for in circuit use. The main strategy for the design is to find a simple way to isolate the SPI interface drivers in your MCU system so that they do not interfere with the drivers in the SPI programming pod. The simplest way to do this is to put series resistors in the MCU driven lines between the MCU and the SPI Flash. The programmer would connect on the SPI flash side of the series resistors. Alternate methods could include adding a MUX or analog switches in the driven interface lines. An even more clever scheme is to add a 'programming enable' input to the MCU that makes the software disconnect all the SPI I/Os from the SPI Flash chip (i.e. make all those GPIOs as inputs).
A second choice to also consider is the USB programer from ASIX. The Presto is able to do various types of SPI and I2C devices including SPI Flash devices. I have one of these devices specifically for programming Atmel MCUs and various types of SPI Flash devices. It is a more cost effective solution than the above unit but not quite as flexible. Their more expensive device called the Forte is able to do more things because it has more target interface pins.
Sometimes it can be beneficial to be able to connect a programmmer to a target board without having to add a programming header. One nice solution for this is to place a small set of pads in a special footprint defined by a company called TagConnect. They manufacture and sell a series of quick connect programming cables that have pogo pins that engage the special footprint on the board. There are 6-pin, 10-pin and 14-pin versions of the cable available to suit a range of applications. Cost of the cables are very reasonable.
I have never heard of any other tools talking SPI directly to such a chip, and I think it is impossible since 'all' chips require different calls for different operations.
The chip needs SPI calls for write, read, change sector, data size etc. Under 7.2 Instructions chapter in the datasheet you can see all the SPI commands you can send to it. Hence, since all external flash memories does not have the same instruction set, you need to write a customized application for this one.
EDIT: Being a follow up, I would really recommend one of Atmels own SPI flash memories, since most of them already has written open available code for them. Looking at this post from AVRFreaks will provide you with code for some of Atmels AT45xxxx serial flash chips.
I bet you could do it with a Bus Pirate without going through your MCU.. that lets you perform somewhat arbitrary serial interactions directly to a chip using SPI, I2C, or UART communication. It might take a bit of work to 'script' it, but it would let you do the job probably.
I've also seen specialized tools for loading EEPROM's over I2C directly, but not flash and not SPI specifically.
I purchased a 'FlashCAT' programmer from Embedded Computers for about $30 US. It was surprisingly easy to connect to the PC via USB and write files to the Winbond flash memory. The methods and programmers in other answers are probably just as good, some more expensive or DIY, but this is a cheap and simple way that fits what I was seeking.
Here's a picture of the setup:
The FlashCAT programmer is at left, connected to USB. It's running the SPI programming firmware (as opposed to JTAG) and supplying power to the flash memory. The supplied power is selectable (3.3V or 5V) with a jumper.
I have a SOIC to DIP socket on the breadboard to make it easy to program multiple chips. (You can see another flash memory IC sitting on the breadboard as well.)
I haven't yet converted my audio file to the proper binary format, but I wrote a 211KB WAV file to memory just to test, pictured above. I then read it back and saved it as a new file, renamed it to .wav, and it plays correctly on the PC.
The next step will be to properly encode the file, and write the AVR software to read the data and send it through a DAC.
Disclaimer: I am not affiliated with Embedded Computers, I'm just a customer who picked something inexpensive and am sharing information about the experience with the product.
Kind of late to the discussion, but for anyone reading it after a search..
One thing I did not see mentioned, which is absolutely critical when programming SPI Flash chips is control of the Chip Select (CS_) pin. The Chip Select pin is used to punctuate commands to the SPI Flash. In particular, a transition from CS_ high to CS_ low must immediately precede the issuance of any Write operation op code (WREN, BE, SE, PP). If there is activity between the CS_ transition (i.e. after CS_ has gone low) and before the write op code is transmitted, the write op code will usually be ignored.
Also, what's not commonly explained in SPI Flash datasheets, because it's an inherent part of the SPI protocol, which is also critical, is that for every byte one transmits on the SPI bus, one receives a byte in return. Also, one cannot receive any bytes, unless one transmits a byte.
Typically, the SPI Master that the user is commanding, has a Transmit Buffer, which sends bytes out on the MOSI line of the SPI bus and a Receive Buffer, which receives bytes in from the MISO line of the SPI bus.
In order for any data to appear in the Receive buffer, some data must have been sent out the Transmit Buffer. Similarly, any time one sends data out of the Transmit buffer, data will appear in the Receive Buffer.
If one is not careful about balancing Transmit writes and Receive reads, one will not know what to expect in the Receive buffer. If the Receive buffer overflow, data is usually just spilled and lost.
So, when one sends a read command, which is a one byte op code and three address bytes, one will first receive four bytes of 'garbage' in the SPI Master Receive buffer. These four bytes of garbage correspond to the op code and three address bytes. While those are being transmitted, the Flash does not yet know what to Read, so it just returns four words of garbage.
After those four words of garbage are returned, in order to get anything else in the Receive Buffer, you must Transmit an amount of data equal to the amount that you want to Read. After the op code and address, it doesn't matter what you transmit, it's just filler to push the Read DAta from the SPI Flash to the Receive Buffer.
If you didn't keep careful track of those first four returned garbage words, you might think that one or more of them is part of your returned Read Data.
So, in order to know what you are actually getting from the receive buffer, it's important to know the size of your buffer, know how to tell whether it's empty or full (there's usually register status bit to report this) and keep track of how much stuff you've transmitted and how much you've received.
Before starting any SPI Flash operation, it's a good idea to 'drain' the Receive FIFO. This means check the status of the receive buffer and empty it (usually done by performing a 'read' of the Receive Buffer) if it is not already empty. Usually, emptying (reading) an already empty Receive Buffer does no harm.
The following information is available from the timing diagrams in datasheets of SPI Flashes, but sometimes folks overlook bits. All commands and data are issued to the SPI flash using the SPI bus. The sequence to read a SPI Flash is:
Note that steps 6 and 7 must be interleaved and repeated depending on the size of the read and the size of your Receive and Transmit Buffers. If you Transmit a larger number of words at one go, than your Receive Buffer can hold, you'll spill some data.
In order to preform a Page Program or Write command perform these steps. Page Size (typically 256 bytes) and Sector Size (typically 64K) and associated boundaries are properties of the SPI Flash you are using. This information should be in the datasheet for the Flash. I will omit the details of balancing the Transmit and Receive buffers.
Finally, if your write address is not on a page boundary (typically a multiple of 256 bytes) and you write enough data to cross the following page boundary, the data that should cross the boundary will be written to the beginning of the page in which your program address falls. So, if you attempt to write three bytes to address 0x0FE. The first two bytes will be written to 0x0fe and 0x0ff. The third byte will be written to address 0x000.
If you transmit a number of data bytes larger than a page size, the earlies bytes will be discarded and only the final 256 (or page size) bytes will be used to program the page.
As always, not responsible for consequences of any errors, typos, oversights, or derangement in the above, nor in how you put it to use.
Contrary to some of the statements here, while there are some quirky SPI PROMs out there, there are also some standard instructions used by a large variety of SPI PROMs, including the one you've chosen.
As vicatcu already mentioned, there are good 'bit-bash' cables available that can directly program SPI. Signal-wise, SPI looks a lot like JTAG, so any bit-bash type of cable should be able to be used provide the interface is open source. The internal protocol of the flash is fairly simple.
We use the big brother of the part you're looking at to boot our FPGA boards (256M - 2G). The addressing has an extra byte to handle the storage volume, but otherwise the commands are basically identical.
The type of PROM you're using has to be erased by sector, then programmed by page. Reading is significantly faster than writing (in the case of the ones we use, programming can take half an hour, but reading the whole PROM takes under a second at 108MHz).
Now for the commands: There are way more commands available in these devices than are actually required to program them. You actually only need the following:
- RDID (read ID) - just to verify the PROM and signalling before you do anything more complex.
- WREN (write enable) - needed before every write.
- PP (0x02 - page program) - needed to program a page.
- SE (0x20 - sector erase) - returns bits in sector to '1'.
- RDSR (0x05 - read status register) - needed to monitor erase / write cycle.
- FREAD (0x0B - fast read) - read PROM data and verify write.
If you want more information look at answer notes on SPI programming for Xilinx FPGAs on their website (http://www.xilinx.com). They implement a reduced subset of commands so their FPGAs can boot from these devices.
I designed my own programmer to do this based on what I have available and wrote a programmer script in Python, but you can do the same using a cable. In your case, I would seriously consider doing everything indirectly through the MCU as Michael Karas suggests. You don't need to program the whole PROM from the MCU in one go - you can do it by sector.
You should be able to re-purpose the USBtiny to program a flash memory instead of a target MCU if you are comfortable changing it's programming. However, there may not be enough memory on that to make it versatile enough to program both the MCU and the flash.
Somewhere I have a board from a project which has both an ATTINY and an SPI flash, and uses as an Arduino as a readily available 'programmer'. A slight modification of the ISP sketch is used to program the MCU with avrdude, then a custom utility sends a sequence which puts the sketch in a special mode and writes blocks of data to the SPI flash.
protected by Community♦Feb 1 '17 at 12:40
Thank you for your interest in this question. Because it has attracted low-quality or spam answers that had to be removed, posting an answer now requires 10 reputation on this site (the association bonus does not count).
Would you like to answer one of these unanswered questions instead?
Not the answer you're looking for? Browse other questions tagged spiprogrammingflash or ask your own question.
Serial EEPROM Programmer
Very useful software for reading and writing 93Cxx, 24Cxx, and 24Wxx series EEPROMs. Needs only a very simple hardware, connects to parallel or serial port.It is just a simple software for testing and programming serial EEPROMs using the PC parallel or serial port. Supply voltage +5V is taken directly from the port. Warning - some parallel ports can't be used this way.
- Publisher: Zdenek Janovsky
- Home page:hw-server.com
- Last updated: May 29th, 2012
93Cx6 Programmer
93Cx6 Programmer is a software designed for writing/reading Serial Microwire BUS EEPROM.The interface is actually a DB25 jack , an 8 pin socket and a capacitor.The application was tested on Intel P3 / P4 / Win98 / WinXP / 93c46, 93LC46, 93C86.93Cx6 Programmer is a freeware.
- Publisher: underc0de
- Home page:underc0de.superbit.ro
- Last updated: October 3rd, 2011
Serial Port PIC Programmer
The PIC programmer presented here uses PC's serial port for communication between the programming software and simple PIC programmer hardware.Serial Port PIC Programmer software is very easy to use and works on all Windows platforms.Here is the list of currently supported flash devices from Microchip PICmicro 12F and 16F product lines: 12F629, 12F675,etc.
- Publisher: Oshon Software
- Home page:www.oshonsoft.com
- Last updated: March 31st, 2008
Topview Programmer A
The Topview Programmer A maintains separate buffer areas for selected device’s flash memory, Program Encryption Table, User parameter Table, Serial EEPROM in the programming environment. Initially you need to transfer your target program code/data from the files into this buffer and then program the selected device with these buffer contents.
- Publisher: Frontline Electronics Pvt Ltd. Salem. India.
- Home page:www.frontline-electronics.com
- Last updated: May 19th, 2008
SEEVAL 32
It includes everything to quickly develop a reliable Serial EEPROM design.Features:- Windows 95/98, ME, NT, 2000, and XP-Total Endurance™ software model-SEEVAL 32 developer board-SEEVAL 32 user interface software-RS-232 serial cable-Power supply-Serial EEPROM sample pack-SEEVAL 32 Quick Start Guide
- Publisher: Microchip Technology Inc.
- Last updated: March 18th, 2010
Hex100
Hex100 is a serial programmer.Features:· Connects to IBM PC, Notebook, through Serial Port· Programs Atmel Microcontrollers and Serial EEPROM’s· No separate adapters required· Free software updates through web site· Windows based software compatible with Win9X
- Publisher: Core Technologies
- Last updated: April 27th, 2012
PICkit2
With Microchip’s powerful MPLAB Integrated Development Environment (IDE) the PICkit™ 2 enables in-circuit debugging on most PIC® microcontrollers. In-Circuit-Debugging runs, halts and single steps the program while the PIC microcontroller is embedded in the application. When halted at a breakpoint, the file registers can be examined and modified.
- Publisher: Microchip
- Home page:www.microchip.com
- Last updated: January 31st, 2012
Total Endurance
Microchip's Total Endurance™ Software Disk provides electronic systems designers with unprecedented visibility into Serial EEPROM-based applications. Now designers can describe their system to an advanced mathematical model (with a very friendly human interface) which will then predict the performance and reliability of the Serial EEPROM within that environment.
- Publisher: Microchip Technology Inc.
- Home page:www.microchip.com
- Last updated: March 11th, 2012
XPROG-box Software
The XPROG-box project is a continuation of the project XPROG that supports more than 450 units (serial EEPROM`s, Microcontrollers (MCU), Electronics Control Units (ECU), DashBoards, Immobilizers, Calculators and others). The program includes a high speed RS232 communication interface, fully compatible with USB0001RS232 adapter and much more.
- Publisher: ELDB Software
- Home page:www.eldb.eu
- Last updated: January 9th, 2018
PICkit 1 Signal Analysis
When combined with PICkit 1 firmware and the signal-analysis PC program, the Signal Analysis PICtail Daughter Board can perform signal-analysis capabilities such as: real-time strip chart, oscilloscope, Fast Fourier Transformation (FFT), histogram and programming. The Signal Analysis PICtail Daughter Board comes populated with a PIC16F684 and two 25LC640 SPI™ compatible serial EEPROM memory.
- Publisher: Microchip Technology Inc.
- Home page:www.microchip.com
- Last updated: April 11th, 2008
EE-Prog
EE-Prog is an USB 24 series EEPROM programmer. Its Hardware is based on AVR ATMega8 microcontroller.Feature:-Support USB 1.1- Support all 24c EEPROM (24c01 - 24c1024) (no Auto Detect yet, Please Help!)- Adjustable TWI Speed (100 KHz-1MHz)- Read - Write - Verify- Reading and writing at speed of ~ 5-6 Kbytes/s
- Publisher: Amir Khorsandi
- Last updated: July 4th, 2013
PE ICS08GPGTZ In-Circuit Simulator
This software package allows you to program and debug ICS08 devices. P&E offers ICS08 software packages, as well as the PROG08SZ interactive programmer package, for a broad range of HC08 parts. The PROG08SZ contains both the PROG08SZ Interactive MON08 Flash/EEPROM Programmer, and the ICD08SZ Real Time In-Circuit Debugger.
- Publisher: P&E Microcomputer Systems
- Home page:www.pemicro.com
- Last updated: August 20th, 2015
ISP Programmer
This software supports programming of Atmel microcontrollers 89Sxx ('51), ATtiny, ATmega and 90Sxx (AVR). It can erase built-in Flash and EEPROM memories as well as read and program them. ISP Programmer also supports serial Atmel DataFlash memories. Communication with devices is made serially in system without the need to pull the chip out of the socket or desolder it.
- Publisher: Adam Dybkowski
- Last updated: December 3rd, 2011
PonyProg2000
Ponyprog is very powerful and popular microchip programmer. Ponyprog enables the user to program EEPROM, FLASH and PIC's using user friendly tools and multiple programmer types.Ponyprog supports AVR, SPI eeprom, AVR micro, 12C bus 8bit eeprom, PIC 16 micro, PIC 12 micro, AT89S micro and SDE2506 eeprom family chips.
- Publisher: Claudio Lanconelli
- Home page:ponyprog.sourceforge.net
- Last updated: August 2nd, 2017
Khazama AVR Programmer
The goals of this program is a nice small, fast, reliable and simple to use program.You can set your settings according to your project. this steps will execute after you push 'Auto Program' button on the main window or press CTRL+P shortcut.Fuses and Lock window help you to set settings for AVR chips.
- Publisher: Behzad khazama
- Last updated: July 17th, 2011
PICPgm Development Programmer
PICPgm is an app designed to program PIC microcontrollers using an external programmer hardware connected to the PC. Ablebits ultimate suite. The program allows you to: check if a PIC microcontroller is empty, program a HEX file into a PIC microcontroller, erase a PIC microcontroller, read the content of a PIC microcontroller and save it to a HEX file.
- Publisher: Christian Stadler
- Home page:picpgm.picprojects.net
- Last updated: December 3rd, 2017
Device Programmer Desktop
Device Programmer Desktop is designed to replace the earlier version of XPROG™ programmer.Device Programmer Desktop is fully upwardcompatible hardware with XPROG™ programmer and have many additional features. The Device Programmer Desktop supports in circuit and on board programming 68HC05,68HC08, 68HC11, 68HC(S)12, TMS370, AVR, ATMEGA, PIC,SPI, EEPROM and FLASH memories.
- Publisher: DB Software
- Last updated: March 1st, 2012
KDI universal programmer
The KDI Universal Programmer 3.0 is a professional low cost parallel programmer, covering most of the classic and mega AVR 8-bit RISC microcontrollers, both I2C and Microwire serial EEPROMs and also MCS-51 family of Atmel corporation. The programmer connects to the PC through a standard parallel port and programs the supported chips via a very user friendly software.
Serial Flash Memory
- Publisher: KDI