

# **Post Configuration Access To SPI Flash**

A KCPSM6 Reference Design for the KC705 Evaluation Board

#### **Ken Chapman**

18th March 2013 - Initial Release

14th November 2013 - Minor corrections

### **Disclaimer**

#### **Notice of Disclaimer**

Xilinx is disclosing this Application Note to you "AS-IS" with no warranty of any kind. This Application Note is one possible implementation of this feature, application, or standard, and is subject to change without further notice from Xilinx. You are responsible for obtaining any rights you may require in connection with your use or implementation of this Application Note. XILINX MAKES NO REPRESENTATIONS OR WARRANTIES, WHETHER EXPRESS OR IMPLIED, STATUTORY OR OTHERWISE, INCLUDING, WITHOUT LIMITATION, IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT, OR FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT WILL XILINX BE LIABLE FOR ANY LOSS OF DATA, LOST PROFITS, OR FOR ANY SPECIAL, INCIDENTAL, CONSEQUENTIAL, OR INDIRECT DAMAGES ARISING FROM YOUR USE OF THIS APPLICATION NOTE.

Copyright © 2012-2013, Xilinx, Inc.

This file contains proprietary information of Xilinx, Inc. and is protected under U.S. and international copyright and other intellectual property laws.



## This Document and Reference Design

The primary purpose of this document is to provide images to supplement the descriptions contained in the source VHDL and PSM code provided with this reference design.

It is assumed that you already have a copy of the KCPSM6 variant of PicoBlaze and are familiar with using it. In particular, this reference design builds on the UART based reference designs provided in the KCPSM6 package so this document focuses on the additions specific to SPI Flash memory.

The reference design is presented on the Kintex-7 KC705 Evaluation Kit. Except for the special requirements associated with the set up of the board, the reference design itself should provide a valid starting point for any 7-Series based design and it is hoped that the SPI related source can be reused.

The SPI Flash memory on the KC705 Evaluation Kit is a Micron/Numonyx N25Q128 device. The source code provided is therefore written to work with this device but it would also be expected to work with similar SPI Flash memory devices from other manufacturers. Most Flash memory devices appear to be the same with respect to general communication and read operations. The differences tend to relate to the internal organization of the flash memory (e.g. the size and number of sectors), the write and the erase operations. Even so, the source code provided should still provide a good starting point.

I do hope you find this reference design useful. Please provide any feedback related to this reference design (good or bad) to...

chapman@xilinx.com



## **Overview of Reference Design**

The design implements a bridge between the user of a terminal (PicoTerm) and the N25Q128 Flash memory on the KC705 board. Whilst the primary focus of this reference design is the ability to communicate with and control the N25Q128 using KCPSM6 (PicoBlaze), inclusion of the USB/UART link in the design makes it possible for direct user interaction including reading, writing and erasing operations to be invoked and observed.

Please be aware that the PSM code provided consists in total of 1604 instructions but the vast majority of these are related to user interaction. In fact, over 1150 instructions are directly associated with the generation of text massages. For this reason it is useful to know immediately that all the fundamental SPI communication and Flash memory operations are actually implemented by just 94 instructions and this is isolated in the 'N25Q128\_SPI\_routines.psm' file to make it easy to locate and for future reuse in your own designs.



The design operates at 100MHz but there is nothing significant about the SPI communication that requires this frequency. As provided, the SPI interface achieves a bit rate equal to the clock frequency divided by 24 (e.g. 3.57 Mbit/s with 100MHz clock). Depending on device type and speed grade, KCPSM6 can be used with a clock up to ~240MHz.



# KC705 Setup & SPI Flash Connections

The Micron/Numonyx N25Q128 device is a 128M-bit (16M-Byte) SPI Flash memory which is connected to the Kintex-7 device on the KC705 board. Its primary purpose is to hold a configuration image that would be automatically loaded by the Kintex-7 device operating in Master SPI Mode. For this reason the Flash memory is connected to the pins specifically required for such configuration.

However, with the KC705 being an 'evaluation kit', it also provides a parallel Flash memory and the capability to use a Master BPI Mode for configuration. Unsurprisingly there are some DIP switches that you use to select the mode. Less obvious, is that when you select the mode you also steer a control signal on the board to either the SPI Flash or the Parallel Flash. In other words, only the intended type of Flash memory is connected to the Kintex-7 device. Therefore, the DIP switches must be set to Master SPI Mode otherwise the reference design will not be able to access the SPI Flash memory after configuration.

Hint – Failing to set the DIP switches to Master SPI mode is an easy mistake to make initially because you nearly always use JTAG configuration in conjunction with iMPACT during your first experiments and design development cycles. Note that you can set the Master SPI mode permanently because JTAG configuration will always be possible (i.e. switches do not need to be set to "101" to use JTAG).

