Introduction

The iCE40™ family of devices is an ultra-low power FPGA and sensor manager designed for ultra-low power mobile applications, such as smartphones, tablets and hand-held devices. The iCE40LM, iCE40 Ultra™ and iCE40 UltraPlus™ include integrated SPI and I2C blocks, while the iCE40 UltraLite™ includes an I2C block only, to interface with virtually all mobile sensors and application processors.

The key components available for iCE40LM, iCE40 Ultra and iCE40 UltraPlus:

- Two I2C IP cores located at the upper left corner and upper right corner of the chip
- Two SPI IP cores located at lower left corner and lower right corner of the chip

The key components available for iCE40 UltraLite:

- Two I2C IP cores located at the lower left corner and lower right corner of the chip

Each device uses a System Bus to connect its Hard IP to the fabric. The device does not preload the Hard IP registers during configuration, thus, a soft IP is required. Using Module Generator to generate the IP is recommended because Module Generator generates the corresponding soft IP as well. For details, refer to Module Generator section.

Figure 1. IP Block Diagram for iCE40LM, iCE40 Ultra and ICE40 UltraPlus

Figure 2. IP Block Diagram for iCE40 UltraLite
I2C IP Core Overview
The I2C hard IP provides industry standard two pin communication interface that conforms to V2.1 of the I2C bus specification. It could be configured as either master or slave port. In master mode, it supports configurable data transfer rate and performs arbitration detection to allow it to operate in multi-master systems. It supports clock stretching in both master and slave modes with enable/disable capability. It supports both 7 bits and 10 bits addressing in slave mode with configurable slave address. It supports general call address detection in both master and slave mode. It provides interrupt logic for easy communicating with host. It also provides configurable digital delay at SDA output for reliably generating start/stop condition.

Key Features for iCE40LM, iCE40 Ultra and iCE40 UltraPlus
- Configurable Master and Slave mode
- Support for 7-bit or 10-bit configurable Slave Address
- Multi-master Arbitration support
- Clock stretching to ensure data setup time
- Up to 400 kHz Data Transfer Speed; also support 100 kHz, 50 kHz modes
- General Call Support
- Master clock source from System Bus clock
- Communication with custom logic through 8-bit wide data bus
- Programmable 5 MSB bits for 7 bits Slave Address or 8 MSB bits for 10 bits Slave Address for user logic Slave I2C port.
- I2C port and all System Bus addressable registers are reset upon Power On Reset (POR)
- 30 ns analog delay required at SDA input for reliable START, STOP condition detection
- Interface to customer logic through the System Bus Interface

Key Features for iCE40 Ultra Lite
- Configurable Master and Slave mode
- Support for 7-bit or 10-bit configurable Slave Address
- Multi-master Arbitration support
- Clock stretching to ensure data setup time
- Up to 1000 kHz Data Transfer Speed, also supports 400 kHz, 100 kHz, 50 kHz modes
- General Call Support
- Optional delaying input or output data, or both
- Optional FIFO mode
- Transmit FIFO size is 10 bits x 16 bytes, receive FIFO size is 10 bits x 32 bytes
I2C Usage with Module Generation

The Module generator is the recommended flow for using the I2C Hard IP block. Please see the Module Generator section for more information.

When the I2C portion of the Hard IP block is disabled, all settings on the I2C tab shall be disabled.

Figure 3. I2C Module GUI for iCE40LM, ICE40 Ultra and ICE40 UltraPlus
Figure 4. I2C Module GUI for iCE40 UltraLite

**General Call Enable**
This setting enables the I2C General Call response (addresses all devices on the bus using the I2C address 0) in Slave mode. This setting can be modified dynamically by enabling the GCEN bit in the I2C Control Register I2CCR1.

**Wakeup Enable**
Turns on the I2C wakeup on address match. Enables the Wakeup port. The WKUPEN bit in the I2CCR1 can be modified dynamically allowing the Wake Up function to be enabled or disabled.

**Master Clock (Desired)**
This edit box allows the user to specify a desired master clock frequency. A calculation is then made to determine a divider value to generate a clock close to this value from the input clock. The frequency of the input System Bus clock is specified on the main/general tab. The divider value is rounded to the nearest integer after dividing the input System Bus clock by the value entered in this field.

