



# Octal SPI Controller IP

IP Version: v1.4.0

## User Guide

FPGA-IPUG-02273-1.4

December 2025

## 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, with all faults, and all associated risk is the responsibility entirely of the Buyer. The information provided herein is for informational purposes only and may contain technical inaccuracies or omissions, and may be otherwise rendered inaccurate for many reasons, and Lattice assumes no obligation to update or otherwise correct or revise this information. 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. LATTICE PRODUCTS AND SERVICES ARE NOT DESIGNED, MANUFACTURED, OR TESTED FOR USE IN LIFE OR SAFETY CRITICAL SYSTEMS, HAZARDOUS ENVIRONMENTS, OR ANY OTHER ENVIRONMENTS REQUIRING FAIL-SAFE PERFORMANCE, INCLUDING ANY APPLICATION IN WHICH THE FAILURE OF THE PRODUCT OR SERVICE COULD LEAD TO DEATH, PERSONAL INJURY, SEVERE PROPERTY DAMAGE OR ENVIRONMENTAL HARM (COLLECTIVELY, "HIGH-RISK USES"). FURTHER, BUYER MUST TAKE PRUDENT STEPS TO PROTECT AGAINST PRODUCT AND SERVICE FAILURES, INCLUDING PROVIDING APPROPRIATE REDUNDANCIES, FAIL-SAFE FEATURES, AND/OR SHUT-DOWN MECHANISMS. LATTICE EXPRESSLY DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY OF FITNESS OF THE PRODUCTS OR SERVICES FOR HIGH-RISK USES. 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.

## Inclusive Language

