

# SMBus Mailbox IP – Lattice Propel Builder

IP Version: 1.2.0

## **User Guide**

FPGA-IPUG-02165-1.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**

| Αb | breviati  | ons in This Document                                   | 5  |
|----|-----------|--------------------------------------------------------|----|
| 1. | Intro     | ductionduction                                         | 6  |
|    | 1.1.      | Features                                               | 7  |
|    | 1.2.      | Conventions                                            | 7  |
| 2. | Funct     | ional Descriptions                                     | 8  |
| :  | 2.1.      | Overview                                               | 8  |
|    | 2.2.      | Signals Description                                    | 9  |
| :  | 2.3.      | Attributes                                             | 10 |
|    | 2.4.      | Register Description                                   | 11 |
|    | 2.4.1     | Target Core Register                                   | 16 |
|    | 2.4.2     | Registers File                                         | 22 |
|    | 2.4.3     | Controller Core Register                               | 22 |
| :  | 2.5.      | SMBus Alert Signal                                     | 22 |
| 3. | Progr     | am Flow                                                | 24 |
|    | 3.1.      | SMBus Target Core Initialization                       | 24 |
| ;  | 3.2.      | SMBus Controller Core Initialization                   | 24 |
|    | 3.3.      | SMBus Target Core Operation Flow                       | 24 |
|    | 3.3.1     | Data Transfer in Response to External Controller Read  | 24 |
|    | 3.3.2     | Data Transfer in Response to External Controller Write | 25 |
| ;  | 3.4.      | SMBus Controller Core Operation Flow                   | 25 |
|    | 3.4.1     | Write Data to the SMBus Target                         | 26 |
|    | 3.4.2     | Read Data from the SMBus Target                        | 27 |
| ;  | 3.5.      | C Code API                                             | 27 |
| 4. | Gene      | rating the SMBus Mailbox IP                            | 28 |
| 5. | Appli     | cable Devices                                          | 31 |
| Ар | pendix .  | A. Resource Utilization                                | 32 |
| Re | ference   | S                                                      | 33 |
| Te | chnical : | Support Assistance                                     | 34 |
| Re | vision H  | istory                                                 | 35 |



## **Figures**

| Figure 1.1. SMBus Mailbox Write Byte Message              | 6  |
|-----------------------------------------------------------|----|
| Figure 1.2. SMBus Mailbox Read Byte Message               |    |
| Figure 1.3. MCTP over SMBus Packet Format                 |    |
| Figure 2.1. SMBus IP Core Functional Diagram              |    |
| Figure 2.2. 7-bit Addressable Device Response             |    |
| Figure 3.1. SMBus Controller Program Flow Interrupt Mode  |    |
| Figure 4.1. Module/IP Block Wizard                        | 28 |
| Figure 4.2. Configuring Parameters                        |    |
| Figure 4.3. Verifying Results                             |    |
| Figure 4.4. Specifying Instance Name                      | 29 |
| Figure 4.5. Generated Instance                            | 30 |
|                                                           |    |
| Tables                                                    |    |
| Table 2.1. Interface Signal Description                   | 9  |
| Table 2.2. Attributes Description                         | 11 |
| Table 2.3. Registers Address Map                          |    |
| Table 2.4. Access Type Definition                         |    |
| Table A.1. Resource Utilization for LFMXO4-050HE-5BBG256A | 32 |



## **Abbreviations in This Document**

A list of abbreviations used in this document.

| Abbreviation             | Definition                                  |  |  |  |  |
|--------------------------|---------------------------------------------|--|--|--|--|
| AHB-Lite                 | Advanced High-performance Bus – Lite        |  |  |  |  |
| API                      | Application Programming Interface           |  |  |  |  |
| CPU                      |                                             |  |  |  |  |
| EBR                      | Embedded Block RAM                          |  |  |  |  |
| FIFO                     | First In First Out                          |  |  |  |  |
| FPGA                     | Field Programmable Gate Array               |  |  |  |  |
| HDL                      | Hardware Description Language               |  |  |  |  |
| I2C                      | Inter-Integrated Circuit                    |  |  |  |  |
| IP Intellectual Property |                                             |  |  |  |  |
| LMMI                     | Lattice Memory Mapped Interface             |  |  |  |  |
| LUT                      | Look-Up Table                               |  |  |  |  |
| MCTP                     | Management Component Transport Protocol     |  |  |  |  |
| RISC-V                   | Reduced Instruction Set Computer – V (Five) |  |  |  |  |
| RX                       | Receive                                     |  |  |  |  |
| RTL                      | Register Transfer Level                     |  |  |  |  |
| SCL Serial Clock Line    |                                             |  |  |  |  |
| SDA Serial Data Line     |                                             |  |  |  |  |
| SMBus                    | System Management Bus                       |  |  |  |  |
| Tx                       | Transmit                                    |  |  |  |  |



### 1. Introduction

The System Management Bus (SMBus) is a two-wire interface through which simple system and power management devices can communicate with the rest of the system. The protocol is compatible with the I2C bus protocol and is often found in monitoring power conditions, temperature, and other sensors on a board. While the SMBus is derived from I2C, there are several major differences existing between the specifications of the two buses. The device that initiates the transmission on the SMBus is commonly known as the Controller, while the device being addressed is called the Target.

SMBus bus protocols support many kinds of formats, such as SMBus write byte, SMBus write word, SMBus read byte, SMBus read word, SMBus write block, SMBus read block and so on. See SMBus Specification for more information.

SMBus Mailbox is an SMBus target, which is designed to communicate with SMBus host mailbox. It responds to the standard SMBus Write Byte and Read Byte format messages, as shown in Figure 1.1 and Figure 1.2.



Figure 1.1. SMBus Mailbox Write Byte Message



Figure 1.2. SMBus Mailbox Read Byte Message

The MCTP over SMBus/I2C transport binding defines how the MCTP packets are delivered over a physical SMBus or I2C medium using SMBus transactions. All MCTP transactions are based on the SMBus Block Write bus protocol. The first eight bytes make up the packet header. The first three fields—Destination Target Address, Command Code, and Length—map directly to SMBus functional fields. The remaining header and payload fields map to SMBus Block Write Data Byte fields, as indicated in Figure 1.1. Hence, the inclusion of the Source Target Address in the header is specified by MCTP rather than SMBus. This is done to facilitate addressing required for establishing communications back to the message originator.



Figure 1.3. MCTP over SMBus Packet Format

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

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



#### 1.1. Features

The soft IP has the following features:

- Compatible with SMBus Specification
- Compatible with AHB-Lite Specification
- Supports SMBus controller
- Supports SMBus target
- Supports SMBus mailbox
- Supports MCTP over SMBus
- Supports 7-bit/10-bit addressing modes
- Supports Fairness arbitration SMBus arbitration mechanism
- Clock stretching and wait state generation
- · Timeout monitor for the Controller
- Interrupt flag generation
- Arbitration lost interrupt, with automatic transfer cancellation
- Bus busy detection
- Integrated glitch filter

#### 1.2. Conventions

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



## 2. Functional Descriptions

#### 2.1. Overview

The functional diagram of this IP is shown in Figure 2.1, which contains two main blocks: one is the Target Core and the other is the Controller Core.

The Target Core performs two operations:

- Normal SMBus transfer as a target
- Register file transfer as SMBus Mailbox

The Controller Core can initiate SMBus transfer as an SMBus Controller.