**Master Clock (Actual)**
Since it is not always possible to divide the input System Bus clock to the exact value requested by the user, the actual value will be returned in this read-only field. When both the desired I2C clock and System Bus clock fields contain valid data and either is updated, the Master Clock field returns the value (FREQ_SB / I2C_CLK_DIVIDER), rounded to an integer as shown in the example below. FREQ_SB is the System Bus Clock Frequency customer will enter in the Module Generator. I2C_CLK_DIVIDER will be a factor to be calculated as in the example below.
Master Clock Calculation Example:

1. Divider = I2C_CLK_DIVIDER = FREQ_SB / I2C_CLK_FREQ
2. Master Clock (Actual) = FREQ_SB / DividerInteger

For example: FREQ_SB = 42.5 MHz, I2C_BUS_PERF = 400 KHZ

1. Divider = I2C_CLK_DIVIDER = FREQ_SB / I2C_BUS_PERF
   Divider = 42500 / 400 = 106.25
   Therefore ROUND DividerInteger = 106
2. Master Clock (Actual) = FREQ_SB / DividerInteger
   Actual frequency = 42500 / 106 = 400.9 kHz

In this example, if the user sees that an I2C_CLK_FREQ of 400 kHz cannot be generated, the user may choose to use the actual value or change the System Bus Clock. For this reason, the user needs to enter a frequency and the actual frequency will be displayed. This value may then be adjusted as desired.

**I2C Addressing**

This option allows the user to set 7-bit or 10-bit addressing and define the Hard I2C address.

**FIFO Mode CLK Stretch Enable:** Used in FIFO mode only. To ensure data setup time. If disabled, then overflow and underflow error flag must be monitored.

**Interrupts**

When any of the interrupts are enabled, the I2C port is also enabled.

**Arbitration Lost Interrupts:** An interrupt which indicates I2C lost arbitration. This interrupt is bit IRQARBL of the register I2CIRQ. When enabled, it indicates that ARBL is asserted. Writing a ‘1’ to this bit clears the interrupt. This option can be changed dynamically by modifying the bit IRQARBLEN in the register I2CIRQEN.

**TX/RX Ready:** An interrupt which indicates that the I2C transmit data register (I2CTXDR) is empty or that the receive data register (I2CRXDR) is full. The interrupt bit is IRQTRRDY of the register I2CIRQ. When enabled, it indicates that TRRDY is asserted. Writing a ‘1’ to this bit clears the interrupt. This option can be changed dynamically by modifying the bit IRQTRRDYEN in the register I2CIRQEN.

**Overrun or NACK:** An interrupt which indicates that the I2CRXDR received new data before the previous data. The interrupt is bit IRQROE of the register I2CIRQ. When enabled, it indicates that ROE is asserted. Writing a ‘1’ to this bit clears the interrupt. This option can be changed dynamically by modifying the bit IRQROEEN in the register I2CIRQEN.

**General Call Interrupts:** An interrupt which indicates that a general call has occurred. The interrupt is bit IRQHGC of the register I2CIRQ. When enabled, it indicates that ROE is asserted. Writing a ‘1’ to this bit clears the interrupt. This option can be changed dynamically by modifying the bit IRQHGCEN in the register I2CIRQEN.

**FIFO Interrupts**

**General Call:** An interrupt which indicates that a general call has occurred. The interrupt is bit IRQHGC of I2CFIFOIRQ. This bit can be changed by modifying the bit IRQHGCEN in the register I2CFIFOIRQEN.

**Receive NACK:** An interrupt which indicates that a NACK has received. This is bit IRQRNACK of register I2CFIFOIRQ. This bit can be changed by modifying the bit IRQRNACKEN in register I2CFIFOIRQEN.

**Master Read Complete:** A transaction is considered complete when 1) the specified number of data bytes from the slave have been received in the RX FIFO; or 2) the Master terminates the read transaction before the specified number of data bytes received. This is bit IRQMRDCMPLE of register I2CFIFOIRQ. This bit can be changed by modifying the bit IRQMRDCMPLEN in register I2CFIFOIRQEN.
Arbitration Lost Interrupts: An interrupt which indicates I2C lost arbitration. This interrupt is bit IRQARBL of the register I2CFIFOIRQ. When enabled, it indicates that ARBL is asserted. Writing a ‘1’ to this bit clears the interrupt. This option can be changed dynamically by modifying the bit IRQARBL in the register I2CFIFOIRQ.

