

## **Generic Soft SPI Master Controller Demo**

## **User Guide**



#### **Disclaimers**

Lattice makes no warranty, representation, or guarantee regarding the accuracy of information contained in this document or the suitability of its products for any particular purpose. All information herein is provided AS IS and with all faults, and all risk associated with such information is entirely with Buyer. Buyer shall not rely on any data and performance specifications or parameters provided herein. Products sold by Lattice have been subject to limited testing and it is the Buyer's responsibility to independently determine the suitability of any products and to test and verify the same. No Lattice products should be used in conjunction with mission- or safety-critical or any other application in which the failure of Lattice's product could create a situation where personal injury, death, severe property or environmental damage may occur. The information provided in this document is proprietary to Lattice Semiconductor, and Lattice reserves the right to make any changes to the information in this document or to any products at any time without notice.



#### **Contents**

| Acronyms in This Document                                                    | Δ  |
|------------------------------------------------------------------------------|----|
| 1. Introduction                                                              |    |
| Functional Description                                                       |    |
| 3. Demo Procedure                                                            |    |
| 3.1. Demo Directory Structure                                                |    |
| 4. Jumper Settings                                                           |    |
| 5. Programming the Board                                                     |    |
| 6. Demo Procedure                                                            |    |
| 7. Customization                                                             |    |
| Appendix A. Simulation Procedures Using the DO file                          |    |
| Appendix B. Port Assignments                                                 |    |
| References                                                                   |    |
| Technical Support                                                            |    |
| Revision History                                                             |    |
| Figure 1.1. MachXO3-9400 Development Board                                   |    |
| Figure 6.2. SPI Master Control Switches                                      |    |
| Figure 6.3. SPI Transaction Waveform During Device ID Command (S25L116K)     |    |
| Figure 6.4. SPI Transaction Waveform During Write Enable Command (S25L116K)  |    |
| Figure 6.5. SPI Transaction Waveform During Write Data Command (S25L116K)    |    |
| Figure 6.6. SPI Transaction Waveform During Read Data Command (S25L116K)     |    |
| Figure 6.7. SPI Transaction Waveform During Block Erase Command (S25L116K)   |    |
| Figure 6.8. SPI Transaction Waveform During Write Disable Command (S25L116K) |    |
| Figure 7.1. Compiler Directives Customization Example                        |    |
| Figure A.1. SIM_TEST Commented-Out in the <i>tb_defines.v</i> Source File    |    |
| Figure A.2. Changing the Simulation Directory                                |    |
| Figure A.3. Running the Simulation File                                      | 17 |
| Figure B.1. MachXO3 Port Assignment Using Diamond Spreadsheet View           |    |
| Tables Table 4.1. MachXO3-9400 Development Board Jumper Settings             | 13 |
| Table 6.2. Slave Address Options                                             |    |
| Table 7.1. Compiler Directives                                               | 15 |



# **Acronyms in This Document**

A list of acronyms used in this document.

| Acronym | Definition                    |
|---------|-------------------------------|
| FPGA    | Field-Programmable Gate Array |
| LED     | Light-emitting Diode          |
| SCLK    | Serial Clock Signal           |
| SPI     | Serial Peripheral Interface   |
| SS      | Slave Select                  |
| USB     | Universal Serial Bus          |



## 1. Introduction

This document describes the setup procedures for the Generic Soft SPI Master Controller reference design demo using a MachXO3™-9400 Development Board to demonstrate simple transactions to an external SPI Flash device.

Figure 1.1 shows the MachXO3-9400 development board (LCMXO3LF-9400C-ASC-B-EVN) with an on-board external SPI Flash (Cypress S25L116K). This demo is not limited to this evaluation board and can be programmed into a wide array of Lattice FPGAs such as MachXO2™, MachXO3, LatticeECP3™, ECP5™, CrossLink™, CrossLink™-NX, and iCE40 UltraPlus™. Separate design projects are included to make it easier for you to custom fit this demo into their desired evaluation board.

For more information on the specific board used in this demo, visit:

http://www.latticesemi.com/products/developmentboardsandkits/machxo39400devboard.



Figure 1.1. MachXO3-9400 Development Board



### 2. Functional Description

Figure 2.1 shows a simplified block diagram of this demo design. The Serial Peripheral Interface (SPI) bus provides an industry standard interface between processors and other devices and a good choice for designs that require full-duplex capability for sending and receiving data at the same time.



Figure 2.1. SPI Master Controller Demo Block Diagram

This demo implements the Generic Soft SPI Master Controller Reference Design(FPGA-RD-02209) by performing simple transactions to the external SPI Flash device found in the MachXO3-9400 Development Board and can be initiated using the onboard switches. These transactions are device specific, which means that if you are going to use another SPI Slave device, you should look into this slave device's datasheet and follow the proper command and data bytes framing.