DIP switches SW13 must be set to Master SPI Mode.



'Classic' 4-Wire SPI Communication (reusing configuration pins)





## **Connecting KCPSM6 to SPI Pins**

For clarity this diagram only shows the ports assigned to drive and monitor the SPI signals in the reference design.

KCPSM6 drives 'spi\_clk', 'spi\_cs\_b' and 'spi\_mosi' with a single output port and reads 'spi\_miso' with a single input port. The only special requirement relates to the fact that 'CCLK' is a dedicated configuration pin on the device and can only be accessed after configuration by using the STARTUPE2 primitive. Note that only the 'USRCCLKO' and 'USRCCLKTS' inputs to this primitive are used for this purpose and the other controls and signals are available for other purposes. As provided, the remaining controls are connected to '0' or '1' such that they have no affect on normal operation.



## **User Terminal UART Macros**

For clarity this diagram only shows the ports assigned to connect to the UART macros used to communicate with the user at 115,200 baud.

For more information about this part of the design please see the documentation provided with KCPSM6 and the UART6 macros.





### **SPI Fundamentals**

In this situation KCPSM6 is the SPI bus master and the N25Q128 Flash Memory is the slave. The following diagram illustrates the key points of any SPI transaction and could actually be an 'RDSR' instruction reading the status byte from the Flash memory.





## **SPI Communication Code**

Hint - This page is provided mainly for educational purposes because SPI provides a good example of 'bit banging' of signals to implement an interface.

The 'N25Q128\_SPI\_routines.psm' file provides a set of routines that implement the fundamental SPI communication as well as complete N25Q128 transactions. In most cases you should be able to reuse this code as provided or only need to enhance the N25Q128 transactions. Shown below is the routine that implements the SPI communication to transmit and receive each byte. Whilst it is unlikely that you would need to adjust this low level code it is a nice example of 'bit banging' code, defines the SPI timing relative to the system clock and completes the description of the SPI signaling in this document.



## **SPI Transaction**

The oscilloscope waveforms shown below were captured from the 'J7' header (SPI EXT) on the KC705 board and show an 'RDID' transaction (execution of the 'read\_spi\_flash\_ID' routine in 'N25Q128\_SPI\_routines.psm').



This 4-bytes transaction ('RDID' instruction and 3-byte response) consisted of 32 clock pulses and bits of information and completed in ~9µs which is approximately 3.56Mbps as expected from the PSM code.

Whilst the N25Q128 is responding with information on 'spi\_miso' the 'spi\_mosi' is ignored. Due to being full-duplex, KCPSM6 has to transmit something on 'spi\_mosi' but anything can be present in these 'dummy bytes' (as they are commonly called). In this case the dummy bytes happen to be a delayed copy of data received.



## Reference Design Files

All source files contain detailed descriptions and comments. In fact, the descriptions and comments in the source code should be considered the *main* documentation for this reference design with this PDF mainly used to provide an introduction and complementary graphics.

#### **Hardware Definition**



Files shown in grey are provided in the KCPSM6 package and should be copied and added to your project directory

Hint – The 'n25q128\_spi\_uart\_bridge.vhd' file is not provided. Assemble the PSM code in the normal way to generate this file.



## N25Q128 Device ID

Probably the best thing to do first when communicating with any device is to attempt to read a known value. The N25Q128 Flash Memory can a identification code that can be read using the 'RDID' instruction. The reference design does attempt to read this value as part of its initialisation procedure and for the purposes of this reference design it even displays the values read.



Reference Design: SPI Flash Memory Controller on KC705 Board

Memory initially used for device configuration

If KCPSM6 does not read the expected known value then it will display a message and stop.

Assembly Date: 25 Sep 2012 Time: 17:56:24

Assembler Version: v2.31

Hardware Design: A

Reading N25Q128 device ID... 20 BA 18

#### Menu

H - Display this menu

R - Read (Page) W - Write (Byte)

E - Erase (Sector)

<u>Hint</u> - See the 'read\_spi\_flash\_ID' routine in 'N25Q128 SPI routines.psm'.

Reference Design: SPI Flash Memory Controller on KC705 Board
Memory initially used for device configuration

Assembly Date: 25 Sep 2012 Time: 17:56:24

Assembler Version: v2.31

Hardware Design: A

PicoTerm.exe

Reading N25Q128 device ID... FF FF FF

ERROR - Unable to detect N25Q128 device. Please check that 'M0' switch on KC705 board is set to '1'.



## **Read Memory Contents**