**TX FIFO SYNC**: An interrupt which indicates I2C TX FIFO Synchronization Error. Synchronization error happens when there are back-to-back commands in the FIFO. The previous command is overwritten. This interrupt is bit IRQTXSERR of register I2CFIFOIRQ. This option can be changed dynamically by modifying the bit IRQTXSERR in the register I2CFIFOIRQ.

**TX FIFO Underflow**: FIFO TX underflow interrupt. mutually exclusive with clock stretching function. This interrupt is bit IRQTXUNDERF of register I2CFIFOIRQ. This option can be changed dynamically by modifying the bit IRQTXUNDERF in the register I2CFIFOIRQ.

**TX FIFO Overflow**: FIFO RX overflow interrupt. mutually exclusive with clock stretching function. This interrupt is bit IRQRXOVERR of register I2CFIFOIRQ. This option can be changed dynamically by modifying the bit IRQRXOVERR in the register I2CFIFOIRQ.

**Include IO Buffers**
Includes buffers for the I2C pins.

*Figure 5. I2C IO Buffers*

*Figure 6. I2C IO Connections*
SB_I2C Hard IP Macro Ports and Wrapper Connections

When the I2C Hard IP is enabled, the necessary signals are included in the generated module.

Table 1. Pins for the Hard I2C IP for iCE40LM, iCE40 Ultra and iCE40 UltraPlus

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SBCLKi</td>
<td>I</td>
<td>System clock input</td>
</tr>
<tr>
<td>SBWRi</td>
<td>O</td>
<td>System Read/Write input. R=0, W=1</td>
</tr>
<tr>
<td>SBSTBi</td>
<td>O</td>
<td>System Strobe Signal</td>
</tr>
<tr>
<td>SBADRI[7:0]</td>
<td>I</td>
<td>System Bus Control Registers Address</td>
</tr>
<tr>
<td>SBDATI[7:0]</td>
<td>I</td>
<td>System Data Input</td>
</tr>
<tr>
<td>SBDATO[7:0]</td>
<td>O</td>
<td>System Data Output</td>
</tr>
<tr>
<td>SBACKo</td>
<td>O</td>
<td>System Acknowledgement</td>
</tr>
<tr>
<td>I2CPIRQ</td>
<td>O</td>
<td>Interrupt request output signal of the I2C core – The intended use of this signal is for it to be connected to a Master controller (such as a microcontroller or state machine) and request an interrupt when a specific condition is met.</td>
</tr>
<tr>
<td>I2CPWKUP</td>
<td>O</td>
<td>Wake-up signal – The signal is enabled only if the Wakeup Enable feature is set.</td>
</tr>
<tr>
<td>I2Cx_SCL1</td>
<td>Bi-directional</td>
<td>Open drain clock line of the I2C core – The signal is an output if the I2C core is performing a Master operation. The signal is an input for Slave operations. This signal can use a dedicated I/O pin.</td>
</tr>
<tr>
<td>I2Cx_SDA1</td>
<td>Bi-directional</td>
<td>Open drain data line of the I2C core – The signal is an output when data is transmitted from the I2C core. The signal is an input when data is received into the I2C core. This signal can use dedicated I/O pin.</td>
</tr>
</tbody>
</table>

