



# I2C Target IP

IP Version: v2.5.0

## User Guide

FPGA-IPUG-02072-2.2

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  |
| Acronyms in This Document .....                                          | 6  |
| 1. Introduction .....                                                    | 7  |
| 1.1. Overview of the IP .....                                            | 7  |
| 1.2. Quick Facts .....                                                   | 7  |
| 1.3. IP Support Summary .....                                            | 7  |
| 1.4. Features .....                                                      | 8  |
| 1.5. Licensing Information .....                                         | 8  |
| 1.6. Hardware Support .....                                              | 8  |
| 1.7. Minimum Device Requirements .....                                   | 8  |
| 1.8. Naming Conventions .....                                            | 8  |
| 1.8.1. Nomenclature .....                                                | 8  |
| 1.8.2. Signal Names .....                                                | 8  |
| 1.8.3. Attribute Names .....                                             | 9  |
| 2. Functional Description .....                                          | 10 |
| 2.1. IP Architecture Overview .....                                      | 10 |
| 2.2. Clocking and Reset .....                                            | 10 |
| 2.3. Operations Details .....                                            | 10 |
| 2.3.1. General I2C Operation .....                                       | 10 |
| 2.3.2. Glitch Filter .....                                               | 11 |
| 2.3.3. Clock Stretching .....                                            | 11 |
| 2.3.4. ACK/NACK Response .....                                           | 12 |
| 2.4. User Interfaces .....                                               | 12 |
| 2.4.1. Selectable Memory-Mapped Interface .....                          | 12 |
| 2.5. Programming Flow .....                                              | 12 |
| 2.5.1. Initialization .....                                              | 12 |
| 2.5.2. Data Transfer in response to I2C Controller Read .....            | 12 |
| 2.5.3. Data Transfer in response to I2C Controller Write .....           | 13 |
| 2.5.4. Data Transfer in response to I2C Combined Format Read .....       | 13 |
| 3. IP Parameter Description .....                                        | 15 |
| 4. Signal Description .....                                              | 16 |
| 5. Register Description .....                                            | 18 |
| 5.1. Overview .....                                                      | 18 |
| 5.2. Write Data Register (WR_DATA_REG) .....                             | 19 |
| 5.3. Read Data Register (RD_DATA_REG) .....                              | 19 |
| 5.4. Target Address Registers (TARGET_ADDR_REG, TARGET_ADDRH_REG) .....  | 19 |
| 5.5. Control Register (CONTROL_REG) .....                                | 19 |
| 5.6. Target Byte Count Register (TGT_BYTE_CNT_REG) .....                 | 20 |
| 5.7. Interrupt Status Registers (INT_STATUS1_REG, INT_STATUS2_REG) ..... | 21 |
| 5.8. Interrupt Enable Registers (INT_ENABLE1_REG, INT_ENABLE2_REG) ..... | 23 |
| 5.9. Interrupt Set Registers (INT_SET1_REG, INT_SET2_REG) .....          | 24 |
| 5.10. FIFO Status Register (FIFO_STATUS_REG) .....                       | 26 |
| 5.11. Received Address Registers (RX_ADDR_1_REG, RX_ADDR_2_REG) .....    | 27 |
| 6. Example Design .....                                                  | 28 |
| 6.1. Example Design Supported Configuration .....                        | 28 |
| 6.2. Overview of the Example Design and Features .....                   | 28 |
| 6.3. Design Components Example .....                                     | 30 |
| 6.4. Generating the Example Design .....                                 | 30 |
| 6.5. Hardware Testing .....                                              | 33 |
| 6.5.1. Hardware Testing Setup .....                                      | 33 |
| 6.5.2. Expected Output .....                                             | 33 |
| 7. Designing with the IP .....                                           | 34 |

---

|                                                 |    |
|-------------------------------------------------|----|
| 7.1. Generating and Instantiating the IP .....  | 34 |
| 7.1.1. Generated Files and File Structure ..... | 36 |
| 7.2. Design Implementation.....                 | 36 |
| 7.2.1. Device Constraint Editor.....            | 36 |
| 7.2.2. Manual PDC File Creation.....            | 36 |
| 7.3. Timing Constraints .....                   | 36 |
| 7.4. Running Functional Simulation .....        | 37 |
| Appendix A. Resource Utilization .....          | 39 |
| References .....                                | 42 |
| Technical Support Assistance .....              | 43 |
| Revision History .....                          | 44 |

## Figures

|                                                              |    |
|--------------------------------------------------------------|----|
| Figure 2.1. I2C Target IP Functional Diagram .....           | 10 |
| Figure 2.2. START and STOP Conditions .....                  | 11 |
| Figure 6.1. I2C Target IP in Propel SoC Project .....        | 29 |
| Figure 6.2. Sample C-Code Test Routine.....                  | 29 |
| Figure 6.3. I2C Target Example Design Block Diagram .....    | 30 |
| Figure 6.4. Create SoC Project .....                         | 31 |
| Figure 6.5. Define Instance .....                            | 31 |
| Figure 6.6. Build SoC Project Result.....                    | 32 |
| Figure 6.7. Lattice C/C++ Design Project.....                | 32 |
| Figure 6.8. Build C/C++ Project Result .....                 | 33 |
| Figure 6.9 Sample I2C Write Command Sent to I2C Target ..... | 33 |
| Figure 7.1. Module/IP Block Wizard .....                     | 34 |
| Figure 7.2. Configure User Interface of I2C Target IP .....  | 35 |
| Figure 7.3. Check Generating Result.....                     | 35 |
| Figure 7.4. Simulation Wizard.....                           | 37 |
| Figure 7.5. Adding and Reordering Source .....               | 37 |
| Figure 7.6. Simulation Waveform .....                        | 38 |

## Tables

|                                                                              |    |
|------------------------------------------------------------------------------|----|
| Table 1.1. Summary of the I2C Target IP .....                                | 7  |
| Table 1.2. I2C Target IP Support Readiness .....                             | 7  |
| Table 3.1. Attributes Table .....                                            | 15 |
| Table 4.1. I2C Target IP Signal Description .....                            | 16 |
| Table 5.1. Registers Address Map.....                                        | 18 |
| Table 5.2. Access Type Definition .....                                      | 18 |
| Table 5.3. Write Data Register.....                                          | 19 |
| Table 5.4. Read Data Register.....                                           | 19 |
| Table 5.5. Target Address Lower Register .....                               | 19 |
| Table 5.6. Target Address Higher Register .....                              | 19 |
| Table 5.7. Control Register .....                                            | 19 |
| Table 5.8. Target Byte Count Register .....                                  | 21 |
| Table 5.9. Interrupt Status First Register .....                             | 21 |
| Table 5.10. Interrupt Status Second Register .....                           | 22 |
| Table 5.11. Interrupt Enable First Register .....                            | 23 |
| Table 5.12. Interrupt Enable Second Register .....                           | 24 |
| Table 5.13. Interrupt Set First Register.....                                | 24 |
| Table 5.14. Interrupt Set Second Register .....                              | 25 |
| Table 5.15. FIFO Status Register .....                                       | 26 |
| Table 5.16. Received Address 1 .....                                         | 27 |
| Table 5.17. Received Address 2 .....                                         | 27 |
| Table 6.1. I2C Target IP Configuration Supported by the Example Design ..... | 28 |
| Table 7.1. Generated File List .....                                         | 36 |
| Table A.1. LAV-AT-E70-1LFG1156I Device Resource Utilization .....            | 39 |
| Table A.2. LFMXO5-25-9BBG400I Device Resource Utilization .....              | 39 |
| Table A.3. LFMXO5-25-7BBG400I Device Resource Utilization .....              | 40 |
| Table A.4. LN2-CT-20-1CBG484C Device Resource Utilization .....              | 40 |
| Table A.5. LFMXO4-110HC-5BBG484I Device Resource Utilization.....            | 41 |

## Acronyms in This Document

A list of acronyms used in this document.

| Acronym | Definition                                  |
|---------|---------------------------------------------|
| APB     | Advanced Peripheral Bus                     |
| AMBA    | Advanced Microcontroller Bus Architecture   |
| DUT     | Design Under Test                           |
| EBR     | Embedded Block RAM                          |
| FIFO    | First In, First Out                         |
| FPGA    | Field Programmable Gate Array               |
| GPIO    | General Purpose Input/Output                |
| I/O     | Input/Output                                |
| I2C     | Inter-Integrated Circuit                    |
| IP      | Intellectual Property                       |
| LMMI    | Lattice Memory Mapped Interface             |
| LSE     | Lattice Synthesis Engine                    |
| LUT     | Look-Up Table                               |
| PIC     | Programmable Interrupt Controller           |
| PLL     | Phase-Locked Loop                           |
| RAM     | Random Access Memory                        |
| RISC-V  | Reduced Instruction Set Computer Five       |
| RTL     | Register Transfer Level                     |
| RX      | Receiver                                    |
| SCL     | Serial Clock                                |
| SDA     | Serial Data                                 |
| SoC     | System on Chip                              |
| SRAM    | Static Random Access Memory                 |
| TX      | Transmitter                                 |
| UART    | Universal Asynchronous Receiver/Transmitter |

# 1. Introduction

## 1.1. Overview of the IP

I2C (Inter-Integrated Circuit) bus is a simple, low-bandwidth, short-distance protocol. It is often seen in systems with peripheral devices that are accessed intermittently. It is commonly used in short-distance systems, where the number of traces on the board should be minimized. The device that initiates the transmission on the I2C bus is commonly known as the Controller, while the device being addressed is called the Target.

Lattice Semiconductor general-purpose I2C Target IP provides device addressing, read/write operation and an acknowledgement mechanism. The programmable nature of FPGA provides you with the flexibility of configuring the I2C Target device to any legal Target address, thus, avoiding a potential Target address collision on an I2C bus with multiple Target devices.

## 1.2. Quick Facts

**Table 1.1. Summary of the I2C Target IP**

|                             |                           |                                                                                                                                |
|-----------------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| <b>IP Requirements</b>      | Supported Devices         | CrossLink™-NX, Certus™-NX, Certus-NX-RT, CertusPro™-NX, CertusPro-NX-RT, MachXO5™-NX, Lattice Avant™, Certus-N2, and MachXO4™. |
|                             | IP Changes <sup>1</sup>   | For a list of changes to the IP, refer to the <a href="#">I2C Target IP Release Notes (FPGA-RN-02028)</a> .                    |
| <b>Resource Utilization</b> | Supported User Interfaces | Lattice Memory Mapped Interface (LMMI) and Advanced Peripheral Bus (APB)                                                       |
|                             | Resources                 | Refer to <a href="#">Appendix A. Resource Utilization</a>                                                                      |
| <b>Design Tool Support</b>  | Lattice Implementation    | IP Core v2.5.0 – Lattice Radiant™ Software 2025.2 and Lattice Propel™ Builder 2025.2                                           |
|                             | Synthesis                 | Lattice Synthesis Engine                                                                                                       |
|                             |                           | Synopsys Synplify Pro® for Lattice                                                                                             |
|                             | Simulation                | For a list of supported simulators, see the <a href="#">Lattice Radiant Software User Guide</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. I2C Target IP Support Readiness**

| Device Family   | System Clock Frequency (MHz) <sup>1</sup> | Supported Feature              | Radiant Timing Model | Hardware Validated |
|-----------------|-------------------------------------------|--------------------------------|----------------------|--------------------|
| Crosslink-NX    | 50                                        | SCL at 100 kHz: I2C Read-Write | Final                | No                 |
| Certus-NX       | 50                                        | SCL at 100 kHz: I2C Read-Write | Final                | No                 |
| Certus-NX-RT    | 50                                        | SCL at 100 kHz: I2C Read-Write | Final                | No                 |
| CertusPro-NX    | 50                                        | SCL at 100 kHz: I2C Read-Write | Final                | Yes                |
| CertusPro-NX-RT | 50                                        | SCL at 100 kHz: I2C Read-Write | Final                | No                 |
| MachXO5-NX      | 50                                        | SCL at 100 kHz: I2C Read-Write | Final                | Yes                |
|                 |                                           | SCL at 400 kHz: I2C Read-Write | Final                | Yes                |
|                 |                                           | SCL at 1 MHz: I2C Read-Write   | Final                | Yes                |
|                 | 40                                        | SCL at 100 kHz: I2C Read-Write | Final                | Yes                |
|                 |                                           | SCL at 400 kHz: I2C Read-Write | Final                | Yes                |
|                 |                                           | SCL at 1 MHz: I2C Read-Write   | Final                | Yes                |
|                 | 200                                       | SCL at 100 kHz: I2C Read-Write | Final                | Yes                |