You can control the switches located on the lower left portion of the demo board shown in Figure 2.2. To control this demo, you need to set the *ADR\_OPT* switch to tell the SPI Master which *SS\_N[4:0]* pin is going to be utilized (see Table 6.1). The type of transaction can be set using the *Transaction\_Type[2:0]* switches (see Table 6.2). You need to hold the *START\_N* switch button to start a SPI transaction with these selected settings. The Internal User module (*spi\_master\_controller\_demo.v*) is utilizing a preloaded 512-byte EBR (Embedded Block RAM), which the SPI Master Demo design can fetch data from and eventually be sent to the *MOSI* pin during a write command.





Figure 2.2. MachXO3-9400 Development Board Implementation



#### 3. Demo Procedure

The following equipment is required for the demo:

- MachXO3-9400 Development Board (LCMXO3LF-9400C-ASC-B-EVN)
- Jumper wires
- Laptop/PC
- Logic Analyzer
- JED programming file
- USB 2.0 Type A to Mini-B cable
- Lattice Diamond® Programmer version 3.11 or higher

#### 3.1. Demo Directory Structure

The demo design folder contains six subfolders: Bitstream, Docs, Project, Simulation, Source, and Testbench. The details of each subfolder are as follows:

- Bitstream Contains the programming file for the MachXO3-9400 Development Board.
- Project Contains subfolders for each FPGA Family. Each of these subfolders contains either a Diamond or a Radiant™ project file (.LDF and .RDF).
- Simulation Contains subfolders for each FPGA Family. Each of these subfolders contains the simulation file (.DO) used to run RTL simulation on Aldec Active-HDL.
- Source Contains all the Generic Soft SPI Master Demo RTL files.
- Testbench Contains all the testbench files including the SPI Slave (spi slave.v).



Figure 3.1. Packaged Design Directory Structure



## 4. Jumper Settings

Figure 4.1 shows the jumpers used in the demo board.



Figure 4.1. MachXO3-9400 Development Board Jumper Settings

Table 4.1. MachXO3-9400 Development Board Jumper Settings

| Jumper | Description        | Settings                                                                |
|--------|--------------------|-------------------------------------------------------------------------|
| JP11   | 12 MHz Oscillator  | Default short (OSC connected)                                           |
|        |                    | Alternate open (OSC unconnected)                                        |
|        |                    | When the 12 MHz external oscillator is intended to be used, you need to |
|        |                    | uncomment the EXT_CLK compiler directive mentioned in Table 7.1.        |
| JP8    | SPI Flash SS_N Pin | Default short (SS_N[0] pin of the SPI Flash is connected to the FPGA).  |
| _      | _                  | All other jumpers should be kept open.                                  |



## 5. Programming the Board

To program the MachXO3-9400 development board:

1. Launch Diamond Programmer with Create a new blank project.



Figure 5.1. Create a New Blank Project

2. Select MachXO3LF for Device Family and LCMXO3LF-9400C for Device.



Figure 5.2. Device Selection

3. Right-click and select **Device Properties** and apply the settings as shown in Figure 5.3.



**Figure 5.3. Device Properties** 

© 2020 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.



- 4. Click **OK** to close the Device Properties window.
- 5. Click the **Program** button in the Diamond Programmer to start the Programming sequence.
- 6. When programming is successful, the output console displays the message shown on Figure 5.4. If programming fails, press **Detect Cable** in the right pane of the programmer as shown in Figure 5.5.



Figure 5.4. Output Console



Figure 5.5. Detect Cable Button



#### 6. Demo Procedure

To run the demo:

1. Connect the logic analyzer probes to the SPI signals (SS\_N[0], SCLK, MOSI, and MISO). Ensure that the board and the logic analyzer has a common ground connection.



Figure 6.1. SS\_N[0], SCLK, MOSI, MISO, and GND Connection Guide

- 2. Power up the board by using the USB Cable. D4 LED blinks if the board has been properly programmed.
- 3. Using Figure 6.2 and Table 6.1 as a guide, put ADR\_OPT switch to 0 (down) so that the SPI Master uses SS\_N[0] during a SPI transaction.
- 4. Using Figure 6.2 and Table 6.2 as a guide, select the desired transaction type and press START\_N until a SPI transaction is registered in the logic analyser as shown in Figure 6.3, Figure 6.4, Figure 6.5, Figure 6.6, and Figure 6.7.



Figure 6.2. SPI Master Control Switches



**Table 6.1. Slave Address Options** 

| ADR_OPT | SS_N[4:0] Bit to be Used* |
|---------|---------------------------|
| 0       | SS_N[0]                   |
| 1       | SS_N[1]                   |