1. x indicates the I2C: x=1 for the left I2C; x=2 for the right I2C.
## Table 2. Pins for the Hard I2C IP for iCE40UltraLite

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SBCSi</td>
<td>I</td>
<td>This chip select signal activates the IP to allow system bus or fabric interface to communicate with the IP.</td>
</tr>
<tr>
<td>SBCLKi</td>
<td>I</td>
<td>System clock input</td>
</tr>
<tr>
<td>SBWRI</td>
<td>O</td>
<td>System Read/Write input. R=0, W=1</td>
</tr>
<tr>
<td>SBSTBi</td>
<td>O</td>
<td>System Strobe Signal. When asserted, indicates that the slave component is selected.</td>
</tr>
<tr>
<td>SBADDR[3:0]</td>
<td>I</td>
<td>System Bus Control Registers Address</td>
</tr>
<tr>
<td>SBDA[9:0]</td>
<td>I</td>
<td>System Data Input [7:0] for register mode; [9:0] for FIFO mode</td>
</tr>
<tr>
<td>SBDAq[9:0]</td>
<td>O</td>
<td>System Data Output [7:0] for register mode; [9:0] for FIFO mode</td>
</tr>
<tr>
<td>SBACKo</td>
<td>O</td>
<td>System Acknowledgement</td>
</tr>
<tr>
<td>SBRSWo</td>
<td>O</td>
<td>Slave read/write signal. A “1” indicates a slave transmitting (external master receiving). A “0” means slave receiving (external master transmitting).</td>
</tr>
<tr>
<td>I2CPIRQ</td>
<td>O</td>
<td>Interrupt request output signal of the I2C core – The intended use of this signal is for it to be connected to a Master controller (such as a microcontroller or state machine) and request an interrupt when a specific condition is met.</td>
</tr>
<tr>
<td>I2CPWKUP</td>
<td>O</td>
<td>Wake-up signal – The signal is enabled only if the Wakeup Enable feature is set.</td>
</tr>
<tr>
<td>FIFO_RST</td>
<td>I</td>
<td>Reset for the FIFO logic</td>
</tr>
<tr>
<td>TXFIFO_AE</td>
<td>O</td>
<td>TXFIFO almost empty status signal coming from TXFIFO, indicating user-defined almost empty threshold value is reached.</td>
</tr>
<tr>
<td>TXFIFO_E</td>
<td>O</td>
<td>TXFIFO empty signal coming from TXFIFO</td>
</tr>
<tr>
<td>TXFIFO_F</td>
<td>O</td>
<td>TXFIFO full signal</td>
</tr>
<tr>
<td>RXFIFO_E</td>
<td>O</td>
<td>RXFIFO is empty. It can be served as an active low DATA RDY signal.</td>
</tr>
<tr>
<td>RXFIFO_AF</td>
<td>O</td>
<td>RXFIFO almost full signal, indicating user-defined almost full threshold value is reached.</td>
</tr>
<tr>
<td>RXFIFO_F</td>
<td>O</td>
<td>RXFIFO full signal</td>
</tr>
<tr>
<td>MRDCMPL</td>
<td>O</td>
<td>Master Read Complete – This is only valid for Master Read Mode. A transaction is considered complete when 1) the specified number of data bytes from the slave have been received in the RX FIFO; or 2) the Master terminates the read transaction before the specified number of data bytes received.</td>
</tr>
<tr>
<td>I2C_x_SCL¹</td>
<td>Bi-directional</td>
<td>Open drain clock line of the I2C core – The signal is an output if the I2C core is performing a Master operation. The signal is an input for Slave operations. This signal can use a dedicated I/O pin.</td>
</tr>
<tr>
<td>I2C_x_SDA¹</td>
<td>Bi-directional</td>
<td>Open drain data line of the I2C core – The signal is an output when data is transmitted from the I2C core. The signal is an input when data is received into the I2C core. This signal can use dedicated I/O pin.</td>
</tr>
</tbody>
</table>

¹: x indicates the I2C: x=1 for the left I2C; x=2 for the right I2C.
I2C Usage Cases

The I2C usage cases described below refer to Figure 7.

1. Master iCE40 I2C Accessing Slave External I2C Devices
   a. A System Bus Master is implemented in the iCE40 logic.
   b. I2C devices 1, 2, and 3 are all Slave devices.
   c. The Master performs bus transactions to the left I2C controller to access external Slave I2C Device 1 on Bus A.
   d. The Master performs bus transactions to the right I2C controller to access the external Slave I2C Devices number 2 or 3 on Bus B.

2. External Master I2C Device Accessing Slave iCE40 I2C
   a. The I2C devices 1, 2, and 3 are I2C Master devices.
   b. The external master I2C Device 1 on Bus A performs I2C memory cycles to access the left I2C controller using address yyyxxxxx01.
   c. The external master I2C Device 2 or 3 on Bus B performs I2C memory cycles to access the right I2C User with the address yyyxxxxx10
   d. A Master in the iCE40 fabric must manage data reception and transmission. The Master can use interrupts or polling techniques to manage data transfer, and to prevent data overrun conditions.