Data can be read sequentially from the N25Q128 starting at any location. The reference design actually reads one byte at a time and this effectively represents totally random access.

The reference design allows you to specify any 24-bit address. The design with then read the Page (see box below) in which that location is a part. In this case the design actually makes 256 separate reads from the N25Q128 device but such sequential reading could be optimised if required.

```
Menu
 H - Display this menu
 R - Read (Page)
 W - Write (Bute)
 E - Erase (Sector)
> R
Please enter a 24-bit (6-digit hexadecimal)address > 2751d7
275100
275110
275120
275130
275140
275150
275160
275170
275180
275190
2751A0
2751B0
275100
2751D0
2751E0
2751F0
           Address of first byte displayed on each line.
```

<u>Hint</u> – 2751D7 hex appears to be the last location occupied by a configuration image for the 7K325T device on the KC705 board. Note that means that the first 28 hex (40) Sectors are used.

<u>Hint</u> - See the 'read\_spi\_byte' routine in 'N25Q128 SPI routines.psm'.

The N25Q128 memory is 128Mbits accessed as 16M-Bytes.

Internally the memory is divided into 256 Sectors of 64K-Bytes.

Each Sector is formed of 256 Pages of 256 Bytes.

Hence the 24-bit address can be considered in three parts as follows...

```
address[23:16] = Sector
address[15:9] = Page
address[7:0] = Byte
```



# **Writing Data**

Data can be written to any location but it must be remembered that during a write operation bits can only be changed from '1' to '0'. Therefore in most situations the memory will have been previously erased (all bytes in a sector to FF hex).

The reference design allows you to specify any 24-bit address and any 8-bit data value and it will then write that information into the N25Q128 device. In a similar way to reading data, it is also possible to write to the memory sequentially. However, writing is absolutely related to Page boundaries (see box below) so some additional consideration would be required.

```
Please enter a 24-bit (6-digit hexadecimal)address > ff3412
Please enter an 8-bit data (2-diqit hexadecimal) value > 42
> R
Please enter a 24-bit (6-diqit hexadecimal)address > ff3412
FF3400
FF3410
FF3420
FF3430
FF3440
FF3450
FF3460
FF3470
FF3480
FF3490
FF34A0
FF34B0
FF34C0
FF34D0
FF34E0
FF34F0
         FF FF
```

<u>Hint</u> - See the 'write\_spi\_byte' routine in 'N25Q128\_SPI\_routines.psm'.

The N25Q128 memory is 128Mbits accessed as 16M-Bytes.

Internally the memory is divided into 256 Sectors of 64K-Bytes.

Each Sector is formed of 256 Pages of 256 Bytes.

Hence the 24-bit address can be considered in three parts as follows...

```
address[23:16] = Sector
address[15:9] = Page
address[7:0] = Byte
```



> W

# **Erasing a Sector**

In most cases (see N25Q128 data sheet for exceptions) the smallest range of memory that can be erased is a Sector (see box below). This means that 64K-Bytes within the specified sector will be erased (all bytes set to FF hex).

The reference design allows you to specify any 24-bit address. Then the Sector in which that address is located will be erased. Note that a typical sector erase time is ~0.7 seconds so you should be able to see the small delay between entering the last digit of the address and the 'Ok' being displayed.

```
> E
                                                                                                  YOU HAVE BEEN WARNED!
WARNING - This command will erase 64KB (65,536 Butes) of memoru!
            The whole of the sector in which the address falls will be erased.
           Press 'CPU RST' button if you want to stop now!
Please enter a 24-bit (6-digit hexadecimal)address > FF0000
                                                                              FF0000 and FF3412 both fall within the FFxxxx Sector so the
0k
                                                                             previously written data has been erased as have all 65,536 bytes.
> R
                                                                                           Hint - See the 'erase_spi_sector' routine
                                                                                                in 'N25Q128 SPI routines.psm'.
Please enter a 24-bit (6-digit hexadecimal)address > FF3412
FF3400
                                                                            The N25Q128 memory is 128Mbits accessed as 16M-Bytes.
FF3410
FF3420
                                                                            Internally the memory is divided into 256 Sectors of 64K-Bytes.
FF3430
FF3440
                                                                            Each Sector is formed of 256 Pages of 256 Bytes.
FF3450
FF3460
                                                                            Hence the 24-bit address can be considered in three parts as
FF3470
                                                                            follows...
FF3480
FF3490
FF34A0
                                                                                address[23:16] = Sector
FF34B0
                                                                                address[15:9] = Page
FF34C0
                                                                                address[7:0] = Byte
FF34D0
FF34E0
FF34F0
```