This document was created consistent with Lattice Semiconductor's inclusive language policy. In some cases, the language in underlying tools and other items may not yet have been updated. Please refer to Lattice's inclusive language [FAQ 6878](#) for a cross reference of terms. Note in some cases such as register names and state names it has been necessary to continue to utilize older terminology for compatibility.

# Contents

|                                                            |    |
|------------------------------------------------------------|----|
| Contents .....                                             | 3  |
| Abbreviations in This Document.....                        | 8  |
| 1. Introduction .....                                      | 9  |
| 1.1. Overview of the IP .....                              | 9  |
| 1.2. Quick Facts .....                                     | 9  |
| 1.3. IP Support Summary .....                              | 10 |
| 1.4. Features .....                                        | 10 |
| 1.5. Licensing and Ordering Information .....              | 10 |
| 1.6. Hardware Support.....                                 | 10 |
| 1.7. Naming Conventions .....                              | 10 |
| 1.7.1. Nomenclature.....                                   | 10 |
| 1.7.2. Signal Names .....                                  | 11 |
| 1.7.3. Attribute Names .....                               | 11 |
| 2. Functional Description.....                             | 12 |
| 2.1. IP Architecture Overview .....                        | 12 |
| 2.2. Clocking .....                                        | 13 |
| 2.3. Reset .....                                           | 13 |
| 2.4. User Interfaces .....                                 | 14 |
| 2.4.1. Address Space Mapping .....                         | 15 |
| 2.4.2. Data Byte Order.....                                | 15 |
| 2.5. User Packets.....                                     | 16 |
| 2.5.1. Packet Frame Structure .....                        | 16 |
| 2.5.2. Packet Field Description .....                      | 19 |
| 2.6. Generating SPI Transactions .....                     | 24 |
| 2.6.1. SPI Transfer Modes .....                            | 24 |
| 2.6.2. Data I/O Width .....                                | 24 |
| 2.6.3. DTR Mode.....                                       | 25 |
| 2.6.4. Generic SPI Write/Read Transactions .....           | 25 |
| 2.6.5. Supported Flash Commands .....                      | 27 |
| 2.7. Target Memory Map Access .....                        | 30 |
| 2.7.1. XiP Access .....                                    | 30 |
| 2.7.2. Non-XiP Memory Map Access .....                     | 31 |
| 2.7.3. FIFO Burst Transfer for Indirect Flash Access ..... | 31 |
| 2.8. Flash Controller Sequence Examples .....              | 32 |
| 2.8.1. Flash Erase Command .....                           | 32 |
| 2.8.2. Flash Program Command .....                         | 35 |
| 2.8.3. Flash Read Command.....                             | 37 |
| 3. IP Parameter Description.....                           | 39 |
| 3.1. General.....                                          | 39 |
| 3.2. Flash Device Configuration.....                       | 43 |
| 4. Signal Description .....                                | 45 |
| 5. Register Description .....                              | 51 |
| 5.1. Overview .....                                        | 51 |
| 5.2. Configuration Registers.....                          | 52 |
| 5.2.1. Octal SPI Configuration 0 Register.....             | 52 |
| 5.2.2. Octal SPI Configuration 1 Register.....             | 55 |
| 5.2.3. Supported Command Code 0 Register .....             | 55 |
| 5.2.4. Supported Command Code 1 Register .....             | 55 |
| 5.2.5. Supported Command Code 2 Register .....             | 56 |
| 5.2.6. Supported Command Configuration Register .....      | 56 |
| 5.2.7. Minimum Target Address Alignment Register .....     | 57 |
| 5.2.8. Target Start Address Offset Register .....          | 58 |

|                                                              |    |
|--------------------------------------------------------------|----|
| 5.2.9. Total Target Address Map Alignment Register.....      | 58 |
| 5.2.10. Target AXI4 Base Address Register.....               | 58 |
| 5.2.11. Interrupt Enable Register .....                      | 58 |
| 5.3. Status Registers.....                                   | 59 |
| 5.3.1. Interrupt Status Register .....                       | 59 |
| 5.3.2. Generic SPI Command Packet Counter Register .....     | 61 |
| 5.3.3. Supported Flash Command Packet Counter Register ..... | 61 |
| 5.3.4. Octal SPI Debug Information 0 Register .....          | 61 |
| 5.3.5. Octal SPI Debug Information 1 Register .....          | 62 |
| 5.4. Control Registers.....                                  | 62 |
| 5.4.1. Tx FIFO Register.....                                 | 62 |
| 5.4.2. Rx FIFO Register.....                                 | 62 |
| 5.4.3. Packet Header 0 – 3 Registers .....                   | 63 |
| 5.4.4. Write Data Register .....                             | 63 |
| 5.4.5. Read Data Register .....                              | 63 |
| 5.4.6. Start Transaction Register .....                      | 63 |
| 5.4.7. Interrupt Set Register .....                          | 64 |
| 5.4.8. Test Mode Register .....                              | 65 |
| 5.4.9. Soft Reset Register .....                             | 65 |
| 5.4.10. IO Delay Control Register .....                      | 66 |
| 6. Example Design.....                                       | 67 |
| 6.1. Example Design Configuration .....                      | 67 |
| 6.2. Example Design Components.....                          | 69 |
| 6.3. Generating the Example Design .....                     | 69 |
| 6.3.1. Creating the Octal SPI Controller SoC Project .....   | 69 |
| 6.3.2. Importing the Design to Radiant Software .....        | 72 |
| 6.3.3. Creating a C/C++ Project .....                        | 72 |
| 6.4. Hardware Testing .....                                  | 73 |
| 7. Designing with the IP .....                               | 77 |
| 7.1. Generating and Instantiating the IP .....               | 77 |
| 7.1.1. Generated Files and File Structure .....              | 80 |
| 7.2. Design Implementation.....                              | 80 |
| 7.3. Timing Constraints .....                                | 81 |
| 7.4. Running Functional Simulation .....                     | 81 |
| 7.4.1. Simulation Results .....                              | 84 |
| 8. Design Considerations .....                               | 85 |
| 8.1. Design Considerations in Propel-Based Designs .....     | 85 |
| Appendix A. Resource Utilization .....                       | 86 |
| References .....                                             | 87 |
| Technical Support Assistance .....                           | 88 |
| Revision History.....                                        | 89 |

## Figures

|                                                                                 |    |
|---------------------------------------------------------------------------------|----|
| Figure 2.1. Octal SPI Controller IP Core Functional Diagram .....               | 12 |
| Figure 2.2. Octal SPI Controller IP Clock Domain Block Diagram.....             | 13 |
| Figure 2.3. Octal SPI Controller Address Space Mapping .....                    | 15 |
| Figure 2.4. Generic SPI Command Packet.....                                     | 16 |
| Figure 2.5. Supported Flash Command Packet with 2DW Header .....                | 16 |
| Figure 2.6. Supported Flash Command Packet with 3DW Header .....                | 17 |
| Figure 2.7. Supported Flash Command Packet with 4DW Header .....                | 18 |
| Figure 2.8. SPI Transfer Mode 0 (cpol = 0, cpha = 0) .....                      | 24 |
| Figure 2.9. SPI Transfer Mode 1 (cpol = 0, cpha = 1) .....                      | 24 |
| Figure 2.10. SPI Transfer Mode 2 (cpol = 1, cpha = 0) .....                     | 24 |
| Figure 2.11. SPI Transfer Mode 3 (cpol = 1, cpha = 1) .....                     | 24 |
| Figure 2.12. Byte Transfer across Different I/O Widths.....                     | 24 |
| Figure 2.13. Byte Transfer in DTR Mode across x4 and x8 I/O Widths .....        | 25 |
| Figure 2.14. SPI Write Transaction .....                                        | 25 |
| Figure 2.15. SPI Read Transaction .....                                         | 25 |
| Figure 2.16. SPI Write and Read Transaction with Dummy Cycles.....              | 25 |
| Figure 2.17. Example Command Pattern 0: Read Command (with 2 Dummy Cycles)..... | 28 |
| Figure 2.18. Example Command Pattern 2: Erase Command .....                     | 28 |
| Figure 2.19. Example Command Pattern 3: Page Program Command .....              | 28 |
| Figure 2.20. Example of Target Device Address Mapping .....                     | 30 |
| Figure 6.1. Octal SPI Controller Example Design Block Diagram .....             | 69 |
| Figure 6.2. Lattice Propel Launcher .....                                       | 70 |
| Figure 6.3. Create SoC Project .....                                            | 70 |
| Figure 6.4. Define Instance .....                                               | 71 |
| Figure 6.5. Address Tab .....                                                   | 71 |
| Figure 6.6. Build SoC Project Result.....                                       | 72 |
| Figure 6.7. C/C++ Project Load System and BSP .....                             | 72 |
| Figure 6.8. Build C/C++ Project Result .....                                    | 73 |
| Figure 6.9. Octal SPI Controller SoC Design Block Diagram .....                 | 73 |
| Figure 7.1. Module/IP Block Wizard .....                                        | 77 |
| Figure 7.2. IP Configuration (View 1).....                                      | 78 |
| Figure 7.3. IP Configuration (View 2).....                                      | 78 |
| Figure 7.4. IP Configuration (View 3).....                                      | 79 |
| Figure 7.5. IP Configuration (View 4) .....                                     | 79 |
| Figure 7.6. Check Generated Result .....                                        | 80 |
| Figure 7.7. Adding Existing Simulation File (View 1).....                       | 81 |
| Figure 7.8. Adding Existing Simulation File (View 2).....                       | 81 |
| Figure 7.9. Simulation Wizard (View 1) .....                                    | 82 |
| Figure 7.10. Simulation Wizard (View 2) .....                                   | 82 |
| Figure 7.11. Add and Reorder Source .....                                       | 83 |
| Figure 7.12. Simulation Waveform .....                                          | 83 |
| Figure 7.13. Simulation Results .....                                           | 84 |

## Tables

|                                                                                                                                                   |    |
|---------------------------------------------------------------------------------------------------------------------------------------------------|----|
| Table 1.1. Summary of the Octal SPI Controller IP .....                                                                                           | 9  |
| Table 1.2. Octal SPI Controller IP Support Readiness .....                                                                                        | 10 |
| Table 2.1. User Interfaces and Supported Protocols .....                                                                                          | 14 |
| Table 2.2. Example of Data Byte Order by Data Endianness .....                                                                                    | 15 |
| Table 2.3. Packet Fields – Generic SPI Command Format .....                                                                                       | 19 |
| Table 2.4. Packet Fields – Supported Flash Command Format .....                                                                                   | 21 |
| Table 2.5. Generic SPI Transaction Example: Write 16 Bytes in x8 STR .....                                                                        | 26 |
| Table 2.6. Generic SPI Transaction Example: Read 16 Bytes in x1 STR, with 12 Dummy Cycles .....                                                   | 26 |
| Table 2.7. Generic SPI Transaction Example: Write 5 Bytes in x8 DTR, then Read 8 Bytes in x8 STR, with 2 Dummy Cycles .....                       | 27 |
| Table 2.8. Supported Command Patterns .....                                                                                                       | 27 |
| Table 2.9. Create Supported Flash Command Example: Read 256 Bytes in x1 STR, with 20 Dummy Cycles, Start Address = 0x00_0400 .....                | 28 |
| Table 2.10. Create Supported Flash Command Example: Sector Erase in x1 STR, Start Address = 0x00_0400, Confirm Done Status .....                  | 29 |
| Table 2.11. Create Supported Flash Command Example: Program 256 Bytes in x8 DTR, Start Address = 0x00_0400 .....                                  | 29 |
| Table 2.12. Using Generic SPI Command Packet: Sector Erase (128 KiB) at Address (0x0159_E5A8), x8 I/O width, DTR, 4-Byte Address Mode .....       | 32 |
| Table 2.13. Using Generic SPI Command Packet: Send Read Status Register Command, x8 I/O Width, DTR .....                                          | 33 |
| Table 2.14. Using Supported Flash Command Packet: Sector Erase (128 KiB) at Address (0x0159_E5A8), x8 I/O Width, DTR, 4-Byte Address Mode .....   | 34 |
| Table 2.15. Using Generic SPI Command Packet: Page Program (256 Bytes) at Address (0x0159_E500), x8 I/O Width, DTR, 4-Byte Address Mode .....     | 35 |
| Table 2.16. Using Supported Flash Command Packet: Page Program (256 Bytes) at Address (0x0159_E500), x8 I/O Width, DTR, 4-Byte Address Mode ..... | 36 |
| Table 2.17. Using Generic SPI Command Packet: Fast Read (256 Bytes) at Address (0x0159_E500), x8 I/O Width, DTR, 4-Byte Address Mode .....        | 37 |
| Table 2.18. Using Supported Flash Command Packet: Fast Read (256 Bytes) at Address (0x0159_E500), x8 I/O Width, DTR, 4-Byte Address Mode .....    | 38 |
| Table 3.1. General Attributes .....                                                                                                               | 39 |
| Table 3.2. Flash Device Configuration Attributes .....                                                                                            | 43 |
| Table 4.1. Octal SPI Controller Ports .....                                                                                                       | 45 |
| Table 5.1. Register Access Types .....                                                                                                            | 51 |
| Table 5.2. Summary of Octal SPI Controller IP Core Registers .....                                                                                | 51 |
| Table 5.3. Octal SPI Configuration 0 Register .....                                                                                               | 52 |
| Table 5.4. Octal SPI Configuration 1 Register .....                                                                                               | 55 |
| Table 5.5. Supported Command Code 0 Register .....                                                                                                | 55 |
| Table 5.6. Supported Command Code 1 Register .....                                                                                                | 55 |
| Table 5.7. Supported Command Code 2 Register .....                                                                                                | 56 |
| Table 5.8. Supported Command Configuration Register .....                                                                                         | 56 |
| Table 5.9. Minimum Target Address Alignment Register .....                                                                                        | 57 |
| Table 5.10. Target Start Address Offset Register .....                                                                                            | 58 |
| Table 5.11. Total Target Address Map Alignment Register .....                                                                                     | 58 |
| Table 5.12. Target AXI4 Base Address Register .....                                                                                               | 58 |
| Table 5.13. Interrupt Enable Register .....                                                                                                       | 58 |
| Table 5.14. Interrupt Status Register .....                                                                                                       | 59 |
| Table 5.15. Generic SPI Command Packet Counter Register .....                                                                                     | 61 |
| Table 5.16. Supported Flash Command Packet Counter Register .....                                                                                 | 61 |
| Table 5.17. Octal SPI Debug Information 0 Register .....                                                                                          | 61 |
| Table 5.18. Octal SPI Debug Information 1 Register .....                                                                                          | 62 |
| Table 5.19. Tx FIFO Register .....                                                                                                                | 62 |
| Table 5.20. Rx FIFO Register .....                                                                                                                | 62 |

---

|                                                                                        |    |
|----------------------------------------------------------------------------------------|----|
| Table 5.21. Packet Header 0 – 3 Registers.....                                         | 63 |
| Table 5.22. Write Data Register.....                                                   | 63 |
| Table 5.23. Read Data Register.....                                                    | 63 |
| Table 5.24. Start Transaction Register.....                                            | 63 |
| Table 5.25. Interrupt Set Register.....                                                | 64 |
| Table 5.26. Test Mode Register .....                                                   | 65 |
| Table 5.27. Soft Reset Register .....                                                  | 65 |
| Table 5.28. IO Delay Control Register.....                                             | 66 |
| Table 6.1. Octal SPI Controller IP Configuration Supported by the Example Design ..... | 67 |
| Table 6.2. Octal SPI Controller IP Test Items and Procedures .....                     | 74 |
| Table 7.1. Generated File List .....                                                   | 80 |
| Table A.1. Resource Utilization.....                                                   | 86 |

## Abbreviations in This Document

A list of abbreviations used in this document.

| Abbreviation | Definition                                  |
|--------------|---------------------------------------------|
| AMBA         | Advanced Microcontroller Bus Architecture   |
| APB          | Advanced Peripheral Bus                     |
| AXI4         | Advanced eXtensible Interface 4             |
| CPHA         | SPI Clock Phase                             |
| CPOL         | SPI Clock Polarity                          |
| CPU          | Central Processing Unit                     |
| CS           | Chip Select                                 |
| CSR          | Configuration Status Register               |
| DRC          | Design Rule Checking                        |
| DSPI         | Dual Serial Peripheral Interface            |
| DTR          | Double Transfer Rate                        |
| DW           | Double Word                                 |
| EBR          | Embedded Block RAM                          |
| FIFO         | First In First Out                          |
| FPGA         | Field Programmable Gate Array               |
| GPIO         | General Purpose I/O                         |
| GUI          | Graphical User Interface                    |
| HDL          | Hardware Description Language               |
| IP           | Intellectual Property                       |
| JEDEC        | Joint Electron Device Engineering Council   |
| KiB          | Kibibyte (1024 bytes)                       |
| LSB          | Least Significant Bit                       |
| MiB          | Mebibyte (1024 kilobytes)                   |
| MSB          | Most Significant Bit                        |
| OSC          | Oscillator                                  |
| PLL          | Phase-Locked Loop                           |
| PVT          | Process, Voltage, Temperature               |
| QSPI         | Quad Serial Peripheral Interface            |
| SCK          | SPI Clock                                   |
| SoC          | System-on-Chip                              |
| SPI          | Serial Peripheral Interface                 |
| STR          | Single Transfer Rate                        |
| UART         | Universal Asynchronous Receiver Transmitter |
| XiP          | Execute-in-Place                            |
| xSPI         | Expanded Serial Peripheral Interface        |

# 1. Introduction

The serial peripheral interface (SPI) is a synchronous serial communication protocol that facilitates data transfer between microcontrollers and peripheral devices. SPI is commonly used in embedded systems to interface with sensors, memory devices, and display controllers, among other peripherals. This document describes the Octal SPI Controller IP.

## 1.1. Overview of the IP

The Lattice Octal SPI Controller IP is an SPI interface that supports different types of SPI protocols: standard, dual, quad, and xSPI. Standard SPI is the legacy four-wire interface with separate data lines for input and output. Dual SPI (DSPI) is an extension of standard SPI using two data lines. Quad SPI (QSPI) is another extension of standard SPI designed to provide a higher data transfer rate using four data lines. Expanded SPI (xSPI) is an advanced extension of standard SPI designed to provide higher data throughput and improved performance while maintaining backward compatibility with standard SPI devices. xSPI uses eight data lines and is capable of double data rate transfer.

## 1.2. Quick Facts

Table 1.1. Summary of the Octal SPI Controller IP

|                      |                          |                                                                                                                                                                        |
|----------------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IP Requirements      | Supported Devices        | CrossLink™-NX, Certus™-NX (LFD2NX-17, LFD2NX-40), CertusPro™-NX, MachXO5™-NX (LFMXO5-25, LFMXO5-55T, LFMXO5-100T), Lattice Avant™ (LAV-AT-E70, LAV-AT-G70, LAV-AT-X70) |
|                      | IP Changes <sup>1</sup>  | Refer to the <a href="#">Octal SPI Controller IP Release Notes (FPGA-RN-02011)</a> .                                                                                   |
| Resource Utilization | Supported User Interface | Advanced eXtensible Interface 4 (AXI4), AXI4-Lite, Advanced Peripheral Bus (APB)                                                                                       |
|                      | Resources                | Refer to <a href="#">Appendix A. Resource Utilization</a> .                                                                                                            |
| Design Tool Support  | Lattice Implementation   | IP Core v1.4.0 – Lattice Radiant™ Software 2025.2                                                                                                                      |
|                      | Synthesis                | Synopsys® Synplify Pro® for Lattice, Lattice Synthesis Engine                                                                                                          |
|                      | Simulation               | Refer to the Lattice Radiant Software User Guide for the list of supported simulators.                                                                                 |
| Driver Support       | API Reference            | Refer to the <a href="#">Octal SPI Controller Driver API Reference (FPGA-TN-02400)</a> .                                                                               |

**Note:**

1. In some instances, the IP may be updated without changes to the user guide. This user guide may reflect an earlier IP version but remains fully compatible with the later IP version. Refer to the IP Release Notes for the latest updates.

## 1.3. IP Support Summary

**Table 1.2. Octal SPI Controller IP Support Readiness**

| Device Family | I/O Width      | SCK Frequency (MHz) | Radiant Timing Model | Hardware Validated |
|---------------|----------------|---------------------|----------------------|--------------------|
| Avant         | x1, x8         | 200 <sup>1</sup>    | Preliminary          | Yes                |
|               | x1, x4         | 100 <sup>2</sup>    | Preliminary          | Yes                |
|               | x2             | 100                 | —                    | No                 |
| CertusPro-NX  | x1, x4         | 50 <sup>2,3</sup>   | Preliminary          | Yes                |
|               | x2, x8         | 50 <sup>3</sup>     | —                    | No                 |
| Certus-NX     | x1, x2, x4, x8 | 50 <sup>3</sup>     | —                    | No                 |
| CrossLink-NX  | x1, x2, x4, x8 | 50 <sup>3</sup>     | —                    | No                 |
| MachXO5-NX    | x1, x2, x4, x8 | 50 <sup>3</sup>     | —                    | No                 |

**Notes:**

2. Hardware validated with UMXSPI primitive (*JEDEC xSPI selected*) and double transfer rate (DTR).
3. Hardware validated with regular I/O primitive (no UMXSPI) and single transfer rate (STR) only.
4. Nexus devices can support 50 MHz in DTR mode and 100 MHz in STR mode. The performance of a Nexus device is limited by I/O (higher roundtrip delay) and the absence of a UMXSPI primitive to handle high-speed I/O.

## 1.4. Features

Key features of the Octal SPI Controller IP include:

- JEDEC JESD251C standard xSPI (x8, double transfer rate) support
- SPI (x1), dual SPI (x2), and quad SPI (x4) support
- AMBA AXI4 protocol bus interface
  - 32-bit data and 32-bit address
  - Single and burst transfers
- Dual bus interface option for separate configuration status register (CSR) and target data path interfaces
- SPI clock frequencies up to 200 MHz
- Double transfer rates up to 400 MT/s with 200 MHz clock
- Generic SPI controller function
- Flash command processing
- Up to 32 (target) chip select lines
- Execute-in-place (XiP) mode
- Optional target reset pin
- Configurable clock phase and polarity
- FIFO up to 512 depth

## 1.5. Licensing and Ordering Information

The Octal SPI Controller IP is provided at no additional cost with the Lattice Radiant software.

## 1.6. Hardware Support

Refer to the [Example Design](#) section for more information on the boards used.

## 1.7. Naming Conventions

### 1.7.1. Nomenclature

The nomenclature used in this document is based on Verilog HDL.

### 1.7.2. Signal Names

Signal names that end with:

- `_n` are active low signals (asserted when value is logic 0)
- `_i` are input signals
- `_o` are output signals

### 1.7.3. Attribute Names

Attribute names in this document are formatted in title case and italicized (*Attribute Name*).

## 2. Functional Description

### 2.1. IP Architecture Overview

The Octal SPI Controller IP core supports the JEDEC standard xSPI and can also be configured to support standard SPI, dual SPI, and quad SPI. Double transfer rate (DTR) is supported in xSPI and can run up to 400 MT/s (per I/O) at a clock frequency of 200 MHz (using the UMXSPI primitive). The UMXSPI primitive handles the I/O logic and converts single transfer rate (STR) to DTR. It also includes several delay primitives that can be used to adjust the timing of I/O signals (clock, data, and data strobe).

The IP can be configured to enable the soft logic for processing of flash commands. XiP mode is also available for applications that require the target (flash device) to be mapped as if it is local memory.

You may send the SPI transactions by:

- Writing to the registers.
- Enabling the FIFOs for burst transfer and command queuing.

Figure 2.1 shows the IP functional diagram.



Figure 2.1. Octal SPI Controller IP Core Functional Diagram

## 2.2. Clocking

The Octal SPI Controller IP has a single input clock operating at up to 200 MHz. The IP generates the SPI clock using the internal clock divider. The SPI clock frequency depends on the divider setting (sck\_rate) and can be calculated as follows:

SPI Clock Frequency = Input Clock Frequency, when sck\_rate = 0

SPI Clock Frequency = Input Clock Frequency / (2 × sck\_rate), when sck\_rate = 1, 2, 3, ...

For example, if the input clock is 200 MHz and the divider setting is 1, then the SPI clock frequency is 100 MHz. If the divider setting is 0, then the SPI clock frequency is the same as the input clock frequency.

Refer to the [General](#) and [Octal SPI Configuration 0 Register](#) sections for more information.



**Figure 2.2. Octal SPI Controller IP Clock Domain Block Diagram**

## 2.3. Reset

The Octal SPI Controller IP provides an input port that serves as an asynchronous active-low reset for the entire IP including the configuration status register (CSR). The minimum reset pulse width is one clock cycle. The reset goes through an internal reset synchronizer and may take several clock cycles to propagate. After de-asserting the reset, wait for at least four clock cycles before starting any transaction.

Besides the reset port, five programmable soft reset controls are provided (refer to the [Soft Reset Register](#) section):

- IP Core Reset – Resets the Octal SPI Controller logic except the CSR block.
- IP CSR Reset – Resets the CSR block only.
- Tx FIFO Reset – Resets the Tx FIFO only.
- Rx FIFO Reset – Resets the Rx FIFO only.
- SPI Target Reset – Resets the target device through the output port `spi_tgt_rst_n_o`.

## 2.4. User Interfaces

The Octal SPI Controller IP offers the flexibility of using either a single bus or dual bus interface. In single bus mode, you can choose between the AXI4, AXI4-Lite, and APB buses. This single bus provides access to the IP register space (CSR) and indirect access to the target. The same bus also provides direct access to the target memory space when target address mapping is enabled.

When target address mapping is enabled, the dual bus option also becomes available. In dual bus mode, one bus provides direct access (data path) to the target memory space while the other bus provides access to the CSR and indirect access to the target.

**Note:** In the [Signal Description](#) section, AXI4 and AXI4-Lite signals use the same signal names (`s_axi4_<port_name>`) in single bus mode. In dual bus mode, AXI4 and AXI4-Lite signals for the bus providing access to the CSR are denoted with `_c` (`s_axi4_c_<port_name>`).

**Table 2.1. User Interfaces and Supported Protocols**

| User Interface                   | Supported Protocols  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CSR Interface                    | AXI4, AXI4-Lite, APB | <p>The CSR interface is used to configure the IP core as well as send indirect transactions to the SPI target device using either the generic SPI command packet or supported flash command packet.</p> <p>In single bus mode, this interface provides access to the CSR, indirect access to the target, and direct target data path access.</p> <p>In dual bus mode, this interface provides access to the CSR and indirect access to the target. When <i>FIFO Interface Mapping</i> is set to <b>Map to Data Interface</b> in the IP GUI, the FIFO is not accessible through the CSR interface.</p>                                                                                                              |
| Target Data Interface (Optional) | AXI4                 | <p>The target data interface is an optional dedicated interface for the target data path. When target address mapping is enabled (<i>Enable Target Address Map</i> is checked in the IP GUI) and dual bus mode is selected, the target device can be directly accessed (using AXI4 write/read transaction) at the allocated address space. An application example is when booting directly from the target flash device with XiP mode enabled.</p> <p>Note that the CSR interface is used for indirect access to the target. However, in dual bus mode, when the <i>FIFO Interface Mapping</i> is set to <b>Map to Data Interface</b> in the IP GUI, the FIFO is accessible through the target data interface.</p> |

## 2.4.1. Address Space Mapping

The base address of the register block and target device can be set anywhere in the 32-bit address space but must be aligned to the size of allocation. The size of a register block is 1 KiB so the register base address should be aligned to 1 KiB. The target memory map size is configurable. The target base address must be aligned to this size.



Figure 2.3. Octal SPI Controller Address Space Mapping

## 2.4.2. Data Byte Order

The data byte order in the bus can be configured by selecting the data endianness. In little endian, the lowest significant byte is stored in the lowest address. In big endian, the most significant byte is stored in the lowest address. Table 2.2 shows an example of AXI4 Data[31:0] = 0x1234\_5678 stored in the respective addresses based on data endianness (AXI4 Address[31:0] = 0x0000\_1000).

Table 2.2. Example of Data Byte Order by Data Endianness

| Byte Address | Data Stored   |            |
|--------------|---------------|------------|
|              | Little Endian | Big Endian |
| 0x0000_1000  | 0x78          | 0x12       |
| 0x0000_1001  | 0x56          | 0x34       |
| 0x0000_1002  | 0x34          | 0x56       |
| 0x0000_1003  | 0x12          | 0x78       |

## 2.5. User Packets

This section describes the user packets used by the IP to generate SPI transactions. These user packets are translated by the Octal SPI Controller IP into SPI serial data. A user packet is written to the Tx FIFO through the AXI4 interface. Read data response from the target device is stored in the Rx FIFO and can be read through the AXI4 interface.

### 2.5.1. Packet Frame Structure

There are four packet frame structures or formats that can be used depending on the command and information needed to perform the SPI transaction. The supported flash command packet formats are applicable only if *Enable Command Processing* is selected in the IP GUI.



Figure 2.4. Generic SPI Command Packet



Figure 2.5. Supported Flash Command Packet with 2DW Header



**Figure 2.6. Supported Flash Command Packet with 3DW Header**

|         | 7            | 6                     | 5              | 4                        | 3           | 2               | 1                | 0 |
|---------|--------------|-----------------------|----------------|--------------------------|-------------|-----------------|------------------|---|
| Byte 0  | en_2byte_fcc |                       |                | user_cmd_code[4:0]       |             | with_payload    | sup_flash_cmd =1 |   |
| Byte 1  |              |                       |                | num_wait_state[7:0]      |             |                 |                  |   |
| Byte 2  |              |                       |                | xfer_len[7:0]            |             |                 |                  |   |
| Byte 3  |              |                       |                | xfer_len[15:8]           |             |                 |                  |   |
| Byte 4  | wait_ds      |                       | xfer_rate[2:0] |                          |             | lane_width[3:0] |                  |   |
| Byte 5  |              | flash_addr_width[2:0] |                |                          | tgt_cs[4:0] |                 |                  |   |
| Byte 6  |              |                       |                | flash_command_code[7:0]  |             |                 |                  |   |
| Byte 7  |              |                       |                | flash_command_code[15:8] |             |                 |                  |   |
| Byte 8  |              |                       |                | flash_addr[63:56]        |             |                 |                  |   |
| Byte 9  |              |                       |                | flash_addr[55:48]        |             |                 |                  |   |
| Byte 10 |              |                       |                | flash_addr[47:40]        |             |                 |                  |   |
| Byte 11 |              |                       |                | flash_addr[39:32]        |             |                 |                  |   |
| Byte 12 |              |                       |                | flash_addr[31:24]        |             |                 |                  |   |
| Byte 13 |              |                       |                | flash_addr[23:16]        |             |                 |                  |   |
| Byte 14 |              |                       |                | flash_addr[15:8]         |             |                 |                  |   |
| Byte 15 |              |                       |                | flash_addr[7:0]          |             |                 |                  |   |
|         |              |                       |                | payload[7:0]             |             |                 |                  |   |
|         |              |                       |                | payload[15:8]            |             |                 |                  |   |
|         |              |                       |                | ...                      |             |                 |                  |   |
|         |              |                       |                | payload[xfer_len*8+:8]   |             |                 |                  |   |

**Figure 2.7. Supported Flash Command Packet with 4DW Header**

## 2.5.2. Packet Field Description

Table 2.3. Packet Fields – Generic SPI Command Format

| Byte | Name                  | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|-----------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | sup_flash_cmd         | [0]   | 0 – Generic SPI command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|      | cmd_type              | [1]   | 0 – Generic SPI read transaction. No payload in the packet but read data is sampled and stored in the FIFO or register.<br>1 – Generic SPI write transaction. Payload is included in the packet except if dummy_data = 1.<br>Applicable when sup_flash_cmd = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      | lane_width[1:0]       | [3:2] | SPI I/O data width<br>Indicates the number of lanes to use when transmitting or receiving data.<br>0 – x1 (Standard SPI)<br>1 – x2 (Dual SPI)<br>2 – x4 (Quad SPI)<br>3 – x8 (xSPI)<br>Applicable when sup_flash_cmd = 0.<br>In standard SPI, data is transmitted in spi_dt_io[0] and received from spi_dt_io[1]. In other modes (x2/x4/x8), data lanes are the same for transmit and receive.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|      | data_rate             | [4]   | 0 – Transaction done using single transfer rate (STR).<br>1 – Transaction done using double transfer rate (DTR).<br>Applicable when sup_flash_cmd = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|      | frm_start             | [5]   | 0 – Transaction is a continuation of the previous packet.<br>1 – Packet is the first of the transaction or a standalone/single packet transaction.<br>This field affects the behavior of the chip select signal.<br>Applicable when sup_flash_cmd = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|      | frm_end               | [6]   | 0 – Transaction continues in the next packet.<br>1 – Packet is the last of the transaction or a standalone/single packet transaction.<br>This field affects the behavior of the chip select signal.<br>Applicable when sup_flash_cmd = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | wait_ds or dummy_data | [7]   | <ul style="list-style-type: none"> <li>wait_ds           <ul style="list-style-type: none"> <li>0 – No data strobe. Read data is sampled after the specified dummy cycle or wait state.</li> <li>1 – Read data arrives along with data strobe. The number of dummy cycles is irrelevant so the num_wait_sck field must be set to 0. The Octal SPI Controller IP continuously provides a clock until all the requested data are retrieved.<br/>Applicable when sup_flash_cmd = 0 and cmd_type = 0 (this is applicable in DTR when data strobe signal is present (spi_ds_i) and supported by the target device).<br/>Set this to 1 when sending an SPI read command (cmd_type = 0) and <i>JEDEC xSPI Support</i> is enabled in the IP GUI.</li> </ul> </li> <li>dummy_data           <ul style="list-style-type: none"> <li>0 – Payload follows after the header.</li> <li>1 – There is no payload to be transferred and the transfer length specifies the number of wait cycles in multiples of 8 (wait cycles = 8 × xfer_len).<br/>Applicable when sup_flash_cmd = 0 and cmd_type = 1.</li> </ul> </li> </ul> |

| Byte | Name               | Field | Description                                                                                                                                                                                                                                                                                                                       |
|------|--------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | tgt_cs[4:0]        | [4:0] | <p>SPI target chip select</p> <p>Indicates the SPI target device to be selected.</p> <p>Applicable when sup_flash_cmd = 0.</p>                                                                                                                                                                                                    |
|      | num_wait_sck[2:0]  | [7:5] | <p>Indicates the number of SPI clock cycles generated while waiting for the read data. This is used for number of dummy cycles that is less than 8.</p> <p>0 – No wait cycle</p> <p>1 – 1 clock wait cycle</p> <p>2 – 2 clocks wait cycle</p> <p>...</p> <p>7 – 7 clocks wait cycle</p> <p>Applicable when sup_flash_cmd = 0.</p> |
| 2    | xfer_len[7:0]      | [7:0] | <p>Indicates the number of data bytes to be transmitted or received.</p> <p>0 – 64K bytes</p> <p>1 – 1 byte</p> <p>2 – 2 bytes</p> <p>...</p> <p>65535 – 65535 bytes</p>                                                                                                                                                          |
| 3    | xfer_len[15:8]     | [7:0] | <p>When sup_flash_cmd = 0 and dummy_data = 1, xfer_len[4:0] is used to indicate the number of dummy cycles in multiples of 8 (xfer_len[15:5] is ignored).</p> <p>1 – 8 dummy cycles</p> <p>2 – 16 dummy cycles</p> <p>...</p> <p>31 – 248 dummy cycles</p>                                                                        |
| —    | Payload Byte 1...n | [7:0] | The data bytes sent for write access.                                                                                                                                                                                                                                                                                             |

**Table 2.4. Packet Fields – Supported Flash Command Format**

| Byte | Name                | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|---------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | sup_flash_cmd       | [0]   | 1 – Supported flash command. See user_cmd_code for specific pattern of transaction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | with_payload        | [1]   | 0 – No payload in the packet.<br>1 – Payload is present in the packet.<br>Applicable when sup_flash_cmd = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      | user_cmd_code[4:0]  | [6:2] | <ul style="list-style-type: none"> <li>user_cmd_code[1:0] indicates the pattern of transaction:           <ul style="list-style-type: none"> <li>0 – [OPCODE], [ADDRESS], [RD DATA]</li> <li>1 – [OPCODE], [ADDRESS], [WR DATA]</li> <li>2 – [WR ENABLE], [OPCODE], [ADDRESS], [WR DATA]</li> <li>3 – [WR ENABLE], [OPCODE], [ADDRESS], [WR DATA], [CHECK STATUS]</li> </ul> </li> </ul> <p>Applicable when sup_flash_cmd = 1.</p> <p><b>Note:</b> Address and write data are optional. These are controlled by the flash_addr_width and with_payload fields, respectively.</p> <ul style="list-style-type: none"> <li>user_cmd_code[2] is reserved.</li> <li>user_cmd_code[3] (en_sr_addr) is reserved for transaction patterns 0, 1, and 2. For transaction pattern 3:           <ul style="list-style-type: none"> <li>0 – No address included.</li> <li>1 – Include 4-byte address 0x0000_0000 when reading the flash status registers.</li> </ul> </li> <li>user_cmd_code[4] is reserved for transaction patterns 0 and 1. For transaction patterns 2 and 3, this field determines if the same settings are used when sending write enable and when reading the flash status registers:           <ul style="list-style-type: none"> <li>0 – Use the default transfer setting in the supported command configuration register.</li> <li>1 – Use the setting in packet field (xfer_rate, lane_width, wait_data_strobe, en_sr_addr, num_wait_state).</li> </ul> </li> </ul> <p>In transaction pattern 3, the target's read status register is read until the transaction is confirmed done. Additionally, the security register or flag status register is read to check the success/fail status of the program/erase command. The status is reflected in the interrupt status register (0x100).</p> |
|      | en_2byte_fcc        | [7]   | Enable 2-byte flash command code.<br>0 – Flash command code is 1 byte only.<br>1 – Flash command code is 2 bytes.<br>Applicable when sup_flash_cmd = 1 and <i>Enable 2 bytes command code == Checked</i> in the IP GUI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1    | num_wait_state[7:0] | [7:0] | Indicates the number of SPI clock cycles generated while waiting for the read data.<br>0 – No wait cycle<br>1 – 1 clock wait cycle<br>2 – 2 clocks wait cycle<br>...<br>255 – 255 clocks wait cycle<br>Applicable when sup_flash_cmd = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Byte | Name            | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-----------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | xfer_len[7:0]   | [7:0] | Indicates the number of data bytes to be transmitted or received.<br>0 – 64K bytes<br>1 – 1 byte<br>2 – 2 bytes<br>...<br>65535 – 65535 bytes                                                                                                                                                                                                                                                                                                              |
| 3    | xfer_len[15:8]  | [7:0] | When sup_flash_cmd = 0 and dummy_data = 1, xfer_len[4:0] is used to indicate the number of dummy cycles in multiples of 8 (xfer_len[15:5] is ignored).<br>1 – 8 dummy cycles<br>2 – 16 dummy cycles<br>...<br>31 – 248 dummy cycles                                                                                                                                                                                                                        |
| 4    | lane_width[1:0] | [3:0] | SPI I/O data width<br>Indicates the number of lanes to use in each phase (Command, Address, and Data).<br>4'h0 – (x1, x1, x1)<br>4'h1 – (x2, x2, x2)<br>4'h2 – (x4, x4, x4)<br>4'h3 – (x8, x8, x8)<br>4'h4 – (x1, x1, x2)<br>4'h5 – (x1, x2, x2)<br>4'h6–4'h7 – reserved<br>4'h8 – (x1, x1, x4)<br>4'h9 – (x1, x4, x4)<br>4'hA–4'hB – reserved<br>4'hC – (x1, x1, x8)<br>4'hD – (x1, x8, x8)<br>4'hE–4'hF – reserved<br>Applicable when sup_flash_cmd = 1. |
|      | xfer_rate[2:0]  | [6:4] | Specifies the transfer rate to be used for each phase: Command (xfer_rate[2]), Address (xfer_rate[1]), and Data (xfer_rate[0]). DTR is currently only valid in x8 width.<br>0 – STR<br>1 – DTR<br>Applicable when sup_flash_cmd = 1.                                                                                                                                                                                                                       |
|      | wait_ds         | [7]   | Wait for data strobe<br>1 – Read data arrives along with data strobe. The number of dummy cycles is irrelevant so the num_wait_state field must be set to 0. The Octal SPI Controller IP continuously provides a clock until all the requested data are retrieved.<br>Applicable when sup_flash_cmd = 1 and data strobe is enabled.                                                                                                                        |

| Byte  | Name                                                                                  | Field  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|---------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5     | tgt_cs[4:0]                                                                           | [4:0]  | SPI target chip select<br>Indicates the SPI target device to be selected.<br>Applicable when sup_flash_cmd = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | flash_addr_width[2:0]                                                                 | [7:5]  | Flash address width<br>0 – no address<br>1 – 16b address<br>2 – 24b address<br>3 – 32b address<br>...<br>7 – 64b address<br>Values 4–7 are reserved if <i>Target Address up to 64b</i> = Unchecked in the IP GUI.<br>Applicable when sup_flash_cmd = 1.                                                                                                                                                                                                                                                                                                                                                                |
| 6     | flash_command_code[7:0]                                                               | [7:0]  | Vendor specific flash command code<br>Applicable when sup_flash_cmd = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7     | flash_command_code[15:8]                                                              | [7:0]  | Vendor specific flash command code<br>Applicable when sup_flash_cmd = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11–8  | {flash_addr[7:0],<br>flash_addr[15:8],<br>flash_addr[23:16]<br>flash_addr[31:24]}     | [31:0] | Lower 32b flash address<br>Applicable when sup_flash_cmd = 1 and flash_addr_width ≤ 3.<br>The flash address byte order is reversed. Valid bytes start on the lowest byte index (byte 8). For example, in 32b address, if flash_addr_width = 3:<br>Byte 8: flash_addr[31:24]<br>Byte 9: flash_addr[23:16]<br>Byte 10: flash_addr[15:8]<br>Byte 11: flash_addr[7:0]<br>If flash_addr_width < 3, then valid bytes of the flash_addr are shifted towards byte 8. For example, if flash_addr_width = 2, then the flash address is {8'h00, flash_addr[7:0], flash_addr[15:8], flash_addr[23:16]}.                            |
|       | {flash_addr[39:32],<br>flash_addr[47:40],<br>flash_addr[55:48],<br>flash_addr[63:56]} | [31:0] | Upper 32b flash address<br>Applicable when sup_flash_cmd = 1 and 3 < flash_addr_width ≤ 7.<br>The flash address byte order is reversed. Valid bytes start on the lowest byte index (byte 8). For example, in 64b address, if flash_addr_width = 7:<br>Byte 8: flash_addr[63:56]<br>Byte 9: flash_addr[55:48]<br>Byte 10: flash_addr[47:40]<br>Byte 11: flash_addr[39:32]<br>If flash_addr_width < 7, then valid bytes of the flash_addr are shifted towards byte 8. For example, if flash_addr_width = 4, then the upper flash address is {flash_addr[15:8], flash_addr[23:16], flash_addr[31:24], flash_addr[39:32]}. |
| 15–12 | {flash_addr[7:0],<br>flash_addr[15:8],<br>flash_addr[23:16],<br>flash_addr[31:24]}    | [31:0] | Lower 32b flash address<br>Applicable when sup_flash_cmd = 1 and 3 < flash_addr_width ≤ 7.<br>The flash address byte order is reversed. For example, in 64b address, if flash_addr_width = 7:<br>Byte 12: flash_addr[31:24]<br>Byte 13: flash_addr[23:16]<br>Byte 14: flash_addr[15:8]<br>Byte 15: flash_addr[7:0]<br>If flash_addr_width < 7, then valid bytes of the flash_addr are shifted towards byte 8. For example, if flash_addr_width = 4, then the lower flash address is {8'h00, 8'h00, 8'h00, flash_addr[7:0]}.                                                                                            |

| Byte | Name               | Field | Description                           |
|------|--------------------|-------|---------------------------------------|
| —    | Payload Byte 1...n | [7:0] | The data bytes sent for write access. |

## 2.6. Generating SPI Transactions

### 2.6.1. SPI Transfer Modes

The SPI transfer mode can be configured by setting the clock polarity and clock phase in the IP GUI. If the respective programmable capabilities are enabled in the IP GUI (*Programmable CPOL*, *Programmable CPHA*), clock polarity and clock phase can be set through configuration 0 register (0x004).

The following figures show the clock idle state and how data is driven and sampled in each mode. Note that for DTR, the SPI transfer mode defaults to mode 0 and driving or sampling of data can occur on both clock edges.



Figure 2.8. SPI Transfer Mode 0 (cpol = 0, cpha = 0)



Figure 2.9. SPI Transfer Mode 1 (cpol = 0, cpha = 1)



Figure 2.10. SPI Transfer Mode 2 (cpol = 1, cpha = 0)



Figure 2.11. SPI Transfer Mode 3 (cpol = 1, cpha = 1)

### 2.6.2. Data I/O Width

The number of active SPI data I/O lines is dynamically controlled in the packet header. The following figure shows sample waveforms of a byte transfer across different I/O widths. This example uses SPI transfer mode 0 and the MSB first setting.



Figure 2.12. Byte Transfer across Different I/O Widths

### 2.6.3. DTR Mode

Double transfer rate (DTR) mode increases the performance of SPI transfer since it uses both the positive and negative edges of the clock for sampling and driving data. This mode is currently only applicable when using a data I/O width greater than four (octal SPI only). When using DTR, the clock phase and clock polarity are restricted to 0.



Figure 2.13. Byte Transfer in DTR Mode across x4 and x8 I/O Widths

### 2.6.4. Generic SPI Write/Read Transactions

In a generic SPI write transaction, the packet payload is transmitted or shifted out on the SPI data I/O line or lines. In a generic SPI read transaction, the received data from input pins is stored in the Rx FIFO or in the read data register. The length of transfer, number of valid SPI data pins, and data rate to use can be controlled in the packet header. Dummy cycles can be controlled and inserted as necessary. The context of a user transaction is not transparent to the IP core. A transaction is simply seen as either a write or read transfer. It is up to you to manipulate the packets in order to convert application-level transactions (such as flash command sequence) into SPI transfer.

There are instances when multiple packets or even transactions combining SPI write and SPI read need to be transferred continuously in a single assertion of chip select. In this case, the frm\_start and frm\_end packet header fields must be used to indicate that these packets belong to a single frame. This means that target chip select will not de-assert until it encounters a packet with frm\_start or frm\_end set to 1.

If a transfer can be completed with one packet, then the packet will have frm\_start = 1 and frm\_end = 1. If a transfer can only be completed with two packets, then the first packet will have frm\_start = 1 and frm\_end = 0, and the second packet will have frm\_start = 0 and frm\_end = 1. If a transfer can only be completed with 3 or more packets, then the first packet will have frm\_start = 1 and frm\_end = 0, the middle packet or packets will have frm\_start = 0 and frm\_end = 0, and the last packet will have frm\_start = 0 and frm\_end = 1.

The following figures show example waveform diagrams of generic SPI transactions.



Figure 2.14. SPI Write Transaction



Figure 2.15. SPI Read Transaction



Figure 2.16. SPI Write and Read Transaction with Dummy Cycles

The following tables show the AXI4 bus transactions to perform SPI transfer.

**Table 2.5. Generic SPI Transaction Example: Write 16 Bytes in x8 STR**

| AXI4 Address                            | Write Data  | Description/Comment                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0010_006E | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 0 (Generic)</li> <li>[1] cmd_type = 1 (Write)</li> <li>[3:2] lane_width = 3 (x8)</li> <li>[4] data_rate = 0 (STR)</li> <li>[5] frm_start = 1</li> <li>[6] frm_end = 1</li> <li>[7] dummy_data = 0</li> <li>[12:8] tgt_cs = 0</li> <li>[15:13] num_wait_sck = 0</li> <li>[31:16] xfer_len = 16 (bytes)</li> </ul> |
|                                         | 0x1234_5678 | Payload DW1                                                                                                                                                                                                                                                                                                                                                                 |
|                                         | 0x9ABC_DEF0 | Payload DW2                                                                                                                                                                                                                                                                                                                                                                 |
|                                         | 0x1122_3344 | Payload DW3                                                                                                                                                                                                                                                                                                                                                                 |
|                                         | 0x5566_7788 | Payload DW4                                                                                                                                                                                                                                                                                                                                                                 |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction                                                                                                                                                                                                                                                                                                                                                           |

**Table 2.6. Generic SPI Transaction Example: Read 16 Bytes in x1 STR, with 12 Dummy Cycles**

| AXI4 Address                            | Write Data  | Description/Comment                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0001_00A0 | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 0 (Generic)</li> <li>[1] cmd_type = 1 (dummy write)</li> <li>[3:2] lane_width = 0 (x1)</li> <li>[4] data_rate = 0 (STR)</li> <li>[5] frm_start = 1</li> <li>[6] frm_end = 0</li> <li>[7] dummy_data = 1 (dummy – no data)</li> <li>[12:8] tgt_cs = 0</li> <li>[15:13] num_wait_sck = 0</li> <li>[31:16] xfer_len = 1 (x8 dummy cycle)</li> </ul> |
|                                         | 0x0010_8040 | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 0 (Generic)</li> <li>[1] cmd_type = 0 (Read)</li> <li>[3:2] lane_width = 0 (x1)</li> <li>[4] data_rate = 0 (STR)</li> <li>[5] frm_start = 0</li> <li>[6] frm_end = 1</li> <li>[7] wait_ds = 0</li> <li>[12:8] tgt_cs = 0</li> <li>[15:13] num_wait_sck = 4 (dummy cycle)</li> <li>[31:16] xfer_len = 16 (bytes)</li> </ul>                       |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction                                                                                                                                                                                                                                                                                                                                                                                           |

After performing the transaction, check the interrupt status register rx\_fifo\_not\_empty or rdata\_available to determine if there is read data available.

**Table 2.7. Generic SPI Transaction Example: Write 5 Bytes in x8 DTR, then Read 8 Bytes in x8 STR, with 2 Dummy Cycles**

| AXI4 Address                            | Write Data  | Description/Comment                                                                                                                                                                                                                                                             |
|-----------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0005_0032 | [0] sup_flash_cmd = 0 (Generic)<br>[1] cmd_type = 1 (Write)<br>[3:2] lane_width = 0 (x8)<br>[4] data_rate = 1 (DTR)<br>[5] frm_start = 1<br>[6] frm_end = 0<br>[7] dummy_data = 0<br>[12:8] tgt_cs = 0<br>[15:13] num_wait_sck = 0<br>[31:16] xfer_len = 5 (bytes)              |
|                                         | 0x55BB_44AA | Payload DW1                                                                                                                                                                                                                                                                     |
|                                         | 0x0000_00CC | Payload DW2                                                                                                                                                                                                                                                                     |
|                                         | 0x0008_4040 | [0] sup_flash_cmd = 0 (Generic)<br>[1] cmd_type = 0 (Read)<br>[3:2] lane_width = 0 (x8)<br>[4] data_rate = 0 (STR)<br>[5] frm_start = 0<br>[6] frm_end = 1<br>[7] dummy_data = 0<br>[12:8] tgt_cs = 0<br>[15:13] num_wait_sck = 2 (dummy cycle)<br>[31:16] xfer_len = 8 (bytes) |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction                                                                                                                                                                                                                                                               |

## 2.6.5. Supported Flash Commands

Applicable only if *Enable Command Processing* is selected in the IP GUI.

For flash controller application, supported flash commands offer a simplified user packet to generate and complete commonly used flash commands (for example, page program, erase, and read). While not all command patterns are supported, these commands can still be generated using generic SPI write/read transactions.

The following table shows the command patterns supported by the IP core.

**Table 2.8. Supported Command Patterns**

| Command Pattern   | Description                                                                             |
|-------------------|-----------------------------------------------------------------------------------------|
| Command Pattern 0 | [OPCODE] + [OPTIONAL ADDRESS] + [READ DATA]                                             |
| Command Pattern 1 | [OPCODE] + [OPTIONAL ADDRESS] + [OPTIONAL WRITE DATA]                                   |
| Command Pattern 2 | [WRITE ENABLE] + [OPCODE] + [OPTIONAL ADDRESS] + [OPTIONAL WRITE DATA]                  |
| Command Pattern 3 | [WRITE ENABLE] + [OPCODE] + [OPTIONAL ADDRESS] + [OPTIONAL WRITE DATA] + [CHECK STATUS] |

The following figures show example commands with the various command patterns.



**Figure 2.17. Example Command Pattern 0: Read Command (with 2 Dummy Cycles)**



**Figure 2.18. Example Command Pattern 2: Erase Command**



**Figure 2.19. Example Command Pattern 3: Page Program Command**

The following tables show examples of how to create the supported command transactions.

**Table 2.9. Create Supported Flash Command Example: Read 256 Bytes in x1 STR, with 20 Dummy Cycles, Start Address = 0x00\_0400**

| AXI4 Address                            | Write Data  | Description/Comment                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0100_1401 | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 1 (Supported Command)</li> <li>[1] with_payload = 0 (none)</li> <li>[3:2] user_cmd_code[1:0] = 0 (command pattern 0)</li> <li>[6:4] user_cmd_code[4:2] = 0 (don't care)</li> <li>[7] en_2byte_fcc = 0 (1-byte command)</li> <li>[15:8] num_wait_state = 20 (dummy cycles)</li> <li>[31:16] xfer_len = 256 (bytes)</li> </ul> |
|                                         | 0x000B_4000 | <ul style="list-style-type: none"> <li>[3:0] lane_width = 0 (x1, x1, x1)</li> <li>[6:4] xfer_rate = 0 (STR, STR, STR)</li> <li>[7] wait_data_strobe = 0</li> <li>[12:8] tgt_cs = 0</li> <li>[15:13] flash_addr_width = 2 (24b)</li> <li>[31:16] flash_cmd_code = 0x000B (opcode)</li> </ul>                                                                                             |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0400 | [31:0] flash_addr = 0x0000_0400 (address)                                                                                                                                                                                                                                                                                                                                               |
|                                         | 0x0000_0001 | Start Transaction                                                                                                                                                                                                                                                                                                                                                                       |

After performing the transaction, check the interrupt status register rx\_fifo\_not\_empty or rdata\_available to determine if there is read data available.

**Table 2.10. Create Supported Flash Command Example: Sector Erase in x1 STR, Start Address = 0x00\_0400, Confirm Done Status**

| AXI4 Address                            | Write Data  | Description/Comment                              |
|-----------------------------------------|-------------|--------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0100_000D | [0] sup_flash_cmd = 1 (Supported Command)        |
|                                         |             | [1] with_payload = 0 (none)                      |
|                                         |             | [3:2] user_cmd_code[1:0] = 3 (command pattern 3) |
|                                         |             | [5:4] user_cmd_code[3:2] = 0 (x1- status width)  |
|                                         |             | [6] user_cmd_code[4] = 0 (STR – status rate)     |
|                                         |             | [7] en_2byte_fcc = 0 (1-byte command)            |
|                                         |             | [15:8] num_wait_state = 0 (no dummy cycles)      |
|                                         |             | [31:16] xfer_len = 0 (don't care)                |
|                                         | 0x0020_4000 | [3:0] lane_width = 0 (x1, x1, x1)                |
|                                         |             | [6:4] xfer_rate = 0 (STR, STR, STR)              |
|                                         |             | [7] wait_data_strobe = 0                         |
|                                         |             | [12:8] tgt_cs = 0                                |
|                                         |             | [15:13] flash_addr_width = 2 (24b)               |
|                                         |             | [31:16] flash_cmd_code = 0x0020 (opcode)         |
|                                         | 0x0000_0400 | [31:0] flash_addr = 0x0000_0400 (address)        |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction                                |

**Table 2.11. Create Supported Flash Command Example: Program 256 Bytes in x8 DTR, Start Address = 0x00\_0400**

| AXI4 Address                            | Write Data  | Comment                                          |
|-----------------------------------------|-------------|--------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0100_00FB | [0] sup_flash_cmd = 1 (Supported Command)        |
|                                         |             | [1] with_payload = 1                             |
|                                         |             | [3:2] user_cmd_code[1:0] = 2 (command pattern 2) |
|                                         |             | [5:4] user_cmd_code[3:2] = 3 (x8- status width)  |
|                                         |             | [6] user_cmd_code[4] = 1 (DTR – status rate)     |
|                                         |             | [7] en_2byte_fcc = 1 (2-byte command)            |
|                                         |             | [15:8] num_wait_state = 0 (no dummy cycles)      |
|                                         |             | [31:16] xfer_len = 256 (bytes)                   |
|                                         | 0xED12_40FF | [3:0] lane_width = 3 (x8, x8, x8)                |
|                                         |             | [6:4] xfer_rate = 7 (DTR, DTR, DTR)              |
|                                         |             | [7] wait_data_strobe = 0                         |
|                                         |             | [12:8] tgt_cs = 0                                |
|                                         |             | [15:13] flash_addr_width = 2 (24b)               |
|                                         |             | [31:16] flash_cmd_code = 0xED12 (opcode)         |
|                                         | 0x0000_0400 | [31:0] flash_addr = 0x0000_0400 (address)        |
|                                         | 0x7654_3210 | [31:0] payload 1                                 |
|                                         | 0x89AB_CDEF | [31:0] payload 2                                 |
|                                         | ...         | ...                                              |
|                                         | ...         | [31:0] payload 256                               |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction                                |

## 2.7. Target Memory Map Access

Applicable only if *Enable Target Address Map* is selected in the IP GUI.

### 2.7.1. XiP Access

This feature can be enabled by selecting *Enable Target Address Map* and *Enable XiP Mode* in the IP GUI.

In flash controller application, XiP mode is a method to execute a code directly from the flash memory. Read operation in XiP mode can be optimized because it only requires an address (command code is not required) in succeeding read transactions.

The Octal SPI Controller IP provides an option to map the target flash device to the IP address space so that the flash can be accessed as if it is a local memory. The activation or deactivation of XiP mode in a flash device is vendor specific and can be different for each device. Refer to the flash device data sheet for the necessary steps or required sequence.

After sending the necessary command to enable or activate XiP mode in the flash device, set the `enter_xip_mode` register (0x220) to indicate that the IP will perform read transaction in XiP mode. This means that the AXI4 read access that hits the target memory map address space will be converted to XiP mode read transaction. The supported command configuration register (0x018) is used when performing XiP mode read transaction. Register fields (such as `lane_width_r` and `xfer_rate_r`) should be configured to the appropriate settings.

This following discussion is an example of XiP access. Before performing XiP access, the required conditions are as follows:

- A 128-MiB flash memory device with XiP mode is mapped to the local address space for CPU access.
- Read access uses the xSPI DTR mode with data strobe and 32b address.
- The flash device XiP mode is enabled by writing to a configuration register and activated on the next fast read command through the confirmation bit after the address.

Firstly, map the flash memory device by allocating the local address space and assigning a base address. The Octal SPI Controller IP uses 1 KiB address space for internal registers. The target base address must be aligned to the size of the address space allocation (128 MiB). If the first address space (0x0000\_0000) is allocated to the IP core registers, the next address space available is 1 × 128 MiB or 0x0800\_0000. Set this in the target AXI4 base address register.



Figure 2.20. Example of Target Device Address Mapping

After address space allocation, configure the transaction settings in the supported command configuration register (`lane_width_r = 4'h3`, `xfer_rate_r = 3'b111`, `wait_ds_r = 1'b1`, `addr_mode_r = 1'b1`). Next, enable XiP mode in the flash device by sending a generic SPI write to the XiP enable register. Then, send a fast read command (using either the generic packet or supported command packet) with the confirmation bit after the address. Note that this is only applicable for this hypothetical flash device. Different vendors may have their own enable or activation methods which are specified in the respective data sheets.

Finally, assert the `enter_xip_mode` register (0x220). The CPU will be able to perform read access on the flash device by sending an AXI4 read transaction to the allocated address range of 0x0800\_0000 to 0x0FFF\_FFFF.

### 2.7.2. Non-XiP Memory Map Access

If XiP mode is not enabled, `enter_xip_mode` is not set to high (non-XiP mode), and an AXI4 read access to the target memory address space is performed, the IP core converts this access to a regular flash read command using the command code in the `fast_read_b0` and `fast_read_b1` registers (0x014). In non-XiP mode, both read and write direct access can be performed. AXI4 write access to the target memory address space is converted to the flash page program command using the command code in the `page_program_b0` and `page_program_b1` registers (0x014).

### 2.7.3. FIFO Burst Transfer for Indirect Flash Access

When the dual bus interface is selected and *FIFO Interface Mapping* is set to **Map to Data Interface**, the FIFO can be accessed using the target data interface with indirect SPI transactions. The Tx and Rx FIFO offsets are the same as with the CSR mapping while the upper address (base) can be anything outside the allocation of the target address space. For example, if *Target Map: AXI4 Base Address* is 0x8000\_0000 and *Total Target Memory Map Size* is 64 KiB, then the Tx and Rx FIFO can be accessed at offsets 0x200 and 0x204, respectively, with a base address that does not fall within 0x8000\_0000 to 0x8000\_FFFF. This feature is useful when the CSR interface is using the AXI4-Lite or APB bus and you want to perform a burst to the FIFO instead of a single transfer. Note that this is different from the direct target data path access in that you will still need to create a generic SPI or supported flash command packet to perform flash access.

## 2.8. Flash Controller Sequence Examples

One of the applications of the Octal SPI Controller IP is to access a flash memory target device.

The typical commands used when accessing a flash target device are erase, program, and read. The examples in the following sections show how to generate these commands in the Octal SPI Controller IP using the generic SPI command packet format and the supported flash command packet format. Each sequence assumes that FIFO is enabled in the IP GUI.

If FIFO is not enabled, packet headers should be written to the packet header registers (0x208 – 0x214) and write data to the write data register (0x218). Read data should be read from the read data register (0x21C). In write access, before writing the next data (except for the first write), wait for wdata\_done to assert. When wdata\_done asserts, the data has already transferred, and the IP is ready to accept new data. Clear wdata\_done before writing new data to the write data register. Alternatively, wdata\_not\_empty in the octal SPI debug information 0 register (0x10C) can be used to determine if the next data can be written to the write data register. Unlike wdata\_done, wdata\_not\_empty does not need to be cleared. When wdata\_not\_empty is de-asserted (0), the next data can be written to the write data register. In read access, wait for rdata\_available to assert before reading the read data register. Clear rdata\_available after getting the read data from the read data register.

### 2.8.1. Flash Erase Command

#### 2.8.1.1. Using Generic SPI Command Packet

The following table shows the AXI4 bus transactions to generate the flash erase command using generic SPI command packet.

**Table 2.12. Using Generic SPI Command Packet: Sector Erase (128 KiB) at Address (0x0159\_E5A8), x8 I/O width, DTR, 4-Byte Address Mode**

| AXI4 Address                            | Write Data  | Description/Comment                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0002_007E | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 0 (Generic)</li> <li>[1] cmd_type = 1 (Write)</li> <li>[3:2] lane_width = 3 (x8)</li> <li>[4] data_rate = 1 (DTR)</li> <li>[5] frm_start = 1</li> <li>[6] frm_end = 1</li> <li>[7] dummy_data = 0</li> <li>[12:8] tgt_cs = 0</li> <li>[15:13] num_wait_sck = 0</li> <li>[31:16] xfer_len = 2 (bytes)</li> </ul> |
|                                         | 0x0000_0606 | WREN Command code                                                                                                                                                                                                                                                                                                                                                          |
|                                         | 0x0002_003E | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 0 (Generic)</li> <li>[1] cmd_type = 1 (Write)</li> <li>[3:2] lane_width = 3 (x8)</li> <li>[4] data_rate = 1 (DTR)</li> <li>[5] frm_start = 1</li> <li>[6] frm_end = 0</li> <li>[7] dummy_data = 0</li> <li>[12:8] tgt_cs = 0</li> <li>[15:13] num_wait_sck = 0</li> <li>[31:16] xfer_len = 2 (bytes)</li> </ul> |
|                                         | 0x0000_DCDC | Sector Erase Command Code                                                                                                                                                                                                                                                                                                                                                  |
|                                         | 0x0004_005E | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 0 (Generic)</li> <li>[1] cmd_type = 1 (Write)</li> <li>[3:2] lane_width = 3 (x8)</li> </ul>                                                                                                                                                                                                                     |

| AXI4 Address                            | Write Data  | Description/Comment                                                                                                                                                    |
|-----------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                         |             | [4] data_rate = 1 (DTR)<br>[5] frm_start = 0<br>[6] frm_end = 1<br>[7] dummy_data = 0<br>[12:8] tgt_cs = 0<br>[15:13] num_wait_sck = 0<br>[31:16] xfer_len = 4 (bytes) |
| Register Map: AXI4 Base Address + 0x220 | 0xA8E5_5901 | {Address[7:0], Address[15:8], Address[23:16], Address[31:24]}                                                                                                          |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction                                                                                                                                                      |

Read the register 0x10C to determine if the erase command has been sent. When spi\_has\_started = 1 and spi\_busy = 0, transfer is done. Once the erase command is sent, the flash status register needs to be checked to determine if erase is complete. This is done by sending a read status register command.

**Table 2.13. Using Generic SPI Command Packet: Send Read Status Register Command, x8 I/O Width, DTR**

| AXI4 Address                            | Write Data  | Description/Comment                                                                                                                                                                                                                                                                   |
|-----------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0002_003E | [0] sup_flash_cmd = 0 (Generic)<br>[1] cmd_type = 1 (Write)<br>[3:2] lane_width = 3 (x8)<br>[4] data_rate = 1 (DTR)<br>[5] frm_start = 1<br>[6] frm_end = 0<br>[7] dummy_data = 0<br>[12:8] tgt_cs = 0<br>[15:13] num_wait_sck = 0<br>[31:16] xfer_len = 2 (bytes)                    |
|                                         | 0x0000_0505 | Read Status Command code                                                                                                                                                                                                                                                              |
|                                         | 0x0002_00DC | [0] sup_flash_cmd = 0 (Generic)<br>[1] cmd_type = 0 (Read)<br>[3:2] lane_width = 3 (x8)<br>[4] data_rate = 1 (DTR)<br>[5] frm_start = 0<br>[6] frm_end = 1<br>[7] wait_ds = 1 (wait for data strobe)<br>[12:8] tgt_cs = 0<br>[15:13] num_wait_sck = 0<br>[31:16] xfer_len = 2 (bytes) |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction                                                                                                                                                                                                                                                                     |

Read the register 0x10C to determine if the read status command is done (spi\_has\_started = 1 and spi\_busy = 0). The flash status data should now be available in the Rx FIFO (if FIFO is enabled in the IP GUI), which can be read at 0x204, or at 0x21C (if FIFO is not enabled).

The flash status busy bit (usually at bit 0) should indicate if the operation is still ongoing (busy = 1) or done (busy = 0). The flash program command may not proceed if the previous command (erase) is not done. The read status command should be repeatedly sent until the busy bit shows that the operation is done.

Some flash devices have another status register that indicates if the erase or program command has failed. You may opt to read this status register by sending another read command that targets the status register.

### 2.8.1.2. Using Supported Flash Command Packet

The following discusses how to perform flash erase using supported flash command packet.

Before sending any supported flash command packet, ensure that the supported command code 0 and 1 registers (0x00C and 0x010) have been configured either in the IP GUI or through programming (if *Programmable Command Code* is enabled). The supported command configuration register (0x018) must be set to the intended configuration if a different setting from that set in the supported flash command packet (for example, when *user\_cmd\_code[4]==0*) is to be used. The write enable and read status command sequences are automatically executed by the Octal SPI Controller IP when the supported flash command packet is used in the flash erase, program, or write command. The IP core relies on the pre-configured command codes and settings (such as I/O width and data rate when *user\_cmd\_code[4]==0*) to generate these command sequences.

**Table 2.14. Using Supported Flash Command Packet: Sector Erase (128 KiB) at Address (0x0159\_E5A8), x8 I/O Width, DTR, 4-Byte Address Mode**

| AXI4 Address                            | Write Data  | Description/Comment                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0001_00CD | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 1 (Supported Command)</li> <li>[1] with_payload = 0 (none)</li> <li>[3:2] user_cmd_code[1:0] = 3 (command pattern 3)</li> <li>[5:4] user_cmd_code[3:2] = 0 (don't care)</li> <li>[6] user_cmd_code[4] = 1 use packet field settings</li> <li>[7] en_2byte_fcc = 1 (2 bytes command)</li> <li>[15:8] num_wait_state = 0 (dummy cycles)</li> <li>[31:16] xfer_len = 1 (no payload)</li> </ul> |
|                                         | 0xDCDC_6073 | <ul style="list-style-type: none"> <li>[3:0] lane_width = 3 (x8, x8, x8)</li> <li>[6:4] xfer_rate = 7 (DTR, DTR, DTR)</li> <li>[7] wait_data_strobe = 0</li> <li>[12:8] tgt_cs = 0</li> <li>[15:13] flash_addr_width = 3 (32b)</li> <li>[31:16] flash_cmd_code = 0xDCDC (Sector Erase)</li> </ul>                                                                                                                                                      |
|                                         | 0xA8E5_5901 | {Address[7:0], Address[15:8],<br>Address[23:16], Address[31:24]}                                                                                                                                                                                                                                                                                                                                                                                       |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction                                                                                                                                                                                                                                                                                                                                                                                                                                      |

Once this command is activated (tx\_start = 1 for start transaction register), the Octal SPI Controller IP generates the write enable sequence, followed by the erase command sequence, and finally the read status and read status flag sequence.

The register 0x10C may be read to determine if the erase command is complete (spi\_has\_started = 1 and spi\_busy = 0). For flash devices that support the status flag for erase fail or program fail, this status is reflected in the interrupt status register (0x100). It is important that the correct bit index be configured in the IP GUI (*Flash Status Register Erase Fail bit index* or *Flash Status Register Program Fail bit index*) together with the appropriate command code in register 0x010. Otherwise, this status is meaningless and should be ignored.

## 2.8.2. Flash Program Command

### 2.8.2.1. Using Generic SPI Command Packet

The following discusses how to perform flash program using generic SPI command packet.

**Table 2.15. Using Generic SPI Command Packet: Page Program (256 Bytes) at Address (0x0159\_E500), x8 I/O Width, DTR, 4-Byte Address Mode**

| AXI4 Address                            | Write Data    | Description/Comment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
|-----------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------------|---------------|-----|----------|-------------|-------|------------|----------|-----|-----------|-----------|-----|-----------|-----|-----|---------|-----|-----|------------|-----|--------|--------|-----|---------|--------------|-----|---------|----------|-------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0002_007E   | <table border="1"> <tr><td>[0]</td><td>sup_flash_cmd</td><td>= 0 (Generic)</td></tr> <tr><td>[1]</td><td>cmd_type</td><td>= 1 (Write)</td></tr> <tr><td>[3:2]</td><td>lane_width</td><td>= 3 (x8)</td></tr> <tr><td>[4]</td><td>data_rate</td><td>= 1 (DTR)</td></tr> <tr><td>[5]</td><td>frm_start</td><td>= 1</td></tr> <tr><td>[6]</td><td>frm_end</td><td>= 1</td></tr> <tr><td>[7]</td><td>dummy_data</td><td>= 0</td></tr> <tr><td>[12:8]</td><td>tgt_cs</td><td>= 0</td></tr> <tr><td>[15:13]</td><td>num_wait_sck</td><td>= 0</td></tr> <tr><td>[31:16]</td><td>xfer_len</td><td>= 2 (bytes)</td></tr> </table> | [0] | sup_flash_cmd | = 0 (Generic) | [1] | cmd_type | = 1 (Write) | [3:2] | lane_width | = 3 (x8) | [4] | data_rate | = 1 (DTR) | [5] | frm_start | = 1 | [6] | frm_end | = 1 | [7] | dummy_data | = 0 | [12:8] | tgt_cs | = 0 | [15:13] | num_wait_sck | = 0 | [31:16] | xfer_len | = 2 (bytes) |
| [0]                                     | sup_flash_cmd | = 0 (Generic)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [1]                                     | cmd_type      | = 1 (Write)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [3:2]                                   | lane_width    | = 3 (x8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [4]                                     | data_rate     | = 1 (DTR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [5]                                     | frm_start     | = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [6]                                     | frm_end       | = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [7]                                     | dummy_data    | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [12:8]                                  | tgt_cs        | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [15:13]                                 | num_wait_sck  | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [31:16]                                 | xfer_len      | = 2 (bytes)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
|                                         | 0x0000_0606   | WREN Command code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
|                                         | 0x0002_003E   | <table border="1"> <tr><td>[0]</td><td>sup_flash_cmd</td><td>= 0 (Generic)</td></tr> <tr><td>[1]</td><td>cmd_type</td><td>= 1 (Write)</td></tr> <tr><td>[3:2]</td><td>lane_width</td><td>= 3 (x8)</td></tr> <tr><td>[4]</td><td>data_rate</td><td>= 1 (DTR)</td></tr> <tr><td>[5]</td><td>frm_start</td><td>= 1</td></tr> <tr><td>[6]</td><td>frm_end</td><td>= 0</td></tr> <tr><td>[7]</td><td>dummy_data</td><td>= 0</td></tr> <tr><td>[12:8]</td><td>tgt_cs</td><td>= 0</td></tr> <tr><td>[15:13]</td><td>num_wait_sck</td><td>= 0</td></tr> <tr><td>[31:16]</td><td>xfer_len</td><td>= 2 (bytes)</td></tr> </table> | [0] | sup_flash_cmd | = 0 (Generic) | [1] | cmd_type | = 1 (Write) | [3:2] | lane_width | = 3 (x8) | [4] | data_rate | = 1 (DTR) | [5] | frm_start | = 1 | [6] | frm_end | = 0 | [7] | dummy_data | = 0 | [12:8] | tgt_cs | = 0 | [15:13] | num_wait_sck | = 0 | [31:16] | xfer_len | = 2 (bytes) |
| [0]                                     | sup_flash_cmd | = 0 (Generic)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [1]                                     | cmd_type      | = 1 (Write)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [3:2]                                   | lane_width    | = 3 (x8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [4]                                     | data_rate     | = 1 (DTR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [5]                                     | frm_start     | = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [6]                                     | frm_end       | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [7]                                     | dummy_data    | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [12:8]                                  | tgt_cs        | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [15:13]                                 | num_wait_sck  | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [31:16]                                 | xfer_len      | = 2 (bytes)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
|                                         | 0x0000_1212   | Page Program Command Code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
|                                         | 0x0004_001E   | <table border="1"> <tr><td>[0]</td><td>sup_flash_cmd</td><td>= 0 (Generic)</td></tr> <tr><td>[1]</td><td>cmd_type</td><td>= 1 (Write)</td></tr> <tr><td>[3:2]</td><td>lane_width</td><td>= 3 (x8)</td></tr> <tr><td>[4]</td><td>data_rate</td><td>= 1 (DTR)</td></tr> <tr><td>[5]</td><td>frm_start</td><td>= 0</td></tr> <tr><td>[6]</td><td>frm_end</td><td>= 0</td></tr> <tr><td>[7]</td><td>dummy_data</td><td>= 0</td></tr> <tr><td>[12:8]</td><td>tgt_cs</td><td>= 0</td></tr> <tr><td>[15:13]</td><td>num_wait_sck</td><td>= 0</td></tr> <tr><td>[31:16]</td><td>xfer_len</td><td>= 4 (bytes)</td></tr> </table> | [0] | sup_flash_cmd | = 0 (Generic) | [1] | cmd_type | = 1 (Write) | [3:2] | lane_width | = 3 (x8) | [4] | data_rate | = 1 (DTR) | [5] | frm_start | = 0 | [6] | frm_end | = 0 | [7] | dummy_data | = 0 | [12:8] | tgt_cs | = 0 | [15:13] | num_wait_sck | = 0 | [31:16] | xfer_len | = 4 (bytes) |
| [0]                                     | sup_flash_cmd | = 0 (Generic)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [1]                                     | cmd_type      | = 1 (Write)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [3:2]                                   | lane_width    | = 3 (x8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [4]                                     | data_rate     | = 1 (DTR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [5]                                     | frm_start     | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [6]                                     | frm_end       | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [7]                                     | dummy_data    | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [12:8]                                  | tgt_cs        | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [15:13]                                 | num_wait_sck  | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [31:16]                                 | xfer_len      | = 4 (bytes)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
|                                         | 0x00E5_5901   | {Address[7:0], Address[15:8],<br>Address[23:16], Address[31:24]}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
|                                         | 0x0100_005E   | <table border="1"> <tr><td>[0]</td><td>sup_flash_cmd</td><td>= 0 (Generic)</td></tr> <tr><td>[1]</td><td>cmd_type</td><td>= 1 (Write)</td></tr> <tr><td>[3:2]</td><td>lane_width</td><td>= 3 (x8)</td></tr> <tr><td>[4]</td><td>data_rate</td><td>= 1 (DTR)</td></tr> <tr><td>[5]</td><td>frm_start</td><td>= 0</td></tr> <tr><td>[6]</td><td>frm_end</td><td>= 1</td></tr> <tr><td>[7]</td><td>dummy_data</td><td>= 0</td></tr> <tr><td>[12:8]</td><td>tgt_cs</td><td>= 0</td></tr> </table>                                                                                                                           | [0] | sup_flash_cmd | = 0 (Generic) | [1] | cmd_type | = 1 (Write) | [3:2] | lane_width | = 3 (x8) | [4] | data_rate | = 1 (DTR) | [5] | frm_start | = 0 | [6] | frm_end | = 1 | [7] | dummy_data | = 0 | [12:8] | tgt_cs | = 0 |         |              |     |         |          |             |
| [0]                                     | sup_flash_cmd | = 0 (Generic)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [1]                                     | cmd_type      | = 1 (Write)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [3:2]                                   | lane_width    | = 3 (x8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [4]                                     | data_rate     | = 1 (DTR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [5]                                     | frm_start     | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [6]                                     | frm_end       | = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [7]                                     | dummy_data    | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |
| [12:8]                                  | tgt_cs        | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |               |               |     |          |             |       |            |          |     |           |           |     |           |     |     |         |     |     |            |     |        |        |     |         |              |     |         |          |             |

| AXI4 Address                            | Write Data  | Description/Comment            |
|-----------------------------------------|-------------|--------------------------------|
|                                         |             | [15:13] num_wait_sck = 0       |
|                                         |             | [31:16] xfer_len = 256 (bytes) |
| 0x0403_0201                             |             | Payload_DW0[31:0]              |
| 0x0807_0605                             |             | Payload_DW1[31:0]              |
| ...                                     |             | ...                            |
| ...                                     |             | ...                            |
| 0x00FF_FEFD                             |             | Payload_DW63[31:0]             |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction              |

Follow the same procedure for flash erase (refer to [2.8.1.1 Using Generic SPI Command Packet](#)) to check the status until it is determined that the program operation is done.

### 2.8.2.2. Using Supported Flash Command Packet

The following discusses how to perform flash program using supported flash command packet.

Similar to the erase command, ensure that all necessary register settings have been configured prior to sending any supported flash command packet (refer to [2.8.1.2 Using Supported Flash Command Packet](#)).

**Table 2.16. Using Supported Flash Command Packet: Page Program (256 Bytes) at Address (0x0159\_E500), x8 I/O Width, DTR, 4-Byte Address Mode**

| AXI4 Address                            | Write Data  | Comment                                                                                                                                                                                                                                                                                                                                          |
|-----------------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0100_00CF | [0] sup_flash_cmd = 1 (Supported Command)<br>[1] with_payload = 1<br>[3:2] user_cmd_code[1:0] = 3 (command pattern 3)<br>[5:4] user_cmd_code[3:2] = 0 (don't care)<br>[6] user_cmd_code[4] = 1 use packet field settings<br>[7] en_2byte_fcc = 1 (2 bytes command)<br>[15:8] num_wait_state = 0 (dummy cycles)<br>[31:16] xfer_len = 256 (bytes) |
|                                         | 0x1212_6073 | [3:0] lane_width = 3 (x8, x8, x8)<br>[6:4] xfer_rate = 7 (DTR, DTR, DTR)<br>[7] wait_data_strobe = 0<br>[12:8] tgt_cs = 0<br>[15:13] flash_addr_width = 3 (32b)<br>[31:16] flash_cmd_code = 0x1212 (Page Program)                                                                                                                                |
|                                         | 0x00E5_5901 | {Address[7:0], Address[15:8],<br>Address[23:16], Address[31:24]}                                                                                                                                                                                                                                                                                 |
|                                         | 0x0403_0201 | Payload_DW0[31:0]                                                                                                                                                                                                                                                                                                                                |
|                                         | 0x0807_0605 | Payload_DW1[31:0]                                                                                                                                                                                                                                                                                                                                |
|                                         | ...         | ...                                                                                                                                                                                                                                                                                                                                              |
|                                         | ...         | ...                                                                                                                                                                                                                                                                                                                                              |
|                                         | 0x00FF_FEFD | Payload_DW63[31:0]                                                                                                                                                                                                                                                                                                                               |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction                                                                                                                                                                                                                                                                                                                                |

Once this command is activated (tx\_start = 1 for start transaction register), the Octal SPI Controller IP generates the write enable sequence, followed by the program command sequence, and finally the read status and read status flag sequence.

The register 0x10C may be read to determine if the program command is complete (spi\_has\_started = 1 and spi\_busy = 0). For flash devices that support the status flag for erase fail or program fail, this status is reflected in the interrupt status register (0x100). It is important that the correct bit index be configured in the IP GUI (*Flash Status Register Erase*

*Fail bit index or Flash Status Register Program Fail bit index) together with the appropriate command code in register 0x010. Otherwise, this status is meaningless and should be ignored.*

## 2.8.3. Flash Read Command

### 2.8.3.1. Using Generic SPI Command Packet

The following discusses how to perform flash read using generic SPI command packet.

**Table 2.17. Using Generic SPI Command Packet: Fast Read (256 Bytes) at Address (0x0159\_E500), x8 I/O Width, DTR, 4-Byte Address Mode**

| AXI4 Address                            | Write Data  | Comment                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0002_003E | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 0 (Generic)</li> <li>[1] cmd_type = 1 (Write)</li> <li>[3:2] lane_width = 3 (x8)</li> <li>[4] data_rate = 1 (DTR)</li> <li>[5] frm_start = 1</li> <li>[6] frm_end = 0</li> <li>[7] dummy_data = 0</li> <li>[12:8] tgt_cs = 0</li> <li>[15:13] num_wait_sck = 0</li> <li>[31:16] xfer_len = 2 (bytes)</li> </ul>                      |
|                                         | 0x0000_0C0C | Fast Read Command code                                                                                                                                                                                                                                                                                                                                                                          |
|                                         | 0x0004_001E | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 0 (Generic)</li> <li>[1] cmd_type = 1 (Write)</li> <li>[3:2] lane_width = 3 (x8)</li> <li>[4] data_rate = 1 (DTR)</li> <li>[5] frm_start = 0</li> <li>[6] frm_end = 0</li> <li>[7] dummy_data = 0</li> <li>[12:8] tgt_cs = 0</li> <li>[15:13] num_wait_sck = 0</li> <li>[31:16] xfer_len = 4 (bytes)</li> </ul>                      |
|                                         | 0x00E5_5901 | {Address[7:0], Address[15:8],<br>Address[23:16], Address[31:24]}                                                                                                                                                                                                                                                                                                                                |
|                                         | 0x0100_00DC | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 0 (Generic)</li> <li>[1] cmd_type = 0 (Read)</li> <li>[3:2] lane_width = 3 (x8)</li> <li>[4] data_rate = 1 (DTR)</li> <li>[5] frm_start = 0</li> <li>[6] frm_end = 1</li> <li>[7] wait_ds = 1 (wait for data strobe)</li> <li>[12:8] tgt_cs = 0</li> <li>[15:13] num_wait_sck = 0</li> <li>[31:16] xfer_len = 256 (bytes)</li> </ul> |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction                                                                                                                                                                                                                                                                                                                                                                               |

Read the register 0x10C to determine if the fast read command is done (spi\_has\_started = 1 and spi\_busy=0). Once it is done, all the expected read data should be in the Rx FIFO and can be read at 0x204. It is also possible to get the read data even if fast read is not yet done. Monitor or poll the register 0x100 to check the rx\_fifo\_not\_empty status before reading 0x204.

If FIFO is not enabled, continuously check the interrupt status (0x100) rdata\_available. Once the read data is available, read the data and then clear the interrupt status. Otherwise, the read command will not proceed further after the first four bytes since there is no space to store the data.

### 2.8.3.2. Using Supported Flash Command Packet

The following discusses how to perform flash read using supported flash command packet.

**Table 2.18. Using Supported Flash Command Packet: Fast Read (256 Bytes) at Address (0x0159\_E500), x8 I/O Width, DTR, 4-Byte Address Mode**

| AXI4 Address                            | Write Data  | Description/Comment                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Map: AXI4 Base Address + 0x200 | 0x0100_0081 | <ul style="list-style-type: none"> <li>[0] sup_flash_cmd = 1 (Supported Command)</li> <li>[1] with_payload = 0 (none)</li> <li>[3:2] user_cmd_code[1:0] = 0 (command pattern 3)</li> <li>[5:4] user_cmd_code[3:2] = 0 (don't care)</li> <li>[6] user_cmd_code[4] = 0 (don't care)</li> <li>[7] en_2byte_fcc = 1 (2 bytes command)</li> <li>[15:8] num_wait_state = 0 (dummy cycles)</li> <li>[31:16] xfer_len = 256 (bytes)</li> </ul> |
|                                         | 0x0C0C_60F3 | <ul style="list-style-type: none"> <li>[3:0] lane_width = 3 (x8, x8, x8)</li> <li>[6:4] xfer_rate = 7 (DTR, DTR, DTR)</li> <li>[7] wait_data_strobe = 1</li> <li>[12:8] tgt_cs = 0</li> <li>[15:13] flash_addr_width = 3 (32b)</li> <li>[31:16] flash_cmd_code = 0x0C0C (Fast Read)</li> </ul>                                                                                                                                         |
|                                         | 0x00E5_5901 | {Address[7:0], Address[15:8], Address[23:16], Address[31:24]}                                                                                                                                                                                                                                                                                                                                                                          |
| Register Map: AXI4 Base Address + 0x220 | 0x0000_0001 | Start Transaction                                                                                                                                                                                                                                                                                                                                                                                                                      |

Read the register 0x10C to determine if the fast read command is done (spi\_has\_started = 1 and spi\_busy = 0). Once it is done, all the expected read data should be in the Rx FIFO and can be read at 0x204. It is also possible to get the read data even if fast read is not yet done. Monitor or poll the register 0x100 to check the rx\_fifo\_not\_empty status before reading 0x204.

If FIFO is not enabled, continuously check the interrupt status (0x100) rdata\_available. Once the read data is available, read the data and then clear the interrupt status. Otherwise, the read command will not proceed further after the first four bytes since there is no space to store the data.

### 3. IP Parameter Description

The configurable attributes of the Octal SPI Controller IP are shown in the following tables. You can configure the IP by setting the attributes accordingly in the IP Catalog Module/IP wizard of the Lattice Radiant software.

Wherever applicable, default values are in bold.

#### 3.1. General

**Table 3.1. General Attributes**

| Attribute                       | Selectable Values                                                                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------------------|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Configuration Preset</b>     |                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SPI Protocol                    | Custom, <b>JEDEC xSPI</b>                                                                            | Preconfigures the required settings for a particular protocol.<br><b>Note:</b> The JEDEC xSPI mode uses the UMXSPI primitive which is only available for the LAV-AT-X70 device.                                                                                                                                                                                                                                                                                                                                                                         |
| <b>Clock Configuration</b>      |                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| System Clock Frequency (MHz)    | <b>1 – 200</b>                                                                                       | Sets the system clock (clk_i) frequency.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Internal Clock Frequency (MHz)  | <b>200</b>                                                                                           | Informational only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SPI Clock (SCK) Pulse width     | <b>0 – 31, 1</b>                                                                                     | Sets the SCK pulse width in terms of number of cycles of system clock (clk_i). Setting this to 0 means that SCK will have the same frequency as the system clock (clk_i).<br>When <i>JEDEC xSPI Support</i> = Unchecked, the minimum SPI clock pulse width is 1.<br>The range of selectable values vary with the supported maximum SCK frequency, which depends on the FPGA device selected and settings such as whether DTR is enabled. For example, Nexus devices support a maximum SCK frequency of 100 MHz in STR mode and only 50 MHz in DTR mode. |
| SPI Clock (SCK) Frequency (MHz) | <b>100</b>                                                                                           | Informational only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SPI Clock (SCK) Period (ns)     | <b>10</b>                                                                                            | Informational only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>User Interface</b>           |                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Interface                       | <b>AXI4</b> , AXI-Lite, APB, Data: AXI4; CSR: AXI4, Data: AXI4; CSR: AIX4-Lite, Data: AXI4; CSR: APB | Selects the bus interface. If <i>Enable Target Address Map</i> == Checked, selects single bus interface or dual bus interface.<br>In single bus interface, CSR access and direct target data path access are on the same bus.<br>In dual bus interface, CSR access and direct target data path access are on separate buses. The option for FIFO mapping is also available through the <i>FIFO Interface Mapping</i> attribute.                                                                                                                         |
| Number of outstanding request   | <b>1 – 16</b>                                                                                        | Specifies the AXI4 request queue size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Enable AXI4-Lite ID             | <b>Checked, Unchecked</b>                                                                            | Enables the optional transaction ID in AXI4-Lite.<br>Applicable when the AXI4-Lite bus is selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| AXI4 Bus ID Width               | <b>1 – 12</b>                                                                                        | Specifies the AXI4 bus ID width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| FIFO Interface Mapping          | <b>Map to CSR Interface, Map to Data Interface</b>                                                   | Selects the bus interface used to access the FIFO.<br>Applicable when the dual bus interface is selected.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| FIFO depth                      | <b>64, 128, 256, 512</b>                                                                             | Specifies the depth of transmit and receive FIFO.<br>Applicable when <i>Include FIFO</i> == Checked.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| FIFO Implementation             | <b>HARD IP, EBR, LUT</b>                                                                             | Specifies the FIFO implementation type.<br>Applicable when <i>Include FIFO</i> == Checked.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Attribute                                                      | Selectable Values | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------------------------------------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SPI Configuration</b>                                       |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Default LSBF value                                             | 0, 1              | <p>Default value of transmit/receive LSB first setting.<br/>0 – Transmit/Receive MSB first<br/>1 – Transmit/Receive LSB first</p>                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Default CPOL value                                             | 0, 1              | <p>Default value of clock polarity setting.<br/>0 – Clock is low in idle state<br/>1 – Clock is high in idle state<br/>When <i>Enable Double Transfer Rate</i> == Checked, CPOL is fixed to 0.</p>                                                                                                                                                                                                                                                                                                                                                                        |
| Default CPHA value                                             | 0, 1              | <p>Default value of clock phase setting.<br/>0 – Sample data at odd number clock edge<br/>1 – Sample data at even number clock edge<br/>When <i>Enable Double Transfer Rate</i> == Checked, CPHA is fixed to 0.</p> <p>CSn : </p> <p>SCK : </p> <p>SCK : </p> <p style="text-align: center;">1    2    3    ...</p> |
| Default Endianness value                                       | 0, 1              | <p>Default value of endianness.<br/>0 – Little endian<br/>1 – Big endian</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Default Use DS value                                           | 0, 1              | <p>Default value of use data strobe setting.<br/>0 – Do not use data strobe<br/>1 – Use data strobe to sample read data in double transfer rate<br/>When <i>SPI Protocol</i> == JEDEC xSPI, DS is required so this setting is fixed to 1. When <i>SPI Protocol</i> = Custom, this setting is applicable only when <i>Enable Double Transfer Rate</i> == Checked.</p>                                                                                                                                                                                                      |
| Default Non-blocking Tx FIFO                                   | 0, 1              | <p>Default value of non-blocking Tx FIFO setting.<br/>0 – Wait for Tx FIFO not full status during write access; block write access if full<br/><b>Note:</b> This may prevent any write access (including register access) until Tx FIFO has free space.<br/>1 – Do not wait for Tx FIFO not full status; discard data when full</p>                                                                                                                                                                                                                                       |
| Default Non-blocking Rx FIFO                                   | 0, 1              | <p>Default value of non-blocking Rx FIFO setting.<br/>0 – Wait for Rx FIFO not empty status during read access; block read access if empty<br/><b>Note:</b> This may prevent any read access (including register access) until Rx FIFO has available data.<br/>1 – Do not wait for Rx FIFO not empty status; return any data (garbage) if empty</p>                                                                                                                                                                                                                       |
| Minimum Timing (number of SPI clock): CS assert to SCK         | 0 – 15, 1         | Sets the minimum timing from chip select (CS) assertion to the first SPI clock edge in terms of SPI clock cycles. For example, if SPI clock is running at 25 MHz, a value of 1 means at least 40 ns.                                                                                                                                                                                                                                                                                                                                                                      |
| Minimum Timing (number of SPI clock): SCK to CS deassert       | 0 – 15            | Sets the minimum timing from the last SPI clock edge to CS de-assertion in terms of SPI clock cycles. For example, if SPI clock is running at 25 MHz, a value of 1 means at least 40 ns.                                                                                                                                                                                                                                                                                                                                                                                  |
| Minimum Timing (number of SPI clock): CS deassert to CS assert | 0 – 15, 1         | Sets the minimum timing from CS de-assertion to the next CS assertion in terms of SPI clock cycles. For example, if SPI clock is running at 25 MHz, a value of 1 means at least 40 ns.                                                                                                                                                                                                                                                                                                                                                                                    |

| Attribute                              | Selectable Values          | Description                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Supported Capabilities</b>          |                            |                                                                                                                                                                                                                                                                                                                                                                                        |
| Generic SPI Controller                 | <b>Checked</b>             | Informational only.                                                                                                                                                                                                                                                                                                                                                                    |
| JEDEC xSPI Support                     | <b>Checked</b> , Unchecked | Informational only.<br>Enables support for JEDEC xSPI standard. Automatically sets when selected in the <i>SPI Protocol</i> preset.                                                                                                                                                                                                                                                    |
| Enable Target Address Map              | Checked, <b>Unchecked</b>  | Enables support for mapping the target address space to AXI4.                                                                                                                                                                                                                                                                                                                          |
| Enable XiP Mode                        | Checked, <b>Unchecked</b>  | Enables support for XiP mode.<br>This feature is only applicable if the flash device used is either Micron™ or Macronix™ or has a similar method of activating and keeping the XiP mode.<br>Applicable when <i>Enable Target Address Map</i> == Checked.                                                                                                                               |
| Enable Command Processing              | Checked, <b>Unchecked</b>  | Enables capability to implement a sequence of transactions in order to complete certain flash commands.                                                                                                                                                                                                                                                                                |
| Enable Double Transfer Rate            | <b>Checked</b> , Unchecked | Enables capability to use both the positive and negative edges of the clock to transfer data.<br>Fixed to DTR if <i>JEDEC xSPI Support</i> == Checked.                                                                                                                                                                                                                                 |
| Max number of data lanes               | <b>X8</b> , X4, X2, X1     | Sets the maximum number of data I/O lines.<br>X1 (SPI) – 1 data pin for transmit and 1 data pin for receive<br>X2 (Dual SPI) – 2 bidirectional data pins for transmit and receive<br>X4 (Quad SPI) – 4 bidirectional data pins for transmit and receive<br>X8 (Octal SPI) – 8 bidirectional data pins for transmit and receive<br>Fixed to X8 if <i>JEDEC xSPI Support</i> == Checked. |
| Max number of SPI Target               | <b>1 – 32</b>              | Sets the maximum number of SPI targets supported. This determines the number of target chip select.<br>Fixed to 1 if <i>JEDEC xSPI Support</i> == Checked.                                                                                                                                                                                                                             |
| Include FIFO                           | <b>Checked</b> , Unchecked | Adds FIFO for transmit and receive data.                                                                                                                                                                                                                                                                                                                                               |
| Programmable SCK Divider               | <b>Checked</b> , Unchecked | Enables programmable SCK divider (sck_rate). Otherwise, the corresponding field is non-programmable (cannot be modified).                                                                                                                                                                                                                                                              |
| Programmable LSBF                      | Checked, <b>Unchecked</b>  | Enables programmable transmit/receive LSB first setting. Otherwise, the corresponding field is non-programmable (cannot be modified).                                                                                                                                                                                                                                                  |
| Programmable CPOL                      | Checked, <b>Unchecked</b>  | Enables programmable clock polarity setting. Otherwise, the corresponding field is non-programmable (cannot be modified). Not applicable when <i>Enable Double Transfer Rate</i> == Checked.                                                                                                                                                                                           |
| Programmable CPHA                      | Checked, <b>Unchecked</b>  | Enables programmable clock phase setting. Otherwise, the corresponding field is non-programmable (cannot be modified). Not applicable when <i>Enable Double Transfer Rate</i> == Checked.                                                                                                                                                                                              |
| Programmable Use DS                    | Checked, <b>Unchecked</b>  | Enables programmable use data strobe setting. Otherwise, the corresponding field is non-programmable (cannot be modified). Not applicable when <i>Enable Double Transfer Rate</i> = Unchecked or <i>JEDEC xSPI Support</i> == Checked.                                                                                                                                                 |
| Programmable Command Code              | <b>Checked</b> , Unchecked | Enables programmable supported command code. Otherwise, the corresponding fields are non-programmable (cannot be modified). Applicable only when <i>Enable Target Address Map</i> == Checked or <i>Enable Command Processing</i> == Checked.                                                                                                                                           |
| Programmable Memory Map                | Checked, <b>Unchecked</b>  | Enables programmable target memory map size and base address. Otherwise, the corresponding field is non-programmable (cannot be modified). Applicable only when <i>Enable Target Address Map</i> == Checked.                                                                                                                                                                           |
| Programmable Non-blocking FIFO setting | Checked, <b>Unchecked</b>  | Enables programmable setting for non-blocking/blocking FIFO access.                                                                                                                                                                                                                                                                                                                    |
| Target Address up to 64b               | Checked, <b>Unchecked</b>  | Enables support for command modifier/address up to 64 bits.                                                                                                                                                                                                                                                                                                                            |
| Enable Target Reset Pin                | Checked, <b>Unchecked</b>  | Adds an optional target reset output pin.                                                                                                                                                                                                                                                                                                                                              |

| Attribute                                 | Selectable Values                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>IO Primitive</b>                       |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Include IO Primitive                      | <b>Checked</b> , Unchecked              | Includes the I/O primitive instance inside the IP. This means that SPI data pins are seen as bidirectional I/O ports at the top level. When this option is disabled, the SPI tristate data control signals are exposed at the top level as ports.<br>Fixed to Checked when <i>JEDEC xSPI Support</i> == Checked.                                                                                                                  |
| Use xSPI IO Primitive                     | <b>Checked</b> , Unchecked              | Uses the dedicated I/O primitive for xSPI (UMXSPI primitive). This is only applicable when enabling xSPI in the Avant device.<br>Fixed to Checked when <i>JEDEC xSPI Support</i> == Checked.                                                                                                                                                                                                                                      |
| <b>Memory Map Configuration</b>           |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Register Space Size (KiB)                 | —                                       | Informational only.                                                                                                                                                                                                                                                                                                                                                                                                               |
| Enable Full CSR Address Decoding          | <b>Checked</b> , <b>Unchecked</b>       | If enabled, the register address is decoded using the full 32b address. If disabled, only the lower 10 bits of the address are decoded. Disabling full decode means that the bus controller will ensure the correct routing of requests to individual targets. This is only applicable for register space.<br>This setting must be disabled when used in Propel-based designs where the address space is automatically allocated. |
| Register Map: AXI4 Base Address (32b Hex) | <b>0x0000_0000</b> – <b>0xFFFF_F400</b> | This is the starting address of the register space.<br>Applicable when <i>Enable Full CSR Address Decoding</i> == Checked.                                                                                                                                                                                                                                                                                                        |
| Target Memory Map Size (KiB)              | <b>1</b> – 2,097,152 (power of 2)       | This is the size of the address space to be mapped per target.<br>Applicable when <i>Enable Target Address Map</i> == Checked.                                                                                                                                                                                                                                                                                                    |
| Target Actual Start Address (32b Hex)     | <b>0x0000_0000</b> – <b>0xFFFF_F400</b> | This is the actual starting address of the memory space in the target. The start address must be aligned to the target memory map size.<br>Applicable when <i>Enable Target Address Map</i> == Checked.                                                                                                                                                                                                                           |
| Total Target Memory Map Size (KiB)        | <b>1</b> – 2,097,152 (power of 2)       | This is the total size of all target address space mapping (target memory map size × number of targets).<br>Applicable when <i>Enable Target Address Map</i> == Checked and <i>Max number of SPI Target</i> > 1.                                                                                                                                                                                                                  |
| Target Map: AXI4 Base Address (32b Hex)   | <b>0x0000_0400</b> – <b>0xFFFF_F400</b> | This is the starting address of the target memory map space. The upper bits of the base address must be set to 0 when used in Propel-based designs where the address space is automatically allocated. For example, if the total memory map size is 64 KiB, then the upper 15 bits must be 0 and the base address is 0x0001_0000.<br>Applicable when <i>Enable Target Address Map</i> == Checked.                                 |
| <b>Optional Debug Registers</b>           |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Enable Tx FIFO free space count           | <b>Checked</b> , <b>Unchecked</b>       | Adds a register that can be read to check the number of free space in the Tx FIFO. At reset, the number of free space is equal to the FIFO depth. The count is decremented each time data is written to the FIFO and incremented each time data is read from the FIFO.                                                                                                                                                            |
| Enable Rx FIFO available data count       | <b>Checked</b> , <b>Unchecked</b>       | Adds a register that can be read to check the number of available Rx FIFO data. The count is incremented each time data is written to the FIFO and decremented each time data is read from the FIFO.                                                                                                                                                                                                                              |
| Enable Generic Packet Counter             | <b>Checked</b> , <b>Unchecked</b>       | Adds a register showing the number of generic packets done.                                                                                                                                                                                                                                                                                                                                                                       |
| Enable Supported Command Packet Counter   | <b>Checked</b> , <b>Unchecked</b>       | Adds a register showing the number of supported command packets done.<br>Applicable when <i>Enable Command Processing</i> == Checked.                                                                                                                                                                                                                                                                                             |
| Packet Counter max count                  | <b>16</b> - 65535                       | Maximum count determines the bit width of the packet counters (generic and supported command packet counters).<br>Applicable when <i>Enable Generic Packet Counter</i> == Checked.                                                                                                                                                                                                                                                |

### 3.2. Flash Device Configuration

This is applicable when *Enable Target Address Map* == Checked or *Enable Command Processing* == Checked. The default values shown in the following table are for Micron flash devices. The attribute values or settings may be different for flash devices from different vendors. Refer to the specific flash device data sheet before configuring these parameters.

**Table 3.2. Flash Device Configuration Attributes**

| Attribute                                    | Selectable Values          | Description                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Vendor Specific Flash Command Code</b>    |                            |                                                                                                                                                                                                                                                                                                                                        |
| Enable 2 bytes command code                  | <b>Checked</b> , Unchecked | Uses 2-byte command codes. This is usually applicable in double transfer rate (DTR) mode.<br>Fixed to Checked when <i>Enable Double Transfer Rate</i> == Checked.                                                                                                                                                                      |
| Write Enable (byte 1)                        | 0x00–0xFF, <b>0x06</b>     | Byte 1 of write enable command code.                                                                                                                                                                                                                                                                                                   |
| Write Enable (byte 2)                        | 0x00–0xFF, <b>0xF9</b>     | Byte 2 of write enable command code.<br>Applicable when <i>Enable 2 bytes command code</i> == Checked.                                                                                                                                                                                                                                 |
| Read Status Register (byte 1)                | 0x00–0xFF, <b>0x05</b>     | Byte 1 of read status register command code.                                                                                                                                                                                                                                                                                           |
| Read Status Register (byte 2)                | 0x00–0xFF, <b>0xFA</b>     | Byte 2 of read status register command code.<br>Applicable when <i>Enable 2 bytes command code</i> == Checked.                                                                                                                                                                                                                         |
| Read Security Register (byte 1)              | 0x00–0xFF, <b>0x70</b>     | Byte 1 of read security register command code.<br>This is another status register. Some flash devices may support this or may have an equivalent register. If it is not available or not supported, set this to the same value as the read status register (byte 1).                                                                   |
| Read Security Register (byte 2)              | 0x00–0xFF, <b>0x8F</b>     | Byte 2 of read security register command code.<br>This is another status register. Some flash devices may support this or may have an equivalent register. If it is not available or not supported, set this to the same value as the read status register (byte 2).<br>Applicable when <i>Enable 2 bytes command code</i> == Checked. |
| Page Program (byte 1)                        | 0x00–0xFF, <b>0x02</b>     | Byte 1 of page program command code.                                                                                                                                                                                                                                                                                                   |
| Page Program (byte 2)                        | 0x00–0xFF, <b>0xFD</b>     | Byte 2 of page program command code.<br>Applicable when <i>Enable 2 bytes command code</i> == Checked.                                                                                                                                                                                                                                 |
| Fast Read (byte 1)                           | 0x00–0xFF, <b>0x0B</b>     | Byte 1 of fast read command code.                                                                                                                                                                                                                                                                                                      |
| Fast Read (byte 2)                           | 0x00–0xFF, <b>0xF4</b>     | Byte 2 of fast read command code.<br>Applicable when <i>Enable 2 bytes command code</i> == Checked.                                                                                                                                                                                                                                    |
| Dummy Cycle: Read Status Register            | <b>0</b> – 31              | Specifies the number of dummy cycles for read status command.                                                                                                                                                                                                                                                                          |
| Dummy Cycle: Read Security Register          | <b>0</b> – 31              | Specifies the number of dummy cycles for read security command.                                                                                                                                                                                                                                                                        |
| Dummy Cycle: Fast Read                       | <b>0</b> – 31              | Specifies the number of dummy cycles for fast read command.                                                                                                                                                                                                                                                                            |
| <b>Flash Status Flags</b>                    |                            |                                                                                                                                                                                                                                                                                                                                        |
| Flash Status Busy Value                      | <b>0</b> – 1               | Specifies the value of the flash register status bit when it is busy during write, program, or erase operation.                                                                                                                                                                                                                        |
| Flash Status Register Busy bit index         | <b>0</b> – 7               | Specifies the bit location index of the flash busy status.                                                                                                                                                                                                                                                                             |
| Flash Status Register Program Fail bit index | <b>0</b> – 7, <b>4</b>     | Specifies the bit location index of the flash program fail status. Some flash devices may support this status flag. If this is not supported, set to 0.                                                                                                                                                                                |
| Flash Status Register Erase Fail bit index   | <b>0</b> – 7, <b>5</b>     | Specifies the bit location index of the flash erase fail status. Some flash devices may support this status flag. If this is not supported, set to 0.                                                                                                                                                                                  |

| Attribute                | Selectable Values      | Description                                                                                                                                                                                                                                                                                                              |
|--------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>XiP Mode</b>          |                        |                                                                                                                                                                                                                                                                                                                          |
| XiP Mode Address Padding | 0x00–0xFF, <b>0x5A</b> | <p>In Flash controller applications, this byte is inserted after the address to remain in XiP mode. Different flash device vendors may require different patterns to achieve this. Refer to the flash vendor data sheet to determine the required pattern.</p> <p>Applicable when <i>Enable XiP Mode</i> == Checked.</p> |

## 4. Signal Description

This section describes the Octal SPI Controller IP ports.

At reset, all output signals are driven low (0) except for specific SPI signals as described in [Table 4.1](#).

**Table 4.1. Octal SPI Controller Ports**

| Port                                                      | Type         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>System Clock and Reset</b>                             |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| clk_i                                                     | Input        | System clock<br>Maximum frequency is 200 MHz.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| rst_n_i                                                   | Input        | Asynchronous active low reset<br>Minimum reset pulse width is one clock cycle (clk_i). The reset goes through an internal reset synchronizer and may take several clock cycles to propagate. After de-asserting the reset, wait for at least four clock cycles before starting any transaction.                                                                                                                                                                                                                                                                                                              |
| <b>SPI Interface</b>                                      |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| spi_sck_o                                                 | Output       | SPI output clock<br>This clock is generated by the Octal SPI Controller IP. SPI data transfer is synchronous to this clock. The idle/default value is based on the SPI clock polarity attribute and is configurable/programmable.                                                                                                                                                                                                                                                                                                                                                                            |
| spi_tgt_rst_n_o                                           | Output       | Asynchronous active low reset<br>This is an optional pin to reset the SPI target and is available if selected in the IP GUI. The default state of this port is high (1).                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| spi_cs_n_o[x:0]                                           | Output       | SPI chip select<br>Active low signal for selecting the SPI target. This signal goes low when there is an active transaction or data transfer. The number of chip select signals is based on the number of supported SPI targets ( <i>Max number of SPI Target</i> ) set in the IP GUI. The default state of this port is high (1).<br><b>Note:</b> x = <i>Max number of SPI Target</i> – 1                                                                                                                                                                                                                   |
| <b>SPI Interface - Internal I/O Primitive<sup>1</sup></b> |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| spi_ds_io                                                 | Input/Output | Data strobe<br>This signal is an input to the controller during read data transfers and is driven by the target. This signal is not driven (tri-stated) by the IP core and only serves as a data strobe or clock input for the received xSPI data.                                                                                                                                                                                                                                                                                                                                                           |
| spi_dt_io[7:0]                                            | Input/Output | Bidirectional SPI data signals<br>Controller and target drivers are operating in push-pull mode. The number of data pins depends on the selected maximum number of data lanes in the IP GUI.<br>x8 – Transmit and receive data is 8 bits<br>x4 – Transmit and receive data is 4 bits<br>x2 – Transmit and receive data is 2 bits<br>x1 – Transmit data on data bit[0]; receive data on data bit[1]<br>The default state of this port is undriven (tri-stated). If the I/O pin has a pull-up resistor, the default state becomes high (1); if it has a pull-down resistor, the default state becomes low (0). |

| Port                                                           | Type   | Description                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SPI Interface - External I/O Primitive<sup>2</sup></b>      |        |                                                                                                                                                                                                                                                                                                                                                 |
| spi_ds_i                                                       | Input  | Data strobe input                                                                                                                                                                                                                                                                                                                               |
| spi_ds_o                                                       | Output | Data strobe output<br>Tied to low.                                                                                                                                                                                                                                                                                                              |
| spi_ds_oe_o                                                    | Output | Active high data strobe output enable<br>Tied to low.                                                                                                                                                                                                                                                                                           |
| spi_dt_i[7:0]                                                  | Input  | SPI data input                                                                                                                                                                                                                                                                                                                                  |
| spi_dt_o[7:0]                                                  | Output | SPI data output<br>The default state of this port is low (0).                                                                                                                                                                                                                                                                                   |
| spi_dt_oe_o[7:0]                                               | Output | Active high SPI data output enable<br>The default state of this port is low (0).                                                                                                                                                                                                                                                                |
| <b>Interrupt Interface</b>                                     |        |                                                                                                                                                                                                                                                                                                                                                 |
| int_o                                                          | Output | Level sensitive active high interrupt signal<br>This signal asserts when any of the enabled interrupt status bits is asserted.                                                                                                                                                                                                                  |
| <b>AXI4 or AXI4-Lite Interface (Data or CSR)<sup>3,4</sup></b> |        |                                                                                                                                                                                                                                                                                                                                                 |
| <b>Write Address Channel</b>                                   |        |                                                                                                                                                                                                                                                                                                                                                 |
| s_axi4_awready_o                                               | Output | Ready indicator                                                                                                                                                                                                                                                                                                                                 |
| s_axi4_awvalid_i                                               | Input  | Valid indicator                                                                                                                                                                                                                                                                                                                                 |
| s_axi4_awid_i[x:0]                                             | Input  | Transaction identifier for write channel<br>The width depends on the configured <i>AXI4 Bus ID Width</i> .<br><b>Note:</b> x = AXI4 Bus ID Width – 1<br>This is optional if the bus is AXI4-Lite.                                                                                                                                               |
| s_axi4_awaddr_i[31:0]                                          | Input  | Transaction address<br>When accessing the registers or FIFO, the address must be DWORD aligned (bit[1:0] = 0).                                                                                                                                                                                                                                  |
| s_axi4_awlen_i[7:0]                                            | Input  | Transaction length<br>The total number of transactions is encoded as Length = s_axi4_awlen_i + 1<br>When accessing the registers, s_axi4_awlen_i must be set to 0 (single transfer).<br>Variable length can be used when accessing the FIFO or target address space.<br>This is not available if the bus is AXI4-Lite and length is fixed to 1. |
| s_axi4_awsize_i[2:0]                                           | Input  | Transaction size<br>2 – 4 bytes per transfer<br>Other values are not supported/reserved.<br>This is not available if the bus is AXI4-Lite.                                                                                                                                                                                                      |
| s_axi4_awburst_i[1:0]                                          | Input  | Burst type<br>0 – Fixed burst<br>1 – Incrementing burst<br>Other values are not supported/reserved.<br>When accessing the registers or FIFO, s_axi4_awburst_i must be set to 0 (fixed burst transfer). s_axi4_awburst_i = 1 can be used when accessing the target address space.<br>This is not available if the bus is AXI4-Lite.              |
| <b>Write Data Channel</b>                                      |        |                                                                                                                                                                                                                                                                                                                                                 |
| s_axi4_wready_o                                                | Output | Ready indicator                                                                                                                                                                                                                                                                                                                                 |
| s_axi4_wvalid_i                                                | Input  | Valid indicator                                                                                                                                                                                                                                                                                                                                 |
| s_axi4_wdata_i[31:0]                                           | Input  | Write data                                                                                                                                                                                                                                                                                                                                      |
| s_axi4_wstrb_i[3:0]                                            | Input  | Write data strobes                                                                                                                                                                                                                                                                                                                              |
| s_axi4_wlast_i                                                 | Input  | Last write data<br>This is not available if the bus is AXI4-Lite.                                                                                                                                                                                                                                                                               |

| Port                          | Type   | Description                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Write Response Channel</b> |        |                                                                                                                                                                                                                                                                                                                                                        |
| s_axi4_bready_i               | Input  | Ready indicator                                                                                                                                                                                                                                                                                                                                        |
| s_axi4_bvalid_o               | Output | Valid indicator                                                                                                                                                                                                                                                                                                                                        |
| s_axi4_bid_o[x:0]             | Output | Transaction identifier for write channel<br><b>Note:</b> $x = AXI4\ Bus\ ID\ Width - 1$<br>This is optional if the bus is AXI4-Lite.                                                                                                                                                                                                                   |
| s_axi4_bresp_o[1:0]           | Output | Write response                                                                                                                                                                                                                                                                                                                                         |
| <b>Read Address Channel</b>   |        |                                                                                                                                                                                                                                                                                                                                                        |
| s_axi4_arready_o              | Output | Ready indicator                                                                                                                                                                                                                                                                                                                                        |
| s_axi4_arvalid_i              | Input  | Valid indicator                                                                                                                                                                                                                                                                                                                                        |
| s_axi4_arid_i[x:0]            | Input  | Transaction identifier for read channel<br>The width depends on the configured <i>AXI4 Bus ID Width</i> .<br><b>Note:</b> $x = AXI4\ Bus\ ID\ Width - 1$<br>This is optional if the bus is AXI4-Lite.                                                                                                                                                  |
| s_axi4_araddr_i[31:0]         | Input  | Transaction address<br>When accessing the registers or FIFO, the address must be DWORD aligned (bit[1:0] = 0).                                                                                                                                                                                                                                         |
| s_axi4_arlen_i[7:0]           | Input  | Transaction length<br>The total number of transactions is encoded as Length = $s\_axi4\_arlen\_i + 1$<br>When accessing the registers, $s\_axi4\_arlen\_i$ must be set to 0 (single transfer). Variable length can be used when accessing the FIFO or target address space.<br>This is not available if the bus is AXI4-Lite and length is fixed to 1. |
| s_axi4_arsize_i[2:0]          | Input  | Transaction size<br>2 – 4 bytes per transfer<br>Other values are not supported/reserved.<br>This is not available if the bus is AXI4-Lite.                                                                                                                                                                                                             |
| s_axi4_arburst_i[1:0]         | Input  | Burst type<br>0 – Fixed burst<br>1 – Incrementing burst<br>Other values are not supported/reserved.<br>When accessing the registers or FIFO, $s\_axi4\_arburst\_i$ must be set to 0 (fixed burst transfer). $s\_axi4\_arburst\_i = 1$ can be used when accessing the target address space.<br>This is not available if the bus is AXI4-Lite.           |
| <b>Read Data Channel</b>      |        |                                                                                                                                                                                                                                                                                                                                                        |
| s_axi4_rready_i               | Input  | Ready indicator                                                                                                                                                                                                                                                                                                                                        |
| s_axi4_rvalid_o               | Output | Valid indicator                                                                                                                                                                                                                                                                                                                                        |
| s_axi4_rid_o[x:0]             | Output | Transaction identifier for read channel<br><b>Note:</b> $x = AXI4\ Bus\ ID\ Width - 1$<br>This is optional if the bus is AXI4-Lite.                                                                                                                                                                                                                    |
| s_axi4_rdata_o[31:0]          | Output | Read data                                                                                                                                                                                                                                                                                                                                              |
| s_axi4_rrresp_o[1:0]          | Output | Read response                                                                                                                                                                                                                                                                                                                                          |
| s_axi4_rlast_o                | Output | Last read data                                                                                                                                                                                                                                                                                                                                         |

| Port                                                                                                         | Type   | Description                                                                                                                                                                                                                   |
|--------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>AXI4-Lite Interface (CSR)<sup>3</sup> – Applicable only if dual bus interface is selected<sup>5</sup></b> |        |                                                                                                                                                                                                                               |
| <b>Write Address Channel</b>                                                                                 |        |                                                                                                                                                                                                                               |
| s_axi4_c_awready_o                                                                                           | Output | Ready indicator                                                                                                                                                                                                               |
| s_axi4_c_awvalid_i                                                                                           | Input  | Valid indicator                                                                                                                                                                                                               |
| s_axi4_c_awid_i[x:0]                                                                                         | Input  | Transaction identifier for write channel<br>The width depends on the configured <i>AXI4 Bus ID Width</i> .<br><b>Note:</b> $x = AXI4 Bus ID Width - 1$<br>Available only if <i>Enable AXI4-Lite ID</i> is selected in IP GUI. |
| s_axi4_c_awaddr_i[31:0]                                                                                      | Input  | Transaction address<br>When accessing the registers or FIFO, the address must be DWORD aligned (bit[1:0] = 0).                                                                                                                |
| <b>Write Data Channel</b>                                                                                    |        |                                                                                                                                                                                                                               |
| s_axi4_c_wready_o                                                                                            | Output | Ready indicator                                                                                                                                                                                                               |
| s_axi4_c_wvalid_i                                                                                            | Input  | Valid indicator                                                                                                                                                                                                               |
| s_axi4_c_wdata_i[31:0]                                                                                       | Input  | Write data                                                                                                                                                                                                                    |
| s_axi4_c_wstrb_i[3:0]                                                                                        | Input  | Write data strobes                                                                                                                                                                                                            |
| <b>Write Response Channel</b>                                                                                |        |                                                                                                                                                                                                                               |
| s_axi4_c_bready_i                                                                                            | Input  | Ready indicator                                                                                                                                                                                                               |
| s_axi4_c_bvalid_o                                                                                            | Output | Valid indicator                                                                                                                                                                                                               |
| s_axi4_c_bid_o[x:0]                                                                                          | Output | Transaction identifier for write channel<br><b>Note:</b> $x = AXI4 Bus ID Width - 1$                                                                                                                                          |
| s_axi4_c_bresp_o[1:0]                                                                                        | Output | Write response                                                                                                                                                                                                                |
| <b>Read Address Channel</b>                                                                                  |        |                                                                                                                                                                                                                               |
| s_axi4_c_arready_o                                                                                           | Output | Ready indicator                                                                                                                                                                                                               |
| s_axi4_c_arvalid_i                                                                                           | Input  | Valid indicator                                                                                                                                                                                                               |
| s_axi4_c_arid_i[x:0]                                                                                         | Input  | Transaction identifier for read channel<br>The width depends on the configured <i>AXI4 Bus ID Width</i> .<br><b>Note:</b> $x = AXI4 Bus ID Width - 1$<br>Available only if <i>Enable AXI4-Lite ID</i> is selected in IP GUI.  |
| s_axi4_c_araddr_i[31:0]                                                                                      | Input  | Transaction address<br>When accessing the registers or FIFO, the address must be DWORD aligned (bit[1:0] = 0).                                                                                                                |
| <b>Read Data Channel</b>                                                                                     |        |                                                                                                                                                                                                                               |
| s_axi4_c_rready_i                                                                                            | Input  | Ready indicator                                                                                                                                                                                                               |
| s_axi4_c_rvalid_o                                                                                            | Output | Valid indicator                                                                                                                                                                                                               |
| s_axi4_c_rid_o[x:0]                                                                                          | Output | Transaction identifier for read channel<br><b>Note:</b> $x = AXI4 Bus ID Width - 1$<br>Available only if <i>Enable AXI4-Lite ID</i> is selected in IP GUI.                                                                    |
| s_axi4_c_rdata_o[31:0]                                                                                       | Output | Read data                                                                                                                                                                                                                     |
| s_axi4_c_rresp_o[1:0]                                                                                        | Output | Read response                                                                                                                                                                                                                 |

| Port                                                                                                    | Type   | Description                                                                                                                                                                                                                                |
|---------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>AXI4 Interface (CSR)<sup>3</sup> – Applicable only if dual bus interface is selected<sup>5</sup></b> |        |                                                                                                                                                                                                                                            |
| <b>Write Address Channel</b>                                                                            |        |                                                                                                                                                                                                                                            |
| s_axi4_c_awready_o                                                                                      | Output | Ready indicator                                                                                                                                                                                                                            |
| s_axi4_c_awvalid_i                                                                                      | Input  | Valid indicator                                                                                                                                                                                                                            |
| s_axi4_c_awid_i[x:0]                                                                                    | Input  | Transaction identifier for write channel<br>The width depends on the configured <i>AXI4 Bus ID Width</i> .<br><b>Note:</b> x = AXI4 Bus ID Width – 1                                                                                       |
| s_axi4_c_awaddr_i[31:0]                                                                                 | Input  | Transaction address<br>When accessing the registers or FIFO, the address must be DWORD aligned (bit[1:0] = 0).                                                                                                                             |
| s_axi4_c_awlen_i[7:0]                                                                                   | Input  | Transaction length<br>The total number of transactions is encoded as Length = s_axi4_awlen_i + 1.<br>When accessing the registers, s_axi4_awlen_i must be set to 0 (single transfer). Variable length can be used when accessing the FIFO. |
| s_axi4_c_awsize_i[2:0]                                                                                  | Input  | Transaction size<br>2 to 4 bytes per transfer. Other values are reserved or not supported.                                                                                                                                                 |
| s_axi4_c_awburst_i[1:0]                                                                                 | Input  | Burst type<br>0 – Fixed burst<br>1 – Incrementing burst<br>Other values are reserved or not supported.<br>When accessing the registers or FIFO, s_axi4_awburst_i must be set to 0 (fixed burst transfer).                                  |
| <b>Write Data Channel</b>                                                                               |        |                                                                                                                                                                                                                                            |
| s_axi4_c_wready_o                                                                                       | Output | Ready indicator                                                                                                                                                                                                                            |
| s_axi4_c_wvalid_i                                                                                       | Input  | Valid indicator                                                                                                                                                                                                                            |
| s_axi4_c_wdata_i[31:0]                                                                                  | Input  | Write data                                                                                                                                                                                                                                 |
| s_axi4_c_wstrb_i[3:0]                                                                                   | Input  | Write data strobes                                                                                                                                                                                                                         |
| s_axi4_c_wlast_i                                                                                        | Input  | Last write data                                                                                                                                                                                                                            |
| <b>Write Response Channel</b>                                                                           |        |                                                                                                                                                                                                                                            |
| s_axi4_c_bready_i                                                                                       | Input  | Ready indicator                                                                                                                                                                                                                            |
| s_axi4_c_bvalid_o                                                                                       | Output | Valid indicator                                                                                                                                                                                                                            |
| s_axi4_c_bid_o[x:0]                                                                                     | Output | Transaction identifier for write channel<br><b>Note:</b> x = AXI4 Bus ID Width – 1                                                                                                                                                         |
| s_axi4_c_bresp_o[1:0]                                                                                   | Output | Write response                                                                                                                                                                                                                             |
| <b>Read Address Channel</b>                                                                             |        |                                                                                                                                                                                                                                            |
| s_axi4_c_arready_o                                                                                      | Output | Ready indicator                                                                                                                                                                                                                            |
| s_axi4_c_arvalid_i                                                                                      | Input  | Valid indicator                                                                                                                                                                                                                            |
| s_axi4_c_arid_i[x:0]                                                                                    | Input  | Transaction identifier for read channel<br>The width depends on the configured <i>AXI4 Bus ID Width</i> .<br><b>Note:</b> x = AXI4 Bus ID Width – 1                                                                                        |
| s_axi4_c_araddr_i[31:0]                                                                                 | Input  | Transaction address<br>When accessing the registers or FIFO, the address must be DWORD aligned (bit[1:0] = 0).                                                                                                                             |
| s_axi4_c_arlen_i[7:0]                                                                                   | Input  | Transaction length<br>The total number of transactions is encoded as Length = s_axi4_arlen_i + 1.<br>When accessing the registers, s_axi4_arlen_i must be set to 0 (single transfer). Variable length can be used when accessing the FIFO. |
| s_axi4_c_arsize_i[2:0]                                                                                  | Input  | Transaction size<br>2 to 4 bytes per transfer. Other values are reserved or not supported.                                                                                                                                                 |

| Port                                           | Type   | Description                                                                                                                                                                                               |
|------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| s_axi4_c_arburst_i[1:0]                        | Input  | Burst type<br>0 – Fixed burst<br>1 – Incrementing burst<br>Other values are reserved or not supported.<br>When accessing the registers or FIFO, s_axi4_arburst_i must be set to 0 (fixed burst transfer). |
| <b>Read Data Channel</b>                       |        |                                                                                                                                                                                                           |
| s_axi4_c_rready_i                              | Input  | Ready indicator                                                                                                                                                                                           |
| s_axi4_c_rvalid_o                              | Output | Valid indicator                                                                                                                                                                                           |
| s_axi4_c_rid_o[x:0]                            | Output | Transaction identifier for read channel<br><b>Note:</b> x = AXI4 Bus ID Width – 1                                                                                                                         |
| s_axi4_c_rdata_o[31:0]                         | Output | Read data                                                                                                                                                                                                 |
| s_axi4_c_rresp_o[1:0]                          | Output | Read response                                                                                                                                                                                             |
| s_axi4_c_rlast_o                               | Output | Last read data                                                                                                                                                                                            |
| <b>APB Interface<sup>3</sup> (Data or CSR)</b> |        |                                                                                                                                                                                                           |
| s_apb_psel_i                                   | Input  | APB select signal<br>Indicates that the target device is selected, and a data transfer is required.                                                                                                       |
| s_apb_penable_i                                | Input  | APB enable signal<br>Indicates the second and subsequent cycles of an APB transfer.                                                                                                                       |
| s_apb_paddr_i [31:0]                           | Input  | APB address signal<br>Address must be DWORD aligned (bit[1:0] = 0).                                                                                                                                       |
| s_apb_pwrite_i                                 | Input  | APB write signal<br>0 – Read<br>1 – Write                                                                                                                                                                 |
| s_apb_pwdata_i [31:0]                          | Input  | APB write data signal                                                                                                                                                                                     |
| s_apb_prdata_o [31:0]                          | Output | APB read data signal                                                                                                                                                                                      |
| s_apb_pready_o                                 | Output | APB ready signal<br>Indicates transfer completion. Completer uses this signal to extend an APB transfer.                                                                                                  |
| s_apb_pslverr_o                                | Output | APB error signal                                                                                                                                                                                          |

**Notes:**

1. Bidirectional SPI interface is only available when internal I/O primitives are enabled in the IP GUI.
2. External I/O SPI interface is only available when internal I/O primitives are disabled in the IP GUI.
3. Availability of signals depends on the selected interface in the IP GUI.
4. For the single bus interface, AXI4 and AXI4-Lite signals use the same signal names.
5. For the dual bus interface, AXI4 and AXI4-Lite signals for access through the CSR interface are denoted with \_c (for example, s\_axi4\_c\_rready\_i).

## 5. Register Description

### 5.1. Overview

This section defines the configuration, status, and control registers of the Octal SPI Controller IP. The Octal SPI Controller IP registers have a total address space region of 1 KiB.

**Table 5.1** defines the register access types. **Table 5.2** lists the address map and specifies the registers available. These registers are accessible through the selected CSR interface (AXI4, AXI4-Lite, APB).

**Table 5.1. Register Access Types**

| Access Type               | Access Type Abbreviation | Behavior on Read Access | Behavior on Write Access                                                                      |
|---------------------------|--------------------------|-------------------------|-----------------------------------------------------------------------------------------------|
| Read only                 | RO                       | Returns register value  | Ignores write access                                                                          |
| Write only                | WO                       | Returns 0               | Updates register value                                                                        |
| Read and write            | RW                       | Returns register value  | Updates register value                                                                        |
| Read and write 1 to clear | RW1C                     | Returns register value  | Writing 1'b1 on register bit clears the bit to 1'b0. Writing 1'b0 on register bit is ignored. |

**Table 5.2. Summary of Octal SPI Controller IP Core Registers**

| Offset Address <sup>1</sup>    | Register Name                                   | Description                                            |
|--------------------------------|-------------------------------------------------|--------------------------------------------------------|
| <b>Configuration Registers</b> |                                                 |                                                        |
| 0x000                          | Reserved                                        | Reserved address for configuration register            |
| 0x004                          | Octal SPI Configuration 0 Register              | Configures SPI settings                                |
| 0x008                          | Octal SPI Configuration 1 Register              | Configures transaction counters                        |
| 0x00C                          | Supported Command Code 0 Register               | Vendor specific flash command code                     |
| 0x010                          | Supported Command Code 1 Register               | Vendor specific flash command code                     |
| 0x014                          | Supported Command Code 2 Register               | Vendor specific flash command code                     |
| 0x018                          | Supported Command Configuration Register        | Configures SPI transaction settings                    |
| 0x02C                          | Minimum Target Address Alignment Register       | Configures address alignment per target                |
| 0x030                          | Target Start Address Offset Register            | Configures address offset per target                   |
| 0x034                          | Total Target Address Map Alignment Register     | Configures total target address alignment              |
| 0x038                          | Target AXI4 Base Address Register               | Configures base address for total target address space |
| 0x03C                          | Interrupt Enable Register                       | Enables interrupt output                               |
| <b>Status Registers</b>        |                                                 |                                                        |
| 0x100                          | Interrupt Status Register                       | Interrupt event information                            |
| 0x104                          | Generic SPI Command Packet Counter Register     | Packet counter information                             |
| 0x108                          | Supported Flash Command Packet Counter Register | Packet counter information                             |
| 0x10C                          | Octal SPI Debug Information 0 Register          | Miscellaneous status and information                   |
| 0x110                          | Octal SPI Debug Information 1 Register          | FIFO data count information                            |
| <b>Control Registers</b>       |                                                 |                                                        |
| 0x200                          | Tx FIFO Register                                | Transmit FIFO mapping                                  |
| 0x204                          | Rx FIFO Register                                | Receive FIFO mapping                                   |
| 0x208                          | Packet Header 0 Register                        | User packet structure for generic SPI commands         |
| 0x20C                          | Packet Header 1 Register                        | User packet structure for support flash commands       |
| 0x210                          | Packet Header 2 Register                        | User packet structure for support flash commands       |
| 0x214                          | Packet Header 3 Register                        | User packet structure for support flash commands       |
| 0x218                          | Write Data Register                             | Payload data register                                  |
| 0x21C                          | Read Data Register                              | Return data register                                   |
| 0x220                          | Start Transaction Register                      | Start IP operation to generate SPI transaction         |

| Offset Address <sup>1</sup> | Register Name             | Description                   |
|-----------------------------|---------------------------|-------------------------------|
| 0x224                       | Interrupt Set Register    | Triggers the interrupt status |
| 0x228                       | Test Mode Register        | Control for loopback test     |
| 0x22C                       | Soft Reset Register       | Programmable reset control    |
| 0x230                       | IO Delay Control Register | Controls the SPI IO delay     |

**Note:**

1. AXI4 starting offset (s\_axi4\_awaddr\_i[9:0] or s\_axi4\_araddr\_i[9:0]).

## 5.2. Configuration Registers

### 5.2.1. Octal SPI Configuration 0 Register

Table 5.3. Octal SPI Configuration 0 Register

| Field   | Name                 | Description                                                                                                                                                                                                                                                                                                                                             | Access | Default                             |
|---------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------|
| [31:24] | <i>reserved</i>      | Reserved                                                                                                                                                                                                                                                                                                                                                | RO     | 0x0                                 |
| [23]    | non_blocking_rx fifo | When Rx FIFO is empty and there is a read access:<br>0 – Wait until Rx FIFO is not empty. This may block the bus from accepting a new request.<br>1 – Do not wait for Rx FIFO status and return any (garbage) data.<br>Applicable only when FIFO is enabled in the IP GUI.                                                                              | RW     | <i>Default Non-blocking Rx FIFO</i> |
| [22]    | non_blocking_tx fifo | When Tx FIFO is full and there is a write access:<br>0 – Wait until Tx FIFO is not full. This may block the bus from accepting a new request.<br>1 – Do not wait for Tx FIFO status and discard the write data.<br>Applicable only when FIFO is enabled in the IP GUI.                                                                                  | RW     | <i>Default Non-blocking Tx FIFO</i> |
| [21]    | use_ds_in_ddrmode    | When set, the read data is captured using the input data strobe generated by the target device.<br>0 – Use SCK to sample read data<br>1 – Use data strobe signal from target device to sample read data<br>Applicable only when <i>Programmable Use DS == Checked</i> .                                                                                 | RW     | <i>Default Use DS value</i>         |
| [20]    | auto_clr_soft_rst    | 0 – Do not auto-clear the soft reset.<br>1 – Auto-clear the soft reset. The soft reset register automatically returns to 0 after write of 1.                                                                                                                                                                                                            | RW     | 0x1                                 |
| [19]    | auto_clr_tx_start    | Auto clear the tx_start register<br>0 – Do not auto-clear tx_start after command is done.<br>1 – Auto-clear tx_start after a command is done. This is useful when debugging to allow execution of commands one at a time.<br>Applicable only when FIFO is enabled in the IP GUI.                                                                        | RW     | 0x0                                 |
| [18]    | <i>reserved</i>      | Reserved                                                                                                                                                                                                                                                                                                                                                | RO     | 0x0                                 |
| [17]    | en_addr_space_map    | Enables mapping of target device in the bus. When set, the target device must have a valid address space allocation in the bus.<br>0 – No address mapping for target device<br>1 – Target device is mapped in the bus address space<br>Applicable only when <i>Enable Target Address Map == Checked</i> and <i>Programmable Memory Map == Checked</i> . | RW     | <i>Programmable Memory Map</i>      |

| Field   | Name            | Description                                                                                                                                                                                                                                                                                                                                                                       | Access | Default                            |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------|
| [16]    | endianness      | Data endianness format in the bus<br>0 – Little endian<br>1 – Big endian                                                                                                                                                                                                                                                                                                          | RO     | <i>Default Endianness</i>          |
| [15:13] | <i>reserved</i> | Reserved                                                                                                                                                                                                                                                                                                                                                                          | RO     | 0x0                                |
| [12:8]  | sck_rate        | Clock divider value that is used to generate SCK clock (spi_sck_o)<br>0 – Divide by 1 (SCK is the same as clk_i)<br>1 – Divide by 2 of clk_i<br>2 – Divide by 4 of clk_i<br>3 – Divide by 6 of clk_i<br>...<br>SCK Frequency = clk_i / (2 × sck_rate)<br>When <i>JEDEC xSPI Support</i> = Unchecked, the minimum value that can be set on this register is 1 (clock divide by 2). | RW     | <i>SPI Clock (SCK) Pulse width</i> |
| [7:3]   | <i>reserved</i> | Reserved                                                                                                                                                                                                                                                                                                                                                                          | RO     | 0x0                                |
| [2]     | cpol            | Clock polarity<br>0 – Active high clock. Clock is low in idle state.<br>1 – Active low clock. Clock is high in idle state.<br>Applicable only when <i>Programmable CPOL</i> == Checked.                                                                                                                                                                                           | RW     | <i>Default CPOL value</i>          |
| [1]     | cpha            | Clock phase setting changes the transmission format in SPI.<br>0 – Sampling of data occurs at odd edges (1, 3, 5, ..., 15) of the SCK clock.<br>1 – Sampling of data occurs at even edges (2, 4, 6, ..., 16) of the SCLK clock.<br>Applicable only when <i>Programmable CPHA</i> == Checked.                                                                                      | RW     | <i>Default CPHA value</i>          |

| Field | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Access | Default             |
|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------|
| [0]   | lsbf | <p>LSB first setting configures the way the data is transmitted or received on the SPI interface.</p> <p>0 – Transmit/Receive MSB first<br/>1 – Transmit/Receive LSB first</p> <p>Applicable only when <i>Programmable LSBF</i> == Checked.</p> <p>x1 MSB first in spi_dt_io[0] (receive in spi_dt_io [1])<br/>spi_dt_io [0] -&gt; 7,6,5,4,3,2,1,0<br/>spi_dt_io [1] &lt;- 7,6,5,4,3,2,1,0</p> <p>x1 LSB first in SPI spi_dt_io [0] (receive in spi_dt_io [1])<br/>spi_dt_io [0] -&gt; 0,1,2,3,4,5,6,7<br/>spi_dt_io [1] &lt;- 0,1,2,3,4,5,6,7</p> <p>x2 MSB first in SPI spi_dt_io [1:0]<br/>spi_dt_io [0] -&gt; 6,4,2,0<br/>spi_dt_io [1] -&gt; 7,5,3,1</p> <p>x2 LSB first in SPI spi_dt_io [1:0]<br/>spi_dt_io [0] -&gt; 0,2,4,6<br/>spi_dt_io [1] -&gt; 1,3,5,7</p> <p>x4 MSB first in SPI spi_dt_io [3:0]<br/>spi_dt_io [0] -&gt; 4,0<br/>spi_dt_io [1] -&gt; 5,1<br/>spi_dt_io [2] -&gt; 6,2<br/>spi_dt_io [3] -&gt; 7,3</p> <p>x4 LSB first in SPI spi_dt_io [3:0]<br/>spi_dt_io [0] -&gt; 0,4<br/>spi_dt_io [1] -&gt; 1,5<br/>spi_dt_io [2] -&gt; 2,6<br/>spi_dt_io [3] -&gt; 3,7</p> <p>x8<br/>spi_dt_io [7:0] -&gt; data[7:0]</p> | RW     | <i>Default LSBF</i> |

## 5.2.2. Octal SPI Configuration 1 Register

Applicable only when *Enable Generic Packet Counter* == Checked or *Enable Supported Command Packet Counter* == Checked in the IP GUI.

**Table 5.4. Octal SPI Configuration 1 Register**

| Field   | Name                | Description                                                                                                                                                                                                                                                                                                                                                                                                                               | Access | Default |
|---------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:16] | rd_trans_int_thresh | Configures the read transaction count threshold for interrupt. When the read transaction counter is equal to or greater than this number, interrupt status asserts. The actual register bit width depends on the <i>Packet Counter max count</i> setting. Unused bits are read-only. For example, if <i>Packet Counter max count</i> is set to 16 in the IP GUI, then only bits 20 down to 16 are valid and the upper bits are read-only. | RW     | 0x1     |
| [15:0]  | wr_trans_int_thresh | Configures the write transaction count threshold for interrupt. When the write transaction counter is equal to or greater than this number, interrupt status asserts. The actual register bit width depends on the <i>Packet Counter max count</i> setting. Unused bits are read-only. For example, if <i>Packet Counter max count</i> is set to 16 in the IP GUI, then only bits 4 down to 0 are valid and the upper bits are read-only. | RW     | 0x1     |

## 5.2.3. Supported Command Code 0 Register

Available only when *Programmable Command Code* == Checked in the IP GUI.

**Table 5.5. Supported Command Code 0 Register**

| Field   | Name     | Description                                                                                                           | Access | Default                      |
|---------|----------|-----------------------------------------------------------------------------------------------------------------------|--------|------------------------------|
| [31:16] | reserved | Reserved                                                                                                              | RO     | 0x0                          |
| [15:8]  | wren_b1  | The second byte of the write enable command code. Applicable only when <i>Enable 2 bytes command code</i> == Checked. | RW     | <i>Write Enable (byte 2)</i> |
| [7:0]   | wren_b0  | Write enable command code                                                                                             | RW     | <i>Write Enable (byte 1)</i> |

## 5.2.4. Supported Command Code 1 Register

Available only when *Programmable Command Code* == Checked in the IP GUI.

**Table 5.6. Supported Command Code 1 Register**

| Field   | Name      | Description                                                                                                                                                       | Access | Default                                |
|---------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------|
| [31:24] | rdscur_b1 | The second byte of the read security or read flag status register command code. Applicable only when <i>Enable 2 bytes command code</i> == Checked in the IP GUI. | RW     | <i>Read Security Register (byte 2)</i> |
| [23:16] | rdscur_b0 | Read security or read flag status register command code.                                                                                                          | RW     | <i>Read Security Register (byte 1)</i> |
| [15:8]  | rdsr_b1   | The second byte of the read status register command code. Applicable only when <i>Enable 2 bytes command code</i> == Checked in the IP GUI.                       | RW     | <i>Read Status Register (byte 2)</i>   |
| [7:0]   | rdsr_b0   | Read status register command code.                                                                                                                                | RW     | <i>Read Status Register (byte 1)</i>   |

### 5.2.5. Supported Command Code 2 Register

Available only when *Programmable Command Code* == Checked in the IP GUI.

**Table 5.7. Supported Command Code 2 Register**

| Field   | Name            | Description                                                                                                                            | Access | Default               |
|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------|
| [31:24] | fast_read_b1    | The second byte of the fast read command code.<br>Applicable only when <i>Enable 2 bytes command code</i> == Checked in the IP GUI.    | RW     | Fast Read (byte 2)    |
| [23:16] | fast_read_b0    | Fast read command code                                                                                                                 | RW     | Fast Read (byte 1)    |
| [15:8]  | page_program_b1 | The second byte of the page program command code.<br>Applicable only when <i>Enable 2 bytes command code</i> == Checked in the IP GUI. | RW     | Page Program (byte 2) |
| [7:0]   | page_program_b0 | Page program command code                                                                                                              | RW     | Page Program (byte 1) |

### 5.2.6. Supported Command Configuration Register

This register specifies default transfer settings and dummy cycles. Available only when *Programmable Command Code* == Checked in the IP GUI. These settings are used when the IP core is performing transactions from supported flash command packet or target memory map access (XiP or non-XiP mode).

**Table 5.8. Supported Command Configuration Register**

| Field   | Name            | Description                                                                                                                                                                                                                                                                       | Access | Default |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31]    | addr_mode_r     | Addressing mode to be used when performing XiP or non-XiP target memory mapped access.<br>0 – 24b address<br>1 – 32b address<br>Applicable only when <i>Enable Target Address Map</i> == Checked and <i>Programmable Memory Map</i> == Checked.                                   | RW     | 0x1     |
| [30]    | en_2byte_fcc    | Indicates the number of bytes of command code to be sent when in STR mode. In DTR mode, the command is 2 bytes by default and is not affected by this setting.<br>0 – 1-byte command<br>1 – 2-byte command<br>Applicable only when <i>Enable 2 bytes command code</i> == Checked. | RW     | 0x0     |
| [29]    | en_sr_addr      | Indicates if an address is necessary when sending read status command or read security command.<br>0 – No address<br>1 – Include 4-byte address 0x0000_0000                                                                                                                       | RW     | 0x0     |
| [28:24] | fast_read_dummy | Default number of dummy cycles required for fast read command.                                                                                                                                                                                                                    | RW     | 0x0     |
| [23:21] | reserved        | Reserved                                                                                                                                                                                                                                                                          | RO     | 0x0     |
| [20:16] | rdscur_dummy    | Default number of dummy cycles required for read security register (or read flag status register) command.                                                                                                                                                                        | RW     | 0x0     |
| [15:13] | reserved        | Reserved                                                                                                                                                                                                                                                                          | RO     | 0x0     |
| [12:8]  | rdsr_dummy      | Default number of dummy cycles required for read status register command.                                                                                                                                                                                                         | RW     | 0x0     |

| Field | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                     | Access | Default |
|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [7]   | wait_ds_r    | Applicable only in DTR when there is a data strobe.<br>0 – No data strobe. Read data will be sampled after the specified dummy cycle or wait state.<br>1 – Read data arrives along with data strobe. The number of dummy cycles is irrelevant. The Octal SPI Controller IP continuously provides a clock until all the requested data are retrieved.                                                                            | RW     | 0x0     |
| [6:4] | xfer_rate_r  | Transfer rate setting specifies the transfer rate to be used for each phase: Command (xfer_rate[2]), Address (xfer_rate[1]), and Data (xfer_rate[0]). DTR is currently only valid in x8 width.<br>0 – STR<br>1 – DTR                                                                                                                                                                                                            | RW     | 0x0     |
| [3:0] | lane_width_r | SPI I/O data width setting indicates the number of lanes to use in each phase (Command, Address, and Data).<br>4'h0 – (x1, x1, x1)<br>4'h1 – (x2, x2, x2)<br>4'h2 – (x4, x4, x4)<br>4'h3 – (x8, x8, x8)<br>4'h4 – (x1, x1, x2)<br>4'h5 – (x1, x2, x2)<br>4'h6 – 4'h7 – reserved<br>4'h8 – (x1, x1, x4)<br>4'h9 – (x1, x4, x4)<br>4'hA – 4'hB – reserved<br>4'hC – (x1, x1, x8)<br>4'hD – (x1, x8, x8)<br>4'hE – 4'hF – reserved | RW     | 0x0     |

### 5.2.7. Minimum Target Address Alignment Register

Applicable only when *Enable Target Address Map* == Checked and *Programmable Memory Map* == Checked in the IP GUI.

**Table 5.9. Minimum Target Address Alignment Register**

| Field   | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Access | Default                                                                 |
|---------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------|
| [31:10] | min_tgt_addr_align | This setting identifies the target address alignment based on the size of the target memory map. The lower bits that are within the memory map size value are set to 0 while the upper bits are set to 1. The minimum size should be 1 KiB.<br>For example, if the memory map size is 1 KiB (0x400), then the lower 10 bits ([9:0]) correspond to the offset and the upper bits [31:10] are the base address. Thus, the min_tgt_addr_align value is 0xFFFF_FC00. | RW     | Calculated based on the attribute value <i>Target Memory Map Size</i> . |
| [9:0]   | min_tgt_addr_align |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RO     | 0x0                                                                     |

### 5.2.8. Target Start Address Offset Register

Applicable only when *Enable Target Address Map* == Checked and *Programmable Memory Map* == Checked in the IP GUI.

**Table 5.10. Target Start Address Offset Register**

| Field   | Name           | Description                                                                                                       | Access | Default                            |
|---------|----------------|-------------------------------------------------------------------------------------------------------------------|--------|------------------------------------|
| [31:10] | tgt_start_addr | This is the actual address offset of the target memory map. The minimum address offset alignment should be 1 KiB. | RW     | <i>Target Actual Start Address</i> |
| [9:0]   | tgt_start_addr |                                                                                                                   | RO     | 0x0                                |

### 5.2.9. Total Target Address Map Alignment Register

Applicable only when *Enable Target Address Map* == Checked and *Programmable Memory Map* == Checked in the IP GUI.

**Table 5.11. Total Target Address Map Alignment Register**

| Field   | Name                 | Description                                                                                                                                                                                                                                                                                                                                       | Access | Default                                                                       |
|---------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------|
| [31:10] | total_addr_map_align | This setting identifies the target address alignment in the AXI4 bus based on the total size of the memory map. For single target only, it has the same value as the minimum target address alignment. The lower bits that are within the memory map size value are set to 0 while the upper bits are set to 1. The minimum size should be 1 KiB. | RW     | Calculated based on the attribute value <i>Total Target Memory Map Size</i> . |
| [9:0]   | total_addr_map_align | For example, if the total memory map size is 64 KiB (0x10000), then the lower 16 bits ([15:0]) correspond to the offset and the upper bits [31:16] are the base address. Thus, the total_addr_map_align value is 0xFFFF_0000.                                                                                                                     | RO     | 0x0                                                                           |

### 5.2.10. Target AXI4 Base Address Register

Applicable only when *Enable Target Address Map* == Checked and *Programmable Memory Map* == Checked in the IP GUI.

**Table 5.12. Target AXI4 Base Address Register**

| Field   | Name        | Description                                                                                                   | Access | Default                              |
|---------|-------------|---------------------------------------------------------------------------------------------------------------|--------|--------------------------------------|
| [31:10] | tgt_axi_bar | This is the AXI4 base address of the target memory map. The minimum address offset alignment should be 1 KiB. | RW     | <i>Target Map: AXI4 Base Address</i> |
| [9:0]   | tgt_axi_bar |                                                                                                               | RO     | 0x0                                  |

### 5.2.11. Interrupt Enable Register

Each interrupt enable bit is applicable only when the corresponding interrupt status is applicable for the device configuration.

**Table 5.13. Interrupt Enable Register**

| Field   | Name               | Description                                           | Access | Default |
|---------|--------------------|-------------------------------------------------------|--------|---------|
| [31:18] | reserved           | Reserved                                              | RO     | 0x0     |
| [17]    | flash_program_fail | See description for bit[13:0].                        | RW     | 0x0     |
| [16]    | flash_erase_fail   |                                                       | RW     | 0x0     |
| [15:14] | reserved           | Reserved                                              | RO     | 0x0     |
| [13]    | rd_on_empty_error  | When set to high, enables the corresponding interrupt | RW     | 0x0     |

| Field | Name                  | Description                                                                                                                                                     | Access | Default |
|-------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [12]  | wr_on_full_error      | status signal to cause the assertion of the interrupt port signal (int_o). Refer to the <a href="#">Interrupt Status Register</a> section for more information. | RW     | 0x0     |
| [11]  | bus_access_error      |                                                                                                                                                                 | RW     | 0x0     |
| [10]  | user_pkt_decode_error |                                                                                                                                                                 | RW     | 0x0     |
| [9]   | sup_rd_trans_cnt_hit  |                                                                                                                                                                 | RW     | 0x0     |
| [8]   | sup_wr_trans_cnt_hit  |                                                                                                                                                                 | RW     | 0x0     |
| [7]   | gen_rd_trans_cnt_hit  |                                                                                                                                                                 | RW     | 0x0     |
| [6]   | gen_wr_trans_cnt_hit  |                                                                                                                                                                 | RW     | 0x0     |
| [5]   | rdata_available       |                                                                                                                                                                 | RW     | 0x0     |
| [4]   | wdata_done            |                                                                                                                                                                 | RW     | 0x0     |
| [3]   | rx_fifo_not_empty     |                                                                                                                                                                 | RW     | 0x0     |
| [2]   | rx_fifo_full          |                                                                                                                                                                 | RW     | 0x0     |
| [1]   | tx_fifo_empty         |                                                                                                                                                                 | RW     | 0x0     |
| [0]   | tx_fifo_full          |                                                                                                                                                                 | RW     | 0x0     |

## 5.3. Status Registers

### 5.3.1. Interrupt Status Register

Each interrupt status bit, when set to high, causes the assertion of the interrupt port (int\_o) if the corresponding interrupt enable bit is high.

**Table 5.14. Interrupt Status Register**

| Field   | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Access | Default |
|---------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:18] | reserved           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO     | 0x0     |
| [17]    | flash_program_fail | When set to high, indicates that the last flash program operation failed.<br><br>Applicable only when <i>Enable Command Processing == Checked</i> in the IP GUI.                                                                                                                                                                                                                                                                                                     | RW1C   | 0x0     |
| [16]    | flash_erase_fail   | When set to high, indicates that the last flash erase operation failed.<br><br>Applicable only when <i>Enable Command Processing == Checked</i> in the IP GUI.                                                                                                                                                                                                                                                                                                       | RW1C   | 0x0     |
| [15:14] | reserved           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO     | 0x0     |
| [13]    | rd_on_empty_error  | <ul style="list-style-type: none"> <li>When FIFO is enabled in the IP GUI:<br/>When set to high, indicates that a read access was done on the Rx FIFO while it is empty. The return data is invalid or garbage.</li> <li>When FIFO is not enabled in the IP GUI:<br/>When set to high, indicates that a read access was done on the read data register while it is empty (rdata_available = 0). The return data may be invalid or garbage.</li> </ul>                | RW1C   | 0x0     |
| [12]    | wr_on_full_error   | <ul style="list-style-type: none"> <li>When FIFO is enabled in the IP GUI:<br/>When set to high, indicates that a write access was done on the Tx FIFO while it is full. This may cause a loss of data and an unexpected result if the packet is broken.</li> <li>When FIFO is not enabled in IP GUI:<br/>When set to high, indicates that a write access was done on the write data register while it is not empty (wdata_not_empty = 1). This may cause</li> </ul> | RW1C   | 0x0     |

| Field | Name                  | Description                                                                                                                                                                                                                                                                                                                           | Access | Default |
|-------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
|       |                       | data corruption during SPI transfer.                                                                                                                                                                                                                                                                                                  |        |         |
| [11]  | bus_access_error      | When set to high, indicates that a request was received that hits a reserved or unallocated address region.                                                                                                                                                                                                                           | RW1C   | 0x0     |
| [10]  | user_pkt_decode_error | When set to high, indicates that an error was encountered while decoding the user packet. This could be a result of inconsistent bit setting or unsupported command in the packet header. This may cause the IP core to stop or an unexpected result. To recover, clean up the FIFOs or issue a soft reset.                           | RW1C   | 0x0     |
| [9]   | sup_rd_trans_cnt_hit  | When set to high, indicates that rd_xfer_done_count value of supported flash command packet counter register is greater than or equal to the set threshold rd_trans_int_thresh.<br>Applicable only when both <i>Enable Command Processing</i> == Checked and <i>Enable Supported Command Packet Counter</i> == Checked in the IP GUI. | RW1C   | 0x0     |
| [8]   | sup_wr_trans_cnt_hit  | When set to high, indicates that wr_xfer_done_count value of supported flash command packet counter register is greater than or equal to the set threshold wr_trans_int_thresh.<br>Applicable only when both <i>Enable Command Processing</i> == Checked and <i>Enable Supported Command Packet Counter</i> == Checked in the IP GUI. | RW1C   | 0x0     |
| [7]   | gen_rd_trans_cnt_hit  | When set to high, indicates that rd_xfer_done_count value of generic SPI command packet counter register is greater than or equal to the set threshold rd_trans_int_thresh.<br>Applicable only when <i>Enable Generic Packet Counter</i> == Checked in the IP GUI.                                                                    | RW1C   | 0x0     |
| [6]   | gen_wr_trans_cnt_hit  | When set to high, indicates that wr_xfer_done_count value of generic SPI command packet counter register is greater than or equal to the set threshold wr_trans_int_thresh.<br>Applicable only when <i>Enable Generic Packet Counter</i> == Checked in the IP GUI.                                                                    | RW1C   | 0x0     |
| [5]   | rdata_available       | When set to high, indicates that read data register has a valid data.<br>Applicable only when FIFO is not enabled in the IP GUI.                                                                                                                                                                                                      | RW1C   | 0x0     |
| [4]   | wdata_done            | When set to high, indicates that the write data register has been taken to be transmitted and is now available for write.<br>Applicable only when FIFO is not enabled in the IP GUI.                                                                                                                                                  | RW1C   | 0x0     |
| [3]   | rx_fifo_not_empty     | When set to high, indicates that the Rx FIFO is not empty.<br>Applicable only when FIFO is enabled in the IP GUI.                                                                                                                                                                                                                     | RW1C   | 0x0     |
| [2]   | rx_fifo_full          | When set to high, indicates that the Rx FIFO is full.<br>Applicable only when FIFO is enabled in the IP GUI.                                                                                                                                                                                                                          | RW1C   | 0x0     |
| [1]   | tx_fifo_empty         | When set to high, indicates that the last data has been taken from the Tx FIFO and it is now empty. Note that this only asserts when the Tx FIFO status transitions from "not empty" to "empty".<br>Applicable only when FIFO is enabled in the IP GUI.                                                                               | RW1C   | 0x0     |
| [0]   | tx_fifo_full          | When set to high, indicates that the Tx FIFO is full.<br>Applicable only when FIFO is enabled in the IP GUI.                                                                                                                                                                                                                          | RW1C   | 0x0     |

### 5.3.2. Generic SPI Command Packet Counter Register

Applicable only when *Enable Generic Packet Counter* == Checked in the IP GUI. The actual counter width depends on the *Packet Counter max count* setting.

**Table 5.15. Generic SPI Command Packet Counter Register**

| Field   | Name               | Description                                                                                                                                                        | Access | Default |
|---------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:16] | rd_xfer_done_count | This field shows the number of completed generic packet for read access. Writing 1 to bit[16] resets this register to 0; writing to other bits is inconsequential. | RW     | 0x0     |
| [15:0]  | wr_xfer_done_count | This field shows the number of completed generic packet for write access. Writing 1 to bit[0] resets this register to 0; writing to other bits is inconsequential. | RW     | 0x0     |

### 5.3.3. Supported Flash Command Packet Counter Register

Applicable only when both *Enable Command Processing* == Checked and *Enable Supported Command Packet Counter* == Checked in the IP GUI. The actual counter width depends on the *Packet Counter max count* setting.

**Table 5.16. Supported Flash Command Packet Counter Register**

| Field   | Name               | Description                                                                                                                                                                | Access | Default |
|---------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:16] | rd_xfer_done_count | This field shows the number of completed supported flash packet for read access. Writing 1 to bit[16] resets this register to 0; writing to other bits is inconsequential. | RW     | 0x0     |
| [15:0]  | wr_xfer_done_count | This field shows the number of completed supported flash packet for write access. Writing 1 to bit[0] resets this register to 0; writing to other bits is inconsequential. | RW     | 0x0     |

### 5.3.4. Octal SPI Debug Information 0 Register

**Table 5.17. Octal SPI Debug Information 0 Register**

| Field  | Name            | Description                                                                                                                                                                                                                                                                                                                                                                                            | Access | Default |
|--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:4] | reserved        | Reserved                                                                                                                                                                                                                                                                                                                                                                                               | RO     | 0x0     |
| [3]    | spi_has_started | SPI transaction has started since the last read on this register. This register asserts when SPI chip select has been asserted. Reading this register automatically clears the value but re-triggers if chip select is still asserted. This register can be used along with spi_busy to check if a recent transaction is done.<br>0 – SPI chip select not asserted<br>1 – SPI chip select was asserted | RO     | 0x0     |
| [2]    | wdata_not_empty | Status of write data register<br>When high, indicates that user has written something to the write data register and it has not been taken yet.<br>Applicable only when <i>Include FIFO</i> is not selected in the IP GUI.                                                                                                                                                                             | RO     | 0x0     |
| [1]    | spi_on_hold     | SPI on-hold transfer status<br>0 – Normal operation<br>1 – When there is an ongoing transfer (spi_busy = 1) and SCK has to be stopped temporarily while waiting for user action or waiting for data to be available in the FIFO.                                                                                                                                                                       | RO     | 0x0     |

| Field | Name     | Description                                                              | Access | Default |
|-------|----------|--------------------------------------------------------------------------|--------|---------|
| [0]   | spi_busy | SPI busy status<br>0 – Idle state<br>1 – There is an ongoing transaction | RO     | 0x0     |

### 5.3.5. Octal SPI Debug Information 1 Register

**Table 5.18. Octal SPI Debug Information 1 Register**

| Field   | Name                | Description                                                                                                                                                                                                    | Access | Default           |
|---------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------|
| [31:16] | rx_fifo_avail_count | Rx FIFO data available counter<br>This field shows the number of data that is currently available in the Rx FIFO.<br>Applicable only when <i>Enable Rx FIFO available data count == Checked</i> in the IP GUI. | RO     | 0x0               |
| [15:0]  | tx_fifo_free_count  | Tx FIFO free space counter<br>This field shows the number of remaining space available in the Tx FIFO.<br>Applicable only when <i>Enable Tx FIFO free space count == Checked</i> in the IP GUI.                | RO     | <i>FIFO depth</i> |

## 5.4. Control Registers

### 5.4.1. Tx FIFO Register

This is a dummy register used to fill data to the Tx FIFO. Applicable only when FIFO is enabled in the IP GUI.

**Note:** When the dual bus interface is selected and *FIFO Interface Mapping* is set to **Map to Data Interface**, this register is accessible through the target data interface and not the CSR interface.

**Table 5.19. Tx FIFO Register**

| Field  | Name         | Description                                                                                                  | Access | Default |
|--------|--------------|--------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:0] | tx_fifo_data | Use this dummy register to send packet frames to the Tx FIFO through repeated write access to this register. | WO     | 0x0     |

### 5.4.2. Rx FIFO Register

This is a dummy register used to get read data from the Rx FIFO. Read data from the response to read commands is stored in the Rx FIFO. Applicable only when FIFO is enabled in the IP GUI.

**Note:** When the dual bus interface is selected and *FIFO Interface Mapping* is set to **Map to Data Interface**, this register is accessible through the target data interface and not the CSR interface.

**Table 5.20. Rx FIFO Register**

| Field  | Name         | Description                                                                                                                                                                                                                                                                                                                                                                    | Access | Default |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:0] | rx_fifo_data | Use this dummy register to get the received data from the Rx FIFO through repeated read access to this register.<br>Check the interrupt status register (bit[3]) to determine if Rx FIFO is not empty. When reading data that is not multiples of 4 bytes, the invalid bytes should be ignored (for example, 3-byte data: bit[23:0] – valid bytes; bit[31:24] – invalid byte). | RO     | 0x0     |

### 5.4.3. Packet Header 0 – 3 Registers

Applicable only when FIFO is not enabled in the IP GUI.

**Table 5.21. Packet Header 0 – 3 Registers**

| Field  | Name         | Description                                                                                                                                                                                                                                                                                                                                                        | Access | Default |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:0] | pkt_header_0 | Refer to the <a href="#">User Packets</a> section for the packet formats and field definitions.<br><br>If <i>Target Address up to 64b</i> = Unchecked in the IP GUI, then pkt_header_3 is reserved. If <i>Enable Command Processing</i> = Unchecked in the IP GUI, then only pkt_header_0 is available and the others (pkt_header_1 to pkt_header_3) are reserved. | RW     | 0x0     |
| [31:0] | pkt_header_1 |                                                                                                                                                                                                                                                                                                                                                                    | RW     | 0x0     |
| [31:0] | pkt_header_2 |                                                                                                                                                                                                                                                                                                                                                                    | RW     | 0x0     |
| [31:0] | pkt_header_3 |                                                                                                                                                                                                                                                                                                                                                                    | RW     | 0x0     |

### 5.4.4. Write Data Register

Applicable only when FIFO is not enabled in the IP GUI.

**Table 5.22. Write Data Register**

| Field  | Name       | Description                                                                                                                                                                                          | Access | Default |
|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:0] | write_data | This is the write data or payload of the packet. For commands with more than 1 DWORD payload, check the interrupt status wdata_done or wdata_not_empty status before writing again to this register. | RW     | 0x0     |

### 5.4.5. Read Data Register

Applicable only when FIFO is not enabled in the IP GUI.

**Table 5.23. Read Data Register**

| Field  | Name      | Description                                                                                                                                                                                                                                                                                                                     | Access | Default |
|--------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:0] | read_data | This is the read data from the response to the read command. Check the interrupt status rdata_available before reading this register to get a valid data. When reading data that is not multiples of 4 bytes, the invalid bytes should be ignored (for example, 3-byte data: bits[23:0] – valid bytes; [31:24] – invalid byte). | RO     | 0x0     |

### 5.4.6. Start Transaction Register

**Table 5.24. Start Transaction Register**

| Field  | Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Access | Default |
|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:2] | reserved       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RO     | 0x0     |
| [1]    | enter_xip_mode | This is applicable in flash controller application and if the target device supports XiP mode.<br><br>When set to high, indicates target address space access using XiP mode. Before setting this to high, ensure that the target device has already been enabled for XiP mode (a command has been issued previously to enable XiP mode). Otherwise, data may be invalid.<br><br>When set to low, indicates exit XiP mode sequence is done.<br><br>Available only when <i>Enable XiP Mode</i> == Checked in the IP GUI. | RW     | 0x0     |

| Field | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Access | Default |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [0]   | tx_start | <p>When set to high, triggers the IP to start processing the commands from the Tx FIFO or packet header register (if FIFO is not enabled). The spi_busy register (0x10C) asserts when transaction starts.</p> <ul style="list-style-type: none"> <li>Without FIFO:<br/>This register auto-clears when a command packet is transmitted.</li> <li>With FIFO:<br/>This register auto-clears when a command is done and the configuration register auto_clr_tx_start is set to 1.</li> </ul> <p><b>Note:</b> If a command is done and the Tx FIFO becomes empty, tx_start auto-clears even if auto_clr_tx_start is set to 0. This means that when a new command is sent to the Tx FIFO, 1 must be written to this register to trigger the start of transaction again. This is useful when debugging to halt the process after each command.</p> | RW     | 0x0     |

#### 5.4.7. Interrupt Set Register

This is a dummy register used to test the assertion of interrupt status. Each interrupt set bit is applicable only when the corresponding interrupt status is applicable for the device configuration

**Table 5.25. Interrupt Set Register**

| Field   | Name                  | Description                                                                                                                                                | Access | Default |
|---------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:18] | reserved              | Reserved                                                                                                                                                   | RO     | 0x0     |
| [17]    | flash_program_fail    | See description for bit[13:0].                                                                                                                             | WO     | 0x0     |
| [16]    | flash_erase_fail      |                                                                                                                                                            | WO     | 0x0     |
| [15:14] | reserved              | Reserved                                                                                                                                                   | RO     | 0x0     |
| [13]    | rd_on_empty_error     | When set to high, triggers the corresponding interrupt status signal. Refer to the <a href="#">Interrupt Status Register</a> section for more information. | WO     | 0x0     |
| [12]    | wr_on_full_error      |                                                                                                                                                            | WO     | 0x0     |
| [11]    | bus_access_error      |                                                                                                                                                            | WO     | 0x0     |
| [10]    | user_pkt_decode_error |                                                                                                                                                            | WO     | 0x0     |
| [9]     | sup_rd_trans_cnt_hit  |                                                                                                                                                            | WO     | 0x0     |
| [8]     | sup_wr_trans_cnt_hit  |                                                                                                                                                            | WO     | 0x0     |
| [7]     | gen_rd_trans_cnt_hit  |                                                                                                                                                            | WO     | 0x0     |
| [6]     | gen_wr_trans_cnt_hit  |                                                                                                                                                            | WO     | 0x0     |
| [5]     | rdata_available       |                                                                                                                                                            | WO     | 0x0     |
| [4]     | wdata_done            |                                                                                                                                                            | WO     | 0x0     |
| [3]     | rx_fifo_not_empty     |                                                                                                                                                            | WO     | 0x0     |
| [2]     | rx_fifo_full          |                                                                                                                                                            | WO     | 0x0     |
| [1]     | tx_fifo_empty         |                                                                                                                                                            | WO     | 0x0     |
| [0]     | tx_fifo_full          |                                                                                                                                                            | WO     | 0x0     |

## 5.4.8. Test Mode Register

**Table 5.26. Test Mode Register**

| Field  | Name        | Description                                                                                                                                                   | Access | Default |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:1] | reserved    | Reserved                                                                                                                                                      | RO     | 0x0     |
| [0]    | en_loopback | This is used for debugging or testing.<br>0 – Loopback is disabled.<br>1 – Loopback is enabled. Any data transmitted or shifted out returns as received data. | RW     | 0x0     |

## 5.4.9. Soft Reset Register

The behavior of soft reset is affected by the configuration register auto\_clr\_soft\_rst. When auto\_clr\_soft\_rst is high, soft reset automatically returns to 0 after 1 is written. When auto\_clr\_soft\_rst is low, the soft reset register retains the previous value unless a new value is written. The ip\_core\_rst and ip\_csr\_rst bits are always auto cleared to avoid deadlock. After performing reset, wait at least four clock cycles before performing any other transactions.

**Table 5.27. Soft Reset Register**

| Field  | Name        | Description                                                                                                                                                        | Access                               | Default |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|---------|
| [31:5] | reserved    | Reserved                                                                                                                                                           | RO                                   | 0x0     |
| [4]    | spi_tgt_rst | When set to high, resets the target by asserting the output reset pin (spi_tgt_rst_n_o).<br>Applicable only when <i>Target Reset Pin</i> == Checked in the IP GUI. | RW <sup>1</sup><br>RW1C <sup>2</sup> | 0x0     |
| [3]    | rx_fifo_rst | When set to high, resets the Rx FIFO.<br>Applicable only when FIFO is enabled in the IP GUI.                                                                       | RW <sup>1</sup><br>RW1C <sup>2</sup> | 0x0     |
| [2]    | tx_fifo_rst | When set to high, resets the Tx FIFO.<br>Applicable only when FIFO is enabled in the IP GUI.                                                                       | RW <sup>1</sup><br>RW1C <sup>2</sup> | 0x0     |
| [1]    | ip_csr_rst  | When set to high, resets the Octal SPI IP core register block.                                                                                                     | RW1C                                 | 0x0     |
| [0]    | ip_core_rst | When set to high, resets the Octal SPI IP core excluding the registers and FIFO.                                                                                   | RW1C                                 | 0x0     |

**Notes:**

1. When auto\_clr\_soft\_rst = 0.
2. When auto\_clr\_soft\_rst = 1.

### 5.4.10. IO Delay Control Register

This register is recommended for advanced users. Applicable only when *Include IO Primitive == Checked* and *Enable Double Transfer Rate == Checked* in the IP GUI. When *Use xSPI IO Primitive == Checked*, this is used to adjust the timing of the following SPI I/O signals: *spi\_ds\_io*, *spi\_dt\_io*, and *spi\_sck\_o*. When *Use xSPI IO Primitive = Unchecked*, this is only used for *spi\_ds\_io* delay adjustment.

**Table 5.28. IO Delay Control Register**

| Field   | Name                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Access | Default |
|---------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| [31:22] | reserved                | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO     | 0x0     |
| [21]    | delay_control_type      | Indicates the operation to perform which is either to toggle the load signal or move signal of the delay controller.<br>0 – Load; update the delay element in tandem<br>1 – Move; increments the delay one step at a time                                                                                                                                                                                                                                                            | RW     | 0x0     |
| [20]    | delay_control_direction | Indicates the direction of delay adjustment. Applicable only if the type is “move”.<br>0 – Increment the delay by delay_control_step<br>1 – Decrement the delay by delay_control_step                                                                                                                                                                                                                                                                                                | RW     | 0x0     |
| [19:17] | delay_control_select    | When set to high, enables a particular delay control element. It is possible to enable all delay control elements at the same time to adjust them with the same parameters.<br>[0] – <i>spi_dt_io</i> delay<br>[1] – <i>spi_ds_io</i> delay<br>[2] – <i>spi_sck_o</i> delay                                                                                                                                                                                                          | RW     | 0x0     |
| [16]    | delay_control_request   | When set to high, the delay control updates or adjusts the delay according to the parameters (such as step and direction) provided in this register. This field automatically clears once the request has been done.                                                                                                                                                                                                                                                                 | RW     | 0x0     |
| [15]    | reserved                | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO     | 0x0     |
| [14:12] | overflow_flag           | When set to high, this flag indicates overflow of the delay counter. Overflow depends on the direction. For example, if the delay_control_direction is 0 (increment), overflow means beyond the maximum delay count. Otherwise, if the delay_control_direction is 1 (decrement), overflow means below the minimum delay count.<br>[0] – overflow flag for <i>spi_dt_io</i> delay<br>[1] – overflow flag for <i>spi_ds_io</i> delay<br>[2] – overflow flag for <i>spi_sck_o</i> delay | RO     | 0x0     |
| [11:9]  | reserved                | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO     | 0x0     |
| [8:0]   | delay_control_step      | Indicates the number of delay steps. One delay step may range from 10 ps to 18 ps depending on PVT (process, voltage, temperature).                                                                                                                                                                                                                                                                                                                                                  | RW     | 0x0     |

## 6. Example Design

This section shows an example of a system design used to validate the Octal SPI Controller IP. The system design is implemented in the Lattice Avant-X Versa board with the LAV-AT-X70ES device.

The Octal SPI Controller example design allows you to compile, simulate, and test the Octal SPI Controller IP on the following Lattice evaluation boards:

- Avant-X Versa Board
- Avant-E Evaluation Board
- CertusPro-NX Versa Board

### 6.1. Example Design Configuration

**Table 6.1. Octal SPI Controller IP Configuration Supported by the Example Design**

| Octal SPI Controller IP GUI Attribute                          | Octal SPI Controller IP Configuration |
|----------------------------------------------------------------|---------------------------------------|
| <b>Configuration Preset</b>                                    |                                       |
| SPI Protocol                                                   | Custom                                |
| <b>Clock Configuration</b>                                     |                                       |
| System Clock Frequency (MHz)                                   | 100                                   |
| SPI Clock (SCK) Pulse width                                    | 1                                     |
| <b>User Interface</b>                                          |                                       |
| Interface                                                      | AXI4                                  |
| Number of outstanding request                                  | 2                                     |
| AXI4 Bus ID Width                                              | 1                                     |
| FIFO depth                                                     | 256                                   |
| FIFO Implementation                                            | HARD IP                               |
| <b>SPI Configuration</b>                                       |                                       |
| Default LSBF value                                             | 0                                     |
| Default CPOL value                                             | 0                                     |
| Default CPHA value                                             | 0                                     |
| Default Endianness value                                       | 0                                     |
| Default Use DS value                                           | 1                                     |
| Default Non-blocking Tx FIFO                                   | 0                                     |
| Default Non-blocking Rx FIFO                                   | 0                                     |
| Minimum Timing (number of SPI clock): CS assert to SCK         | 2                                     |
| Minimum Timing (number of SPI clock): SCK to CS deassert       | 2                                     |
| Minimum Timing (number of SPI clock): CS deassert to CS assert | 2                                     |
| <b>Supported Capabilities</b>                                  |                                       |
| Generic SPI Controller                                         | Checked                               |
| Enable Target Address Map                                      | Checked                               |
| Enable XiP Mode                                                | Checked                               |
| Enable Command Processing                                      | Checked                               |
| Enable Double Transfer Rate                                    | Checked                               |
| Max number of data lanes                                       | X8                                    |
| Max number of SPI Target                                       | 1                                     |
| Include FIFO                                                   | Checked                               |
| Programmable Command Code                                      | Checked                               |
| Programmable Memory Map                                        | Checked                               |
| Programmable Non-blocking FIFO setting                         | Checked                               |

| Octal SPI Controller IP GUI Attribute        |           | Octal SPI Controller IP Configuration |
|----------------------------------------------|-----------|---------------------------------------|
| <b>IO Primitive</b>                          |           |                                       |
| Include IO Primitive                         | Checked   |                                       |
| <b>Memory Map Configuration</b>              |           |                                       |
| Register Space Size (KiB)                    | 1         |                                       |
| Enable Full CSR Address Decoding             | Unchecked |                                       |
| Register Map: AXI4 Base Address (32b Hex)    | 00000000  |                                       |
| Target Memory Map Size (KiB)                 | 65536     |                                       |
| Target Actual Start Address (32b Hex)        | 00000000  |                                       |
| Total Target Memory Map Size (KiB)           | 65536     |                                       |
| Target Map: AXI4 Base Address (32b Hex)      | 04000000  |                                       |
| <b>Optional Debug Registers</b>              |           |                                       |
| Enable Tx FIFO free space count              | Checked   |                                       |
| Enable Rx FIFO available data count          | Checked   |                                       |
| Enable Generic Packet Counter                | Checked   |                                       |
| Enable Supported Command Packet Counter      | Checked   |                                       |
| Packet Counter max count                     | 16        |                                       |
| <b>Vendor Specific Flash Command Code</b>    |           |                                       |
| Enable 2 bytes command code                  | Checked   |                                       |
| Write Enable (byte 1)                        | 0x06      |                                       |
| Write Enable (byte 2)                        | 0xF9      |                                       |
| Read Status Register (byte 1)                | 0x05      |                                       |
| Read Status Register (byte 2)                | 0xFA      |                                       |
| Read Security Register (byte 1)              | 0x70      |                                       |
| Read Security Register (byte 2)              | 0x8F      |                                       |
| Page Program (byte 1)                        | 0x02      |                                       |
| Page Program (byte 2)                        | 0xFD      |                                       |
| Fast Read (byte 1)                           | 0x0B      |                                       |
| Fast Read (byte 2)                           | 0xF4      |                                       |
| Dummy Cycle: Read Status Register            | 0         |                                       |
| Dummy Cycle: Read Security Register          | 0         |                                       |
| Dummy Cycle: Fast Read                       | 0         |                                       |
| <b>Flash Status Flags</b>                    |           |                                       |
| Flash Status Busy Value                      | 1         |                                       |
| Flash Status Register Busy bit index         | 0         |                                       |
| Flash Status Register Program Fail bit index | 4         |                                       |
| Flash Status Register Erase Fail bit index   | 5         |                                       |

## 6.2. Example Design Components

This example design utilizes the “Hello World” design template that is available in the Lattice Propel™ Builder.



Figure 6.1. Octal SPI Controller Example Design Block Diagram

The Octal SPI Controller example design includes the following blocks:

- RISC-V RX CPU – Embedded processor
- System Memory and TCM – A shared memory for instruction and data
- OSC and PLL – Provides the system clock (100 MHz)
- AXI4 System Bus – Bus interconnect
- AXI4 to APB Bridge – Converts AXI4 to APB interface
- GPIO – Used to drive the 7-segment LED display
- UART – Used for printing debug messages
- Octal SPI Controller – Instance of the design under test (DUT)
- Micron Flash – Non-volatile SPI flash memory that is included in the Avant-X Versa board

## 6.3. Generating the Example Design

The Lattice Propel Builder and Propel SDK can be used to create an embedded system which consists of a system-on-chip (SoC) design with an embedded processor and system software. The following sections describe the procedures for generating an example design for the Octal SPI Controller IP. A workspace is generated on Propel SDK. The SoC project is then created in Propel Builder and imported to the Lattice Radiant software to be synthesized. For complete step-by-step instructions, refer to [A Step-By-Step Approach to Lattice Propel \(FPGA-AN-02052\)](#) or the [Lattice Propel Builder User Guide \(FPGA-UG-02212\)](#) and [Lattice Propel SDK User Guide \(FPGA-UG-02211\)](#).

### 6.3.1. Creating the Octal SPI Controller SoC Project

1. Launch Propel SDK. The **Lattice Propel Launcher** opens as shown in [Figure 6.2](#). Browse to a directory for the **Workspace** field and click **Launch**.



Figure 6.2. Lattice Propel Launcher

2. Create a new SoC design project by selecting **File > New > Lattice SoC Design Project**. The **Create SoC Project** window opens as shown in [Figure 6.3](#).



Figure 6.3. Create SoC Project

3. Enter a name for the SoC project in the **Project name** field. Customize the options under **Device Select** using drop-down menus or configure them through the **Board** option. Then, select the template design from the **Template Design** list. For this example design, RISC-V RX processor, LAV-AT-X70ES device, LFG1156 package, and RISC-V RX SoC Project Avant are used.

4. Click **Finish**.
5. Select the generated project, then run Propel Builder by clicking the  icon or select **LatticeTools > Open Design in Propel Builder**. Propel Builder opens and loads the design template.
6. In the **IP Catalog** tab in the Propel Builder window, double-click on the Octal SPI Controller IP and generate the IP configuration as shown in [Table 6.1](#). This process is similar to that covered in the [Generating and Instantiating the IP](#) section.
7. After generating the IP, the **Define Instance** window opens as shown in [Figure 6.4](#). Modify the instance name if needed, then click **OK**.



**Figure 6.4. Define Instance**

8. Connect the instantiated IP to the system. Modify the system component settings from default as follows:
  - RISC-V RX CPU Number of User Interrupt Requests to 3.
  - Update the AXI4 interconnect and AXI4 to APB bridge instances. If an error message is flagged during regeneration, select the instances, then delete and replace these instances with the latest IP versions available on the IP server.
  - Modify the AXI4 interconnect to have three AXI4 subordinates.
  - Connect the AXI4 interface of the Octal SPI Controller to one of the AXI4 interconnect interface. Connect the system clock and the reset port. Connect the interrupt port to the RISC-V RX CPU. Right-click on the SPI interface and select **Export** to export the interface to FPGA pins.
9. View the memory space of the project by selecting the **Address** tab as shown in [Figure 6.5](#). Enable **Lock** for the address space settings so that addresses cannot be manually or automatically updated.



**Figure 6.5. Address Tab**

10. Click the  icon to perform design rule checking (DRC).
11. Save the SoC project.

### 6.3.2. Importing the Design to Radiant Software

1. Click the  icon or select **Design > Run Radiant** to launch the Lattice Radiant Software.
2. Create the IP constraint file. On the pdc file, connect the SPI ports of the IP to the on-board flash pins. Set sysCONFIG MASTER\_SPI\_PORT to DISABLE to use the on-board flash as the target device.
3. Run the Synthesis, Map, and Place and Route Flow to generate the bitstream programming file.

### 6.3.3. Creating a C/C++ Project

1. In the Lattice Propel software, build your SoC project to generate the system environment needed for the embedded C/C++ project by selecting the generated SoC project followed by **Project > Build Project**.
2. Check the build result from the **Console** view as shown in [Figure 6.6](#).



```

Problems Tasks Console X Properties Terminal
<terminated> sge [SDP Builder] C:\lsc\propel\2024.1\tools\python38_embed\python.exe [Terminated Jul 30, 2024, 10:34:48 PM] [pid: 26412]
INFO - (PGE FileExistence) No available driver for octal_spi_controller
INFO - (PGE FileExistence) No available driver for localbus_tcm
INFO - (PGE) Finished: sge generated

```

**Figure 6.6. Build SoC Project Result**

3. Generate a new Lattice C/C++ project by selecting **File > New > Lattice C/C++ Project**. The **C/C++ Project Load System and BSP** window opens as shown in [Figure 6.7](#). For this example design, select the Hello World Project template.



**Figure 6.7. C/C++ Project Load System and BSP**

4. Update the **Project name** field, then click **Next** followed by **Finish**. The C/C++ Hello World project template is as shown in [Figure 6.8](#).



```

124     trap_init();
125 }
126
127
128 int main(void) {
129     static uint8_t idx = 0;
130     static uint8_t pin_state = 0xFF;
131
132     bsp_init();
133
134     printf("Started!\nHello RISC-V world!\n");
135
136     while (true) {
137 #ifdef GPIO_INST_BASE_ADDR
138         gpio_output_write(&gpio_inst, idx, pin_state);
139 #else
140         printf("0x%02X\n", (pin_state ^ (1<<idx)));
141 #endif
142
143         if (++idx == LED_COUNT) {
144             idx = 0;
145             pin_state = ~pin_state;
146         }
147
148         if (RTL_SIM) {
149             delay(1);
150         } else {
151             delay(500);
152         }
153     }
154
155     return 0;
156 }
157
158

```

**Figure 6.8. Build C/C++ Project Result**

Use the generated C code file to further develop the drivers and test sequences. Once the C code is ready, compile and load the code to run on the FPGA board. Refer to the On-Chip Debugging section under [Propel SDK Flow in A Step-By-Step Approach to Lattice Propel \(FPGA-AN-02052\)](#) for details on how to run the design on the FPGA board.

## 6.4. Hardware Testing

The Octal SPI Controller is validated using the Avant-X Versa board with the LAV-AT-X70ES device. The following block diagram shows the system design setup created in Propel Builder.



**Figure 6.9. Octal SPI Controller SoC Design Block Diagram**

The system clock frequency used in this setup is 100 MHz while the SPI clock frequency is 50 MHz. The system design is imported into the Radiant software to be synthesized. The bitstream is generated after running the Synthesis, Map, and Place and Route Flow in the Radiant software. This bitstream is then loaded into the FPGA using the Radiant Programmer tool. The test sequence and drivers (C code) are developed and run using Propel SDK.

The following table lists the test items, procedures, and results.

**Table 6.2. Octal SPI Controller IP Test Items and Procedures**

| No. | Test Item / Feature                                                   | Test Method / Procedure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Result |
|-----|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 1   | Read ID, read and write to flash register in x1 mode, generic command | <ol style="list-style-type: none"> <li>1. Initialize Octal SPI Controller:           <ul style="list-style-type: none"> <li>• SCK divider = 1 (50 MHZ).</li> <li>• Enable interrupt for bus access error, flash program fail, and flash erase fail.</li> <li>• Flash device starts at x1 mode.</li> </ul> </li> <li>2. Initiate read ID (x1 mode) on SPI flash using generic command packet.</li> <li>3. Enable xSPI DTR mode by writing to non-volatile register using generic command packet.</li> <li>4. Repeat step 2 in x8 mode.</li> <li>5. Read the non-volatile register to get the I/O mode. Compare to expected value (x8).</li> <li>6. Disable xSPI DTR mode by writing to non-volatile register using generic command packet.</li> <li>7. Read the non-volatile register to get the I/O mode. Compare to expected value (x1).</li> <li>8. Compare the returned data of read ID in step 2 and step 4 to the known ID value of Micron flash.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Pass   |
| 2   | Read ID, read and write to flash register in x8 mode, generic command | Same as Test #1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Pass   |
| 3   | Random erase 4K, page program, fast read in x1 mode, generic command  | <ol style="list-style-type: none"> <li>1. Initialize Octal SPI Controller:           <ul style="list-style-type: none"> <li>• SCK divider = 1 (50 MHZ).</li> <li>• Enable interrupt for bus access error, flash program fail, and flash erase fail</li> <li>• Flash device starts at x1 mode.</li> </ul> </li> <li>2. Randomize a 4-KiB aligned starting flash address that is beyond the size of the bitstream (avoid overwrite).</li> <li>3. Initiate a 4-KiB erase using generic command packet. Once the erase command is sent, wait until transaction is done then send a command to read the status register to determine if erase is done in the flash. Once confirmed done, send a command to read the status flag register to check if the erase command is successful.</li> <li>4. Randomize an offset within a page (256 bytes) and a random length such that offset + length does not exceed 256 bytes. Store the offset and length in an array and repeat this 16 times (incrementing the page offset each time).</li> <li>5. With the list of page offset and length, iterate through these items and initiate a page program command with random data.<br/>After a page program command is sent, wait until the transaction is done then send a command to read the status register to determine if program is done in the flash. Once confirmed done, send a command to read the status flag register to check if the program command is successful.</li> <li>6. Compare all the program data and read data.</li> </ol> | Pass   |

| No. | Test Item / Feature                                                    | Test Method / Procedure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Result |
|-----|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 4   | Random erase 4K, page program, fast read in x8 mode, generic command   | Same as Test #3.<br>After step 1, enable xSPI DTR mode by writing to non-volatile register using generic command packet.<br>After step 5, disable xSPI DTR mode by writing to non-volatile register using generic command packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Pass   |
| 5   | Random erase 4K, page program, fast read in x1 mode, supported command | Same as Test #3 but using supported command packet format.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Pass   |
| 6   | Random erase 4K, page program, fast read in x8 mode, supported command | Same as Test #4 but using supported command packet format.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Pass   |
| 7   | Random direct bus write and read flash access in x1 mode               | <ol style="list-style-type: none"> <li>1. Initialize Octal SPI Controller:           <ul style="list-style-type: none"> <li>• SCK divider = 1 (50 MHZ).</li> <li>• Enable interrupt for bus access error, flash program fail, and flash erase fail.</li> <li>• Flash device starts at x1 mode.</li> </ul> </li> <li>2. Randomize a 4-KiB aligned starting flash address that is beyond the size of the bitstream (avoid overwrite).</li> <li>3. Initiate a 4-KiB erase using generic command packet. Once the erase command is sent, wait until transaction is done then send a command to read the status register to determine if erase is done in the flash. Once confirmed done, send a command to read the status flag register to check if the erase command is successful.</li> <li>4. Select a program command and a read command to be used:           <ul style="list-style-type: none"> <li>• Setup the target base address and the size of address map.</li> <li>• Configure the supported flash commands.</li> <li>• Set the supported command configuration register based on the program command and read command to be used.</li> </ul> </li> <li>5. Initiate a random bus write access on the target address space. This is expected to trigger a write access to the flash device.</li> <li>6. Initiate bus read access on the same address in step 5. This is expected to trigger a read access to the flash device.</li> <li>7. Compare all written and read data.</li> </ol> | Pass   |
| 8   | Random direct bus write and read flash access in x8 mode               | Same as Test #7.<br>After step 1, enable xSPI DTR mode by writing to non-volatile register using generic command packet.<br>After step 6, disable xSPI DTR mode by writing to non-volatile register using generic command packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Pass   |

| No. | Test Item / Feature               | Test Method / Procedure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Result |
|-----|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 9   | Random XiP mode access in x1 mode | <ol style="list-style-type: none"> <li>1. Initialize Octal SPI Controller:           <ul style="list-style-type: none"> <li>• SCK divider = 1 (50 MHZ).</li> <li>• Enable interrupt for bus access error, flash program fail, and flash erase fail.</li> <li>• Flash device starts at x1 mode.</li> </ul> </li> <li>2. Randomize a 4-KiB aligned starting flash address that is beyond the size of the bitstream (avoid overwrite).</li> <li>3. Initiate a 4-KiB erase using generic command packet. Once the erase command is sent, wait until transaction is done then send a command to read the status register to determine if erase is done in the flash. Once confirmed done, send a command to read the status flag register to check if the erase command is successful. Once erase is done, fill up the 4-KiB block by sending 16 x 256 bytes page program command with random data.</li> <li>4. Select a read command to be used:           <ul style="list-style-type: none"> <li>• Setup the target base address and the size of address map.</li> <li>• Configure the supported flash commands.</li> <li>• Set the supported command configuration register based on the read command to be used.</li> </ul> </li> <li>5. Enable XiP mode by writing to the non-volatile register.</li> <li>6. Activate the XiP transaction by sending the initial read (at address 0) using generic command packet. This read transaction has the read command code sent as this is the first read. After this, the command need not be sent and the XiP confirmation bit (first bit of the dummy cycle after the address) just needs to be 0 to keep the XiP mode active.</li> <li>7. Initiate a bus read access and sweep the whole 4-KiB block.</li> <li>8. Terminate the XiP mode by sending a read (at address 0) with confirmation bit = 1 using generic command packet. Then, write to the non-volatile register to disable XiP mode.</li> <li>9. Compare all written and read data.</li> </ol> | Pass   |
| 10  | Random XiP mode access in x8 mode | <p>Same as Test #9.</p> <p>After step 1, enable xSPI DTR mode by writing to non-volatile register using generic command packet.</p> <p>After step 8, disable xSPI DTR mode by writing to non-volatile register using generic command packet.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Pass   |

The Octal SPI Controller IP has also been validated on the following hardware and configurations using a similar test method and SoC design:

- Avant-X Versa Board: IP configured as Octal Flash Controller (JEDEC xSPI enabled), 200 MHz system clock, 200 MHz SPI clock.
- Avant-E Evaluation Board: IP configured as QSPI Flash Controller, 100 MHz system clock, 100 MHz SPI clock.
- CertusPro-NX Versa Board: IP configured as QSPI Flash Controller, 100 MHz system clock, 50 MHz SPI clock.

## 7. Designing with the IP

This section provides information on how to generate the IP core using the Lattice Radiant software and how to run simulation and synthesis. For more details on the Lattice Radiant software, refer to the Lattice Radiant Software User Guide.

**Note:** The screenshots provided are for reference only. Details may vary depending on the version of the IP or software being used. If there have been no significant changes to the GUI, a screenshot may reflect an earlier version of the IP.

### 7.1. Generating and Instantiating the IP

You can use the Lattice Radiant software to generate IP modules and integrate them into the device architecture. The following steps describe how to generate the Octal SPI Controller IP in the Lattice Radiant software.

To generate the Octal SPI Controller IP:

1. Create a new Lattice Radiant software project or open an existing project.
2. Click the **IP Catalog** button to view the **IP Catalog** pane.
3. On the **IP on Local** tab, double-click **Octal SPI Controller** under the **IP/.../Processors.Controllers\_and\_Peripherals** category. The **Module/IP Block Wizard** opens.

**Note:** If the IP is not available on the **IP on Local** tab, download the IP from the **IP on Server** tab.



Figure 7.1. Module/IP Block Wizard

4. Enter values in the **Component name** and the **Create in** fields, then click **Next**.
5. Customize the selected Octal SPI Controller IP using drop-down lists and check boxes. [Figure 7.2](#) through [Figure 7.5](#) show an example configuration of the Octal SPI Controller IP. For details on the configuration options, refer to the [IP Parameter Description](#) section.



Figure 7.2. IP Configuration (View 1)



Figure 7.3. IP Configuration (View 2)



Figure 7.4. IP Configuration (View 3)



Figure 7.5. IP Configuration (View 4)

6. Click **Generate**. The **Check Generated Result** window opens. This window shows design block messages and results.



Figure 7.6. Check Generated Result

7. Click **Finish**. All generated files are placed in the directory specified by the **Component name** and **Create in** fields shown in [Figure 7.1](#).

### 7.1.1. Generated Files and File Structure

The generated Octal SPI Controller module package includes the closed-box (*<Component name>\_bb.v*) and instance templates (*<Component name>\_tmpl.v/vhd*) that can be used to instantiate the core in a top-level design. An example RTL top-level reference source file (*<Component name>.v*) that can be used as an instantiation template for the module is also provided. You may also use this example as the starting template for your top-level design. The generated files are listed in [Table 7.1](#).

Table 7.1. Generated File List

| Attribute                                                                                 | Description                                                              |
|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| <i>&lt;Component name&gt;.ipx</i>                                                         | Contains the information on the files associated with the generated IP.  |
| <i>&lt;Component name&gt;.cfg</i>                                                         | Contains the parameter values used in IP configuration.                  |
| <i>component.xml</i>                                                                      | Contains the ipxact: component information of the IP.                    |
| <i>design.xml</i>                                                                         | Documents the configuration parameters of the IP in IP-XACT 2014 format. |
| <i>rtl/&lt;Component name&gt;.v</i>                                                       | Provides an example RTL top file that instantiates the module.           |
| <i>rtl/&lt;Component name&gt;_bb.v</i>                                                    | Provides the synthesis closed-box.                                       |
| <i>misc/&lt;Component name&gt;_tmpl.v</i><br><i>misc /&lt;Component name&gt;_tmpl.vhd</i> | Provide instance templates for the module.                               |

## 7.2. Design Implementation

Completing your design includes additional steps to specify analog properties, pin assignments, and timing and physical constraints. You can add and edit the constraints using the Device Constraint Editor or by manually creating a .pdc file.

Post-Synthesis constraint files (.pdc) contain both timing and non-timing *constraint.pdc* source files for storing logical timing/physical constraints. Constraints that are added using the Device Constraint Editor are saved to the active .pdc file. The active post-synthesis design constraint file is then used as input for post-synthesis processes.

Refer to the relevant sections in the Lattice Radiant Software User Guide for more information on how to create or edit constraints and how to use the Device Constraint Editor.

### 7.3. Timing Constraints

The timing constraints are based on the clock frequency used. The timing constraints for the IP are defined in relevant constraint files. Refer to *constraints/<instance\_name>.sdc* for the recommended constraints for this IP.

For more information on timing constraints, refer to the [Lattice Radiant Timing Constraints Methodology \(FPGA-AN-02059\)](#).

### 7.4. Running Functional Simulation

You can run functional simulation after the IP is generated.

To run functional simulation:

1. In the File List view, right-click on **Input Files**, select **Add > Existing Simulation File** followed by *testbench/tb\_top.v*.



Figure 7.7. Adding Existing Simulation File (View 1)



Figure 7.8. Adding Existing Simulation File (View 2)

2. Check to make sure the **Copy file to directory** option is unchecked, then click **Add**.

3. Click the  button located on the **Toolbar** to initiate the **Simulation Wizard** shown in [Figure 7.9](#).



**Figure 7.9. Simulation Wizard (View 1)**



**Figure 7.10. Simulation Wizard (View 2)**

4. Click **Next** to open the **Add and Reorder Source** window as shown in [Figure 7.11](#). Note that only two files are listed, `tb_top.v` and the generated IP wrapper file. If there are other files, they must be removed. Otherwise, this may cause a failure in the compilation and simulation.



Figure 7.11. Add and Reorder Source

5. Click **Next**. The **Summary** window is shown.

6. Click **Finish** to run the simulation.

The waveform in [Figure 7.12](#) shows an example simulation result.



Figure 7.12. Simulation Waveform

### 7.4.1. Simulation Results

The simulation generates random flash access (write/read) and compares the written and read data. Figure 7.13 shows an example log after the simulation is done.

```
# [ 57494000]:[Info ]--- [DATA MATCH] [DWORD 51] Expected = 32'h65d2_73cb : Observed = 32'h65d2_73cb---[tb_top.random_octal_flash_access]
# [ 57524000]:[Info ]--- [DATA MATCH] [DWORD 52] Expected = 32'ha934_be52 : Observed = 32'ha934_be52---[tb_top.random_octal_flash_access]
# [ 57554000]:[Info ]--- [DATA MATCH] [DWORD 53] Expected = 32'heaad_74d5 : Observed = 32'heaad_74d5---[tb_top.random_octal_flash_access]
# [ 57584000]:[Info ]--- [DATA MATCH] [DWORD 54] Expected = 32'h2fc0_695f : Observed = 32'h2fc0_695f---[tb_top.random_octal_flash_access]
# [ 57614000]:[Info ]--- [DATA MATCH] [DWORD 55] Expected = 32'h6a24_7dd4 : Observed = 32'h6a24_7dd4---[tb_top.random_octal_flash_access]
# [ 57644000]:[Info ]--- [DATA MATCH] [DWORD 56] Expected = 32'h53c9_b7a7 : Observed = 32'h53c9_b7a7---[tb_top.random_octal_flash_access]
# [ 57674000]:[Info ]--- [DATA MATCH] [DWORD 57] Expected = 32'h0c37_8718 : Observed = 32'h0c37_8718---[tb_top.random_octal_flash_access]
# [ 60173000]:Ending Simulation...
# ****Message Counters****
#   Info : 845
#   Warning: 0
#   Debug : 0
#   Error : 0
# ****SIMULATION PASSED***
```

Figure 7.13. Simulation Results

## 8. Design Considerations

### 8.1. Design Considerations in Propel-Based Designs

- When *Enable Target Address Map* is selected, the total address space allocation of the Octal SPI Controller IP is twice the size of the selected *Total Target Memory Map Size*. This is because the register space allocation of 1 KiB is added to the target memory map size and the nearest power of 2 is taken as the total size.
- *Enable Full CSR Address Decoding* must not be selected. The address routing is handled by the bus interconnect thus only the lower address bits are necessary. The base address is automatically assigned by the Propel Builder software.
- *Target Map: AXI4 Base Address* must be set based on the *Total Target Memory Map Size* + base address offset assigned by Propel to the Octal SPI Controller. For example, if base address offset assigned = 0x8000\_0000 and *Total Target Memory Map Size* = 64 KiB, then *Target Map: AXI4 Base Address* = 0x8001\_0000.

## Appendix A. Resource Utilization

Table A.1 shows a sample resource utilization of the Octal SPI Controller IP core using the LAV-AT-X70 device.

**Table A.1. Resource Utilization**

| Configuration                                                                                                                                                    | Slices | Registers | LUTs | EBRs |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|------|------|
| Default                                                                                                                                                          | 1289   | 1289      | 1377 | 2    |
| SPI Protocol: Custom<br>Max number of data lanes: X8<br>Enable Double Transfer Rate                                                                              | 1294   | 1294      | 1617 | 2    |
| SPI Protocol: Custom<br>Max number of data lanes: X4                                                                                                             | 1050   | 1050      | 1306 | 2    |
| SPI Protocol: Custom<br>Max number of data lanes: X1                                                                                                             | 1061   | 1061      | 1294 | 2    |
| SPI Protocol: Custom<br>Max number of data lanes: X8<br>Enable Double Transfer Rate<br>Enable Target Address Map<br>Enable XiP Mode<br>Enable Command Processing | 1739   | 1739      | 2753 | 2    |
| SPI Protocol: Custom<br>Max number of data lanes: X4<br>Enable Target Address Map<br>Enable XiP Mode<br>Enable Command Processing                                | 1402   | 1402      | 2094 | 2    |
| SPI Protocol: Custom<br>Max number of data lanes: X1<br>Number of outstanding requests: 2                                                                        | 1287   | 1287      | 1527 | 2    |

## References

- [Octal SPI Controller IP Release Notes \(FPGA-RN-02011\)](#)
- [Octal SPI Controller Driver API Reference \(FPGA-TN-02400\)](#)
- [A Step-By-Step Approach to Lattice Propel \(FPGA-AN-02052\)](#)
- [Lattice Radiant Timing Constraints Methodology \(FPGA-AN-02059\)](#)
- [Avant-E web page](#)
- [Avant-G web page](#)
- [Avant-X web page](#)
- [Certus-NX web page](#)
- [CertusPro-NX web page](#)
- [CrossLink-NX web page](#)
- [MachXO5-NX web page](#)
- [Avant-X Versa Board web page](#)
- [Avant-E Evaluation Board web page](#)
- [CertusPro-NX Versa Board web page](#)
- [Octal SPI Controller IP Core web page](#)
- [Lattice Radiant Software web page](#)
- [Lattice Propel Design Environment web page](#)
- [Lattice Solutions IP Cores web page](#)
- [Lattice Solutions Reference Designs web page](#)
- [Lattice Insights](#) for Lattice Semiconductor training courses and learning plans

## Technical Support Assistance

Submit a technical support case through [www.latticesemi.com/techsupport](http://www.latticesemi.com/techsupport).

For frequently asked questions, refer to the Lattice Answer Database at  
[www.latticesemi.com/Support/AnswerDatabase](http://www.latticesemi.com/Support/AnswerDatabase).

## Revision History

**Note:** In some instances, the IP may be updated without changes to the user guide. The user guide may reflect an earlier IP version but remains fully compatible with the later IP version. Refer to the IP Release Notes for the latest updates.

### Revision 1.4, IP v1.4.0, December 2025

| Section               | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All                   | <ul style="list-style-type: none"> <li>Added a note on the IP version in the <a href="#">Quick Facts</a> and <a href="#">Revision History</a> sections.</li> <li>Made minor editorial fixes.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Introduction          | <ul style="list-style-type: none"> <li>In <a href="#">Table 1.1. Summary of the Octal SPI Controller IP</a>: <ul style="list-style-type: none"> <li>Updated IP core version and software version in <i>Lattice Implementation</i>.</li> <li>Added <i>Driver Support</i> row.</li> </ul> </li> <li>Removed the Ordering Part Number section.</li> </ul>                                                                                                                                                                                                                                                                                                         |
| Register Description  | In <a href="#">Table 5.3. Octal SPI Configuration 0 Register</a> : <ul style="list-style-type: none"> <li>Updated <i>sck_src_i</i> to <i>clk_i</i> in the description of <i>sck_rate</i>.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Example Design        | <ul style="list-style-type: none"> <li>Removed note on check and cross symbols in the <a href="#">Example Design Configuration</a> section.</li> <li>In <a href="#">Table 6.1. Octal SPI Controller IP Configuration Supported by the Example Design</a>: <ul style="list-style-type: none"> <li>Replaced check symbol with <i>Checked</i> and cross symbol with <i>Unchecked</i>.</li> <li>Updated attributes names to <i>Enable Full CSR Address Decoding</i>, <i>Register Map: AXI4 Base Address (32b Hex)</i>, <i>Target Actual Start Address (32b Hex)</i>, and <i>Target Map: AXI4 Base Address (32b Hex)</i>.</li> </ul> </li> </ul>                    |
| Designing with the IP | <ul style="list-style-type: none"> <li>Added note on IP version in GUI.</li> <li>In the <a href="#">Generating and Instantiating the IP</a> section: <ul style="list-style-type: none"> <li>Split Step 2 into Steps 2, 3, and 4.</li> <li>Updated Steps 2 through 7.</li> </ul> </li> <li>In the <a href="#">Generated Files and File Structure</a> section: <ul style="list-style-type: none"> <li>Updated statement on using example top-level reference as starting template.</li> <li>Added statement referencing Lattice Radianc Timing Constraints Methodology (FPGA-AN-02059) in the <a href="#">Timing Constraints</a> section.</li> </ul> </li> </ul> |
| Design Considerations | Updated attribute name to <i>Enable Full CSR Address Decoding</i> in the <a href="#">Design Considerations in Propel-Based Designs</a> section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

### Revision 1.3, IP v1.3.0, June 2025

| Section                        | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Abbreviations in This Document | Updated definition of <i>APB</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Introduction                   | <ul style="list-style-type: none"> <li>In <a href="#">Table 1.1. Summary of the Octal SPI Controller IP</a>: <ul style="list-style-type: none"> <li>Renamed <i>Supported FPGA Family</i> to <i>Supported Devices</i> and incorporated <i>Targeted Devices</i> information into row.</li> <li>Removed <i>Targeted Devices</i> row.</li> <li>Added AXI4-Lite and APB to <i>Supported User Interface</i>.</li> <li>Added IP core version to <i>Lattice Implementation</i>.</li> </ul> </li> <li>In <a href="#">Table 1.2. Octal SPI Controller IP Support Readiness</a>: <ul style="list-style-type: none"> <li>Added x2 I/O width row for Avant device and x2/x8 I/O width row for CertusPro-NX device.</li> <li>Made minor editorial changes to Notes 1 and 2.</li> </ul> </li> <li>Added <i>dual bus interface option for separate CSR and target data path interfaces</i> in the Features section.</li> </ul> |
| Functional Description         | <ul style="list-style-type: none"> <li>Updated Figure 2.1. Octal SPI Controller IP Core Functional Diagram.</li> <li>In the <a href="#">User Interfaces</a> section: <ul style="list-style-type: none"> <li>Added description of single bus and dual bus interfaces.</li> <li>In <a href="#">Table 2.1. User Interfaces and Supported Protocols</a>:</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Section                  | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | <ul style="list-style-type: none"> <li>Removed Advanced eXtensible Interface 4.</li> <li>Added CSR Interface and Target Data Interface.</li> <li>Added the FIFO Burst Transfer for Indirect Flash Access section.</li> <li>In Table 2.18. Using Supported Flash Command Packet: Fast Read (256 Bytes) at Address (0x0159_E500), x8 I/O Width, DTR, 4-Byte Address Mode: <ul style="list-style-type: none"> <li>Updated [31:16] flash_cmd_code description to <i>Fast Read</i>.</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| IP Parameter Description | <p>In Table 3.1. General Attributes:</p> <ul style="list-style-type: none"> <li>Updated description for SPI Clock (SCK) Pulse width under Clock Configuration.</li> <li>Updated selectable values and description for Interface under User Interface.</li> <li>Added Enable AXI4-Lite ID and FIFO Interface Mapping attributes under User Interface.</li> <li>Added Programmable SCK Divider under Supported Capabilities.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Signal Description       | <ul style="list-style-type: none"> <li>In Table 4.1. Octal SPI Controller Ports: <ul style="list-style-type: none"> <li>Updated section title to <i>AXI4 and AXI4-Lite Interface (Data and CSR)</i>.</li> <li>In AXI4 or AXI4-Lite Interface (Data or CSR) section: <ul style="list-style-type: none"> <li>Updated descriptions for s_axi4_awid_i[x:0], s_axi4_awlen_i[7:0], s_axi4_awsize_i[2:0], and s_axi4_awburst_i[1:0] under Write Address Channel.</li> <li>Updated description for s_axi4_wlast_i under Write Data Channel.</li> <li>Updated description for s_axi4_bid_o[x:0] under Write Response Channel.</li> <li>Updated descriptions for s_axi4_arid_i[x:0], s_axi4_arlen_i[7:0], s_axi4_arsize_i[2:0], and s_axi4_arburst_i[1:0] under Read Address Channel.</li> <li>Updated description for s_axi4_rid_o[x:0] under Read Data Channel.</li> </ul> </li> <li>Added the AXI4-Lite Interface (CSR) section.</li> <li>Added the AXI4 Interface (CSR) section.</li> <li>Added the APB Interface (Data or CSR) section.</li> <li>Added notes on signal availability and signal naming based on single bus or dual bus interface selection.</li> </ul> </li> </ul> |
| Register Description     | <ul style="list-style-type: none"> <li>Updated description to reference the CSR interface and buses in the Overview section.</li> <li>In Table 5.2. Summary of Octal SPI Controller IP Core Registers: <ul style="list-style-type: none"> <li>Corrected offset addresses for Packet Header 1 Register and Packet Header 2 Register.</li> </ul> </li> <li>Added note on the applicable interface in the Tx FIFO Register section.</li> <li>Added note on the applicable interface in the Rx FIFO Register section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Designing with the IP    | <ul style="list-style-type: none"> <li>Updated Figure 7.8. Adding Existing Simulation File (View 2).</li> <li>Added new Step 2 regarding ensuring <i>Copy file to directory</i> option is unchecked in the Running Functional Simulation section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| References               | <ul style="list-style-type: none"> <li>Updated listing name to Lattice Radiant Software web page.</li> <li>Added Octal SPI Controller IP Core web page.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### Revision 1.2, IP v1.2.0, February 2025

| Section      | Change Summary                                                                                                                                                                                                                        |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | <ul style="list-style-type: none"> <li>Added IP core version to Lattice Implementation in Table 1.1. Summary of the Octal SPI Controller IP.</li> <li>Added notes to Table 1.2. Octal SPI Controller IP Support Readiness.</li> </ul> |
| References   | Added Octal SPI Controller Driver API Reference.                                                                                                                                                                                      |

#### Revision 1.1, IP v1.1.0, December 2024

| Section | Change Summary                |
|---------|-------------------------------|
| All     | Made minor editorial changes. |
| Cover   | Added IP version.             |

| Section                     | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                | <ul style="list-style-type: none"> <li>In Table 1.1. Summary of the Octal SPI Controller IP: <ul style="list-style-type: none"> <li>Added Certus-NX, CertusPro-NX, CrossLink-NX, and MachXO5-NX to <i>Supported FPGA Family</i>.</li> <li>Added IP Changes row.</li> <li>Removed IP Version row.</li> <li>Added LAV-AT-E70, LAV-AT-G70, LFD2NX-17, LFD2NX-40, LFCPNX-50, LFCPNX-100, LIFCL-17, LIFCL-33, LIFCL-40, LFMXO5-25, LFMXO5-55T, and LFMXO5-100T to <i>Targeted Devices</i>.</li> <li>Added Resources row.</li> <li>Added IP core version to <i>Lattice Implementation</i>.</li> </ul> </li> <li>Added the IP Support Summary section.</li> <li>Removed the IP Validation Summary section.</li> <li>Added the Hardware Support section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Functional Description      | <ul style="list-style-type: none"> <li>Updated description in the Data Byte Order section.</li> <li>In Table 2.3. Packet Fields – Generic SPI Command Format: <ul style="list-style-type: none"> <li>Updated title.</li> <li>Updated description for sup_flash_cmd and wait_ds or dummy_data.</li> <li>Removed with_payload, user_cmd_code[4:0], en_2byte_fcc, and num_wait_state[7:0].</li> <li>Removed bytes 4 through 15.</li> </ul> </li> <li>Added Table 2.4. Packet Fields – Supported Flash Command Format.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IP Parameter Description    | <ul style="list-style-type: none"> <li>In Table 3.1. General Attributes: <ul style="list-style-type: none"> <li>Added <i>AXI4 Bus ID Width</i> and <i>FIFO Implementation</i> attributes under User Interface.</li> <li>Removed <i>Programmable Endianness</i> attribute.</li> <li>Updated description for <i>SPI Protocol</i>, <i>Default CPOL value</i>, <i>Default CPHA value</i>, <i>Default Use DS value</i>, <i>Enable XiP Mode</i>, <i>Include IO Primitive</i>, <i>Use xSPI IO Primitive</i>, <i>Register Map: AXI4 Base Address (32b Hex)</i>, <i>Target Memory Map Size (KiB)</i>, <i>Target Actual Start Address (32b Hex)</i>, <i>Total Target Memory Map Size (KiB)</i>, <i>Target Map: AXI4 Base Address (32b Hex)</i>, <i>Packet Counter max count</i>, and <i>Enable Supported Command Packet Counter</i>.</li> <li>Updated attribute name to <i>Enable Full CSR Address Decoding</i>, <i>Register Map: AXI4 Base Address (32b Hex)</i>, <i>Target Actual Start Address (32b Hex)</i>, and <i>Target Map: AXI4 Base Address (32b Hex)</i>.</li> </ul> </li> <li>In Table 3.2. Flash Device Configuration: <ul style="list-style-type: none"> <li>Added <i>XiP Mode Address Padding</i> attribute under XiP Mode.</li> <li>Updated description for <i>Enable 2 bytes command code</i>, <i>Write Enable (byte 2)</i>, <i>Read Status Register (byte 2)</i>, <i>Read Security Register (byte 2)</i>, <i>Page Program (byte 2)</i>, and <i>Fast Read (byte 2)</i>.</li> </ul> </li> </ul> |
| Signal Description          | <p>In Table 4.1. Octal SPI Controller Ports:</p> <ul style="list-style-type: none"> <li>Updated description for s_axi4_awid_i[x:0], s_axi4_bid_o[x:0], s_axi4_arid_i[x:0], s_axi4_arlen_i[7:0], and s_axi4_rid_o[x:0].</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Register Description        | Updated description for endianness in Table 5.3. Octal SPI Configuration 0 Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Example Design              | <ul style="list-style-type: none"> <li>Added introductory paragraph to list the evaluation boards used for the example design.</li> <li>Added <i>AXI Bus ID Width</i> and <i>FIFO Implementation</i> under User Interface in Table 6.1. Octal SPI Controller IP Configuration Supported by the Example Design.</li> <li>Added information about validation using other configurations and boards in the Hardware Testing section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Designing with the IP       | Updated Figure 7.1. Module/IP Block Wizard, Figure 7.2. IP Configuration (View 1), and Figure 7.6. Check Generated Result.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Known Issues or Limitations | Removed section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| References                  | <ul style="list-style-type: none"> <li>Added Avant-G, Avant-X, Certus-NX, CertusPro-NX, CrossLink-NX, and MachXO5-NX web pages.</li> <li>Removed Lattice Radiant Software User Guide, Lattice Propel Builder User Guide, and</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Section | Change Summary                                                                                                                                                        |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | <p>Lattice Propel SDK User Guide.</p> <ul style="list-style-type: none"><li>Added Versa/Evaluation Board and Lattice Solutions Reference Designs web pages.</li></ul> |

**Revision 1.0, September 2024**

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



[www.latticesemi.com](http://www.latticesemi.com)