Figure 7. I2C Circuit
**SPI IP Core Overview**

The SPI hard IP provide industry standard four-pin communication interface with 8 bit wide System Bus to communicate with System Host. It could be configured as Master or Slave SPI port with separate Chip Select Pin. In master mode, it provides programmable baud rate, and supports CS HOLD capability for multiple transfers. It provides variety status flags, such as Mode Fault Error flag, Transmit/Receive status flag etc. for easy communicate with system host.

**Key Features**

Configurable Master and slave mode

- Full-Duplex data transfer
- Mode fault error flag with CPU interrupt capability
- Double-buffered data register
- Serial clock with programmable polarity and phase
- LSB First or MSB First Data Transfer
- Communicate with custom logic through 8 bit wide System Bus
- Maximum 4 Slave select output could be routed to any IO through fabric for Master mode
- Slave chip select pin could be routed to any IO through fabric for custom logic
- Clock source for Master clock (MCLK) generation come from System Bus clock.
- Optionally send out status byte to inform remote SPI master the slave receiving register status during slave write.
- Optionally enable the Slow Response Mode for slave SPI read, which will automatically deploy the Lattice specific protocol to resolve the issue that caused by the slow initial respond of the System host at high SPI clock rate.
- The SPI port and all System Bus addressable registers will be reset upon Power On Reset (POR)
- Interface to customer logic through the System Bus Interface
SPI Usage with Module Generation

The Module generator is the recommended flow for using the SPI Hard IP block. See the Module Generator section for more information.

When the SPI portion of the Hard IP block is disabled, all settings on the SPI tab shall be disabled.

*Figure 8. SPI Module GUI for iCE40LM, iCE40 Ultra and iCE40 UltraPlus*

**SPI Mode (Enable Slave Interface)**
This option allows the user to enable Slave Mode interface for the initial state of the SPI block. By default, Slave Mode interface is enabled. Options and ports that are applicable to only one mode will be disabled when the other is chosen.

**SPI Mode (Enable Master Interface)**
This option allows the user to enable Master Mode interface for the initial state of the SPI block. This option can be updated dynamically by modifying the MSTR bit of the register SPICR2. Options and ports that are applicable to only one mode will be disabled when the other is chosen.

**Master Clock Rate (Desired)**
("Enable Master Interface" only) This edit box allows the user to specify a desired master clock frequency. A calculation is then made to determine a divider value to generate a clock close to this value from the input clock. The frequency of the input System Bus clock is specified on the main/general tab. The divider value is rounded to the nearest integer after dividing the input System Bus clock by the value entered in this field.

**Master Clock Rate (Actual)**
("Enable Master Interface" only) Since it is not always possible to divide the input System Bus clock exactly to that requested by the user, the actual value will be returned in this read-only field. When both the desired SPI clock and
System Bus clock fields have valid data and either is updated, this field returns the value (FREQ_SB / SPI_CLK_DIVIDER), rounded to two decimal places as shown in the example below. FREQ_SB is the System Bus Clock Frequency that the customer enters in the Module Generator. SPI_CLK_DIVIDER is a factor to be calculated, which is also shown in the example below.

**Master Clock Calculation Example:**

1. Divider = SPI_CLK_DIVIDER = FREQ_SB / SPI_CLK_FREQ
2. Master Clock (Actual) = FREQ_SB / DividerInteger

For example: FREQ_SB = 66 MHz, SPI_CLK_FREQ = 25 MHz

1. Divider = SPI_CLK_DIVIDER = FREQ_SB / SPI_CLK_FREQ
   Divider = 66 / 25 = 2.64
   Therefore ROUND DividerInteger = 3
2. Master Clock (Actual) = FREQ_SB / DividerInteger
   Actual frequency = 66 / 3 = 22 MHz

In this example, if the user sees that an SPI_CLK_FREQ of 25 MHz cannot be generated, the user may choose to use the actual value or change the System Bus Clock. For this reason, the user needs to enter a frequency and the actual frequency will be displayed. This value may then be adjusted as desired.

**LSB First**