The SMBus interface is connected to the external bus through SDA/SCL signals. The Controller Core connects through the P1 interface and the Target Core connects through the P0 interface. Therefore, a switch/mux is needed between Controller and Target Cores. The switch is implemented in SMBus interface by the following method:

- If the Controller Core does not initiate a transfer, P0 is routed to the SMBus interface and P1 is switched off. The SMBus target core can then exchange data using the SDA/SCL signals.
- If the Controller Core initiates a transfer, P1 is routed to the SMBus interface and P0 is switched off. The SMBus Controller Core can then exchange data using the SDA/SCL signals.

The Controller Core can initiate SMBus transfer to access other SMBus Targets. The MCTP transfer is also controlled by the Controller Core logic. The Controller Core supports multi-controller on one bus simultaneously. All the controllers obey fairness arbitration rules to avoid any bus conflicts.

The Target Core makes sure the IP serves as an SMBus target device on the bus. The external controller writing messages are routed to RX\_FIFO. Reading messages may come from two data sources, TX\_FIFO and Register File according to register configuration. The Register File can only be updated by the external host writing through the AHB-Lite port SO1. The IP responds to two target addresses: the configured I2C Target Address from IP attributes, which can also be changed dynamically by the host, and the SMBus Device Default Address (7'b1100-001) as specified by the SMBus Specification.

The host accesses the IP through the AHB-Lite port. From the system level, it only has one AHB-Lite subordinate port, which can be connected to the host or another AHB-Lite Interconnect. The host can access Controller Core Register, Target Core Register, and Register File by the different addresses.





Figure 2.1. SMBus IP Core Functional Diagram

### 2.2. Signals Description

**Table 2.1. Interface Signal Description** 

| Signal Name       | Width | Direction | Reset                                                                                                                                                                                                                                                                                                                             | Description                                                                                                                                                                                               |  |  |  |
|-------------------|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Clock and Reset   |       |           |                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                           |  |  |  |
| clk_i             | 1     | input     | _                                                                                                                                                                                                                                                                                                                                 | System Clock                                                                                                                                                                                              |  |  |  |
| rst_n_i           | 1     | input     | _                                                                                                                                                                                                                                                                                                                                 | System Reset. The reset assertion can be asynchronous but reset negation should be synchronous. This is an active low signal. When asserted, output ports and registers are forced to their reset values. |  |  |  |
| AHB-Lite Bus      |       |           |                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                           |  |  |  |
| ahbl_hsel_slv_i   | 1     | input     | _                                                                                                                                                                                                                                                                                                                                 | AHB-Lite Select Signal Indicates that the subordinate device is selected and a data transfer is required.                                                                                                 |  |  |  |
| ahbl_haddr_slv_i  | 32    | input     | _                                                                                                                                                                                                                                                                                                                                 | The System Address Bus                                                                                                                                                                                    |  |  |  |
| ahbl_hburst_slv_i |       |           | 3'b000: SINGLE Single Burst 3'b001: INCR Incrementing burst of undefined length (NOT supported) 3'b010: WRAP4 4-bit wrapping burst 3'b011: INCR4 4-bit incrementing burst 4'b100: WRAP8 8-bit wrapping burst 3'b101: INCR8 8-bit incrementing burst 8'b110: WRAP16 16-bit wrapping burst 3'b111: INCR16 16-bit incrementing burst |                                                                                                                                                                                                           |  |  |  |



| Signal Name          | Width | Direction | Reset                               | Description                                                                                                                                                                                                                                                              |
|----------------------|-------|-----------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ahbl_hprot_slv_i     | 4     | input     | _                                   | ahbl_hprot_slv_i [0]:  1'b0 – opcode fetch.  1'b1 – data access. ahbl_hprot_slv_i [1]:  1'b0 – user access.  1'b1 – privileged access. ahbl_hprot_slv_i [2]:  1'b0 – non-bufferable.  1'b1 – bufferable. ahbl_hprot_slv_i [3]:  1'b0 – non-cacheable;  1'b1 – cacheable. |
| ahbl_hsize_slv_i     | 3     | input     | _                                   | 3'b000: 1 byte<br>3'b001: 2 bytes<br>3'b010: 4 bytes                                                                                                                                                                                                                     |
| ahbl_htrans_slv_i    | 2     | input     | _                                   | Indicates the transfer type of the current transfer. This can be: 2'b00: IDLE 2'b01: BUSY 2'b10: NONSEQUENTIAL 2'b11: SEQUENTIAL                                                                                                                                         |
| ahbl_hwdata_slv_i    | 32    | input     | _                                   | The write data bus.                                                                                                                                                                                                                                                      |
| ahbl_hwrite_slv_i    | 1     | input     | _                                   | When this signal is HIGH, it indicates a write transfer and when it is LOW, it indicates a read transfer.                                                                                                                                                                |
| ahbl_hready_slv_i    | 1     | input     | 0                                   | This signal should come from AHB-Lite Interconnect. When it is set to 1, it indicates the previous transfer is complete.                                                                                                                                                 |
| ahbl_hrdata_slv_o    | 32    | output    | 0                                   | The read data bus                                                                                                                                                                                                                                                        |
| ahbl_hreadyout_slv_o | 1     | output    | 0                                   | When this signal is HIGH, it indicates that a transfer has finished on the bus. This signal can be driven LOW to extend a transfer.                                                                                                                                      |
| ahbl_hresp_slv_o     | 1     | output    | 0                                   | When this signal is LOW, it indicates that the transfer status is OKAY. When it is HIGH, it indicates that the transfer status is ERROR.                                                                                                                                 |
| Interrupt Signal     |       |           |                                     |                                                                                                                                                                                                                                                                          |
| int_o                | 1     | output    | 0                                   | Interrupt to host (CPU). The reset value is 1'b0.                                                                                                                                                                                                                        |
| SMBus Signal         |       |           |                                     |                                                                                                                                                                                                                                                                          |
| scl_io               | 1     | inout     | Reset value is weak high (pull-up). | SMBus Serial Clock                                                                                                                                                                                                                                                       |
| sda_io               | 1     | inout     | Reset value is weak high (pull-up). | SMBus data signal                                                                                                                                                                                                                                                        |
| smbalert_n_o         | 1     | output    | 0                                   | SMBus alert (active low)                                                                                                                                                                                                                                                 |

### 2.3. Attributes

The configurable attributes of the IP Core are shown in Table 2.2. The attributes can be configured through the IP Catalog's Module/IP Wizard of the Lattice Propel™ Builder.



**Table 2.2. Attributes Description** 

| Parameter                           | Value Range                                 | Description                                                                                                                   |
|-------------------------------------|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| Enable Controller Function          | Checkbox:<br>Check, Uncheck                 | Switch on/off controller function. Check: enable the Controller Core; Uncheck: disable the Controller Core. Target-only mode. |
| SMBus Mailbox Base Address          | 0-{AHB-Lite Address assignment designation} | Specify IP base address on AHB-Lite bus.                                                                                      |
| AHB-Lite Address bus number of bits | [1–32]                                      | AHB-Lite bus address width                                                                                                    |
| AHB-Lite Data Bus number of bits    | [8–32]                                      | AHB-Lite bus data width                                                                                                       |
| Addressing Mode                     | 7-bit, 10-bit                               | 7-bit or 10-bit addressing selection                                                                                          |
| I2C Target Address: 0x              | 7-bit: 0x0–0x7f,<br>10-bit: 0x0–3ff         | As a target device, it is the target address for external controller to address.                                              |
| Device Architecture                 | ['LFMNX', 'MachXO3D']                       | FPGA Architecture                                                                                                             |
| System Clock Frequency (MHz)        | [40-100]                                    | System Clock Frequency                                                                                                        |
| I2C Frequency (kHz)                 | [100, 400, 1000]                            | I2C Bus Frequency                                                                                                             |

### 2.4. Register Description

The register address map, shown in Table 2.3, specifies the available IP Core registers. The offset of each register increments by four to allow easy interfacing with the Processor and System Buses. In this case, each register is 32-bit wide.

Table 2.3. Registers Address Map

| Offset   | Register Name              | Access     | Reset                                          | Description                                                               |                                            |              |
|----------|----------------------------|------------|------------------------------------------------|---------------------------------------------------------------------------|--------------------------------------------|--------------|
| AHB-Lite | S00: Each register is 32-b | it wide wh | erein the upper bits [31:8] are re             | served and th                                                             | e lower 8 bits [7:0] are u                 | used.        |
| 0x00     | RD_DATA_REG                | RO         | Not guaranteed.                                | Read Data F                                                               | legister                                   |              |
| 0x00     | WR_DATA_REG                | wo         | Not guaranteed.                                | Write Data                                                                | Register                                   |              |
| 0x04     | SLVADR_L_REG               | R/W        | [7] RSVD<br>[6:0] I2C Target<br>Address[6:0]   |                                                                           | ess Lower Register, same<br>ess attribute. | e as the I2C |
| 0x08     | SLVADR_H_REG               | R/W        | [7:3] RSVD<br>[2:0] I2C Target<br>Address[9:7] | Target Address Higher Register, same as the I2C Target Address attribute. |                                            |              |
|          |                            | R/W        | [7:6] RSVD                                     | Control Reg                                                               | ister                                      |              |
|          |                            |            |                                                | Field                                                                     | Name                                       | Access       |
|          |                            |            |                                                | [7:6]                                                                     | RSVD                                       | RSVD         |
|          |                            |            |                                                | [5]                                                                       | dat_src_sw                                 | R/W          |
| 0x0C     | CONTROL_REG                |            | [5:1] 0                                        | [4]                                                                       | nack_data                                  | R/W          |
|          |                            |            | [0] See Addressing Mode in Table 2.2.          | [3]                                                                       | nack_addr                                  | R/W          |
|          |                            |            | Table 2.2.                                     | [2]                                                                       | reset                                      | WO           |
|          |                            |            |                                                | [1]                                                                       | clk_stretch_en                             | R/W          |
|          |                            |            |                                                | [0]                                                                       | addr_10bit_en                              | R/W          |
| 0x10     | TGT_BYTE_CNT_REG           | R/W        | 8'h00                                          | Target Byte                                                               | Count Register                             |              |



| Offset | Register Name   | Access | Reset | Description                     |                       |        |
|--------|-----------------|--------|-------|---------------------------------|-----------------------|--------|
|        |                 |        |       | Interrupt Status First Register |                       |        |
|        |                 |        |       | Field                           | Name                  | Access |
|        |                 |        |       | [7]                             | tr_cmp_int            | RW1C   |
|        |                 |        |       | [6]                             | stop_det_int          | RW1C   |
|        |                 |        |       | [5]                             | tx_fifo_full_int      | RW1C   |
| 0x14   | INT_STATUS1_REG | RW1C   | 8'h00 | [4]                             | tx_fifo_aempty_int    | RW1C   |
|        |                 |        |       | [3]                             | tx_fifo_empty_int     | RW1C   |
|        |                 |        |       | [2]                             | rx_fifo_full_int      | RW1C   |
|        |                 |        |       | [1]                             | rx_fifo_afull_int     | RW1C   |
|        |                 |        |       | [0]                             | rx_fifo_ready_int     | RW1C   |
|        |                 |        |       | Interrupt E                     | nable First Register  |        |
|        |                 |        |       | Field                           | Name                  | Access |
|        |                 |        |       | [7]                             | tr_cmp_en             | R/W    |
|        |                 |        |       | [6]                             | stop_det_en           | R/W    |
|        |                 | - /    | 8'h00 | [5]                             | tx_fifo_full_en       | R/W    |
| 0x18   | INT_ENABLE1_REG | R/W    |       | [4]                             | tx_fifo_aempty_en     | R/W    |
|        |                 |        |       | [3]                             | tx_fifo_empty_en      | R/W    |
|        |                 |        |       | [2]                             | rx_fifo_full_en       | R/W    |
|        |                 |        |       | [1]                             | rx_fifo_afull_en      | R/W    |
|        |                 |        |       | [0]                             | rx_fifo_ready_en      | R/W    |
|        |                 |        |       | Interrupt Set First Register    |                       |        |
|        |                 |        |       | Field                           | Name                  | Access |
|        |                 |        |       | [7]                             | tr_cmp_set            | WO     |
|        |                 |        |       | [6]                             | stop_det_set          | WO     |
| 0x1C   | INIT CET1 DEC   | wo     | 9'600 | [5]                             | tx_fifo_full_set      | WO     |
| OXIC   | INT_SET1_REG    | WO     | 8'h00 | [4]                             | tx_fifo_aempty_set    | WO     |
|        |                 |        |       | [3]                             | tx_fifo_empty_set     | WO     |
|        |                 |        |       | [2]                             | rx_fifo_full_set      | WO     |
|        |                 |        |       | [1]                             | rx_fifo_afull_set     | WO     |
|        |                 |        |       | [0]                             | rx_fifo_ready_set     | WO     |
|        |                 |        |       | Interrupt S                     | tatus Second Register |        |
|        |                 |        |       | Field                           | Name                  | Access |
|        |                 |        |       | [7]                             | reserved              | RSVD   |
|        |                 |        |       | [6]                             | scl_h_to              | RW1C   |
| 0v20   | INT CTATUCA DEC | DW41C  | 9'h00 | [5]                             | scl_l_to              | RW1C   |
| 0x20   | INT_STATUS2_REG | RW1C   | 8'h00 | [4]                             | SR_check_value        | RW1C   |
|        |                 |        |       | [3]                             | SR_check_valid        | RW1C   |
|        |                 |        |       | [2]                             | arp_cmd_det           | RW1C   |
|        |                 |        |       | [1]                             | stop_err_int          | RW1C   |
|        |                 |        |       | [0]                             | start_err_int         | RW1C   |



| Offset | Register Name   | Access | Reset                  | Description          | 1                         |                    |
|--------|-----------------|--------|------------------------|----------------------|---------------------------|--------------------|
|        |                 |        |                        | Interrupt E          | nable Second Registe      | r                  |
|        |                 |        |                        | Field                | Name                      | Access             |
|        |                 |        |                        | [7]                  | reserved                  | RSVD               |
|        |                 |        |                        | [6]                  | scl_h_to_en               | R/W                |
| 0x24   | INT_ENABLE2_REG | R/W    | [7:2] RSVD             | [5]                  | scl_l_to_en               | R/W                |
|        |                 | ', '   | [1:0] 2'b00            | [4]                  | reserved                  | RSVD               |
|        |                 |        |                        | [3]                  | SR_valid_en               | R/W                |
|        |                 |        |                        | [2]                  | arp_cmd_en<br>stop_err_en | R/W<br>R/W         |
|        |                 |        |                        | [0]                  | start_err_en              | R/W                |
|        |                 |        |                        | -                    |                           | .,                 |
|        |                 |        |                        | Field                | et Second Register Name   | Access             |
|        |                 |        |                        |                      |                           | RSVD               |
|        |                 |        |                        | [7]                  | reserved                  | <del> </del>       |
|        |                 |        |                        | [6]                  | sch_h_to_set              | WO                 |
| 0x28   | INT_SET2_REG    | wo     | [7:2] RSVD             | [5]                  | sch_l_to_set              | WO                 |
| 0,120  | 01.110          |        | [1:0] 2'b00            | [4]                  | reserved                  | RSVD               |
|        |                 |        |                        | [3]                  | SR_valid_set              | WO                 |
|        |                 |        |                        | [2]                  | arp_cmd_set               | WO                 |
|        |                 |        |                        | [1]                  | stop_err_set              | WO                 |
|        |                 |        |                        | [0]                  | start_err_set             | WO                 |
|        |                 |        |                        | FIFO Status Register |                           |                    |
|        |                 |        |                        | Field                | Name                      | Access             |
|        |                 |        |                        | [7:6]                | RSVD                      | RSVD               |
|        |                 |        |                        | [5]                  | tx_fifo_full              | RO                 |
| 0x2C   | FIFO_STATUS_REG | RO     | [7:6] RSVD             | [4]                  | tx_fifo_aempty            | RO                 |
|        |                 |        | [5:0] 6'b011001        | [3]                  | tx_fifo_empty             | RO                 |
|        |                 |        |                        | [2]                  | rx_fifo_full              | RO                 |
|        |                 |        |                        | [1]                  | rx_fifo_afull             | RO                 |
|        |                 |        |                        | [0]                  | rx_fifo_empty             | RO                 |
|        |                 |        |                        | Interrunt F          | nable Second Registe      |                    |
|        |                 |        |                        | Field                | Name                      | Access             |
| 0x2C   | FLUSH FIFO      | wo     | [7:2] RSVD             | [7:2]                | reserved                  | RSVD               |
|        |                 |        | [1:0] 2'b0             | [1]                  | rxfifo_flush              | wo                 |
|        |                 |        |                        | [0]                  | txfifo_flush              | WO                 |
|        |                 |        |                        |                      | trol and Status Regis     |                    |
|        |                 |        |                        | [7:1] RSVD           |                           |                    |
|        |                 |        | [7,1] DCVD             | [0] smb_ale          | ert: Transmits the ale    | rt interrupt to    |
| 0x30   | SMB_CONTROL_REG | R/W    | [7:1] RSVD<br>[0] 1'b0 | SMBus Con            |                           |                    |
|        |                 |        | [0] 1 00               |                      | No interrupt to Cont      |                    |
|        |                 |        |                        |                      | SMBus target sends        | alert interrupt to |
|        |                 |        |                        | Contro<br>Reserved   | nier.                     |                    |
| 0x34-  | Reserved        | RSVD   | RSVD                   |                      | ss is ignored and 0 is    | returned on read   |
| 0x3C   |                 | ,      |                        | access.              |                           |                    |



| Offset    | Register Name              | Access      | Reset                               | Description                                |                                       |  |
|-----------|----------------------------|-------------|-------------------------------------|--------------------------------------------|---------------------------------------|--|
| AHB-Lite  | _                          | 7.00033     |                                     | 2 300 1 1 1 1 1 1                          |                                       |  |
| Allo Lite | 301                        |             |                                     | Registers File 256x32bi<br>Registers File. | ts, SMBus Mailbox                     |  |
|           |                            |             |                                     | Offset                                     | Dword Number                          |  |
| 0x2000-   |                            | - 6         | - 11 (2)                            | 0x00                                       | 0                                     |  |
| 0x23ff    | Registers File             | R/W         | All '0's                            | 0x04                                       | 1                                     |  |
|           |                            |             |                                     | 0x08                                       | 2                                     |  |
|           |                            |             |                                     |                                            |                                       |  |
|           |                            |             |                                     | 0x3fc                                      | 255                                   |  |
| AHB-Lite  | S02: each register is 32-k | oit wide wh | nerein the upper bits [31:8] are re | served and the lower 8 l                   | oits [7:0] are used.                  |  |
| 0x400     | PRERIO                     | R/W         | [31:8] RSVD                         | Clock prescale register                    |                                       |  |
|           |                            | ,           | [7:0] 8'hff                         |                                            | i / (PRERhi<<8 + PRERlo)              |  |
| 0x404     | PRERhi                     | R/W         | [31:8] RSVD<br>[7:0] 8'hff          | Clock prescale register                    | nign-byte<br>i / (PRERhi<<8 + PRERlo) |  |
|           |                            |             | [7.0] 8 1111                        |                                            | I / (FNLNIIIXXO + FNLNIO)             |  |
|           |                            |             |                                     | Control Register                           |                                       |  |
|           |                            |             |                                     | Field Description                          |                                       |  |
|           |                            |             | [31:8] RSVD                         | [7] EN –Contro                             | oller Core enable bit.                |  |
| 0x408     | CTR                        | R/W         | [7:6] 2'h00<br>[5:0] RSVD           | 0 = Core is                                |                                       |  |
|           |                            |             |                                     | l <del> </del>                             | rupt enable bit.                      |  |
|           |                            |             |                                     |                                            | ot is enabled                         |  |
|           |                            |             |                                     | 0 = Interru                                | ot is disabled                        |  |
|           |                            |             |                                     | Transmit Register                          |                                       |  |
|           |                            |             |                                     | Field Description                          |                                       |  |
|           |                            |             |                                     | Next byte to be transmitted via            |                                       |  |
|           |                            |             | [31:8] RSVD                         | [7:1] SMBus Cor                            | troller Core                          |  |
| 0x40c     | TXR                        | WO          | [7:0] 8'h00                         | a) The byte                                |                                       |  |
|           |                            |             |                                     | b) RW bit of transfer                      | uring target address                  |  |
|           |                            |             |                                     | [ [ ]                                      | g from target                         |  |
|           |                            |             |                                     | 0 = Writing                                |                                       |  |
|           |                            |             | fa., al. a.,                        | Receive Register                           |                                       |  |
| 0x40c     | RXR                        | RO          | [31:8] RSVD                         |                                            | ugh the SMBus Controller              |  |
|           |                            |             | [7:0] 8'h00                         | Core.                                      |                                       |  |
|           |                            |             |                                     | Command Register                           |                                       |  |
|           |                            |             |                                     | Field Name                                 |                                       |  |
|           |                            |             |                                     |                                            | rate (repeated) start                 |  |
|           |                            |             |                                     | condition                                  |                                       |  |
|           |                            |             |                                     |                                            | erate stop condition                  |  |
|           |                            |             | [31:8] RSVD                         | <del> </del>                               | from target                           |  |
| 0x410     | CR                         | wo          | [31:8] KSVD<br>[7:0] 8'h00          | [4] WR – Write                             | a receiver sends ACK                  |  |
|           |                            |             | [:::5] 000                          |                                            | r NACK (ACK = 1).                     |  |
|           |                            |             |                                     |                                            | clears the timeout status             |  |
|           |                            |             |                                     | [1] Reserved                               |                                       |  |
|           |                            |             |                                     |                                            | rrupt acknowledge.                    |  |
|           |                            |             |                                     | When set,                                  | clears a pending                      |  |
|           |                            |             |                                     | interrupt.                                 |                                       |  |



| Offset | Register Name | Access | Reset       | Description     |                                                                                                                                                                                   |
|--------|---------------|--------|-------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |               |        |             | Status Register |                                                                                                                                                                                   |
|        |               |        |             | Field           | Name                                                                                                                                                                              |
|        |               |        |             |                 | RxACK – Received acknowledge from addressed target.  1 = No acknowledge received.  0 = Acknowledge received.                                                                      |
|        |               |        |             | [6]             | Busy – Indicates that the SMBus bus is busy.  1 = bus is busy.  0 = bus is idle.                                                                                                  |
|        |               |        |             |                 | AL – Arbitration lost. This bit is set when the core loses arbitration. Arbitration is lost when:  A STOP signal is detected, but not requested.  A START signal is detected, but |
|        |               |        | [31:8] RSVD |                 | not requested.  The controller drives SDA high, but SDA is low.  Controller drive SCL high, but                                                                                   |
| 0x410  | SR            | RO     | [7:0] 8'h00 | [4]             | SCL is low. Not clock stretch.                                                                                                                                                    |
|        |               |        |             | [3] Timeout     | Timeout  1 = SCL and SDA line have been high for 50 us.                                                                                                                           |
|        |               |        |             | [2]             | Timeout                                                                                                                                                                           |
|        |               |        |             |                 | 1 = SCL line has been low for 25 ms. TIP – Transfer in Progress                                                                                                                   |
|        |               |        |             |                 | 1 = Transferring data.                                                                                                                                                            |
|        |               |        |             |                 | 0 = Transfer is complete. IF – Interrupt Flag. This bit is set                                                                                                                    |
|        |               |        |             | ;<br>;          | when an interrupt is pending. The int_o signal is asserted if the IEN bit is set. The Interrupt Flag is set when:                                                                 |
|        |               |        |             |                 | One byte transfer has been completed.                                                                                                                                             |
|        |               |        |             |                 | Target NACK.                                                                                                                                                                      |
|        |               |        |             |                 | <ul><li>Arbitration is lost.</li><li>Controller changes from busy</li></ul>                                                                                                       |

#### Table 2.4. Access Type Definition

| Table 2.4. Access Type Definition    |                         |                                                                                               |  |  |  |  |  |
|--------------------------------------|-------------------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|
| Access Type Behaviour on Read Access |                         | Behaviour 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. Writing 1'b0 on register bit is ignored. |  |  |  |  |  |
| RSVD                                 | Returns 0.              | Ignores write access.                                                                         |  |  |  |  |  |



#### 2.4.1. Target Core Register

AHB-Lite S00 is the port to access Target Core Register. The offset address is 0. The detailed description for every register is shown below.

The RD\_DATA\_REG and WR\_DATA\_REG share the same offset. The Write access to this offset goes to WR\_DATA\_REG, while the Read access goes to RD\_DATA\_REG. Write Data Register is the interface to Transmit FIFO (TX\_FIFO). Writing to WR\_DATA\_REG pushes a word to Transmit FIFO (TX\_FIFO). When writing to WR\_DATA\_REG, the host should ensure that Transmit FIFO (TX\_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 (TX\_FIFO) are not reset but the FIFO control logic is reset. Thus, the content is not guaranteed after reset. The Read Data register is the interface to Receive FIFO (RX\_FIFO). After a data is received from I2C bus during I2C write transaction, the received data is pushed to Receive FIFO (RX\_FIFO). Reading from RD\_DATA\_REG pops a word from Receive FIFO (RX\_FIFO). The host should ensure that Receive FIFO (RX\_FIFO) has data before reading RD\_DATA\_REG, data is not guaranteed when this register is read during Receive FIFO (RX\_FIFO) empty condition. On the other hand, if Receive FIFO (RX\_FIFO) is full but I2C target continues to receive data, new data is lost. The Read FIFO\_STATUS\_REG to determine the status of Receive FIFO (RX\_FIFO). Similar to Transmit FIFO (TX\_FIFO), the reset value of Receive FIFO (RX\_FIFO) is also not guaranteed after reset.

The Target Address Lower Register (TARGET\_ADDRL\_REG) 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 seven bits of the Target address. The Target Address Higher Register (TARGET\_ADDRH\_REG) is the upper three 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 2.2.

Each bit of the Control Register (CONTROL\_REG) controls the behavior of the Target Core.

dat\_src\_sw

Data source switch. Select data source when external controller read routine.

- 1'b0 selects register file for mailbox.
- 1'b1 selects tx fifo for normal external read.
- 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 Core for one clock cycle. The registers and LMMI interface are not affected by this reset. This is write-only bit because it has the auto-clear feature. It is cleared to 1'b0 after one clock cycle.

- 1'b0 No action.
- 1'b1 Resets I2C Target IP Core.
- clk\_stretch\_en

Clock Stretch Enable. Enables clock stretching on ACK bit of data.

- 1'b0 I2C Target IP Core releases SCL signal.
- 1'b1 I2C Target IP Core pulls down SCL signal on the next ACK bit of data phase 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 Core rejects the 10-bit I2C address. It sends NACK.
- 1'b1 I2C Target IP Core responds to 10-bit I2C address. If TARGET\_ADDRH\_REG is 3'h0, it also responds to the 7-bit address.



The desired number of bytes to transfer (read/write) in I2C bus should be written to this Target Byte Count Register (TGT\_BYTE\_CNT\_REG). This is used for Transfer Complete interrupt generation which asserts when the target byte count is achieved.

The Interrupt Status Register (INT\_STATUS1\_REG and INT\_STATUS2\_REG) contains all the interrupts currently pending in the Target Core. 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 description of Interrupt Enable Registers (INT\_ENABLE1\_REG, INT\_ENABLE2\_REG) below 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.

The corresponding bits of INT STATUS1 REG are shown below:

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\_REG.

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

- 1'b0 No interrupt.
- 1'b1 Interrupt pending.
- tx fifo full int

Transmit FIFO (TX\_FIFO) Full Interrupt Status. This interrupt status bit asserts when Transmit FIFO (TX\_FIFO) changes from not full state to full state.

- 1'b0 No interrupt.
- 1'b1 Interrupt pending.
- tx\_fifo\_aempty\_int

Transmit FIFO (TX\_FIFO) Almost Empty Interrupt Status. This interrupt status bit asserts when the amount of data words in Transmit FIFO (TX\_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 (TX\_FIFO) Empty Interrupt Status. This interrupt status bit asserts when the last data in Transmit FIFO (TX\_FIFO) is popped-out, causing the FIFO to become empty.

- 1'b0 No interrupt.
- 1'b1 Interrupt pending.
- rx\_fifo\_full\_int

Receive FIFO (RX\_FIFO) Full Interrupt Status. This interrupt status bit asserts when RX FIFO full status changes from not full to full state.

- 1'b0 No interrupt.
- 1'b1 Interrupt pending.
- rx fifo afull int

Receive FIFO (RX\_FIFO) Almost Full Interrupt Status. This interrupt status bit asserts when the amount of data words in Receive FIFO (RX\_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 (RX\_FIFO) Ready Interrupt Status. This interrupt status bit asserts when Receive FIFO (RX\_FIFO) is empty and receives a data word from I2C interface.

- 1'b0 No interrupt.
- 1'b1 Interrupt pending.

The corresponding bit of INT\_STATUS2\_REG is shown below:

scl h to

Timeout flag when SCL and SDA lines have been high for 50 us in transfer mode.

- 1'b0 No interrupt.
- 1'b1 Interrupt pending.
- scl\_l\_to

Timeout flag when SCL line has been low for 25 ms.

- 1'b0 No interrupt.
- 1'b1 Interrupt pending.
- arp cmd det

Flag when 7'h61 is addressed.

- 1'b0 No interrupt.
- 1'b1 Interrupt pending.
- SR\_check\_valid: repeat start check valid.
- SR check value: repeat start value.

When SR\_check\_valid is valid (=1), then you know whether repeat start happens or not according to SR check value (=1, happen; =0 does not happen).

stop\_err\_int

STOP Condition Error Interrupt Status. This interrupt status bit asserts after detecting a STOP condition when it is not expected. A 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.

INT\_ENABLE1\_REG/INT\_ENABLE2\_REG 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 assert and the corresponding bit of INT\_ENABLE1\_REG/ INT\_ENABLE2\_REG is 1'b1, the interrupt signal int\_o asserts.

The corresponding bits of INT\_ENABLE1\_REG are shown below:

tr\_cmp\_en

Transfer Complete Interrupt Enable. Interrupt enable bit corresponds to Transfer Complete Interrupt Status.

- 1'b0 Interrupt disabled.
- 1'b1 Interrupt enabled.
- stop\_det\_en

STOP Condition Detected Interrupt Enable. Interrupt enable bit corresponds to STOP Condition Detected Interrupt Status.

- 1'b0 Interrupt disabled.
- 1'b1 Interrupt enabled.

18



tx fifo full en

Transmit FIFO Full Interrupt Enable. Interrupt enable bit corresponds 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 corresponds 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 corresponds 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 corresponds 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 corresponds 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 corresponds to Receive FIFO Ready Interrupt Status.

- 1'b0 Interrupt disabled.
- 1'b1 Interrupt enabled.

The corresponding bits of INT ENABLE2 REG are shown below:

scl\_h\_to\_en

Enable interrupt when SCL and SDA line have been high for 50 us in transfer mode.

- 1'b0 Interrupt disabled.
- 1'b1 Interrupt enabled.
- scl I to en

Enable interrupt when SCL line has been low for 25 ms.

- 1'b0 Interrupt disabled.
- 1'b1 Interrupt enabled.
- SR valid en

Enable interrupt when repeat start check finish.

- 1'b0 Interrupt disabled.
- 1'b1 Interrupt enabled.
- arp\_cmd\_en

Enable interrupt when 7'h61 is addressed.

- 1'b0 Interrupt disabled.
- 1'b1 Interrupt enabled.
- stop\_err\_en

STOP Condition Error Interrupt Enable. Interrupt enable bit corresponds 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 corresponds to START Condition Error Interrupt Status.

- 1'b0 Interrupt disabled.
- 1'b1 Interrupt enabled.

INT\_SET1\_REG/INT\_SET2\_REG corresponds to interrupts status bits in INT\_STATUS1\_REG and INT\_STATUS2\_REG. 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.

The corresponding bit of INT SET1 REG shows below:

tr\_cmp\_set

Transfer Complete Interrupt Set. Interrupt set bit corresponds 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 corresponds 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 corresponds 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 corresponds 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 corresponds 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 corresponds 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 corresponds 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 corresponds to Receive FIFO Ready Interrupt Status.

- 1'b0 No action.
- 1'b1 Asserts INT\_STATUS1\_REG.rx\_fifo\_ready\_int.

20



The corresponding bits of INT SET2 REG are shown below:

scl h to set

SCL and SDA line high timeout interrupt set. Interrupt set bit corresponds to scl h to bit in INT STATUS2 REG.

- 0 No action.
- 1 Asserts INT STATUS2 REG. scl h to.
- scl\_l\_to\_set

SCL line low timeout interrupt set. Interrupt set bit corresponds to scl\_l\_to bit in INT\_STATUS2\_REG.

- 0 No action.
- 1 Asserts INT\_STATUS2\_REG. scl\_l\_to.
- arp\_cmd\_det

7'h61 is addressed interrupt set. Interrupt set bit corresponds to arp\_cmd\_det bit in INT\_STATUS2\_REG.

- 0 No action.
- 1 Asserts INT\_STATUS2\_REG. arp\_cmd\_det.
- stop\_err\_set

STOP Condition Error Interrupt Set. Interrupt set bit corresponds to STOP Condition Error Interrupt Status.

- 0 − No action.
- 1 Asserts INT\_STATUS2\_REG.stop\_err\_set.
- start\_err\_set

START Condition Error Interrupt Set. Interrupt set bit corresponds to START Condition Error Interrupt Status.

- 0 No action.
- 1 Asserts INT\_STATUS2\_REG.start\_err\_set.

FIFO Status Register reflects the status of Transmit FIFO and Receive FIFO as shown below.

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 the TX FIFO Almost Empty Flag attribute.
- 1'b1 Data words in Transmit FIFO is less than or equal to the 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 one 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 Full. This bit reflects the almost full condition of Receive FIFO.

- 1'b0 Data words in Receive FIFO is less than the RX FIFO Almost Full Flag attribute.
- 1'b1 Data words in Receive FIFO is greater than or equal to the RX FIFO Almost Full Flag attribute.
- rx\_fifo\_empty

Receive FIFO Full. This bit reflects the empty condition of Receive FIFO.

- 1'b0 Receive FIFO is not empty has at least one data word.
- 1'b1 Receive FIFO is empty.



The corresponding bits of FLUSH FIFO are shown below:

rxfifo\_flush

Flush RX FIFO data.

- 0 No action.
- 1 Flush RX FIFO data to empty.
- txfifo flush

Flush TX FIFO data.

- 0 No action.
- 1 Flushes TX FIFO data to empty.

#### 2.4.2. Registers File

The external SMBus controller initiates an SMBus Mailbox read transaction. The read byte data message is routed to the Register File. The external SMBus controller cannot write message to the Register File. The external SMBus controller writes messages to the RX\_FIFO. The host reads that message data from the RX\_FIFO and write to the Register File through the AHB-Lite port S01. The Host can read and write to the Register File from the ABH\_Lite port S01. The offset address is 0x2000.

#### 2.4.3. Controller Core Register

AHB-Lite SO2 is the port to access Controller Core Register. The offset address is 0x400.

The prescale register (offset = 0x00 and 0x04) is used to prescale the SCL clock line based on the system clock. This design uses an internal clock enable signal, clk\_en, to generate the SCL clock frequency. The frequency of clk\_en is calculated by the equation [clk\_i frequency / (Prescale Register + 1)] and this frequency is five times SCL frequency. The contents of the prescale register can only be modified when the core is not enabled.

Only two bits of the control register (offset = 0x08) are used for this design. The MSB of this register is the most critical one because it enables or disables the entire SMBus core. The core does not respond to any command unless this bit is set. If the bit is set, the Target Core to SMBus interface route is disabled.

The transmit register and the receive register share the same address (offset = 0x0C) depending on the direction of data transfer. The data to be transmitted through the SMBus is stored in the transmit register, while the byte received through the SMBus is available in the receive register.

The status register and the command register share the same address (offset = 0x10). The status register allows the monitoring of the SMBus operations, while the command register stores the next command for the next SMBus operation. Unlike the rest of the registers, the bits in the command register are cleared automatically after each operation. Therefore, this register must be written for each start, write, read, or stop of the SMBus operation.

### 2.5. SMBus Alert Signal

The SMBus alert signal provides interrupt signal to the SMBus controller when pulled Low. A target device can signal the controller through smbalert\_n\_o interrupt line that it wants to talk. The controller processes the interrupt and simultaneously accesses all the smbalert devices through the Alert Response Address. Only the target device, which pulled smbalert\_n\_o low, acknowledges the Alert Response address (0001 100b). The host performs a modified Receive Byte operation. The 7-bit device address provided by the target transmit device is placed in the seven most significant bits of the byte. The eighth bit can be zero or one.

If more than one device pulls smbalert\_n\_o low, the highest priority device (lowest address) device wins the communication rights.



After receiving an acknowledge (ACK) from the controller in response to its address, the device stops pulling down the smbalert\_n\_o signal. If the controller still sees the smbalert\_n\_o low when the message transfer is complete, the same process repeats again. The SMBus target core monitors the data bus to see if any other target is responding to the Alert Response address. This can be achieved by checking the input and output of smbdat\_io. When there is match, the smb\_alert register bit is cleared and the controller generates an interrupt signal to the host.



Figure 2.2. 7-bit Addressable Device Response



## 3. Program Flow

The SMBus mailbox IP can be used as an SMBus controller and SMBus target simultaneously. But the SMBus controller function also can be disabled by unchecking the Enable Controller function attribute box when configuring the IP in Lattice Propel Builder.

If both SMBus controller and SMBus target are enabled, when SMBus controller initiates a transfer, SMBus target logic is halted, and it cannot receive external controller's messages. When SMBus controller logic is complete and halts, the SMBus target logic wakes up and is available for receiving messages from any controller.

The SMBus mailbox IP needs to be initialized for both SMBus controller and SMBus target core blocks to enable normal operation.

### 3.1. SMBus Target Core Initialization

To perform initialization, load the following appropriate registers of the Target Core:

- TARGET\_ADDRL\_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. Read access to the address by external
  controller is routed to Register File, while write access to the address is routed to internal RX\_FIFO.
- CONTROL REG
- 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.

#### 3.2. SMBus Controller Core Initialization

Write the appropriate data to the prescale register based on the frequency of SCL through the AHB-Lite bus S02. The SCL frequency meets the equation: 5×SCL frequency = clk\_i / (PRERhi<<8 + PRERIo).

### 3.3. SMBus Target Core Operation Flow

#### 3.3.1. Data Transfer in Response to External Controller Read

As mentioned, the two target address for the IP are the normal SMBus target device data transfer and the SMBus mailbox Register File access. According to the accessed address, there are two ways to respond to the external controller read.

#### 3.3.1.1. Normal SMBus Target Device Read Data Transfer

The following are the recommended steps to perform data transfer in response to the read request of the external SMBus controller. This assumes that the amount of data to send is known.

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

- 1. Write data to WR DATA REG, amounting to ≤ FIFO Depth.
- 2. Enable only Transfer Complete Interrupt. If transmit data > FIFO Depth, also enable TX FIFO Almost Empty interrupt if there is no more data to transfer. Otherwise, proceed to step 7.
- 3. Wait for TX FIFO Almost Empty Interrupt. If polling mode is desired, 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\_aempt\_int is asserted. Also read INT\_STATUS2\_REG to check that no error occurs.
- 4. Clear TX FIFO Almost Empty Interrupt. It is 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 TX FIFO Almost Empty Interrupt.
- 7. Wait for Transfer Complete Interrupt. If polling mode is desired, 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. Also read INT\_STATUS2\_REG to check that no error occurred.
- 8. Clear all interrupts.

#### 3.3.1.2. SMBus Mailbox Register File Read Data Transfer

If the accessed address is Register File, the SMBus Mailbox IP outputs the addressed data in Register File automatically. The data format is shown in Figure 1.2.

#### 3.3.2. Data Transfer in Response to External Controller Write

Similarly, the external SMBus controller can initiate a write transaction to two target addresses. One is routed to the internal RX\_FIFO logic and the other is to the Register File through RISC-V host.

#### 3.3.2.1. Normal SMBus Target Device Write Data Transfer

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

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

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

#### 3.3.2.2. SMBus Mailbox Register File Write data transfer

If the accessed address is Register File, the external controller write data firstly inputs to RX\_FIFO. The host reads out the data and write it to the Register File according to the Register File address. The data format is shown in Figure 1.1.

#### 3.4. SMBus Controller Core Operation Flow

Figure 3.1 shows the SMBus controller program flow in interrupt mode. The Controller Core can also be used in polling mode. The polling mode is the same as interrupt mode except that the polling mode needs to poll the SR bit 0 instead of being interrupted by int\_o to check status. In the polling mode, set the CTR to 0x80.





Figure 3.1. SMBus Controller Program Flow Interrupt Mode

#### 3.4.1. Write Data to the SMBus Target

- 1. Write 0x80 to the control register (CTR) to enable the SMBus Controller through the AHB-Lite bus. If enable interrupt, the write data is 0xC0.
- 2. Read the status register (SR) through the AHB-Lite bus until all bits of the status register is 0.
- 3. Write the SMBus target address and write bit to the transmit register (TXR) through the AHB-Lite bus.
- 4. Write 0x90 to the command register (CR) through the AHB-Lite bus to start the SMBus write operation.
- 5. When using polling mode, read the status register (SR) until bit 0 of the status register is set and check if other bits except bit 6 are 0s. When using interrupt mode, if host is interrupted by the int\_o signal, read the status register (SR) and check if other bits except bit 0 and bit 6 are 0s. Both modes need to write 0x1 to CR to clear bit 0 of SR. If other bits except bit 0 and bit 6 are not 0s, there is an error. Write 0x5 to CR to clear SR and go back to step 2.
- 6. Write the byte which is sent to the SMBus target to the transmit register (TXR) through the AHB-Lite bus.
- 7. Write 0x10 to the CR through the AHB-Lite bus to set SMBus write operation.
- 8. When using polling mode, read the status register (SR) until bit 0 of the status register is set and check if other bits except bit 6 are 0s. When using interrupt mode, if host is interrupted by int\_o signal, read the status register (SR) and check if other bits except bit 0 and bit 6 are 0s. Both modes need to write 0x1 to CR to clear bit 0 of SR. If other bits except bit 0 and bit 6 are not 0s, there is an error. Write 0x5 to CR to clear SR and go back to step 2. If there is no error and there is another data to write, go back to step 6.

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

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



- 9. When all the bytes have been sent, write 0x40 to the command register (CR) through the AHB-Lite bus to stop the SMBus write operation.
- 10. When using polling mode, read the status register (SR) until bit 0 of the status register is set and check if other bits except bit 6 are 0s. Bit 6 is set when other controllers use the bus at this time. Otherwise, it also should be 0. When using interrupt mode, if the host is interrupted by the int\_o signal, read the status register (SR) and check if other bits except bit 0 and bit 6 are 0s. Both modes need to write 0x1 to CR to clear bit 0 of SR. If other bits except bit 0 and bit 6 are not 0s, there is an error. Write 0x5 to CR to clear SR and go back to step 9.

#### 3.4.2. Read Data from the SMBus Target

- 1. Write 0x80 to the control register (CTR) to enable the SMBus Controller through the AHB-Lite bus. If enable interrupt, the write data is 0xC0.
- 2. Read the status register (SR) through the AHB-Lite bus until all bits of the status register is 0s.
- 3. Write the SMBus target address and the read bit to the transmit register (TXR) through the AHB-Lite bus.
- 4. Write 0x90 to the command register (CR) through the AHB-Lite bus to start the SMBus read operation.
- 5. When using polling mode, read the status register (SR) until bit 0 of the status register is set and check if other bits except bit 6 are 0s. When using interrupt mode, if the host is interrupted by the int\_o signal, read the status register (SR) and check if other bits except bit 0 and bit 6 are 0s. Both modes need to write 0x1 to CR to clear bit 0 of SR. If other bits except bit 0 and bit 6 are not 0s, there is an error. Write 0x5 to CR to clear SR and go back to step 2.
- 6. Write 0x20 to command register (CR) through the AHB-Lite bus to read data from the target. If it is the last byte to read, write 0x28 to command register (CR) to NACK last byte.
- 7. When using polling mode, read the status register (SR) until bit 0 of the status register is set and check if other bits except bit 6 are 0s. When using interrupt mode, if host is interrupted by int\_o signal, read the status register (SR) and check if other bits except bit 0 and bit 6 are 0s. Both modes need to write 0x1 to CR to clear bit 0 of SR. If other bits except bit 0 and bit 6 are not 0s, there is an error, write 0x5 to CR to clear SR and go back to step 2.
- 8. Read data from the receive register (RXR) through the AHB-Lite bus. If no error and have another data to read, go back to step 6.
- 9. When the read operation is finished, write 0x40 to the command register (CR) through the AHB-Lite bus to stop the SMBus read operation.
- 10. When using polling mode, read the status register (SR) until bit 0 of the status register is set and check if other bits except bit 6 are 0s. Bit6 is set when other controllers use the bus at this time, otherwise it also should be 0. When using interrupt mode, if host is interrupted by int\_o signal, read the status register (SR) and check if other bits except bit 0 and bit 6 are 0s. Both modes need to write 0x1 to CR to clear bit 0 of SR. If other bits except bit 0 and bit 6 are not 0s, there is an error, write 0x5 to CR to clear SR and go back to step 9.

#### 3.5. C Code API

Refer to the IP driver for the details.



## 4. Generating the SMBus Mailbox IP

This section provides information on how to generate the SMBus Mailbox IP Core module using Lattice Propel Builder. To generate the SMBus Mailbox IP Core module:

- 1. In Lattice Propel Builder, create a new design. Select the SMBus Mailbox IP in IP Catalog.
- 2. Enter the component name as shown in Figure 4.1. Click **Next**.



Figure 4.1. Module/IP Block Wizard

3. Configure the parameters as shown in Figure 4.2. Click Generate.



Figure 4.2. Configuring Parameters



4. Verify the information. Click Finish.



Figure 4.3. Verifying Results

5. Confirm or modify the module instance name. Click **OK**.



Figure 4.4. Specifying Instance Name

The CPU IP instance is successfully generated, as shown in Figure 4.5.





Figure 4.5. Generated Instance



## 5. Applicable Devices

- MachXO3D™
- MachXO5™-NX
- CertusPro™-NX
- MachXO4™



## **Appendix A. Resource Utilization**

Table A.1 shows the SMBus Mailbox resource utilization for LFMXO4-050HE-5BBG256A device using Symplify Pro of Lattice Radiant Software 2025.2.

Table A.1. Resource Utilization for LFMXO4-050HE-5BBG256A

| Configuration                                                                                                                            | clk Fmax (MHz)1 | Registers | LUTs | EBRs |
|------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------|------|------|
| Default                                                                                                                                  | 124.15          | 387       | 778  | 0    |
| Enable Master Function = Unchecked,<br>Others = Default                                                                                  | 132.34          | 251       | 540  | 0    |
| Addressing Mode = 10 bit, System Clock Frequency = 100MHz, I2C Frequency = 1000kHZ, Others = Default                                     | 131.22          | 399       | 816  | 0    |
| Enable Master Function = Unchecked, Addressing Mode = 10 bit, System Clock Frequency = 100MHz, I2C Frequency = 1000kHZ, Others = Default | 131.06          | 248       | 493  | 0    |

#### Notes:

1. Fmax is generated when the FPGA design only contains the SMBus Mailbox module, and the target frequency is 100 MHz. These values may be reduced when a user logic is added to the FPGA design.



### References

- SMBus Mailbox IP Release Notes (FPGA-RN-02108)
- SMBus Mailbox IP web page
- CertusPro-NX Devices web page
- MachXO3D Devices web page
- Mach-XO4 Devices web page
- MachXO5-NX Devices web page
- AMBA 3 AHB-Lite Protocol Specification
- SMBus Specification
- Lattice Radiant Software web page
- Lattice Propel Design Environment web page
- Lattice Insights for Lattice Semiconductor training courses and learning plans



## **Technical Support Assistance**

Submit a technical support case through www.latticesemi.com/techsupport. For frequently asked questions, refer to the Lattice Answer Database at www.latticesemi.com/Support/AnswerDatabase.

34



## **Revision History**

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

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

| Section                          | Change Summary                                                                                                                                                                                                                                                       |  |  |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| All                              | Updated the document title from Lattice Sentry SMBus Mailbox IP Core- Propel Builder to SMBus Mailbox IP – Lattice Propel Builder.                                                                                                                                   |  |  |
|                                  | Added the IP version to the cover page.                                                                                                                                                                                                                              |  |  |
| Abbreviations in This Document   | Updated the section name to its current.                                                                                                                                                                                                                             |  |  |
|                                  | Updated the abbreviation list.                                                                                                                                                                                                                                       |  |  |
| Applicable Devices               | Removed <i>Mach-NX</i> .                                                                                                                                                                                                                                             |  |  |
|                                  | Added MachXO5™-NX, CertusPro™-NX, and MachXO4™.                                                                                                                                                                                                                      |  |  |
| Appendix A. Resource Utilization | Added this section.                                                                                                                                                                                                                                                  |  |  |
| References                       | Updated this section.                                                                                                                                                                                                                                                |  |  |
| Revision History                 | Added the following note: In some instances, the IP may be updated without changes to the user guide. The user guide may reflect an earlier IP version but remains fully compatible with the later IP version. Refer to the IP Release Notes for the latest updates. |  |  |

#### Revision 1.1, August 2024

| Section                         | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| All                             | Changed master to controller and slave to target globally.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| Introduction                    | Updated Figure 1.1. SMBus Mailbox Write Byte Message, Figure 1.2. SMBus Mailbox Read Byte Message, and Figure 1.3. MCTP over SMBus Packet Format to reflect inclusive language.                                                                                                                                                                                                                                                                                                                              |  |  |
| Functional Description          | <ul> <li>Updated Figure 2.1. SMBus IP Core Functional Diagram to reflect inclusive language.</li> <li>In Table 2.1. Interface Signal Description, updated Reset from O to O for the following signals: ahbl_hrdata_slv_o, ahbl_hreadyout_slv_o, ahbl_hresp_slv_o, int_o, and smbalert_n_o.</li> <li>In Table 2.3. Registers Address Map, updated the Reset value of 0x0C from [7:6] RSVD [4:1] 0 [0] See Addressing Mode in Table 2.2 to [7:6] RSVD [5:1] 0 [0] See Addressing Mode in Table 2.2.</li> </ul> |  |  |
| Generating the SMBus Mailbox IP | Updated Figure 4.1. Module/IP Block Wizard, Figure 4.2. Configuring Parameters, Figure 4.3. Verifying Results, Figure 4.4. Specifying Instance Name, and Figure 4.5. Generated Instance.                                                                                                                                                                                                                                                                                                                     |  |  |
| Technical Support Assistance    | Added the link to Lattice Answer Database.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |

#### Revision 1.0, December 2021

| nerision 210) Describer 2022 |                  |  |
|------------------------------|------------------|--|
| Section                      | Change Summary   |  |
| All                          | Initial release. |  |



www.latticesemi.com