\*Note: SS\_N[4:2] are not used in this demo.

**Table 6.2. Slave Address Options** 

| Transaction_Type[2] | Transaction_Type[1] | Transaction_Type[0] | Command Name             | First Byte Instruction <sup>1</sup> |
|---------------------|---------------------|---------------------|--------------------------|-------------------------------------|
| 0                   | 0                   | 0                   | Device ID                | 90h                                 |
| 0                   | 0                   | 1                   | Write Enable             | 06h                                 |
| 0                   | 1                   | 0                   | Write Disable            | 04h                                 |
| 0                   | 1                   | 1                   | Write Data               | 02h                                 |
| 1                   | 0                   | 0                   | Read Data                | 03h                                 |
| 1                   | 0                   | 1                   | Block Erase <sup>2</sup> | D8h                                 |

#### Notes:

- Byte instruction may vary across different slave devices. This demo design is using the instructions for Cypress S25L116K SPI Flash. Refer to the datasheet for more info.
- 2. Block Erase can only be performed after performing Write Enable command. After successfully performing the Block Erase command, the SPI flash automatically locks the device to prevent writing (Write Disable).



Figure 6.3. SPI Transaction Waveform During Device ID Command (S25L116K)



Figure 6.4. SPI Transaction Waveform During Write Enable Command (S25L116K)



Figure 6.5. SPI Transaction Waveform During Write Data Command (S25L116K)



Figure 6.6. SPI Transaction Waveform During Read Data Command (S25L116K)



Figure 6.7. SPI Transaction Waveform During Block Erase Command (S25L116K)



Figure 6.8. SPI Transaction Waveform During Write Disable Command (S25L116K)



## 7. Customization

To customize this demo design, a file named *tb\_defines.v* in the testbench folder contains all the compiler directives that you can modify. This includes device selection, slave addresses settings, clock source, clock speed, and others. Table 7.1 shows the complete list of compiler directives. Figure 7.1 shows an example of customization implemented in the *tb\_defines.v* file.

**Table 7.1. Compiler Directives** 

| Category                 | Compiler Directives | Remarks                                                                                                                                                                                                                                                                                            |  |
|--------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Simulation Test          | SIM_TEST            | Uncomment to enable simulation. This disables the debounce logic and shorten the time needed before waveforms are displayed during simulation. When generating a bitstream, you should comment this out to enable the debounce logic and prevent spurious SPI transactions in the actual hardware. |  |
|                          | ECP3                |                                                                                                                                                                                                                                                                                                    |  |
|                          | ECP5                | 7                                                                                                                                                                                                                                                                                                  |  |
|                          | LIFMD               | 1                                                                                                                                                                                                                                                                                                  |  |
| Device Selection         | LIFCL               | Uncomment only one to enable the selected device. The                                                                                                                                                                                                                                              |  |
|                          | MachXO2             | default for this demo is MachXO3.                                                                                                                                                                                                                                                                  |  |
|                          | MachXO3             | 1                                                                                                                                                                                                                                                                                                  |  |
|                          | iCE40 UltraPlus     |                                                                                                                                                                                                                                                                                                    |  |
| Slave Selection          | SLAVE_A             | Defines the input for the <i>i_SS_cfg</i> port and determines whi bit of the <i>SS_N[4:0]</i> is activated during a SPI transaction. In this demo, the ADR OPT switch determines whether                                                                                                           |  |
|                          | SLAVE_B             | SLAVE_A (SS_N[0]) or SLAVE_B (SS_N[1]) is used in the SPI transaction.                                                                                                                                                                                                                             |  |
|                          | SPI_MODE_0          |                                                                                                                                                                                                                                                                                                    |  |
| SPI Mode                 | SPI_MODE_1          | Uncomment only one to enable the selected SPI Mode with defined CPOL and CPHA combinations. The default for this                                                                                                                                                                                   |  |
| 3FT WIOGE                | SPI_MODE_2          | demo is SPI_MODE_0.                                                                                                                                                                                                                                                                                |  |
|                          | SPI_MODE_3          |                                                                                                                                                                                                                                                                                                    |  |
| Clock Selection          | EXT_CLK             | Uncomment if external clock is desired. If internal clock is selected, only select 24 MHz in the Clock Speed selection.  The default for this demo is using the internal oscillator (EXT_CLK is commented out).                                                                                    |  |
|                          | CLK_12MHZ           | Uncomment only one to enable the selected clock speed. If                                                                                                                                                                                                                                          |  |
| Clock Speed Selection    | CLK_24MHZ           | the desired clock speed is not in the selection, you need to                                                                                                                                                                                                                                       |  |
|                          | CLK_32MHZ           | modify the testbench. The default for this demo is 24 MHz.                                                                                                                                                                                                                                         |  |
| SCLK Frequency Selection | CLOCK_SEL           | Generates the SCLK clock frequency in terms of system clock cycles using the formula:  SCLK=clk/2*(CLOCK_SEL+1)  Allowable value is from 0 to 255.                                                                                                                                                 |  |
| Byte Interval            | BYTE_INTERVAL       | Defines the interval between SPI data bytes in terms of system clock cycles. Allowable value is from 1 to 255.                                                                                                                                                                                     |  |
| SS to SCLK Interval      | SS_SCLK_INTERVAL    | Defines the interval between the SS_N assertion to zero and the first SCLK edge. Allowable value is from 1 to 255.                                                                                                                                                                                 |  |
| SCLK to SS Interval      | SCLK_SS_INTERVAL    | Defines the interval between the SS_N deassertion to high and the last SCLK edge. Allowable value is from 1 to 255.                                                                                                                                                                                |  |