This setting specifies the order of the serial shift of a byte of data. The data order (MSB or LSB first) is programmable within the SPI core. This option can be updated dynamically by modifying the LSBF bit in the register SPICR2.

**Inverted Clock**

The inverts the clock polarity used to sample and output data is programmable for the SPI core. When selected the edge changes from the rising to the falling clock edge. This option can be updated dynamically by accessing the CPOL bit of register SPICR2.

**Phase Adjust**

An alternate clock-data relationship is available for SPI devices with particular requirements. This option allows the user to specify a phase change to match the application. This option can be updated dynamically by accessing the CPHA bit in the register SPICR2.

**Slave Handshake Mode**

Enables Lattice proprietary extension to the SPI protocol. For use when the internal sup-port circuit (e.g. WISH-BONE host) cannot respond with initial data within the time required, and to make the Slave read out data predictably available at high SPI clock rates. This option can be updated dynamically by accessing the SDBRE bit in the register SPICR2.

**Master Chip Selects**

("Enable Master Interface“ only) The core has the ability to provide up to 4 individual chip select outputs for master operation. This field allows the user to prevent extra chip selects from being brought out of the core. This option can be updated dynamically by modifying the register SPICSR.

**SPI Controller Interrupts**

**TX Ready:** An interrupt which indicates the SPI transmit data register (SPITXDR) is empty. The interrupt bit is IRQTRDY of the register SPIIRQ. When enabled, indicates TRDY was asserted. Write a ‘1’ to this bit to clear the interrupt. This option can be change dynamically by modifying the bit IRQTRDYEN in the register SPIIRQEN.

**RX Ready:** An interrupt which indicates the receive data register (SPIRXDR) contains valid receive data. The interrupt is bit IRQRDD of the register SPIIRQ. When enabled, indicates RRDY was asserted. Write a ‘1’ to this bit to clear the interrupt. This option can be change dynamically by modifying the bit IRQRDDYEN in the register SPICSR.
**TX Overrun:** An interrupt which indicates the Slave SPI chip select (SPI_SCSN) was driven low while a SPI Master. The interrupt is bit IRQMDF of the register SPIIRQ. When enabled, indicates MDF (Mode Fault) was asserted. Write a ‘1’ to this bit to clear the interrupt. This option can be change dynamically by modifying the bit IRQMDFEN in the register SPIIRQEN.

**RX Overrun:** An interrupt which indicates SPIRXDR received new data before the previous data. The interrupt is bit IRQROE of the register SPIIRQ. When enabled, indicates ROE was asserted. Write a ‘1’ to this bit to clear the interrupt. This option can be change dynamically by modifying the bit IRQROEEN in the register SPIIRQEN.

**Wakeup Enable**
The core can optionally provide a wakeup signal to the device to resume from low power mode. This option can be updated dynamically by modifying the bit WKUPEN_USER in the register SPICR1.

**Include IO Buffers**
Includes buffers for the SPI pins.

*Figure 9. SPI IO Buffers included*
**SB_SPI Hard IP Macro Ports and Wrapper Connections**

When the SPI Hard IP is enabled, the necessary signals will be included in the generated module.

**Table 3. Pins for the Hard SPI IP**

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SBCLKi</td>
<td>I</td>
<td>System clock input</td>
</tr>
<tr>
<td>SBWRi</td>
<td>O</td>
<td>System Read/Write input. R=0, W=1</td>
</tr>
<tr>
<td>SBSTBi</td>
<td>O</td>
<td>System Strobe Signal</td>
</tr>
<tr>
<td>SBADRI[7:0]</td>
<td>I</td>
<td>System Bus Control Registers Address</td>
</tr>
<tr>
<td>SBDATi[7:0]</td>
<td>I</td>
<td>System Data Input</td>
</tr>
<tr>
<td>SBDATo[7:0]</td>
<td>O</td>
<td>System Data Output</td>
</tr>
<tr>
<td>SBACKo</td>
<td>O</td>
<td>System Acknowledgement</td>
</tr>
<tr>
<td>SPIIRQ</td>
<td>O</td>
<td>Interrupt request output signal of the I2C core – The intended use of this signal is for it to be connected to a Master controller (i.e. a microcontroller or state machine) and request an interrupt when a specific condition is met.</td>
</tr>
<tr>
<td>SPIPWKUP</td>
<td>O</td>
<td>Wake-up signal – The signal is enabled only if the Wakeup Enable feature has been set</td>
</tr>
<tr>
<td>SPx_SCK(^1)</td>
<td>Bi-directional</td>
<td>The signal is an output if the SPI core is in Master mode (MCLK). The signal is an input if the SPI core is in Slave mode (CCLK). This signal could use dedicated I/O pin.</td>
</tr>
<tr>
<td>SPx_MOSI(^1)</td>
<td>Bi-directional</td>
<td>The signal is an output if the SPI core is in Master mode (SISPI). The signal is an input if the SPI core is in Slave mode (SI). This signal could use dedicated I/O pin.</td>
</tr>
<tr>
<td>SPx_MISO(^1)</td>
<td>Bi-directional</td>
<td>The signal is an input if the SPI core is in Master mode (SPISO). The signal is an output if the SPI core is in Slave mode (SO). This signal could use dedicated I/O pin.</td>
</tr>
<tr>
<td>SPx_SCSN(^1)</td>
<td>I</td>
<td>User Slave Chip Select (Active Low). An external SPI Master controller asserts this signal to transfer data to/from the SPI Controllers Transmit Data/Receive Data registers. This signal could use dedicated I/O pin. The dedicated pin is shared with SPI_MCSN[0].</td>
</tr>
<tr>
<td>SPx_MCSN[3:0](^1)</td>
<td>O</td>
<td>Master Chip Select (Active Low). Up to 4 independent slave SPI devices can be accessed using the SPI Controller when it is in Master SPI mode. Only SPI_MCSN[0] could use dedicated I/O pin.</td>
</tr>
</tbody>
</table>

1. x indicates the SPI: x=1 for the left SPI; x=2 for the right SPI.
iCE40LM, iCE40 Ultra and iCE40 UltraPlus SPI Usage Cases

The SPI usage cases described below refer to Figure 11 and Figure 12.

1. External Master SPI Device Accessing the Slave iCE40LM, iCE40 Ultra and iCE40 UltraPlus User SPI
   a. The External Master SPI is connected to the iCE40LM, iCE40 Ultra and iCE40 UltraPlus using the dedicated SI, SO, CCLK pins. The spi_scsn is placed on any Generic I/O. The SPI Mode is set to Slave only.
   b. A Master controller is implemented in the general purpose logic array. The master controller monitors the availability to transmit or receive data by polling the SPI status registers, or by responding to interrupts generated by the SPI Controller.

   Figure 11. External Master SPI Device Accessing the Slave User SPI

2. iCE40LM, iCE40 Ultra and iCE40 UltraPlus user SPI Master accessing one or multiple External Slave SPI devices
   a. The iCE40LM, iCE40 Ultra and iCE40 UltraPlus Master is connected to External SPI Slave devices. The Chip Selects are configured as follows:
      i. The iCE40LM, iCE40 Ultra and iCE40 UltraPlus SPI Master Chip Select spi_mcsn[0] is placed on the dedicated CSSPIN and connected to the External Slave Chip Select.
      ii. The iCE40LM, iCE40 Ultra and iCE40 UltraPlus SPI Master Chip Select spi_mcsn[1] is placed on any I/O and connected to another External Slave Chip Select.
      iii. Up to 4 External Slave SPIs can be connected using spi_mcsn[3:0]
   b. A Master controller is implemented in the iCE40LM, iCE40 Ultra and iCE40 UltraPlus general logic. It controls transfers to the slave SPI devices. It can use a polling method, or it can use SPI Controller interrupts to manage transfer and reception of data.
Figure 12. iCE40LM, iCE40 Ultra and iCE40 UltraPlus User SPI Master Accessing One or Multiple External Slave SPI Devices
Module Generator

The iCE40LM, iCE40 Ultra and iCE40 UltraPlus use a System Bus to connect its Hard IP to the fabric. The system bus is connected to two SPI and two I2C Hard IPs. The iCE40LM, iCE40 Ultra and iCE40 UltraPlus devices do not preload the Hard IP registers during configuration, so a soft IP will be required.

Key Features

- Module Generator will generate the Soft IP which is a wrapper around the Hard IP
- Soft IP will release the System Bus after the Hard IPs have been configured
- The Soft IP by default will use the HSSG for iCE40LM and use SB_HFOSC for iCE40 Ultra and iCE40 UltraPlus. For details on HSSG, please refer to TN1275, iCE40LM On-Chip Strobe Generator Usage Guide. For details on SB_HFOSC please refer to TN1296, iCE40 Oscillator Usage Guide.
- The Register file will be [9:256]
  - The address size is 256 bits which encompasses all address of the Hard IPs
  - The data size is 9 bits with the format [W, Register Data]. When W=1 the state machine will write the corresponding Hard IP address with data

See TN1276, Advanced iCE40 I2C and SPI Hardened IP Usage Guide for more information.

Figure 13. Soft IP Block Diagram

Notes: Only SPI_MSCN[1:0] have dedicated pins
IPDONE = 1 when Hard IP Configuration is complete, IPDONE = 0 during configuration
IPLOAD is an input signal which is used to begin configuration on a positive edge
Enable Left I2C
This option allows the user to enable left I2C on the I2C Tab

Enable Right I2C
This option allows the user to enable right I2C on the I2C Tab

Enable Left SPI
This option allows the user to enable left SPI on the SPI Tab

Enable Right SPI
This option allows the user to enable right SPI on the SPI Tab

System Clock
User setting which is used to set the divider settings of the I2C and SPI

Configuration Clock Source
User will select to use the HSSG/SB_HFOSC or the CLKCONF (User provided clock). For details, please refer to TN1275, iCE40LM On-Chip Strobe Generator Usage Guide for HSSG and TN1296, iCE40 Oscillator Usage Guide for SB_HFOSC.
Technical Support Assistance

Submit a technical support case through www.latticesemi.com/techsupport.

Revision History

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>June 2016</td>
<td>1.4</td>
<td>Added support for iCE40 UltraPlus.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Updated Introduction section.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>— Revised introductory paragraph and description of key components.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>— Revised figure caption to Figure 1. IP Block Diagram for iCE40LM, iCE40 Ultra and iCE40 UltraPlus.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Updated I2C IP Core Overview section. Revised heading to Key Features for iCE40LM, iCE40 Ultra and iCE40 UltraPlus.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Updated I2C Usage with Module Generation section.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>— Revised figure caption to Figure 3. I2C Module GUI for iCE40LM, iCE40 Ultra and iCE40 UltraPlus.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>— Revised figure caption to Figure 4. I2C Module GUI for iCE40 UltraLite.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Updated SB_SPI Hard IP Macro Ports and Wrapper Connections section.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>— Revised table caption to Table 1. Pins for the Hard I2C IP for iCE40LM, iCE40 Ultra and iCE40 UltraPlus.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>— Revised table caption to Table 2. Pins for the Hard I2C IP for iCE40 UltraLite.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Updated SPI Usage with Module Generation section.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>— Revised figure caption to Figure 8. SPI Module GUI for iCE40LM, iCE40 Ultra and iCE40 UltraPlus.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Updated iCE40LM, iCE40 Ultra and iCE40 UltraPlus SPI Usage Cases section.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>— Revised section heading to include iCE40 UltraPlus.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>— Revised use cases to include iCE40 UltraPlus.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>— Added iCE40 UltraPlus to Figure 11, External Master SPI Device Accessing the Slave User SPI.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>— Added iCE40 UltraPlus to Figure 12, iCE40LM, iCE40 Ultra and iCE40 UltraPlus User SPI Master Accessing One or Multiple External Slave SPI Devices.</td>
</tr>
<tr>
<td>January 2015</td>
<td>1.3</td>
<td>Added support for iCE40 UltraLite.</td>
</tr>
<tr>
<td>June 2014</td>
<td>1.2</td>
<td>Changed document title to iCE40 I2C and SPI Hardened IP Usage Guide.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Added support for iCE40 Ultra.</td>
</tr>
<tr>
<td>November 2013</td>
<td>01.1</td>
<td>Changed hard IP pin names.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Updated screen captures of Module Generator user interface.</td>
</tr>
<tr>
<td>October 2013</td>
<td>01.0</td>
<td>Initial release.</td>
</tr>
</tbody>
</table>