| Device Family | System Clock Frequency (MHz) <sup>1</sup> | Supported Feature              | Radiant Timing Model | Hardware Validated |
|---------------|-------------------------------------------|--------------------------------|----------------------|--------------------|
|               |                                           | SCL at 400 kHz: I2C Read-Write | Final                | Yes                |
|               |                                           | SCL at 1 MHz: I2C Read-Write   | Final                | Yes                |
| Avant         | 50                                        | SCL at 100 kHz: I2C Read-Write | Preliminary          | No                 |
| Certus-N2     | 50                                        | SCL at 100 kHz: I2C Read-Write | Preliminary          | No                 |

**Note:**

1. This is the system clock frequency used during hardware validation. For the actual frequency supported by the IP, refer to [Appendix A. Resource Utilization](#).

## 1.4. Features

The I2C Target IP supports the following key features:

- Supports 7-bit and 10-bit Addressing Mode
- Supports the following bus speeds:
  - Standard-mode (Sm) – up to 100 kbit/s
  - Fast-mode (Fm) – up to 400 kbit/s
  - Fast-mode Plus (Fm+) – up to 1 Mbit/s
- Supports Clock stretching
- Configurable ACK/NACK response on address and data phases
- Integrated Pull-up
- Integrated Glitch filter
- Polling and Out-of-band Interrupt Modes

## 1.5. Licensing Information

The I2C Target 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. Minimum Device Requirements

There is no limitation in device speed grade for the I2C Target IP. See [Appendix A. Resource Utilization](#) for minimum required resources to instantiate this IP and maximum clock frequency supported.

## 1.8. Naming Conventions

### 1.8.1. Nomenclature

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

### 1.8.2. Signal Names

Signal Names that end with:

- `_n` are active low
- `_i` are input signals
- `_o` are output signals
- `_io` are bi-directional input/output signals

### 1.8.3. Attribute Names

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

## 2. Functional Description

This section provides a detailed functional description of the I2C Target IP which includes information regarding clock and reset handling, and user interfaces.

### 2.1. IP Architecture Overview

Functional diagram of the I2C Target is presented in [Figure 2.1](#). The APB2LMMI bridge and APB interface is only available when *APB Mode Enable* attribute is Checked.



Figure 2.1. I2C Target IP Functional Diagram

### 2.2. Clocking and Reset

The I2C Target IP requires a system clock: `clk_i`. You need to provide this clock via an external source and route it to an appropriate pin on the FPGA. The system clock (externally sourced) will provide a timing reference and be used to operate the IP's internal logic.

The I2C Target IP contains an asynchronous active low reset: `rst_n_i`. When asserted, the output ports and registers are forced to their default values. The reset assertion can be asynchronous but reset negation should be synchronous. The IP contains internal logic to synchronously de-assert the internal reset once `rst_n_i` is de-asserted, so you do not need to implement your own de-assertion logic.

Refer to [Clock Stretching](#) section for more information on clock and reset signal requirements.

### 2.3. Operations Details

#### 2.3.1. General I2C Operation

In I2C bus, the transaction is always initiated by the controller. A target may not transmit data unless it has been addressed by the controller. Each device on the I2C bus has a specific device address to differentiate between other devices that are on the same I2C bus. Data transfer is initiated only when the bus is idle. A bus is considered idle if both SDA and SCL lines are high after a STOP condition.

The general procedure for an I2C transaction is as follows:

1. Controller wants to send data to a target:
  - Controller-transmitter sends a START condition and addresses the target-receiver
  - Controller-transmitter sends data to target-receiver
  - Controller-transmitter terminates the transfer with a STOP condition
2. Controller wants to receive/read data from a target:
  - Controller-receiver sends a START condition and addresses the target-transmitter
  - Controller-receiver receives data from the target-transmitter
  - Controller-receiver terminates the transfer with a STOP condition

I2C communication is initiated by the controller sending a START condition and terminated by the controller sending a STOP condition. Normal data on the SDA line must be stable during the high level of the SCL line. The High or Low state of the data line can only change when SCL is Low. The Start condition is a unique case and is defined by a High-to-Low transition on the SDA line while SCL is High. The Stop condition is a unique case and is defined by a Low-to-High transition on the SDA line while SCL is High. These are shown in [Figure 2.2](#).



**Figure 2.2. START and STOP Conditions**

Each data packet on the I2C bus consists of eight bits of data followed by an acknowledge bit (ACK) so one complete data byte transfer requires nine clock pulses. Data is transferred with the most significant bit (MSB) first. The transmitter releases the SDA line during the ACK bit and the receiver of the data transfer must drive the SDA line low during the ACK bit to acknowledge the data receipt. If a Target-receiver does not drive the SDA line low during the ACK bit, this indicates that the Target-receiver was unable to accept the data and the Controller can then generate a Stop condition to abort the transfer. If the Controller-receiver does not generate an ACK, this indicates to the Target-transmitter that this byte was the last byte of the transfer.

For more information on I2C bus, refer to [I2C Bus Specification and User Manual](#).

### 2.3.2. Glitch Filter

I2C Target IP has integrated glitch filter to remove 50ns noise/spike as recommended by the I2C Bus Spec for Standard mode, Fast mode and Fast mode Plus. The glitch filter is applied to both the SCL and SDA signals before they are fed to internal logic. Thus, the I2C signals seen by the IP is delayed by a number of clock cycles (~50 ns +1 clock cycle). The filter depth is automatically adjusted based on the *System Clock Frequency* attribute.

### 2.3.3. Clock Stretching

Clock stretching allows the I2C target to pause a transaction by holding the SCL line Low. The transaction cannot continue until the line is released high again. On the byte level, a target device may be able to receive bytes of data at a fast rate, but needs more time to store a received byte or prepare another byte to be transmitted. Targets can then hold the SCL line Low after reception and acknowledgment (ACK bit) of a byte to force the controller into a wait state until the target is ready for the next byte transfer.

I2C Target IP performs clock stretching on the byte level (during ACK/NACK bit) if CONTROL\_REG.clk\_stretch\_en is set to 1 and one of the three interrupt status bits is set:

- tx\_fifo\_empty\_int (bit 3 of INT\_STATUS1)
- rx\_fifo\_full\_int (bit 2 of INT\_STATUS1)
- rx\_addr\_int (bit 3 of INT\_STATUS2)

The I2C Target IP will release the SCL line once all of the three interrupt status bits above are cleared. This gives firmware a larger window in time to prepare for a new message, fill an empty Transmit FIFO or empty a full Receive FIFO.

### 2.3.4. ACK/NACK Response

I2C Target IP can be configured to send an ACK or a NACK based on settings of CONTROL\_REG.nack\_data and CONTROL\_REG.nack\_addr, refer to [Control Register \(CONTROL\\_REG\)](#) section for details. If the host would like to temporarily disable the access to I2C Target IP, it should set CONTROL\_REG.nack\_addr = 1'b1. In this case, I2C Target IP sends NACK when it is addressed by the external I2C controller.

If the host would like to terminate an on-going I2C write transaction to the I2C Target IP, it should set CONTROL\_REG.nack\_data = 1'b1. In this case, I2C Target IP sends NACK on the next ACK bit for a data byte. Note that the ACK bit is always sent by the receiver, the CONTROL\_REG.nack\_data has no effect on I2C read transaction.

## 2.4. User Interfaces

### 2.4.1. Selectable Memory-Mapped Interface

The memory-mapped interface of I2C Target IP is selected by the *APB Mode Enable* attribute; it can be APB or LMMI. Register access are done via the selected memory-mapped interface. These interfaces are not described in this user guide, references to their respective specifications are provided below.

For LMMI interface, refer to the [Lattice Memory Mapped Interface and Lattice Interrupt Interface \(FPGA-UG-02039\)](#) document for information and timing diagram of the LMMI. Take note of the following information when checking LMMI timing diagram in the said document:

- Immi\_ready\_o is always asserted; thus, write and read transactions have no wait state.
- Read latency is one clock cycle.

For APB interface, refer to [AMBA 3 APB Protocol v1.0 Specification](#) for information and timing diagram of the APB interface. Take note of the following information when checking APB timing diagram in the said document:

- Write transaction has one wait state.
- Read transaction has one wait state (IP Core v1.0.2 or earlier has two wait states).

## 2.5. Programming Flow

### 2.5.1. Initialization

To perform initialization, load the appropriate registers of the I2C Target namely:

- TARGET\_ADDR\_REG, TARGET\_ADDRH\_REG – This step is optional. In most cases, initial value set in I2C Target Addresses attribute of the user interface does not need to be changed.
- CONTROL\_REG – It is recommended to set this if you want I2C Target to NACK during the Data or Address phase, or if you want to enable/disable clock stretching and 10-bit addressing.
- TGT\_BYTE\_CNT\_REG – It is recommended to set this if the size of the data is known. Set this to 8'h00 if the number of bytes to transfer is not known, that is receiving unknown amount of data.
- INT\_ENABLE1\_REG – It is recommended to enable only the following interrupts when receiving commands from controller.
  - Transfer Complete Interrupt – If the size of data is known
  - Receive FIFO Data Interrupt – If the size of data is unknown
- INT\_ENABLE2\_REG – It is recommended to enable both error interrupts.

### 2.5.2. Data Transfer in response to I2C Controller Read

Below are the recommended steps to perform data transfer in response to read request of I2C Controller. This assumes that the amount of data to send is known.

To perform data transfer in response to read request of I2C Controller:

1. Write data to WR\_DATA\_REG, amounting to <= FIFO Depth.

2. Enable only Transfer Complete Interrupt. If transmit data is > FIFO Depth, enable also Transmit FIFO Almost Empty interrupt. If no more data to transfer, otherwise, proceed to step 7.
3. Wait for Transmit FIFO Almost Empty Interrupt.  
If polling mode is desired (interrupts are disabled), read INT\_STATUS1\_REG until tx\_fifo\_aempty\_int asserts.  
If interrupt mode is desired, simply wait for interrupt signal to assert, then read INT\_STATUS1\_REG and check that tx\_fifo\_aempty\_int is asserted.  
Read INT\_STATUS2\_REG also to check that no error occurred.
4. Clear Transmit FIFO Almost Empty Interrupt, it also okay to clear all interrupts.
5. Write data byte to WR\_DATA\_REG, amounting to less than or equal to (FIFO Depth - TX FIFO Almost Empty Setting).
6. If there are remaining data to transfer, go back to Step 3, otherwise, disable Transmit FIFO Almost Empty Interrupt.
7. Wait for Transfer Complete Interrupt  
If polling mode is desired (interrupts are disabled), read INT\_STATUS1\_REG until tr\_cmp\_int asserts.  
If interrupt mode is desired, simply wait for interrupt signal to assert, then read INT\_STATUS1\_REG and check that tr\_cmp\_int is asserted.  
Read INT\_STATUS2\_REG also to check that no error occurred.
8. Clear all interrupts.

### 2.5.3. Data Transfer in response to I2C Controller Write

Below are the recommended steps to perform data transfer in response to write request of I2C Controller. This assumes that the amount of data to receive is known.

To perform data transfer in response to write request of I2C Controller:

1. Enable only Transfer Complete Interrupt. If data to receive is > FIFO Depth, enable also Receive FIFO Almost Full interrupt. If data to receive is <= FIFO Depth, proceed to Step 6.
2. Wait for Receive FIFO Almost Full Interrupt.  
If polling mode is desired (interrupts are disabled), read INT\_STATUS2\_REG until rx\_fifo\_afull\_int asserts.  
If interrupt mode is desired, simply wait for interrupt signal to assert, then read INT\_STATUS2\_REG and check that rx\_fifo\_afull\_int is asserted.  
Read INT\_STATUS2\_REG also to check that no error occurred.
3. Clear Receive FIFO Almost Full Interrupt, it also okay to clear all interrupts.
4. Read data byte from RD\_DATA\_REG, amounting to less than or equal to (RX FIFO Almost Full Setting).
5. If there are remaining data to receive, go back to Step 2, otherwise, disable Receive FIFO Almost Full Interrupt.
6. Wait for Transfer Complete Interrupt  
If polling mode is desired (interrupts are disabled), read INT\_STATUS1\_REG until tr\_cmp\_int asserts.  
If interrupt mode is desired, simply wait for interrupt signal to assert, then read INT\_STATUS1\_REG and check that tr\_cmp\_int is asserted.  
Read INT\_STATUS2\_REG also to check that no error occurred.
7. Clear all interrupts.
8. Read all data from RD\_DATA\_REG.

### 2.5.4. Data Transfer in response to I2C Combined Format Read

Below are the recommended steps to perform data transfer in response to a read request of I2C Controller using a combined format.

To perform data transfer in response to read request of I2C Controller:

1. Enable Transmit FIFO Empty, Receive FIFO Full, Receive Address Interrupt, and Stop Detect Interrupt.
2. Enable Clock Stretch in the CONTROL\_REG.
3. Wait for the interrupt to assert.
4. Check the cause of the interrupt.

- a. If the interrupt is due to Receive Address Interrupt, check RX\_ADDR\_1\_REG.rx\_rnw to check if the request is a write or a read. For a combined format, first transaction is a write.
5. Clear all interrupts and wait for the interrupt to assert again.
6. Check the cause of the interrupt.
  - a. If the interrupt is due to Receive Address Interrupt, check RX\_ADDR\_1\_REG.rx\_rnw to confirm the next transaction. In a combined format, the second transaction is a read. Read all data from Receive FIFO and provide appropriate response in the Transmit FIFO. Go back to step 5.
  - b. If the interrupt is due to Receive FIFO Full, the Receive FIFO should be emptied to allow more data to be received. Go back to step 5.
  - c. If the interrupt is due to Transmit FIFO Empty, provide necessary data by writing to the Transmit FIFO. Go back to step 5.
  - d. If the interrupt is due to Stop Detect Interrupt, proceed to the remaining steps.
7. Check if there are remaining data in the Receive FIFO and Transmit FIFO.
8. Clear the FIFOs after consuming the necessary data by writing to CONTROL\_REG.rx\_fifo\_reset and CONTROL\_REG.tx\_fifo\_reset.
9. Clear all interrupts.

### 3. IP Parameter Description

The configurable attributes of the I2C Target IP are shown in [Table 3.1](#). The attributes can be configured through the IP Catalog's Module/IP wizard of the Lattice Radiant software.

Wherever applicable, default values are in **bold**.

**Table 3.1. Attributes Table**

| Attribute                                   | Selectable Values                                                         | Description                                                                                                                                                                                                                                                                       |
|---------------------------------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>General</b>                              |                                                                           |                                                                                                                                                                                                                                                                                   |
| APB Mode Enable                             | <b>Checked</b> , Unchecked                                                | Selects memory-mapped interface for register access by the host. The unselected interfaces are not available in the generated IP.<br>Checked: APB I/F is enabled.<br>Unchecked: LMMI I/F is enabled.                                                                              |
| Remove Tristate Buffers                     | Checked, <b>Unchecked</b>                                                 | Removes the tristate buffer to allow you to include additional logic between the IP and the buffers.<br>Checked: Tristate buffers will not be instantiated inside the IP.<br>Unchecked: Tristate buffers will be instantiated inside the IP.                                      |
| Addressing Mode                             | <b>7-bit</b> , 10-bit                                                     | Specifies the reset value of CONTROL_REG.addr_10bit_en.<br>7-bit: CONTROL_REG.addr_10bit_en = 1'b0<br>10-bit: CONTROL_REG.addr_10bit_en = 1'b1                                                                                                                                    |
| I2C Target Address:0x                       | 7-bit: 0–7F, <b>0x51</b><br>10 bit: 0–3FF, <b>0x51</b>                    | Specifies the reset value of Target Address Register. Your input is converted into 10-bit address value. The lower 7 bits are assigned to TARGET_ADDR_L_REG.target_addr_l_reg while the upper 3 bits are assigned to TARGET_ADDR_H_REG.target_addr_h_reg.                         |
| STOP Condition Detected Interrupt Assertion | All STOP condition detected on bus, <b>STOP Condition addressed to IP</b> | Specifies whether STOP Detect Interrupt will assert for all STOP condition detected on bus or only for STOP condition after I2C transaction addressed to IP. Refer to the <a href="#">Interrupt Status Registers (INT_STATUS1_REG, INT_STATUS2_REG)</a> section for more details. |
| System Clock Frequency (MHz)                | <b>40–100, 50</b>                                                         | Specifies the frequency of system clock. This is used to configure the internal glitch filter.                                                                                                                                                                                    |
| <b>Timing Adjustment</b>                    |                                                                           |                                                                                                                                                                                                                                                                                   |
| I2C SDA Register Depth                      | <b>0, 1, 2</b>                                                            | Allows you to delay the SDA timing by 0 to 2 clock cycles. This helps to compensate any delays on the SCL line as it is sampled by the IP.                                                                                                                                        |
| <b>FIFO</b>                                 |                                                                           |                                                                                                                                                                                                                                                                                   |
| FIFO Width                                  | —                                                                         | Specifies the bit width of each data word of the internal FIFO. This is not editable and is fixed to 8 because each I2C data is 8 bits.                                                                                                                                           |
| FIFO Depth                                  | <b>16, 32, 64, 128, 256</b>                                               | Specifies the number of FIFO levels. Accepts only power of two values.                                                                                                                                                                                                            |
| Implementation of FIFO                      | <b>EBR, LUT</b>                                                           | Selects the FPGA resource that are used to implement the FIFO: EBR or LUT.                                                                                                                                                                                                        |
| TX FIFO Almost Empty Flag                   | <b>1–256, 2</b>                                                           | Specifies the trigger level for asserting INT_STATUS_REG.tx_fifo_aempty_int. Refer to the <a href="#">Interrupt Status Registers (INT_STATUS1_REG, INT_STATUS2_REG)</a> section for more details.                                                                                 |
| RX FIFO Almost Full Flag                    | <b>1–256, 14</b>                                                          | Specifies the trigger level for asserting INT_STATUS_REG.rx_fifo_afull_int. Refer to the section <a href="#">Interrupt Status Registers (INT_STATUS1_REG, INT_STATUS2_REG)</a> for more details.                                                                                  |

## 4. Signal Description

Table 4.1. I2C Target IP Signal Description

| Port Name                                          | I/O    | Width | Description                                                                                                                                                                                    |
|----------------------------------------------------|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Clock and Reset</b>                             |        |       |                                                                                                                                                                                                |
| clk_i                                              | In     | 1     | System clock                                                                                                                                                                                   |
| rst_n_i                                            | In     | 1     | Asynchronous active low reset<br>The reset assertion can be asynchronous but reset negation should be synchronous. When asserted, output ports and registers are forced to their reset values. |
| <b>Interrupt Port</b>                              |        |       |                                                                                                                                                                                                |
| int_o                                              | Out    | 1     | Interrupt signal<br>Reset value is 1'b0.                                                                                                                                                       |
| <b>I2C Interface (Remove Tristate Buffers = 0)</b> |        |       |                                                                                                                                                                                                |
| scl_io                                             | In/Out | 1     | I2C Serial Clock<br>Generated by the external I2C Controller to synchronize data transfers.<br>Reset value is weak high (pull-up).                                                             |
| sda_io                                             | In/Out | 1     | I2C data signal<br>Reset value is weak high (pull-up).                                                                                                                                         |
| <b>I2C Interface (Remove Tristate Buffers = 1)</b> |        |       |                                                                                                                                                                                                |
| scl_i                                              | In     | 1     | I2C serial clock input<br>Input from tristate buffer.                                                                                                                                          |
| scl_o                                              | Out    | 1     | I2C serial clock output<br>Output to tristate buffer. This signal is fixed to 1'b0.                                                                                                            |
| scl_oe_o                                           | Out    | 1     | I2C serial clock output enable<br>Active low signal to enable output of a tristate buffer. Reset value is 1'b1.                                                                                |
| sda_i                                              | In     | 1     | I2C data signal input<br>Input from tristate buffer.                                                                                                                                           |
| sda_o                                              | Out    | 1     | I2C data signal output<br>Output to tristate buffer. This signal is fixed to 1'b0.                                                                                                             |
| sda_oe_o                                           | Out    | 1     | I2C data signal output enable<br>Active low signal to enable output of a tristate buffer. Reset value is 1'b1.                                                                                 |
| <b>LMMI Interface*</b>                             |        |       |                                                                                                                                                                                                |
| lmmi_request_i                                     | In     | 1     | Start transaction                                                                                                                                                                              |
| lmmi_wr_rdn_i                                      | In     | 1     | Write = 1'b1, Read = 1'b0                                                                                                                                                                      |
| lmmi_offset_i                                      | In     | 4     | Register offset, starting at offset 0                                                                                                                                                          |
| lmmi_wdata_i                                       | In     | 8     | Input data bus.                                                                                                                                                                                |
| lmmi_rdata_o                                       | Out    | 8     | Output data bus<br>Reset value is 0.                                                                                                                                                           |
| lmmi_rdata_valid_o                                 | Out    | 1     | Read transaction is complete and lmmi_rdata_o contains valid data.<br>Reset value is 1'b0.                                                                                                     |
| lmmi_ready_o                                       | Out    | 1     | IP is ready to receive a new transaction. This is always asserted (tied to 1'b1).                                                                                                              |
| <b>APB Interface*</b>                              |        |       |                                                                                                                                                                                                |
| apb_psel_i                                         | In     | 1     | APB Select signal<br>Indicates that the device is selected and a data transfer is required.                                                                                                    |
| apb_paddr_i                                        | In     | 6     | APB Address signal.                                                                                                                                                                            |
| apb_pwdata_i                                       | In     | 32    | APB Write data signal<br>Bits [31:8] are not used.                                                                                                                                             |
| apb_pwrite_i                                       | In     | 1     | APB Direction signal<br>Write = 1, Read = 0                                                                                                                                                    |

| Port Name     | I/O | Width | Description                                                                                                               |
|---------------|-----|-------|---------------------------------------------------------------------------------------------------------------------------|
| apb_penable_i | In  | 1     | APB Enable signal<br>Indicates the second and subsequent cycles of an APB transfer.                                       |
| apb_pready_o  | Out | 1     | APB Ready signal<br>Indicates transfer completion. IP uses this signal to extend an APB transfer.<br>Reset value is 1'b0. |
| apb_pslverr_o | Out | 1     | APB Error signal<br>Indicates a transfer failure. This signal is tied to 1'b0.                                            |
| apb_prdata_o  | Out | 32    | APB Read data signal<br>Bits [31:8] are not used and are fixed to 0.<br>Reset value is 0.                                 |

\*Note: Only one of the two interfaces are available as selected by *APB Mode Enable* attribute.

## 5. Register Description

### 5.1. Overview

The I2C Target IP configuration registers are located at the addresses shown in [Table 5.1](#). The offset of each register is dependent on *APB Mode Enable* attribute setting as follows:

- *APB Mode Enable* is Unchecked – the offset increments by 1.
- *APB Mode Enable* is Checked – the offset increments by 4 to allow easy interfacing with the Processor and System Buses. In this mode, each register is 32-bit wide wherein the upper bits [31:8] are reserved and the lower 8 bits [7:0] are described in the next section.

**Table 5.1. Registers Address Map**

| Offset<br>LMMI | Offset<br>APB  | Register Name    | Access Type | Description                                                           |
|----------------|----------------|------------------|-------------|-----------------------------------------------------------------------|
| 0x0            | 0x00           | RD_DATA_REG      | RO          | Read Data Register                                                    |
| 0x0            | 0x00           | WR_DATA_REG      | WO          | Write Data Register                                                   |
| 0x1            | 0x04           | TARGET_ADDRL_REG | RW          | Target Address Lower Register                                         |
| 0x2            | 0x08           | TARGET_ADDRH_REG | RW          | Target Address Higher Register                                        |
| 0x3            | 0x0C           | CONTROL_REG      | RW          | Control Register                                                      |
| 0x4            | 0x10           | TGT_BYTE_CNT_REG | RW          | Target Byte Count Register                                            |
| 0x5            | 0x14           | INT_STATUS1_REG  | RW1C        | Interrupt Status First Register                                       |
| 0x6            | 0x18           | INT_ENABLE1_REG  | RW          | Interrupt Enable First Register                                       |
| 0x7            | 0x1C           | INT_SET1_REG     | WO          | Interrupt Set First Register                                          |
| 0x8            | 0x20           | INT_STATUS2_REG  | RW1C        | Interrupt Status Second Register                                      |
| 0x9            | 0x24           | INT_ENABLE2_REG  | RW          | Interrupt Enable Second Register                                      |
| 0xA            | 0x28           | INT_SET2_REG     | WO          | Interrupt Set Second Register                                         |
| 0xB            | 0x2C           | FIFO_STATUS_REG  | RO          | FIFO Status Register                                                  |
| 0xC            | 0x30           | RX_ADDR_1_REG    | RO          | Received Address First Register                                       |
| 0xD            | 0x34           | RX_ADDR_2_REG    | RO          | Received Address Second Register                                      |
| 0xE –<br>0xF   | 0x38 –<br>0x3C | Reserved         | RSVD        | Reserved<br>Write access is ignored and 0 is returned on read access. |

The RD\_DATA\_REG and WR\_DATA\_REG share the same offset. Write access to this offset goes to WR\_DATA\_REG while read access goes to RD\_DATA\_REG.

The behavior of registers to write and read access is defined by its access type, which is defined in [Table 5.2](#).

**Table 5.2. Access Type Definition**

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

## 5.2. Write Data Register (WR\_DATA\_REG)

**Table 5.3** presents the Write Data Register. This is the interface to Transmit FIFO. Writing to WR\_DATA\_REG pushes a word to Transmit FIFO. When writing to WR\_DATA\_REG, the host should ensure that Transmit FIFO is not full. This can be done by reading FIFO\_STATUS\_REG. Data is popped from WR\_DATA\_REG during I2C read transaction. When reset is performed, the contents of Transmit FIFO are not reset but the FIFO control logic is reset. Thus, content is not guaranteed after reset.

**Table 5.3. Write Data Register**

| Field | Name    | Access | Width | Reset          |
|-------|---------|--------|-------|----------------|
| [7:0] | tx_fifo | WO     | 8     | not guaranteed |

## 5.3. Read Data Register (RD\_DATA\_REG)

**Table 5.4** presents the Read Data register. This is the interface to Receive FIFO. After a data is received from I2C bus during I2C write transaction, the received data is pushed to Receive FIFO. Reading from RD\_DATA\_REG pops a word from Receive FIFO. The host should ensure that Receive FIFO has data before reading RD\_DATA\_REG, data is not guaranteed when this register is read during Receive FIFO empty condition. On the other hand, if Receive FIFO is full but I2C Target continues to receive data, new data is lost. Read FIFO\_STATUS\_REG to determine the status of Receive FIFO. Similar to Transmit FIFO, the reset value of Receive FIFO is also not guaranteed after reset.

**Table 5.4. Read Data Register**

| Field | Name    | Access | Width | Reset          |
|-------|---------|--------|-------|----------------|
| [7:0] | rx_fifo | RO     | 8     | not guaranteed |

## 5.4. Target Address Registers (TARGET\_ADDRL\_REG, TARGET\_ADDRH\_REG)

The Target Address Lower Register (TARGET\_ADDRL\_REG) shown in **Table 5.5** is a 7-bit Target address. This is used for 7-bit and 10-bit addressing mode as follows:

- For 7-bit Addressing Mode, it is the Target address
- For 10-bit Addressing Mode, it is the lower 7 bits of the Target address

**Table 5.5. Target Address Lower Register**

| Field | Name              | Access | Width | Reset                   |
|-------|-------------------|--------|-------|-------------------------|
| [7]   | reserved          | RSVD   | 1     | –                       |
| [6:0] | target_addr_l_reg | RW     | 7     | I2C Target Address[6:0] |

The Target Address Higher Register (TARGET\_ADDRH\_REG) shown in **Table 5.6** is the upper 3 bits of 10-bit Target address. This is not used in 7-bit addressing mode. The reset values of TARGET\_ADDRL\_REG and TARGET\_ADDRH\_REG is set by the I2C Target Address attribute as shown in **Table 5.5** and **Table 5.6**.

**Table 5.6. Target Address Higher Register**

| Field | Name              | Access | Width | Reset                   |
|-------|-------------------|--------|-------|-------------------------|
| [7:3] | reserved          | RSVD   | 5     | –                       |
| [2:0] | target_addr_h_reg | RW     | 3     | I2C Target Address[9:7] |

## 5.5. Control Register (CONTROL\_REG)

**Table 5.7** presents a summary of Control Register. This each bit of this register controls the behavior of I2C Target IP.

**Table 5.7. Control Register**

| Field | Name          | Access | Width | Reset |
|-------|---------------|--------|-------|-------|
| [7]   | reserved      | RSVD   | 1     | –     |
| [6]   | rx_fifo_reset | WO     | 1     | 1'b0  |

| Field | Name           | Access | Width | Reset                                               |
|-------|----------------|--------|-------|-----------------------------------------------------|
| [5]   | tx_fifo_reset  | WO     | 1     | 1'b0                                                |
| [4]   | nack_data      | RW     | 1     | 1'b0                                                |
| [3]   | nack_addr      | RW     | 1     | 1'b0                                                |
| [2]   | reset          | RW     | 1     | 1'b0                                                |
| [1]   | clk_stretch_en | RW     | 1     | 1'b0                                                |
| [0]   | addr_10bit_en  | RW     | 1     | See Addressing Mode<br>in <a href="#">Table 3.1</a> |

- rx\_fifo\_reset

Resets the Receive FIFO logic, effectively flushing the contents. This is write-only bit because it has an auto clear feature; it is cleared to 1'b0 after 1 clock cycle.

1'b0 – No action.

1'b1 – Resets the Receive FIFO.

- tx\_fifo\_reset

Resets the Transmit FIFO logic, effectively flushing the contents. This is write-only bit because it has an auto clear feature; it is cleared to 1'b0 after 1 clock cycle.

1'b0 – No action.

1'b1 – Resets the Transmit FIFO.

- nack\_data

NACK on Data Phase. Specifies ACK/NACK response on I2C data phase.

1'b0 – Sends ACK to received data

1'b1 – Sends NACK to received data

- nack\_addr

NACK on Address Phase. Specifies ACK/NACK response on I2C address phase.

1'b0 – Sends ACK to received address if it matches the programmed target address

1'b1 – Sends NACK to received address

- reset

Reset. Resets I2C Target IP. The registers and LMMI interface are not affected by this reset.

1'b0 – No action.

1'b1 – Resets I2C Target IP.

- clk\_stretch\_en

Clock Stretch Enable. Enables clock stretching on ACK bit.

1'b0 – I2C Target IP releases SCL signal

1'b1 – I2C Target IP pulls down SCL signal on the next ACK bit and keeps pulling-down until the host writes 1'b0 on this bit.

- addr\_10bit\_en

10-bit Address Mode Enable. Enables the reception of 10-bit I2C address.

1'b0 – I2C Target IP rejects the 10-bit I2C address, it sends NACK.

1'b1 – I2C Target IP responds to 10-bit I2C address. If TARGET\_ADDRH\_REG.target\_addr\_h\_reg is 3'h0, it also responds to 7-bit address.

## 5.6. Target Byte Count Register (TGT\_BYTE\_CNT\_REG)

[Table 5.8](#) presents the summary of Target Byte Count Register. The desired number of bytes to transfer (read/write) in I2C bus should be written to this register. This is used for Transfer Complete interrupt generation – asserts when the target byte count is achieved.

© 2025 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at [www.latticesemi.com/legal](http://www.latticesemi.com/legal).

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

FPGA-IPUG-02072-2.2

20

**Table 5.8. Target Byte Count Register**

| Field | Name     | Access | Width | Reset |
|-------|----------|--------|-------|-------|
| [7:0] | byte_cnt | RW     | 8     | 8'h00 |

## 5.7. Interrupt Status Registers (INT\_STATUS1\_REG, INT\_STATUS2\_REG)

[Table 5.9](#) and [Table 5.10](#) presents Interrupt Status Register (INT\_STATUS1\_REG and INT\_STATUS2\_REG), they contain all the interrupts currently pending in the I2C Target IP. When an interrupt bit asserts, it remains asserted until it is cleared by the host by writing 1'b1 to the corresponding bit.

The interrupt status bits are independent of the interrupt enable bits; in other words, status bits may indicate pending interrupts, even though those interrupts are disabled in the Interrupt Enable Register, see the [Interrupt Enable Registers \(INT\\_ENABLE1\\_REG, INT\\_ENABLE2\\_REG\)](#) section for details. The logic which handles interrupts should mask (bitwise AND logic) the contents of INT\_STATUS1\_REG and INT\_ENABLE1\_REG registers as well as INT\_STATUS2\_REG and INT\_ENABLE2\_REG to determine the interrupts to service. The int\_o interrupt signal is asserted whenever both an interrupt status bit and the corresponding interrupt enable bits are set.

**Table 5.9. Interrupt Status First Register**

| Field | Name               | Access | Width | Reset |
|-------|--------------------|--------|-------|-------|
| [7]   | tr_cmp_int         | RW1C   | 1     | 1'b0  |
| [6]   | stop_det_int       | RW1C   | 1     | 1'b0  |
| [5]   | tx_fifo_full_int   | RW1C   | 1     | 1'b0  |
| [4]   | tx_fifo_aempty_int | RW1C   | 1     | 1'b0  |
| [3]   | tx_fifo_empty_int  | RW1C   | 1     | 1'b0  |
| [2]   | rx_fifo_full_int   | RW1C   | 1     | 1'b0  |
| [1]   | rx_fifo_afull_int  | RW1C   | 1     | 1'b0  |
| [0]   | rx_fifo_ready_int  | RW1C   | 1     | 1'b0  |

- **tr\_cmp\_int**  
Transfer Complete Interrupt Status. This interrupt status bit asserts when the number of bytes transferred in I2C interface is equal to TGT\_BYTE\_CNT.byte\_cnt.  
1'b0 – No interrupt  
1'b1 – Interrupt pending
- **stop\_det\_int**  
STOP Condition Detected Interrupt Status. This interrupt status bit asserts when STOP condition is detected after an ACK/NACK following any I2C address or I2C IP Target Address depending on the *STOP Condition Detected Interrupt Assertion* attribute.  
1'b0 – No interrupt  
1'b1 – Interrupt pending
- **tx\_fifo\_full\_int**  
Transmit FIFO Full Interrupt Status. This interrupt status bit asserts when Transmit FIFO changes from not full state to full state.  
1'b0 – No interrupt  
1'b1 – Interrupt pending
- **tx\_fifo\_aempty\_int**  
Transmit FIFO Almost Empty Interrupt Status. This interrupt status bit asserts when the amount of data words in Transmit FIFO changes from 'TX FIFO Almost Empty Flag' + 1 to 'TX FIFO Almost Empty Flag'.  
1'b0 – No interrupt  
1'b1 – Interrupt pending

- tx\_fifo\_empty\_int

Transmit FIFO Empty Interrupt Status. This interrupt status bit asserts when the last data in Transmit FIFO is popped-out, causing the FIFO to become empty.

1'b0 – No interrupt  
1'b1 – Interrupt pending

- rx\_fifo\_full\_int

Receive FIFO Full Interrupt Status. This interrupt status bit asserts when Receive FIFO full status changes from not full to full state.

1'b0 – No interrupt  
1'b1 – Interrupt pending

- rx\_fifo\_afull\_int

Receive FIFO Almost Full Interrupt Status. This interrupt status bit asserts when the amount of data words in Receive FIFO changes from 'RX FIFO Almost Full Flag' – 1 to 'RX FIFO Almost Full Flag'.

1'b0 – No interrupt  
1'b1 – Interrupt pending

- rx\_fifo\_ready\_int

Receive FIFO Ready Interrupt Status. This interrupt status bit asserts when Receive FIFO is empty and receives a data word from I2C interface.

1'b0 – No interrupt  
1'b1 – Interrupt pending

**Table 5.10. Interrupt Status Second Register**

| Field | Name          | Access | Width | Reset |
|-------|---------------|--------|-------|-------|
| [7:4] | reserved      | RSVD   | 4     | –     |
| [3]   | rx_addr_int   | RW1C   | 1     | 1'b0  |
| [2]   | start_det_int | RW1C   | 1     | 1'b0  |
| [1]   | stop_err_int  | RW1C   | 1     | 1'b0  |
| [0]   | start_err_int | RW1C   | 1     | 1'b0  |

- rx\_addr\_int

Received I2C Address Interrupt Status. A new transaction has started and the I2C address has been received.

1'b0 – No interrupt  
1'b1 – Interrupt pending

- start\_det\_int

START Condition Detect Interrupt Status. This interrupt status bit asserts after detecting a START condition or a repeated START condition.

1'b0 – No interrupt  
1'b1 – Interrupt pending

- stop\_err\_int

STOP Condition Error Interrupt Status. This interrupt status bit asserts after detecting a STOP condition when it is not expected. STOP condition is expected to occur only after the ACK/NACK bit. The stop\_err\_int and stop\_det\_int do not assert at the same time.

1'b0 – No interrupt  
1'b1 – Interrupt pending

- start\_err\_int

START Condition Error Interrupt Status. This interrupt status bit asserts after detecting a START condition when it is not expected. START condition is expected to occur only when I2C bus is idle and after receiving an ACK or a NACK (repeated START condition).

1'b0 – No interrupt  
1'b1 – Interrupt pending

## 5.8. Interrupt Enable Registers (INT\_ENABLE1\_REG, INT\_ENABLE2\_REG)

[Table 5.11](#) and [Table 5.12](#) present the summary of Interrupt Enable Registers, they corresponds to interrupts status bits in INT\_STATUS1\_REG and INT\_STATUS2\_REG. They do not affect the contents of the INT\_STATUS1\_REG and INT\_STATUS2\_REG. If one of the INT\_STATUS1\_REG/ INT\_STATUS2\_REG bits asserts, and the corresponding bit of INT\_ENABLE1\_REG/ INT\_ENABLE2\_REG is 1'b1, the interrupt signal int\_o asserts.

**Table 5.11. Interrupt Enable First Register**

| Field | Name              | Access | Width | Reset |
|-------|-------------------|--------|-------|-------|
| [7]   | tr_cmp_en         | RW     | 1     | 1'b0  |
| [6]   | stop_det_en       | RW     | 1     | 1'b0  |
| [5]   | tx_fifo_full_en   | RW     | 1     | 1'b0  |
| [4]   | tx_fifo_aempty_en | RW     | 1     | 1'b0  |
| [3]   | tx_fifo_empty_en  | RW     | 1     | 1'b0  |
| [2]   | rx_fifo_full_en   | RW     | 1     | 1'b0  |
| [1]   | rx_fifo_afull_en  | RW     | 1     | 1'b0  |
| [0]   | rx_fifo_ready_en  | RW     | 1     | 1'b0  |

- **tr\_cmp\_en**  
Transfer Complete Interrupt Enable. Interrupt enable bit corresponded to Transfer Complete Interrupt Status.  
1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled
- **stop\_det\_en**  
STOP Condition Detected Interrupt Enable. Interrupt enable bit corresponded to STOP Condition Detected Interrupt Status.  
1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled
- **tx\_fifo\_full\_en**  
Transmit FIFO Full Interrupt Enable. Interrupt enable bit corresponded to Transmit FIFO Full Interrupt Status.  
1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled
- **tx\_fifo\_aempty\_en**  
Transmit FIFO Almost Empty Interrupt Enable. Interrupt enable bit corresponded to Transmit FIFO Almost Empty Interrupt Status.  
1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled
- **tx\_fifo\_empty\_en**  
Transmit FIFO Empty Interrupt Enable. Interrupt enable bit corresponded to Transmit FIFO Empty Interrupt Status.  
1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled
- **rx\_fifo\_full\_en**  
Receive FIFO Full Interrupt Enable. Interrupt enable bit corresponded to Receive FIFO Full Interrupt Status.  
1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled
- **rx\_fifo\_afull\_en**  
Receive FIFO Almost Full Interrupt Enable. Interrupt enable bit corresponded to Receive FIFO Almost Full Interrupt Status.  
1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled

- rx\_fifo\_ready\_en

Receive FIFO Ready Interrupt Enable. Interrupt enable bit corresponded to Receive FIFO Ready Interrupt Status.

1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled

**Table 5.12. Interrupt Enable Second Register**

| Field | Name         | Access | Width | Reset |
|-------|--------------|--------|-------|-------|
| [7:4] | reserved     | RSVD   | 4     | –     |
| [3]   | rx_addr_en   | RW     | 1     | 1'b0  |
| [2]   | start_det_en | RW     | 1     | 1'b0  |
| [1]   | stop_err_en  | RW     | 1     | 1'b0  |
| [0]   | start_err_en | RW     | 1     | 1'b0  |

- rx\_addr\_en

Received I2C Address Interrupt Set. Interrupt set bit corresponding to the Received I2C Address Interrupt Status.

1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled

- start\_det\_en

START Condition Detected Interrupt Enable. Interrupt enable bit corresponded to START Condition Detected Interrupt Status.

1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled

- stop\_err\_en

STOP Condition Error Interrupt Enable. Interrupt enable bit corresponded to STOP Condition Error Interrupt Status.

1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled

- start\_err\_en

START Condition Error Interrupt Enable. Interrupt enable bit corresponded to START Condition Error Interrupt Status.

1'b0 – Interrupt disabled  
1'b1 – Interrupt enabled

## 5.9. Interrupt Set Registers (INT\_SET1\_REG, INT\_SET2\_REG)

[Table 5.13](#) and [Table 5.14](#) presents the summary of Interrupt Set Registers. Writing 1'b1 to a register bit in INT\_SET1\_REG or INT\_SET2\_REG asserts the corresponding interrupts status bit in INT\_STATUS1\_REG or INT\_STATUS2\_REG while writing 1'b0 is ignored. This is intended for testing purposes only.

**Table 5.13. Interrupt Set First Register**

| Field | Name               | Access | Width | Reset |
|-------|--------------------|--------|-------|-------|
| [7]   | tr_cmp_set         | WO     | 1     | 1'b0  |
| [6]   | stop_det_set       | WO     | 1     | 1'b0  |
| [5]   | tx_fifo_full_set   | WO     | 1     | 1'b0  |
| [4]   | tx_fifo_aempty_set | WO     | 1     | 1'b0  |
| [3]   | tx_fifo_empty_set  | WO     | 1     | 1'b0  |
| [2]   | rx_fifo_full_set   | WO     | 1     | 1'b0  |
| [1]   | rx_fifo_afull_set  | WO     | 1     | 1'b0  |
| [0]   | rx_fifo_ready_set  | WO     | 1     | 1'b0  |

- **tr\_cmp\_set**  
Transfer Complete Interrupt Set. Interrupt set bit corresponded to Transfer Complete Interrupt Status.  
1'b0 – No action  
1'b1 – Asserts INT\_STATUS1\_REG.tr\_cmp\_int
- **stop\_det\_set**  
STOP Condition Detected Interrupt Set. Interrupt set bit corresponded to STOP Condition Detected Interrupt Status.  
1'b0 – No action  
1'b1 – Asserts INT\_STATUS1\_REG.stop\_det\_int
- **tx\_fifo\_full\_set**  
Transmit FIFO Full Interrupt Set. Interrupt set bit corresponded to Transmit FIFO Full Interrupt Status.  
1'b0 – No action  
1'b1 – Asserts INT\_STATUS1\_REG.tx\_fifo\_full\_int
- **tx\_fifo\_aempty\_set**  
Transmit FIFO Almost Empty Interrupt Set. Interrupt set bit corresponded to Transmit FIFO Almost Empty Interrupt Status.  
1'b0 – No action  
1'b1 – Asserts INT\_STATUS1\_REG.tx\_fifo\_aempty\_int
- **tx\_fifo\_empty\_set**  
Transmit FIFO Empty Interrupt Set. Interrupt set bit corresponded to Transmit FIFO Empty Interrupt Status.  
1'b0 – No action  
1'b1 – Asserts INT\_STATUS1\_REG.tx\_fifo\_empty\_int
- **rx\_fifo\_full\_set**  
Receive FIFO Full Interrupt Set. Interrupt set bit corresponded to Receive FIFO Full Interrupt Status.  
1'b0 – No action  
1'b1 – Asserts INT\_STATUS1\_REG.rx\_fifo\_full\_int
- **rx\_fifo\_afull\_set**  
Receive FIFO Almost Full Interrupt Set. Interrupt set bit corresponded to Receive FIFO Almost Full Interrupt Status.  
1'b0 – No action  
1'b1 – Asserts INT\_STATUS1\_REG.rx\_fifo\_afull\_int
- **rx\_fifo\_ready\_set**  
Receive FIFO Ready Interrupt Set. Interrupt set bit corresponded to Receive FIFO Ready Interrupt Status.  
1'b0 – No action  
1'b1 – Asserts INT\_STATUS1\_REG.rx\_fifo\_ready\_int

**Table 5.14. Interrupt Set Second Register**

| Field | Name          | Access | Width | Reset |
|-------|---------------|--------|-------|-------|
| [7:4] | reserved      | RSVD   | 4     | –     |
| [3]   | rx_addr_set   | WO     | 1     | 1'b0  |
| [2]   | start_det_set | WO     | 1     | 1'b0  |
| [1]   | stop_err_set  | WO     | 1     | 1'b0  |
| [0]   | start_err_set | WO     | 1     | 1'b0  |

- **rx\_addr\_set**  
Received I2C Address Interrupt Set. Interrupt set bit corresponding to the Received I2C Address Interrupt Status.  
0 – No action.  
1 – Asserts INT\_STATUS2\_REG.rx\_addr\_int.
- **start\_det\_set**  
START Condition Detected Interrupt Set. Interrupt set bit corresponded to START Condition Detected Interrupt Status.

- 0 – No action.
- 1 – Asserts INT\_STATUS2\_REG.start\_det\_int.
- **stop\_err\_set**  
STOP Condition Error Interrupt Set. Interrupt set bit corresponded to STOP Condition Error Interrupt Status.  
0 – No action.  
1 – Asserts INT\_STATUS2\_REG.stop\_err\_int.
- **start\_err\_set**  
START Condition Error Interrupt Set. Interrupt set bit corresponded to START Condition Error Interrupt Status.  
0 – No action.  
1 – Asserts INT\_STATUS2\_REG.start\_err\_int.

## 5.10. FIFO Status Register (FIFO\_STATUS\_REG)

FIFO Status Register reflects the status of Transmit FIFO and Receive FIFO as shown in [Table 5.15](#).

**Table 5.15. FIFO Status Register**

| Field | Name           | Access | Width | Reset |
|-------|----------------|--------|-------|-------|
| [7:6] | reserved       | RSVD   | 2     | –     |
| [5]   | tx_fifo_full   | RO     | 1     | 1'b0  |
| [4]   | tx_fifo_aempty | RO     | 1     | 1'b1  |
| [3]   | tx_fifo_empty  | RO     | 1     | 1'b1  |
| [2]   | rx_fifo_full   | RO     | 1     | 1'b0  |
| [1]   | rx_fifo_afull  | RO     | 1     | 1'b0  |
| [0]   | rx_fifo_empty  | RO     | 1     | 1'b1  |

- **tx\_fifo\_full**  
Transmit FIFO Full. This bit reflects the full condition of Transmit FIFO.  
1'b0 – Transmit FIFO is not full  
1'b1 – Transmit FIFO is full
- **tx\_fifo\_aempty**  
Transmit FIFO Almost Empty. This bit reflects the almost empty condition of Transmit FIFO.  
1'b0 – Data words in Transmit FIFO is greater than ‘TX FIFO Almost Empty Flag’ attribute  
1'b1 – Data words in Transmit FIFO is less than or equal to ‘TX FIFO Almost Empty Flag’ attribute
- **tx\_fifo\_empty**  
Transmit FIFO Empty. This bit reflects the empty condition of Transmit FIFO.  
1'b0 – Transmit FIFO is not empty – has at least 1 data word  
1'b1 – Transmit FIFO is empty
- **rx\_fifo\_full**  
Receive FIFO Full. This bit reflects the full condition of Receive FIFO.  
1'b0 – Receive FIFO is not full  
1'b1 – Receive FIFO is full
- **rx\_fifo\_afull**  
Receive FIFO Almost Full. This bit reflects the almost full condition of Receive FIFO.  
1'b0 – Data words in Receive FIFO is less than ‘RX FIFO Almost Full Flag’ attribute  
1'b1 – Data words in Receive FIFO is greater than or equal to ‘RX FIFO Almost Full Flag’ attribute
- **rx\_fifo\_empty**  
Receive FIFO Empty. This bit reflects the empty condition of Receive FIFO.  
1'b0 – Receive FIFO is not empty – has at least 1 data word  
1'b1 – Receive FIFO is empty

## 5.11. Received Address Registers (RX\_ADDR\_1\_REG, RX\_ADDR\_2\_REG)

The first (RX\_ADDR\_1\_REG) and second (RX\_ADDR\_2\_REG) most recently received I2C address bytes. RX\_ADDR\_2\_REG is only applicable in 10-bit addressing mode. The LSB of RX\_ADDR\_1\_REG always contains the most recently received RNW bit.

**Table 5.16. Received Address 1**

| Field | Name      | Access | Width | Reset |
|-------|-----------|--------|-------|-------|
| [7:1] | rx_addr_1 | RO     | 7     | 7'b0  |
| [0]   | rx_rnw    | RO     | 1     | 1'b0  |

- **rx\_addr\_1**

First address of the most recently received transaction. When using the 7-bit Address Mode, it contains the most recently received address. When using the 10-bit Address Mode, the 5 most significant bits should contain the 10-bit Address Mode reserved address. The next 2 bits contain the two most significant bits of the 10-bit address.

- **rx\_rnw**

Received I2C Read or Write Bit. Read or write bit of the most recently received I2C transaction.

1'b0 – Most recently received transaction is a write.

1'b1 – Most recently received transaction is a read.

**Table 5.17. Received Address 2**

| Field | Name      | Access | Width | Reset |
|-------|-----------|--------|-------|-------|
| [7:0] | rx_addr_2 | RO     | 8     | 8'b0  |

- **rx\_addr\_2**

Second address of the most recently received transaction. When using the 7-bit Address Mode, data in this field should not be used. When using the 10-bit Address Mode, this field contains the 8 least significant bits of the received address.

## 6. Example Design

The I2C Target example design allows you to compile, simulate, and test the I2C Target IP on the following Lattice evaluation boards:

- CertusPro-NX Evaluation Board
- MachXO5-NX Development Board

### 6.1. Example Design Supported Configuration

**Note:** In the table below, ✓ refers to a checked option while — refers to an unchecked option in the I2C Target IP example design.

**Table 6.1. I2C Target IP Configuration Supported by the Example Design**

| Attribute                                   | I2C Target                         |
|---------------------------------------------|------------------------------------|
| <b>General</b>                              |                                    |
| APB Mode Enable                             | ✓                                  |
| Remove Tristate Buffers                     | —                                  |
| Addressing Mode                             | 7-bit                              |
| I2C Target Address:0x                       | 0x51                               |
| STOP Condition Detected Interrupt Assertion | STOP Condition addressed to the IP |
| System Clock Frequency (MHz)                | 50                                 |
| <b>Timing Adjustment</b>                    |                                    |
| I2C SDA Register Depth                      | 0                                  |
| <b>FIFO</b>                                 |                                    |
| FIFO Width                                  | 8 (Display only)                   |
| FIFO Depth                                  | 16                                 |
| Implementation of FIFO                      | EBR                                |
| TX FIFO Almost Empty Flag                   | 2                                  |
| RX FIFO Almost Full Flag                    | 14                                 |

### 6.2. Overview of the Example Design and Features

The example design discussed in this section is created using the *RISC-V MC SoC Project* template in the [Lattice Propel Design Environment](#). The generated project includes the following components:

- Processor – RISC-V (MC w/ PIC/Timer)
- GPIO
- Asynchronous SRAM
- UART – Serial port
- PLL
- Glue Logic

I2C Controller and I2C Target IPs are instantiated and connected in the project as shown in [Figure 6.1](#). In this example, I2C Controller and I2C Target are instantiated in the same system. In actual hardware or use case, you can connect the I2C Target IP to external I2C Controller and Target devices.



Figure 6.1. I2C Target IP in Propel SoC Project

An Embedded C/C++ Project is also created in the Propel software to enable developing and debugging application code for different IP features. I2C Target features can be tested by sending I2C Commands from an I2C Controller to the I2C Target. Runtime configuration of IP and feature testing can be done through C-Code Test Routine. [Figure 6.2](#) shows an example routine to write to *WR\_DATA\_REG* and read from *RD\_DATA\_REG*. This sample test routine can be found in the driver file included in the generated IP.

```

48 uint8_t i2c_slave_data_write(struct i2c_slave_instance *this_i2cs,uint8_t *tx_buf,uint8_t length)
49 {
50     uint8_t count=0;
51     if (this_i2cs == NULL)
52         return I2C_SLV_PTR_ERROR;
53
54     while (count < length) {
55         reg_8b_write(this_i2cs->base_addr | I2C_SLAVE_DATA_BUFFER,
56                     tx_buf[count++]);
57     }
58     return I2C_SLV_SUCCESS;
59 }
60
61 uint8_t i2c_slave_data_read(struct i2c_slave_instance *this_i2cs,uint8_t *rx_buf,uint8_t *length)
62 {
63     uint8_t count=0;
64     uint8_t fifo_status = 0;
65     uint8_t rd_data;
66
67     if (this_i2cs == NULL)
68         return I2C_SLV_PTR_ERROR;
69
70     reg_8b_read(this_i2cs->base_addr | I2C_SLAVE_FIFO_STATUS, &fifo_status);
71
72     while ((fifo_status & I2C_SLAVE_RX_FIFO_EMPTY) == 0) {
73         reg_8b_read(this_i2cs->base_addr | I2C_SLAVE_DATA_BUFFER, &rd_data);
74         *rx_buf=rd_data;
75         rx_buf++;
76         count++;
77         reg_8b_read(this_i2cs->base_addr | I2C_SLAVE_FIFO_STATUS, &fifo_status);
78     }
79     *length = count;
80
81     return I2C_SLV_SUCCESS;
82 }

```

Figure 6.2. Sample C-Code Test Routine

### 6.3. Design Components Example



Figure 6.3. I2C Target Example Design Block Diagram

The I2C Target example design includes the following blocks:

- RISC-V CPU – Passes the C-Code Test Routine from system memory to system bus. Handles interrupts.
- Memory – Contains commands for testing.
- System Bus – AHB-Lite systems bus for transfers between memory and IP
- I2C Controller – I2C Controller IP instance and/or I2C Analyzer/Exerciser that acts as the Controller
- I2C Target Device(s) – I2C Target IP instance and/or I2C Analyzer/Exerciser that acts as the Target

### 6.4. Generating the Example Design

Refer to the [Lattice Propel SDK User Guide](#) for more details on the Lattice Propel software.

1. Launch Lattice Propel software and set your workspace directory.
2. In the Propel software, create a new Lattice SoC Design Project by navigating to **File > New > Lattice SoC Design Project**.
3. The **Create SoC Project** window will open.

In **Device Select** section, indicate the correct details of the device or board that you are using. In [Figure 6.4](#), device is set to LFMXO5-25-9BBG400C since MachXO5-NX Development Board is used in the hardware testing. In **Template Design** section, choose **RISC-V MC SoC Project**. Click **Finish**.



Figure 6.4. Create SoC Project

4. Run Propel Builder by clicking the  icon or navigate to **LatticeTools > Open Design** in Propel Builder. The Propel Builder will open and load the design template.
5. In the **IP Catalog** tab, instantiate the I2C Target IP. Refer to the [Generating and Instantiating the IP](#) section for more details. In this example, there is one instance of the I2C Target IP.  
See the [Example Design Supported Configuration](#) section for the corresponding parameter settings.
6. After generating the IP, the **Define Instance** window will open. Modify the instance name if needed, then click **OK**.



Figure 6.5. Define Instance

7. Connect the instantiated IPs to the system. Refer to [Figure 6.1](#) for the connections used in this IP. You will need to update other components of the system for clock and reset sources, interrupt, and bus interface.

8. Click the  icon or navigate to **Design > Run Radiant** to launch the Lattice Radiant Software.
9. Update your constraints file accordingly and generate the programming file.
10. In the Lattice Propel software, build your SoC project to generate the system environment needed for the embedded C/C++ project. Select your SoC project then navigate to **Project > Build Project**.
11. Check the build result from the **Console** view.



```

Problems Tasks Console X Properties Terminal
<terminated> sge [SDP Builder] C:\lsc\propel\2024.1\tools\python38_embed\python.exe (Terminated Aug 6, 2024, 12:56:17 PM) [pid: 3780]
WARNING - (PGE SoCDesign) cpu0_inst_TIMER IRQ_M0 remains unconnected
INFO - (PGE) Finished: sge generated
  
```

Figure 6.6. Build SoC Project Result

12. Generate a new Lattice C/C++ project by navigating to **File > New > Lattice C/C++ Project**. Update your **Project name**, click **Next**, and then click **Finish**.



Figure 6.7. Lattice C/C++ Design Project

13. Select your C/C++ project then select **Project > Build**.
14. Check the build result from the **Console** view.



```

Problems Tasks Console Properties Terminal
CDT Build Console [i2c_target_cproj]

Invoking: GNU RISC-V Cross Print Size
riscv-none-embed-size --format=berkeley "i2c_target_cproj.elf"
  text  data  bss  dec  hex filename
  3536    24  2876  6436  1924 i2c_target_cproj.elf
Finished building: i2c_target_cproj.size

Invoking: Lattice Create Memory Deployment
riscv-none-embed-objcopy -O binary --gap-fill 0 "i2c_target_cproj.elf" "i2c_target_cproj.bin"; srec_cat "i2c_target_cproj.bin" -Binary -byte-swap 4 -DISable Header -Output "i2c_target_cproj.mem" -MEM 32
Finished building: i2c_target_cproj.mem

12:59:08 Build Finished. 0 errors, 0 warnings. (took 12s.777ms)

```

Figure 6.8. Build C/C++ Project Result

15. This environment is now ready for running your tests on the device. Refer to the *Running Demo on MachXO3D Breakout Board – Hello World* section of the [Lattice Propel SDK User Guide](#) for step-by-step guide.

## 6.5. Hardware Testing

### 6.5.1. Hardware Testing Setup

Download the generated bitstream file from the [Generating the Example Design](#) section to the MachXO5-NX Development Board via the Lattice Radiant Programmer.

### 6.5.2. Expected Output

Below is a sample waveform captured via I2C Analyzer/Exerciser tool.



Figure 6.9 Sample I2C Write Command Sent to I2C Target

## 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

The Lattice Radiant software allows you to customize and generate modules and IPs and integrate them into the device's architecture. The procedure for generating the I2C Target IP in Lattice Radiant software is described below.

To generate the I2C Target IP:

1. Create a new Lattice Radiant software project or open an existing project.
2. In the **IP Catalog** tab, double-click on **I2C Target** under **IP, Processors\_Controllers\_and\_Peripherals** category. The **Module/IP Block Wizard** opens as shown in [Figure 7.1](#). Enter values in the **Component name** and the **Create in** fields and click **Next**.



**Figure 7.1. Module/IP Block Wizard**

3. In the module's dialog box of the **Module/IP Block Wizard** window, customize the selected I2C Target IP using drop-down menus and check boxes. As a sample configuration, see [Figure 7.2](#). For configuration options, see the [IP Parameter Description](#) section.



Figure 7.2. Configure User Interface of I2C Target IP

- Click **Generate**. The **Check Generating Result** dialog box opens, showing design block messages and results as shown in Figure 7.3.



Figure 7.3. Check Generating Result

- Click the **Finish** button. All the generated files are placed under the directory paths in the **Create in** and the **Component name** fields shown in Figure 7.1.

### 7.1.1. Generated Files and File Structure

The generated I2C Target IP package includes the closed-box (`<Component name>_bb.v`) and instance templates (`<Component name>_tmpl.v/vhd`) that can be used to instantiate the IP 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 IP is also provided. You may also use this top-level reference as the starting template for the top-level for their complete design. The generated files are listed in [Table 7.1](#).

**Table 7.1. Generated File List**

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

## 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.

A post-synthesis constraint file (.pdc) contains both timing and non-timing constraint. 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.

### 7.2.1. Device Constraint Editor

Refer to the [Lattice Radiant Software User Guide](#) for more information on how to use the device constraint editor.

### 7.2.2. Manual PDC File Creation

Add the post-synthesis constraint file (.pdc) in the Lattice Radiant software and define the I/O pins according to the schematic design for ports defined in your design. You can define different types of constraints such as pins, clocks, and other timing paths.

## 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. The example below shows the IP timing constraints generated for I2C Target IP.

You need to provide proper timing and physical design constraints to ensure that your design meets the desired performance goals on the FPGA. Add the content of the following IP constraint file to your design constraints:

`<IP_Instance_Path>/<IP_Instance_Name>/constraints/<IP_Instance_Name>.ldc`

The constraint file has been verified during IP evaluation with the IP instantiated directly in the top-level module. You can modify the constraints in this file with thorough understanding of the effect of each constraint.

To use this constraint file:

1. Copy the contents of `<IP_Instance_Name>.ldc` to the top-level design constraint for post-synthesis
2. Remove `create_clock` constraints if the I2C Target is instantiated in another module.
3. Remove `ldc_set_port` for `scl_io` and `sda_io` if `REMOVE_TRISTATE` buffer is enabled.

Refer to [Lattice Radiant Timing Constraints Methodology \(FPGA-AN-02059\)](#) for details on how to constraint your design.

## 7.4. Running Functional Simulation

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



**Figure 7.4. Simulation Wizard**

2. Click **Next** to open the **Add and Reorder Source** window as shown in [Figure 7.5](#).



**Figure 7.5. Adding and Reordering Source**

3. Click **Next**. The **Summary** window is shown. Click **Finish** to run the simulation.

**Note:** It is necessary to follow the procedure above until it is fully automated in the Lattice Radiant software suite.

The results of the simulation in our example are provided in [Figure 7.6](#).



**Figure 7.6. Simulation Waveform**

## Appendix A. Resource Utilization

**Table A.1** shows the resource utilization of the I2C Target IP for the LAV-AT-E70-1LFG1156I device using Synplify Pro of the Lattice Radiant Software 2023.1. Default configuration is used, and some attributes are changed from the default value to show the effect on the resource utilization.

**Table A.1. LAV-AT-E70-1LFG1156I Device Resource Utilization**

| Configuration                                                                                                       | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs |
|---------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------|------|------|
| Default                                                                                                             | 107                         | 320       | 394  | 0    |
| <i>APB Mode Enable: false,<br/>Others = Default</i>                                                                 | 251                         | 318       | 394  | 0    |
| <i>Implementation of FIFO: EBR,<br/>Others = Default</i>                                                            | 127                         | 304       | 372  | 2    |
| <i>TX FIFO Almost Empty Flag: 1,<br/>RX FIFO Almost Full Flag: 1,<br/>Others = Default</i>                          | 112                         | 320       | 394  | 0    |
| <i>FIFO Depth: 256,<br/>TX FIFO Almost Empty Flag: 256,<br/>RX FIFO Almost Full Flag: 256,<br/>Others = Default</i> | 105                         | 350       | 910  | 0    |

**Note:**

1. Fmax is generated when the FPGA design contains only I2C Target IP, and the target frequency is 50 MHz. These values may be reduced when user logic is added to the FPGA design.

**Table A.2** shows the resource utilization of the I2C Target IP for the LFMXO5-25-9BBG400I device using Synplify Pro of the Lattice Radiant Software 3.1. Default configuration is used, and some attributes are changed from the default value to show the effect on the resource utilization.

**Table A.2. LFMXO5-25-9BBG400I Device Resource Utilization**

| Configuration                                                                                                       | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs |
|---------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------|------|------|
| Default                                                                                                             | 168                         | 319       | 397  | 0    |
| <i>APB Mode Enable: false,<br/>Others = Default</i>                                                                 | 200                         | 304       | 370  | 0    |
| <i>Implementation of FIFO: EBR,<br/>Others = Default</i>                                                            | 157                         | 303       | 364  | 2    |
| <i>TX FIFO Almost Empty Flag: 1,<br/>RX FIFO Almost Full Flag: 1,<br/>Others = Default</i>                          | 168                         | 319       | 385  | 0    |
| <i>FIFO Depth: 256,<br/>TX FIFO Almost Empty Flag: 256,<br/>RX FIFO Almost Full Flag: 256,<br/>Others = Default</i> | 167                         | 349       | 1088 | 0    |

**Note:**

1. Fmax is generated when the FPGA design contains only I2C Target IP, and the target frequency is 50 MHz. These values may be reduced when user logic is added to the FPGA design.

**Table A.3** shows the resource utilization of the I2C Target IP for the LFMX05-25-7BBG400I device using Synplify Pro of the Lattice Radiant Software 3.1. Default configuration is used, and some attributes are changed from the default value to show the effect on the resource utilization.

**Table A.3. LFMX05-25-7BBG400I Device Resource Utilization**

| Configuration                                                                                                       | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs |
|---------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------|------|------|
| Default                                                                                                             | 101                         | 319       | 385  | 0    |
| <i>APB Mode Enable: false,<br/>Others = Default</i>                                                                 | 120                         | 304       | 370  | 0    |
| <i>Implementation of FIFO: EBR,<br/>Others = Default</i>                                                            | 103                         | 303       | 365  | 2    |
| <i>TX FIFO Almost Empty Flag: 1,<br/>RX FIFO Almost Full Flag: 1,<br/>Others = Default</i>                          | 94                          | 319       | 385  | 0    |
| <i>FIFO Depth: 256,<br/>TX FIFO Almost Empty Flag: 256,<br/>RX FIFO Almost Full Flag: 256,<br/>Others = Default</i> | 101                         | 349       | 1089 | 0    |

**Note:**

1. Fmax is generated when the FPGA design contains only I2C Target IP, and the target frequency is 50 MHz. These values may be reduced when user logic is added to the FPGA design.

**Table A.4** shows the resource utilization of the I2C Target IP for the LN2-CT-20-1CBG484C device using Synplify Pro of the Lattice Radiant Software 2024.2. Default configuration is used, and some attributes are changed from the default value to show the effect on the resource utilization.

**Table A.4. LN2-CT-20-1CBG484C Device Resource Utilization**

| Configuration                                                                                                     | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs |
|-------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------|------|------|
| Default                                                                                                           | 103.146                     | 343       | 393  | 0    |
| <i>APB Mode Enable: false,<br/>Others = Default</i>                                                               | 250                         | 328       | 396  | 0    |
| <i>Implementation of FIFO: EBR,<br/>Others = Default</i>                                                          | 115.128                     | 327       | 378  | 2    |
| <i>TX FIFO Almost Empty Flag: 1,<br/>RX FIFO Almost Full Flag: 1,<br/>Others = Default</i>                        | 97.314                      | 343       | 393  | 0    |
| <i>FIFO Depth: 256,<br/>TX FIFO Almost Empty Flag: 1,<br/>RX FIFO Almost Full Flag: 256,<br/>Others = Default</i> | 120.120                     | 414       | 936  | 0    |

**Note:**

1. Fmax is generated when the FPGA design contains only I2C Target IP, and the target frequency is 50 MHz. These values may be reduced when user logic is added to the FPGA design.

**Table A.5** shows the resource utilization of the I2C Target IP for the LFMXO4-110HC-5BBG484I device using Synplify Pro of the Lattice Radiant Software 2025.2. Default configuration is used, and some attributes are changed from the default value to show the effect on the resource utilization.

**Table A.5. LFMXO4-110HC-5BBG484I Device Resource Utilization**

| Configuration                                                                                                     | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs |
|-------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------|------|------|
| Default                                                                                                           | 77.35                       | 572       | 555  | 0    |
| <i>APB Mode Enable: false,<br/>Others = Default</i>                                                               | 97.95                       | 541       | 538  | 0    |
| <i>Implementation of FIFO:<br/>EBR,<br/>Others = Default</i>                                                      | 69.47                       | 397       | 283  | 2    |
| <i>TX FIFO Almost Empty Flag: 1,<br/>RX FIFO Almost Full Flag: 1,<br/>Others = Default</i>                        | 76.29                       | 563       | 555  | 0    |
| <i>FIFO Depth: 256,<br/>TX FIFO Almost Empty Flag: 1,<br/>RX FIFO Almost Full Flag: 256,<br/>Others = Default</i> | 61.93                       | 3197      | 4515 | 0    |

**Note:**

1. Fmax is generated when the FPGA design contains only I2C Target IP, and the target frequency is 50 MHz. These values may be reduced when user logic is added to the FPGA design.

## References

For more information, refer to:

- [Lattice Memory Mapped Interface and Lattice Interrupt Interface \(FPGA-UG-02039\)](#)
- [AMBA 3 APB Protocol v1.0 Specification](#)
- [I2C Bus Specification and User Manual](#)
- [Lattice Radiant Software 2023.1 User Guide](#)
- [Lattice Radiant Timing Constraints Methodology \(FPGA-AN-02059\)](#)
- [Reveal User Guide for Radiant Software](#)
- [I2C Target IP Release Notes \(FPGA-RN-02028\)](#)
- [I2C Target IP Core web page](#)
- [Lattice Propel Design Environment web page](#)
- [Lattice Radiant Software web page](#)
- [Lattice Solutions IP Cores web page](#)
- [Lattice Solutions Reference Designs web page](#)
- [Avant-E web page](#)
- [Avant-G web page](#)
- [Avant-X web page](#)
- [Certus-N2 web page](#)
- [Certus-NX web page](#)
- [CertusPro-NX web page](#)
- [CrossLink-NX web page](#)
- [MachXO4 web page](#)
- [MachXO5-NX web page](#)
- [CertusPro-NX Evaluation Board web page](#)
- [MachXO5-NX Development Board web page](#)
- [Lattice Insights web page 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/en/Support/AnswerDatabase](http://www.latticesemi.com/en/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 2.2, IP v2.5.0, December 2025

| Section               | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All                   | <ul style="list-style-type: none"> <li>Updated the IP version information on the cover page.</li> <li>Added a note on the IP version in the <i>Quick Facts</i> and <i>Revision History</i> sections.</li> <li>Made editorial fixes.</li> </ul>                                                                                                                                                                                                        |
| Introduction          | <ul style="list-style-type: none"> <li>In <a href="#">Table 1.1. Summary of the I2C Target IP</a>:</li> <li>Added MachXO4 to Supported Devices.</li> <li>Updated Lattice Implementation.</li> <li>In <a href="#">Table 1.2. I2C Target IP Support Readiness</a>: <ul style="list-style-type: none"> <li>Added a table note.</li> <li>Removed the <i>IP</i> column.</li> </ul> </li> <li>Added the <a href="#">Attribute Names</a> section.</li> </ul> |
| Signal Description    | In <a href="#">Table 4.1. I2C Target IP Signal Description</a> : <ul style="list-style-type: none"> <li>Added (<i>Remove Tristate Buffers = 0</i>) to the <i>I2C Interface</i> header.</li> <li>Added ports for <i>I2C Interface</i> (<i>Remove Tristate Buffers = 1</i>).</li> </ul>                                                                                                                                                                 |
| Designing with the IP | Added a note on screenshots in this section.                                                                                                                                                                                                                                                                                                                                                                                                          |
| Resource Utilization  | Added the MachXO4 device resource utilization.                                                                                                                                                                                                                                                                                                                                                                                                        |
| References            | Added <i>I2C Target IP Core</i> , <i>MachXO4</i> , <i>MachXO5-NX</i> , <i>Lattice Propel Design Environment</i> , and <i>Lattice Solutions Reference Designs</i> web pages.                                                                                                                                                                                                                                                                           |

### Revision 2.1, IP v2.4.0, June 2024

| Section      | Change Summary                                                                                                                                                                                                                                               |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All          | Updated the IP version information on the cover page.                                                                                                                                                                                                        |
| Introduction | <ul style="list-style-type: none"> <li>In Table 1.1. Summary of the I2C Target IP: <ul style="list-style-type: none"> <li>Updated <i>Supported FPGA Family</i> to <i>Supported Devices</i>.</li> <li>Removed <i>Targeted Devices</i>.</li> </ul> </li> </ul> |

### Revision 2.0, IP v2.3.0, December 2024

| Section                   | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All                       | <ul style="list-style-type: none"> <li>Added the IP version information on the cover page.</li> <li>Updated <i>I<sup>2</sup>C</i> to <i>I2C</i>.</li> <li>Removed the <i>Debugging</i> section.</li> <li>Made editorial fixes.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Acronyms in This Document | Added <i>Design Under Test (DUT)</i> , <i>Embedded Block RAM (EBR)</i> , <i>First In, First Out (FIFO)</i> , <i>General Purpose Input/Output (GPIO)</i> , <i>Input/Output (I/O)</i> , <i>Intellectual Property (IP)</i> , <i>Lattice Synthesis Engine (LSE)</i> , <i>Look-Up Table (LUT)</i> , <i>Programmable Interrupt Controller (PIC)</i> , <i>Phase-Locked Loop (PLL)</i> , <i>Random Access Memory (RAM)</i> , <i>Receiver (RX)</i> , <i>Reduced Instruction Set Computer Five (RISC-V)</i> , <i>Serial Clock (SCL)</i> , <i>Static Random Access Memory (SRAM)</i> , <i>System on Chip (SoC)</i> , <i>Serial Data (SDA)</i> , <i>Transmitter (TX)</i> , and <i>Universal Asynchronous Receiver/Transmitter (UART)</i> . |
| Introduction              | <ul style="list-style-type: none"> <li>Updated Table 1.1. Summary of the I2C Target IP: <ul style="list-style-type: none"> <li>Added the <i>Certus-N2</i> device family to <i>Supported FPGA Family</i>.</li> <li>Removed <i>IP Version</i> and added <i>IP Changes</i>.</li> <li>Added the <i>LFD2NX-9</i>, <i>LFD2NX-28</i>, <i>LAV-AT-G70</i>, <i>LAV-AT-X70</i>, and <i>LN2-CT-20</i> devices to <i>Targeted Devices</i>.</li> <li>Updated <i>Resources</i> and <i>Lattice Implementation</i>.</li> </ul> </li> </ul>                                                                                                                                                                                                      |

| Section                  | Change Summary                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | <ul style="list-style-type: none"> <li>Updated the Licensing Information and Minimum Device Requirements sections.</li> <li>Replaced the <i>IP Validation Summary</i> section with the IP Support Summary section.</li> <li>Removed the <i>1.7.3. Host</i> and <i>1.7.4. Attribute</i> sections.</li> </ul>                                                                                          |
| Functional Description   | <ul style="list-style-type: none"> <li>Changed <i>I2C Controller</i> to <i>I2C Target</i> and added description to <i>CONTROL_REG</i> in the Initialization section.</li> <li>Added (<i>interrupts are disabled</i>) to steps 3 and 7 in the Data Transfer in response to I2C Controller Read section and steps 2 and 6 in the Data Transfer in response to I2C Controller Write section.</li> </ul> |
| IP Parameter Description | Updated this section.                                                                                                                                                                                                                                                                                                                                                                                |
| Register Description     | Updated the description for <i>stop_det_int</i> in the Interrupt Status Registers ( <i>INT_STATUS1_REG</i> , <i>INT_STATUS2_REG</i> ) section.                                                                                                                                                                                                                                                       |
| Example Design           | Added this section.                                                                                                                                                                                                                                                                                                                                                                                  |
| Designing with the IP    | <ul style="list-style-type: none"> <li>Updated the paragraph in the Designing with the IP section.</li> <li>Updated Figure 7.1. Module/IP Block Wizard, Figure 7.2. Configure User Interface of I2C Target IP, and Figure 7.3. Check Generating Result.</li> </ul>                                                                                                                                   |
| Resource Utilization     | Added resource utilizations for the Lattice Radiant software version 2024.2.                                                                                                                                                                                                                                                                                                                         |
| References               | Added the <i>Lattice Solutions IP Cores</i> web page, <i>Avant-G</i> web page, <i>Avant-X</i> web page, <i>Certus-N2</i> web page, <i>CertusPro-NX Evaluation Board</i> web page, <i>MachXO5-NX Development Board</i> web page, and <i>I2C Target IP Release Notes (FPGA-RN-02028)</i> .                                                                                                             |

**Revision 1.9, June 2024**

| Section                  | Change Summary                                                                                                        |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------|
| IP Parameter Description | Added <i>Remove Tristate Buffers</i> attribute to Table 3.1. Attributes Table and Table 3.2. Attributes Descriptions. |

**Revision 1.8, March 2024**

| Section                | Change Summary                                                                                                                                |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Functional Description | Updated Step 1 to point to Step 6 if the data to receive is <= FIFO Depth in 2.5.3 Data Transfer in response to I2C Controller Write section. |
| Register Description   | Updated <i>stop_det_int</i> description in 5.7 Interrupt Status Registers ( <i>INT_STATUS1_REG</i> , <i>INT_STATUS2_REG</i> ) section.        |

**Revision 1.7, January 2024**

| Section            | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All                | <ul style="list-style-type: none"> <li>Renamed the document from <i>I2C Target IP Core – Lattice Radiant Software</i> to <i>I2C Target IP</i>.</li> <li>Updated the instances of <i>I2C Target IP Core</i> to <i>I2C Target IP</i>.</li> <li>Made editorial fixes.</li> <li>Minor adjustments to ensure that the document is consistent with Lattice Semiconductor's inclusive language policy.</li> <li>Updated the device name from <i>LAV-AT-500E</i> to <i>LAV-AT-E70</i>.</li> </ul>                                                                                         |
| Disclaimers        | Updated boilerplate.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Inclusive Language | Added boilerplate.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Introduction       | <ul style="list-style-type: none"> <li>Moved the first two paragraph of the 1. Introduction section to 1.1. Overview of the IP section.</li> <li>Updated the heading number for 1.2. Quick Facts and 1.3. Features sections.</li> <li>Updated Table 1.1 caption from <i>Quick Facts</i> to <i>Summary of the I2C Target IP</i>.</li> <li>Updated the IP Version from 2.0.0 to 2.1.0 in Table 1.1. Summary of the I2C Target IP and Table 1.2. IP Validation Level.</li> <li>Moved the previous 3.1. <i>Licensing the IP</i>, and 3.4. <i>IP Evaluation</i> sections to</li> </ul> |

| Section                  | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | <ul style="list-style-type: none"> <li>1.4. Licensing Information section.</li> <li>Moved the previous 3.5. <i>Hardware Validation</i> section to 1.5. IP Validation Summary section.</li> <li>Added the 1.6. Minimum Device Requirements section.</li> <li>Updated the previous header from 1.3. <i>Conventions</i> to 1.7. <i>Naming Conventions</i>.</li> </ul>                                                                                                                                                                                                                                   |
| Functional Description   | <ul style="list-style-type: none"> <li>Updated the previous header from 2.1. <i>Overview</i> to 2.1. IP Architecture Overview.</li> <li>Added the 2.2. Clocking and Reset section.</li> <li>Moved the previous 2.5. <i>Operations Details</i> (except 2.5.5. <i>Selectable Memory-Mapped Interface</i>) section to 2.3. Operations Details section.</li> <li>Moved the previous 2.5.5. <i>Selectable Memory-Mapped Interface</i> to 2.4.1. Selectable Memory-Mapped Interface section.</li> <li>Moved the previous 2.6. <i>Programming Flow</i> section to 2.5. Programming Flow section.</li> </ul> |
| IP Parameter Description | <ul style="list-style-type: none"> <li>Moved the previous 2.3. <i>Attributes Summary</i> section to 3. IP Parameter Description section.</li> <li>Removed <i>Remove Tristate Buffers</i> attribute from Table 3.1. Attributes Table and Table 3.2. Attributes Descriptions.</li> </ul>                                                                                                                                                                                                                                                                                                               |
| Signal Description       | Moved the previous 2.2. <i>Signal Description</i> section to 4. Signal Description section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Register Description     | Moved the previous 2.4. <i>Register Description</i> section to 5. Register Description section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Designing with the IP    | <ul style="list-style-type: none"> <li>Moved the previous section 3.2. <i>Generation and Synthesis</i> to 6.1. Generating and Instantiating the IP section.</li> <li>Updated Figure 6.1. Module/IP Block Wizard, Figure 6.2. Configure User Interface of I2C Target IP, and Figure 6.3. Check Generating Result.</li> <li>Added 6.2. Design Implementation and 6.3. Timing Constraints sections.</li> <li>Moved the previous section 3.3. <i>Running Functional Simulation</i> to 6.4. Running Functional Simulation section.</li> </ul>                                                             |
| Debugging                | Added this section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| References               | <ul style="list-style-type: none"> <li>Updated the names of existing references.</li> <li>Added references to <i>Lattice Memory Mapped Interface</i> and <i>Lattice Interrupt Interface (FPGA-UG-02039)</i>, <i>AMBA 3 APB Protocol v1.0 Specification</i>, <i>I2C Bus Specification and User Manual</i>, <i>Lattice Radiant Software 2023.1 User Guide</i>, <i>Lattice Radiant Timing Constraints Methodology (FPGA-AN-02059)</i>, <i>Reveal User Guide for Radiant Software</i>, <i>Avant-E web page</i>, and <i>Lattice Insights web page</i>.</li> </ul>                                         |

### Revision 1.6, August 2023

| Section                | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All                    | <ul style="list-style-type: none"> <li>Changed the word 'Master' to 'Controller'.</li> <li>Changed the word 'Slave' to 'Target'.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Introduction           | <p>In Table 1.1. Quick Facts:</p> <ul style="list-style-type: none"> <li>Added Certus-NX-RT and CertusPro-NX-RT to Supported FPGA Family.</li> <li>Added LIFCL-33, LFCPNX-50, LFMXO5-55T, LFMXO5-100T, UT24C40, and UT24CP100 to Targeted Devices.</li> <li>Updated Lattice Implementation to 'IP Core v2.x.x - Lattice Radiant Software 2022.1 or later and Lattice Propel Builder 2022.1 or later'.</li> </ul>                                                                                                                                                 |
| Functional Description | <ul style="list-style-type: none"> <li>Updated Figure 2.1. I2C Target IP Core Functional Diagram.</li> <li>Updated Table 2.1. I2C Target IP Core Signal Description.</li> <li>Updated Table 2.2. Attributes Table.</li> <li>Updated Table 2.3. Attributes Descriptions.</li> <li>Updated Table 2.4. Registers Address Map.</li> <li>Updated Table 2.8. Target Address Lower Register.</li> <li>Updated Table 2.11. Target Byte Count Register.</li> <li>Updated the Register Description section.</li> <li>Updated the General I2C Operation section.</li> </ul> |

| Section                                     | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Core Generation, Simulation, and Validation | <ul style="list-style-type: none"> <li>Updated the Programming Flow section.</li> <li>Updated the Generation and Synthesis section.</li> <li>Updated Figure 3.1. Module/IP Block Wizard.</li> <li>Updated Figure 3.2. Configure User Interface of I2C Target IP Core.</li> <li>Updated Figure 3.3. Check Generating Result.</li> <li>Updated Figure 3.4. Simulation Wizard.</li> <li>Updated Figure 3.5. Adding and Reordering Source.</li> </ul> |
| References                                  | <p>Added reference links to the following:</p> <ul style="list-style-type: none"> <li>Lattice Radiant Software website</li> <li>CrossLink-NX FPGA website</li> <li>Certus-NX FPGA website</li> <li>CertusPro-NX FPGA website</li> <li>MachXO5-NX FPGA website</li> <li>Lattice Avant-E FPGA website</li> </ul>                                                                                                                                    |

### Revision 1.5, April 2023

| Section                                     | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                                | <p>In Table 1.1. Summary of the I2C Target IP:</p> <ul style="list-style-type: none"> <li>Added Lattice Avant to Supported FPGA Family.</li> <li>Added LAV-AT-500E to Targeted Devices</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Functional Description                      | <ul style="list-style-type: none"> <li>Revised Figure 2.1. I2C Target IP Functional Diagram to update the int_o connection.</li> <li>Revised Table 5.1. Registers Address Map to add new register fields.</li> <li>Revised Table 5.7. Control Register to add new register fields and their descriptions.</li> <li>Revised Table 5.10. Interrupt Status Second Register, Table 5.12. Interrupt Enable Second Register, and Table 5.14. Interrupt Set Second Register to add new register fields and their descriptions.</li> <li>Added Received Address Registers (RX_ADDR_1_REG, RX_ADDR_2_REG) section.</li> <li>Consolidated the content of the Clock Stretching sections, and removed the duplicate Clock Stretching text.</li> </ul> |
| Core Generation, Simulation, and Validation | <ul style="list-style-type: none"> <li>Updated Figure 6.1. Module/IP Block Wizard,</li> <li>Figure 6.2. Configure User Interface of I2C Target IP, and Figure 6.3. Check Generating Result to show the latest version 1.4.0.</li> <li>Changed the section title Hardware Evaluation to IP Evaluation.</li> <li>Changes default value for the hardware evaluation capability from 'enabled' to 'disabled' in IP Evaluation section.</li> <li>Added Hardware Validation section.</li> <li>Moved the Data Transfer in response to I2C Combined Format Read section from 2.4.13 to 2.6.4.</li> </ul>                                                                                                                                          |
| Appendix A. Resource Utilization            | Added Resource Utilization for LAV-AT.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Technical Support Assistance                | Added link to the Lattice Answer Database.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

### Revision 1.4, May 2022

| Section                                        | Change Summary                                                                                                                                     |
|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                                   | Added MachXO5-NX to the Supported FPGA Family, and LFMXO5-25 to the Supported User Interfaces in Table 1.1.                                        |
| Functional Description                         | Corrected range for TX FIFO Almost Empty Flag and RX FIFO Almost Full Flag in Table 3.1.                                                           |
| IP Core Generation, Simulation, and Validation | Updated Figure 6.1, Figure 6.2, and Figure 6.3 to show the latest version 1.3.0.                                                                   |
| Appendix A. Resource Utilization               | <ul style="list-style-type: none"> <li>Updated Table A.2 for resource utilization of the I2C Target IP Core for the LFMXO5-25-9BBG400I.</li> </ul> |

| Section | Change Summary                                                                                                                                   |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------|
|         | <ul style="list-style-type: none"> <li>Added Table A.3 for resource utilization of the I2C Target IP Core for the LFMX05-25-7BBG400I.</li> </ul> |

#### Revision 1.3, June 2021

| Section      | Change Summary                                                                                                                                                                                                                                                                                                                                                       |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | <ul style="list-style-type: none"> <li>Remove second paragraph.</li> <li>Updated Table 1.1. Summary of the I2C Target IP. <ul style="list-style-type: none"> <li>Revised Supported FPGA Families</li> <li>Revised Targeted Devices</li> <li>Revised Lattice Implementation.</li> <li>Revised reference to Lattice Radiant Software User Guide</li> </ul> </li> </ul> |
| References   | Updated this section.                                                                                                                                                                                                                                                                                                                                                |

#### Revision 1.2, June 2020

| Section                          | Change Summary                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                     | <p>Updated Table 1.1. Quick Facts.</p> <ul style="list-style-type: none"> <li>Added Certus-NX as supported FPGA family.</li> <li>Added LFD2NX-40 as targeted device.</li> <li>Changed Synplify version to Pro for Lattice.</li> </ul>                                                                                                                                           |
| Functional Description           | <ul style="list-style-type: none"> <li>Updated Implementation of FIFO attribute default value to LUT in Table 2.2.</li> <li>Updated reset values in Table 2.8, Table 2.9, and Table 2.10.</li> <li>The wait state of APB read transaction has been reduced to one in Selectable Memory-Mapped Interface section.</li> <li>Updated content of Initialization section.</li> </ul> |
| Appendix A. Resource Utilization | Updated Table A1.                                                                                                                                                                                                                                                                                                                                                               |
| References                       | Updated this section.                                                                                                                                                                                                                                                                                                                                                           |

#### Revision 1.1, February 2020

| Section                                     | Change Summary                                                                                                                                                                               |
|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                                | <p>Updated Table 1.1. Quick Facts.</p> <ul style="list-style-type: none"> <li>Changed LIFCL to CrossLink-NX as supported FPGA family.</li> <li>Added LIFCL-17 as targeted device.</li> </ul> |
| Core Generation, Simulation, and Validation | Updated user interface item to <i>IP, Processors_Controllers_and_Peripherals</i> category.                                                                                                   |

#### Revision 1.0, December 2019

| Section                          | Change Summary                                                                                                                                                            |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All                              | Changed document status from Preliminary to final.                                                                                                                        |
| Introduction                     | <p>Updated Table 1.1. Quick Facts.</p> <ul style="list-style-type: none"> <li>Added Resource information.</li> <li>Updated Lattice Implementation information.</li> </ul> |
| References                       | Removed reference to the FPGA device web page.                                                                                                                            |
| Appendix A. Resource Utilization | Added resource utilization information.                                                                                                                                   |
| All                              | Minor editorial changes                                                                                                                                                   |

**Revision 0.80, October 2019**

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



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