```
//`define SIM TEST
// (Uncomment the selected device.)
 //`define ECP3
 //`define ECP5
 //`define XO2
 `define XO3
 //'define Ultraplus
// Slave Selection
 // (Defines Wh)
 'define SLAVE_A 5'b00001
'define SLAVE_B 5'b00010
// SPI Mode
// (Enter the desired value.)
 'define DIRECTION 1'b0 // 1'b0 = MSB First, 1'b1 = LSB First
//`define EXT_CLK // Only select 24MHz in the Clock Speed Selection when using the internal oscillator.
// Clock Speed Selection
 // (Uncomment the selected clock speed.)
 // ******************
 'define CLK_24MHZ
 //`define CLK 32MHZ
// SPI Clock and Tiiming Parameters
 // (Enter the desired value).)
 'define CLOCK_SEL 1 // From 0 to 255. SCLK=clk/2*(CLOCK_SEL+1)
'define BYTE_INTERVAL 1 // From 1 to 255. Defines the interval between SPI data bytes in terms of
'define SS_SCLK_INTERVAL 1 // From 1 to 255. Defines the interval between the SS_N assertion to low a
 'define SCLK_SS_INTERVAL 1 // From 1 to 255. Defines the interval between the SS_N deassertion to hig
```

Figure 7.1. Compiler Directives Customization Example



## Appendix A. Simulation Procedures Using the DO file

To use the simulation DO file, perform the following steps:

1. Before running the simulation, make sure *SIM\_TEST* is not commented out in the *tb\_defines.v* source as shown in Figure A.1.

```
1 // Simulation Test
3 // (Uncomment to enable simulation.)
4 define SIM_TEST
```

Figure A.1. SIM\_TEST Commented-Out in the tb\_defines.v Source File

2. Open the DO file on a text editor and replace the text **<ENTER simulation DIRECTORY PATH HERE>** from Line 1 with the directory path of the simulation file. An example is seen on Line 4 of the file.

```
| tl_verlog.do \( \) | 1 | set SIM_DIR "<ENTER simulation DIRECTORY PATH HERE>" | 2 | 3 | Example: | 4 | set SIM_DIR "D:/Generic_Soft_SPI_Master_Controller_Demo/Simulation/XO3"
```

Figure A.2. Changing the Simulation Directory

3. Run the file on Aldec Active-HDL by selecting *Execute macro...* under the **Tools** option.



Figure A.3. Running the Simulation File



## **Appendix B. Port Assignments**

Most of the projects included in this demo have no port assignments. You should manually assign them based on their selected device and package option. However, the included demo bitstream (SPI\_Master\_Demo-XO3.jed) is compiled using the port assignments and settings as shown in Figure B.1.



Figure B.1. MachXO3 Port Assignment Using Diamond Spreadsheet View



### References

For more information, refer to the following documents:

- LatticeECP3 EA Family Data Sheet (DS1021)
- ECP5 and ECP5-5G Family Data Sheet (FPGA-DS-02012)
- CrossLink Family Data Sheet (FPGA-DS-02007)
- CrossLink-NX Family Data Sheet (FPGA-DS-02049)
- MachXO2 Family Data Sheet (DS1035)
- MachXO3 Family Data Sheet (FPGA-DS-02032)
- iCE40 UltraPlus Family Data Sheet (FPGA-DS-02008)
- Generic Soft SPI Master Controller (FPGA-RD-02209)



# **Technical Support**

For assistance, submit a technical support case at www.latticesemi.com/techsupport.

20



# **Revision History**

#### Revision 1.0, December 2020

| Section | Change Summary  |
|---------|-----------------|
| All     | Initial release |



www.latticesemi.com