

# **CSI-2/DSI D-PHY Transmitter Submodule IP**

# **User Guide**

FPGA-IPUG-02024-1.6

April 2021



#### **Disclaimers**

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



# **Contents**

| Acronyms in This Document                       | 5  |
|-------------------------------------------------|----|
| 1. Introduction                                 | 6  |
| 1.1. Quick Facts                                | 6  |
| 1.2. Features                                   | 6  |
| 1.3. Conventions                                | 7  |
| 1.3.1. Nomenclature                             | 7  |
| 1.3.2. Data Ordering and Data Types             | 7  |
| 1.3.3. Signal Names                             | 7  |
| 2. Functional Descriptions                      | 8  |
| 2.1. Interface and Timing Diagram               | 10 |
| 2.1.1. Input Interface                          | 10 |
| 2.1.2. Output Interface                         |    |
| 2.2. Clock, Reset and Initialization            | 13 |
| 2.2.1. Reset and Initialization                 |    |
| 2.2.2. Clock Domains and Clock Domain Crossing  | 13 |
| 2.3. Design and Module Description              | 15 |
| 3. Parameter Settings                           |    |
| 4. IP Generation and Evaluation                 |    |
| 4.1. Licensing the IP                           | 18 |
| 4.2. Getting Started                            | 18 |
| 4.3. Generating IP in Clarity Designer          |    |
| 4.4. Generated IP Directory Structure and Files |    |
| 4.5. Running Functional Simulation              | 25 |
| 4.6. Simulation Strategies                      | 26 |
| 4.7. Simulation Environment                     | 26 |
| 4.8. Instantiating the IP                       |    |
| 4.9. Synthesizing and Implementing the IP       | 27 |
| 4.10. Hardware Evaluation                       |    |
| 4.10.1. Enabling Hardware Evaluation in Diamond |    |
| 4.11. Updating/Regenerating the IP              |    |
| 4.11.1. Regenerating an IP in Clarity Designer  |    |
| References                                      |    |
| Technical Support Assistance                    |    |
| Appendix A. Resource Utilization                |    |
| Appendix B. What is Not Supported               |    |
| Appendix C. PLL Programming                     | 33 |
| Revision History                                | 36 |



# **Figures**

| Figure 2.1. CSI-2/DSI D-PHY Transmitter Submodule Top-level Block Diagram                                | 8  |
|----------------------------------------------------------------------------------------------------------|----|
| Figure 2.2. D-PHY Tx Input Bus for Short Packet Transmission                                             | 10 |
| Figure 2.3. D-PHY Tx Input Bus for Long Packet Transmission in CSI-2 Interface                           | 11 |
| Figure 2.4. D-PHY Tx Input Bus for Long Packet Transmission in DSI Interface                             |    |
| Figure 2.5. D-PHY Tx Input Bus for Long Packet Transmission in DSI/CSI-2 Interface without pkt_formatter | 11 |
| Figure 2.6. High-Speed Data Transmission                                                                 |    |
| Figure 2.7. Clock Domain Crossing Block Diagram                                                          | 13 |
| Figure 2.8. PLL Block Diagram                                                                            | 14 |
| Figure 2.9. D-PHY Transmitter Submodule Block Diagram                                                    | 15 |
| Figure 4.1. Clarity Designer Window                                                                      | 18 |
| Figure 4.2. Starting Clarity Designer from Diamond Design Environment                                    | 19 |
| Figure 4.3. Configuring D-PHY Transmitter IP in Clarity Designer                                         |    |
| Figure 4.4. Configuration Tab in IP User Interface                                                       | 21 |
| Figure 4.5. Protocol Timing Parameter Tab in IP User Interface                                           | 22 |
| Figure 4.6. D-PHY Transmitter IP Directory Structure                                                     | 23 |
| Figure 4.7. Simulation Environment Block Diagram                                                         | 26 |
| Figure 4.8 D-PHY Tx configured as CSI-2 Transmitter                                                      | 26 |
| Figure 4.9. D-PHY Tx configured as DSI Transmitter                                                       | 27 |
| Figure 4.10. IP Regeneration in Clarity Designer                                                         | 28 |
| Tables                                                                                                   |    |
| Table 1.1. CSI-2/DSI D-PHY Transmitter Submodule IP Quick Facts                                          | 6  |
| Table 1.2. CSI-2/DSI D-PHY Transmitter Submodule IP Features Summary                                     |    |
| Table 2.1. D-PHY Transmitter Submodule IP Pin Function Description                                       |    |
| Table 2.2. Byte Data Bus Assignments                                                                     |    |
| Table 2.3. Clock Domain Crossing                                                                         |    |
| Table 2.4. PLL Operating Frequencies                                                                     |    |
| Table 3.1. CSI-2/DSI D-PHY Tx Submodule IP Parameter Settings in User Interface                          |    |
| Table 4.1. Files Generated in Clarity Designer                                                           |    |
| Table 4.2. Testbench Compiler Directives                                                                 |    |
| Table A.1. Resource Utilization <sup>1, 3</sup>                                                          |    |
| Table C.1. 5-Bit Input Divider                                                                           |    |
| Table C.2. 8-Bit Feedback Divider                                                                        |    |
| Table C.3. 2-Bit Output Divider                                                                          |    |
|                                                                                                          |    |



# **Acronyms in This Document**

A list of acronyms used in this document.

| Acronym | Definition                          |  |  |
|---------|-------------------------------------|--|--|
| CM      | Coded PLL M parameter               |  |  |
| CN      | Coded PLL N parameter               |  |  |
| СО      | Coded PLL O parameter               |  |  |
| CSI-2   | Camera Serial Interface-2           |  |  |
| DCS     | Display Command Set                 |  |  |
| DSI     | Display Serial Interface            |  |  |
| EBR     | Embedded Block RAM                  |  |  |
| ЕоТр    | End of Transmit Packet              |  |  |
| FIFO    | First In First Out buffer           |  |  |
| HS      | High Speed                          |  |  |
| IP      | Intellectual Property               |  |  |
| LP      | Low Power                           |  |  |
| LUT     | Lookup Table                        |  |  |
| M       | PLL feedback multiplier             |  |  |
| MIPI    | Mobile Industry Processor Interface |  |  |
| N       | PLL input clock divider             |  |  |
| 0       | PLL VCO output frequency divider    |  |  |
| PLL     | Phase-Locked Loop / Phase Lock Loop |  |  |
| VCO     | Voltage Controlled Oscillator       |  |  |



# 1. Introduction

The Lattice Semiconductor CSI-2/DSI D-PHY Transmitter Submodule IP converts 64-bit data to either DSI or CSI-2 data for Lattice Semiconductor CrossLink™ and CrossLinkPlus™ devices. This is useful for wearable, tablet, human-machine interfacing, medical equipment, and other applications.

Mobile Industry Processor Interface (MIPI<sup>®</sup>) D-PHY has become the industry's primary high-speed PHY solution for camera and display interconnection in mobile devices. It is typically used in conjunction with MIPI Camera Serial Interface-2 (CSI-2) and MIPI Display Serial Interface (DSI) protocol specifications. It meets requirements of low-power, low-noise generation, and high-noise immunity that mobile phone designs demand.

This user guide is for CSI-2/DSI D-PHY Transmitter Submodule IP design version 1.4.

### 1.1. Quick Facts

Table 1.1 provides quick facts about the CSI-2/DSI D-PHY Transmitter Submodule IP for CrossLink and CrossLinkPlus devices.

Table 1.1. CSI-2/DSI D-PHY Transmitter Submodule IP Quick Facts

|                                         |                        | D-PHY Transmitter Submodule IP Configuration        |            |  |
|-----------------------------------------|------------------------|-----------------------------------------------------|------------|--|
|                                         |                        | CSI-2 4-Lane                                        | DSI 4-Lane |  |
| IP Requirements FPGA Families Supported |                        | CrossLink/CrossLinkPlus                             |            |  |
|                                         | Targeted Device        | LIF-MD6000-                                         | -6MG81I    |  |
|                                         | Data Path Width        | 64-bit                                              | 64-bit     |  |
| Resource Utilization                    | LUTs*                  | 1496                                                | 5548       |  |
|                                         | sysMEM™ EBRs           | 0                                                   | 0          |  |
|                                         | Registers              | 517                                                 | 656        |  |
|                                         | MIPI D-PHY             | 1                                                   | 1          |  |
|                                         | Lattice Implementation | Lattice Diamond® 3.11 SP1                           |            |  |
| Design Tool Support                     | Counth a sin           | Lattice Synthesis Engine                            |            |  |
|                                         | Synthesis              | Synplify Pro® N-2018.03L-SP1-1                      |            |  |
|                                         | Simulation             | Aldec <sup>®</sup> Active HDL™ 10.5 Lattice Edition |            |  |

<sup>\*</sup>Note: DSI packet formatter includes a FIFO while CSI-2 packet formatter does not. In addition, the distributed RAM utilization is accounted for in the total LUT4 utilization. The actual LUT4 utilization is distribution among logic, distributed RAM, and ripple logic.

#### 1.2. Features

The key features of the CSI-2/DSI D-PHY Transmitter Submodule IP include:

- Compliant with MIPI DSI v1.1, MIPI CSI-2 v1.1, and MIPI D-PHY v1.1 Specifications
- Supports MIPI DSI and MIPI CSI-2 interfacing up to 6 Gb/s
- Supports 1, 2, 3, or 4 MIPI D-PHY data lanes
- Supports Burst Mode, Non-Burst Mode with Sync Pulses and Non-Burst Mode with Sync Events for transmission of DSI packets
- Supports low-power (LP) mode during vertical and horizontal blanking

Table 1.2. CSI-2/DSI D-PHY Transmitter Submodule IP Features Summary

| · · · · · · · · · · · · · · · · · · · | •          |
|---------------------------------------|------------|
| IP Configuration                      | Options    |
| Number of Tx lanes                    | 1, 2, 3, 4 |
| Gearing                               | 8, 16      |
| MIPI Interface                        | DSI, CSI-2 |



## 1.3. Conventions

#### 1.3.1. Nomenclature

The nomenclature used in this document is based on Verilog HDL. This includes radix indications and logical operators.

## 1.3.2. Data Ordering and Data Types

The most significant bit within the pixel data is the highest index.

## 1.3.3. Signal Names

Signal names that end with:

- \_n are active low
- \_i are input signals
- \_o are output signals
- \_io are bidirectional signals



# 2. Functional Descriptions

The CSI-2/DSI D-PHY Transmitter Submodule IP converts 64-bit data to either DSI or CSI-2 byte packets. The input interface consists of a 64-bit data arranged in CSI-2 or DSI data type format, a byte data enable, frame/vsync start signal, line/hsync start signal, or short/long packet enable, virtual channel, data type, EoTP, word count, and byte clock.

The output interface consists of serialized HS (High-speed) data packets following the MIPI CSI-2 or DSI specifications. It has a maximum of five lanes per channel (four data lanes and one clock lane only).



Figure 2.1. CSI-2/DSI D-PHY Transmitter Submodule Top-level Block Diagram

Table 2.1. D-PHY Transmitter Submodule IP Pin Function Description

| Pin Name                        | Direction         | ection Function Description                                                                                           |  |  |  |  |
|---------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                 | For DSI Interface |                                                                                                                       |  |  |  |  |
| vsync_start_i <sup>1</sup>      | I                 | Start of vertical sync (active high pulse)                                                                            |  |  |  |  |
| hsync_start_i <sup>1</sup>      | I                 | Start of horizontal sync (active high pulse)                                                                          |  |  |  |  |
|                                 |                   | For CSI-2 Interface with Packet Formatter                                                                             |  |  |  |  |
| sp_en_i <sup>2</sup>            | I                 | Short packet enable; this includes line start/end and frame start/end packets                                         |  |  |  |  |
| frame_max_i [7:0]               | I                 | Sets maximum frame count when the frame number count is enabled from the user interface                               |  |  |  |  |
| lp_en_i <sup>2</sup>            | I                 | Long packet enable; active high pulse to request long packet creation and transmission                                |  |  |  |  |
| ld_pyld_o                       | 0                 | For CSI-2, this indicates that the requestor can send the valid payload data after a long packet transmission request |  |  |  |  |
|                                 |                   | Byte Data Input without Packet Formatter                                                                              |  |  |  |  |
| byte_data_i [63:0] <sup>3</sup> | I                 | Byte data                                                                                                             |  |  |  |  |
| byte_data_en_i <sup>3</sup>     | I                 | Active high byte data enable                                                                                          |  |  |  |  |
|                                 |                   | D-PHY Packet Input                                                                                                    |  |  |  |  |
| dphy_pkt_i [63:0] 4             | I                 | D-PHY packet data                                                                                                     |  |  |  |  |
| dphy_pkten_i <sup>4</sup>       | I                 | Active high D-PHY packet enable                                                                                       |  |  |  |  |
|                                 | Common Interface  |                                                                                                                       |  |  |  |  |
| reset_n_i                       | I                 | Asynchronous active low system reset.                                                                                 |  |  |  |  |
|                                 |                   | 0 – System is on reset                                                                                                |  |  |  |  |
| ref_clk_i                       | I                 | Reference clock for D-PHY PLL used to generate D-PHY serial clock and byte clock.                                     |  |  |  |  |

© 2017-2021 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.



| Pin Name                     | Direction | Function Description                                                                                                                                                                                                                                                                                                                                   |  |  |
|------------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| pd_dphy_i                    | I         | Power down input signal for D-PHY. When high, all D-PHY blocks are powered down. Tie low if not used.                                                                                                                                                                                                                                                  |  |  |
| vc_i [1:0] <sup>3</sup>      | I         | Virtual channel ID.                                                                                                                                                                                                                                                                                                                                    |  |  |
| dt_i [5:0] <sup>3</sup>      | į         | Data type                                                                                                                                                                                                                                                                                                                                              |  |  |
| wc_i [15:0] <sup>3</sup>     | ĺ         | Word Count field. This corresponds to header word1 and 2 in the header packet.                                                                                                                                                                                                                                                                         |  |  |
| eotp_i <sup>1</sup>          | I         | End of Transmission packet enable                                                                                                                                                                                                                                                                                                                      |  |  |
| clk_hs_en_i <sup>5</sup>     | ı         | Active high pulse going to the Tx Global operation to start LP to HS transition of clock lane                                                                                                                                                                                                                                                          |  |  |
| d_hs_en_i                    | ı         | Active high pulse going to the Tx Global operation to start LP to HS transition of data lane                                                                                                                                                                                                                                                           |  |  |
| d_hs_rdy_o                   | 0         | Active high signal that indicates the data lanes are already in high-speed mode in response to an earlier transmit request.  The requestor needs to check this signal before sending a valid long or short packet.                                                                                                                                     |  |  |
| c2d_rdy_o                    | 0         | In the case of non-continuous clock mode, this active high signal indicates the clock is in LP-11 state and is ready to accept new transmit request. For continuous clock mode, this indicates the data lanes are in LP-11 state and ready to accept new requests.  The requestor needs to check this ready signal before sending a d hs en i request. |  |  |
| byte_clk_o                   | 0         | Byte clock generated by D-PHY PLL                                                                                                                                                                                                                                                                                                                      |  |  |
| d0_p_io                      | I/O       | D-PHY data lane 0 Positive Data                                                                                                                                                                                                                                                                                                                        |  |  |
| d0_n_io                      | I/O       | D-PHY data lane 0 Negative Data                                                                                                                                                                                                                                                                                                                        |  |  |
| d1_p_o                       | 0         | D-PHY data lane 1 Positive Data                                                                                                                                                                                                                                                                                                                        |  |  |
| d1_n_o                       | 0         | D-PHY data lane 1 Negative Data                                                                                                                                                                                                                                                                                                                        |  |  |
| d2_p_o                       | 0         | D-PHY data lane 2 Positive Data                                                                                                                                                                                                                                                                                                                        |  |  |
| d2_n_o                       | 0         | D-PHY data lane 2 Negative Data                                                                                                                                                                                                                                                                                                                        |  |  |
| d3_p_o                       | 0         | D-PHY data lane 3 Positive Data                                                                                                                                                                                                                                                                                                                        |  |  |
| d3_n_o                       | 0         | D-PHY data lane 3 Negative Data                                                                                                                                                                                                                                                                                                                        |  |  |
| clk_p_o                      | 0         | D-PHY clock lane Positive end                                                                                                                                                                                                                                                                                                                          |  |  |
| clk_n_o                      | 0         | D-PHY clock lane Negative end                                                                                                                                                                                                                                                                                                                          |  |  |
|                              |           | Miscellaneous                                                                                                                                                                                                                                                                                                                                          |  |  |
| tinit_done_o <sup>6</sup>    | 0         | tINIT done signal generated from IP.                                                                                                                                                                                                                                                                                                                   |  |  |
| pll_lock_o <sup>6</sup>      | 0         | D-PHY PLL lock signal.                                                                                                                                                                                                                                                                                                                                 |  |  |
| pix2byte_rstn_o <sup>6</sup> | 0         | Active low done signal. Indicates the end of a long packet transmission. This signal may be used to reset the FIFOs of the requestor module.                                                                                                                                                                                                           |  |  |

#### Notes:

- Enabled only for DSI interface (TX\_DSI is defined).
- 2. Enabled only for CSI-2 interface (TX\_CSI2 is defined).
  - lp\_en\_i is equivalent to the start of active line (long packet).
    - sp\_en\_i is equivalent to the start and end of frame or line (short packet).
- 3. Enabled when you need the packet formatter, and disabled when packet formatter is not needed.
- 4. Enabled when you do not need the packet formatter.
- 5. Enabled for non-continuous clock mode.
- 6. Can be turned-on when MISC\_ON is defined.



## 2.1. Interface and Timing Diagram

### 2.1.1. Input Interface

#### 2.1.1.1. Short Packet Transmission (Packet Formatter Enabled)

Figure 2.2 shows the timing relationship between sp\_en\_i (frame and line short packets) for CSI-2 interface, hsync/vsync start for DSI interface, and d\_hs\_en\_i/clk\_hs\_en\_i and d\_hs\_rdy\_o signals for short packet transmission. Short packet transmission is as follows:

- Requestor checks the c2d\_ready\_o signal and asserts the d\_hs\_en\_i when it wants to send a request for HS transmission. The clk\_hs\_en\_i is not enabled for continuous (HS\_ONLY) clock mode. For non-continuous (HS\_LP) clock mode, clk\_hs\_en\_i can be asserted earlier to enable the module to start performing the clock lane LP to HS sequence, or it can be asserted with the d\_hs\_en\_i. Enabling the clock lane to go to high-speed mode earlier reduces the transmit latency.
- 2. Wait for d\_hs\_rdy\_o to assert. This indicates the data lane has completed the LP to HS transition and is now transmitting HS-ZERO bits.
- 3. For CSI-2 interface, the requestor sends one pulse of sp\_en\_i together with the valid packet header fields, for every short packet transmission requests.

For DSI, send one pulse of vsync\_start\_i or hsync\_start\_i. Modify the data type dt\_i to 0x01, 0x11, 0x21or 0x31 when transmitting V Sync Start, V Sync End, H Sync Start or H Sync End packets respectively.



Figure 2.2. D-PHY Tx Input Bus for Short Packet Transmission

#### 2.1.1.2. Long Packet Transmission (Packet Formatter Enabled)

Figure 2.3 and Figure 2.4 show the timing relationship between the lp\_en\_i (long packet enable), byte\_data\_en\_i and byte data. Long packet transmission is as follows:

- 1. Requestor checks the c2d\_ready\_o signal and asserts d\_hs\_en\_i when it wants to send a request for HS transmission. The clk\_hs\_en\_i is not enabled for continuous (HS\_ONLY) clock mode. For non-continuous (HS\_LP) clock mode, clk\_hs\_en\_i needs to be asserted with the d\_hs\_en\_i.
- 2. Wait for d\_hs\_rdy\_o to assert. This indicates the data lane has completed the LP to HS transition and is now transmitting HS-ZERO bits.
- 3. For CSI-2 interface, send one pulse of lp\_en\_i together with the valid packet header fields. The signal ld\_pyld\_o asserts the next cycle after reception of the lp\_en\_i.
  - For DSI, there is no lp\_en\_i or ld\_pyld\_o. Instead, the byte\_data\_en\_i needs to be asserted one cycle earlier than the valid data.
- 4. For DSI, there is no lp\_en\_i or ld\_pyld\_o. Send byte\_data\_i together with the byte\_data\_en\_i and the dt\_i[5:0]. For CSI-2, the requestor must send the byte\_data\_i and byte\_data\_en\_i 2 cycles after ld\_pyld\_o assertion (or 3 cycles after lp\_en\_i) to let the IP have enough time to create the header packets.

© 2017-2021 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.





Figure 2.4. D-PHY Tx Input Bus for Long Packet Transmission in DSI Interface

<Valid data>

#### 2.1.1.3. Packet Transmission when Packet Formatter is Disabled

byte\_data\_i

Figure 2.5 shows the timing diagram when the packet formatter module is disabled. The dphy\_pkt\_i should already include the sync code, packet header, payload and trail bits. After assertion of d\_hs\_en\_i/clk\_hs\_en\_i, wait for d\_hs\_rdy\_o to assert and send the dphy\_pkt\_i with the dphy\_pkten\_i.



Figure 2.5. D-PHY Tx Input Bus for Long Packet Transmission in DSI/CSI-2 Interface without pkt\_formatter

Table 2.2 shows the byte arrangement of the input byte\_data\_i in relation to how it will appear on the D-PHY data lanes.



**Table 2.2. Byte Data Bus Assignments** 

| To D DUVI and a last data : |             | 4-Lane  |        | 2-Lane  |        | 1-Lane  |        |
|-----------------------------|-------------|---------|--------|---------|--------|---------|--------|
| Tx D-PHY Lanes              | byte_data_i | Gear 16 | Gear 8 | Gear 16 | Gear 8 | Gear 16 | Gear 8 |
| Lane 0                      | [7:0]       | Byte 1  | Byte 1 | Byte 1  | Byte 1 | Byte 1  | Byte 1 |
| Lane 0                      | [15:8]      | Byte 5  | _      | Byte 3  | _      | Byte 2  | _      |
| Long 1                      | [23:16]     | Byte 2  | Byte 2 | Byte 2  | Byte 2 | -       | _      |
| Lane 1                      | [31:24]     | Byte 6  | _      | Byte 4  | _      | _       | _      |
| Long 2                      | [39:32]     | Byte 3  | Byte 3 | _       | _      | _       | _      |
| Lane 2                      | [47:40]     | Byte 7  | _      | _       | _      | _       | _      |
| Lana 2                      | [55:48]     | Byte 4  | Byte 4 | _       | _      | _       | _      |
| Lane 3                      | [63:56]     | Byte 8  | _      | _       | _      | _       | _      |

### 2.1.2. Output Interface

Figure 2.6 shows that prior to the HS mode data transfer, all clock and data lanes are in the LP11 state (1.2 V on the P channel and 1.2 V on the N channel). The clock lane then goes to the LP01 state (0 V on the P channel and 1.2 V on the N channel) followed by the LP00 state (0 V on the P channel and 0 V on the N channel). After that, the clock lane goes into HS mode with SLVS200 signaling (Vcm=200 mV, Vdiff=±100 mV), and holds an HS0 state (differential 0 state of P channel = 100 mV and N channel = 300 mV when termination of the receiver is turned on) according to the MIPI D-PHY Specifications. The clock starts shortly after. When the HS clock runs, the data lanes follow a similar procedure going from LP11 to LP01, LP00, and HS0 states. The Start-of-Transmit sync pattern is driven on the line followed by the packet header and data payload. At the end of the transfer, the data lanes first go back into LP mode by going to LP00 then LP11 states. The clock lane follows shortly after.



Figure 2.6. High-Speed Data Transmission



### 2.2. Clock, Reset and Initialization

#### 2.2.1. Reset and Initialization

After power-up, the transmitting D-PHY is required to drive a Stop State (LP-11) for a period longer than tINIT. The D-PHY forces the lane module into transmit mode and generates the Stop State after system reset.

The Slave PHY is initialized when the Master PHY drives a Stop State (LP-11). The first Stop State that is longer than the specified tINIT is called the Initialization period. tINIT is estimated to be minimum 100 µs.

An asynchronous reset pin (active high) is used for resetting the entire FPGA. Internal reset logic is implemented to guarantee synchronous de-assertion throughout different clock domains for both hard and soft IPs. A powerdown signal pd\_dphy\_i also resets the hardened D-PHY block. This block must remain powered down until the internal PLL has locked. This requirement is already handled by the CSI-2/DSI D-PHY Transmitter Submodule IP. Unless specified by MIPI IP or Soft IP requirement, no special reset sequence is needed for CrossLink and CrossLinkPlus devices. However, there is a wait time requirement before the Application Processor can send valid data to the bridge. When set in DSI, until the DCS commands are sent to the display, valid data from the Application Processor might be lost. Likewise, for CSI-2, until PLL is locked, valid data from the Application Processor might be lost.

### 2.2.2. Clock Domains and Clock Domain Crossing

The D-PHY PLL generates the bit clock from the input reference clock. Byte clock is then derived from this bit clock through a clock generator inside the D-PHY block. Both the reference clock and byte clock are free-running.



Figure 2.7. Clock Domain Crossing Block Diagram

**Table 2.3. Clock Domain Crossing** 

| Clock Domain Crossing        | Handling Approach |
|------------------------------|-------------------|
| Byte clock to DPHY bit clock | Hard D-PHY        |

The general formula for computing the required clocks of the system:

Tx line rate (total) = total pixels(active + blanking) \* frame rate \* bits per pixel

Tx line rate (per lane) =  $\frac{\text{Tx line rate (total)}}{\text{no.of Tx lane}}$ D-PHY clock =  $\frac{\text{Tx line rate (per lane)}}{2}$ Byte clock =  $\frac{\text{D-PHY clock}}{\text{Tx gear/2}}$ 

© 2017-2021 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.



#### 2.2.2.1. D-PHY TX PLL

The CSI-2/DSI D-PHY Transmitter Submodule IP contains its own PLL to generate the D-PHY clock lanes and the byteclock. The block diagram of the PLL is shown in Figure 2.8.



Figure 2.8. PLL Block Diagram

The output of the PLL is the D-PHY clock. It multiplies the input frequency by (M/(N\*O)), where N is the input divider, M is the feedback divider, and O is the output divider.

The valid CLKREF of the D-PHY PLL, connected to the signal refclk\_i, ranges from 24 MHz up to 200 MHz, but the CrossLink and CrossLinkPlus fabric supports only up to 150 MHz. The input divider, N, has to be programmed such that the frequency FF after the input divider is within 24 MHz and 30 MHz. The VCO output, which is also the input to the O divider, must be between 640 MHz and 1500 MHz.

**Table 2.4. PLL Operating Frequencies** 

| Symbol | Parameter                                    | Min (MHz) | Max (MHz) |
|--------|----------------------------------------------|-----------|-----------|
| CLKREF | Input frequency of <i>refclk_i</i>           | 24        | 200       |
| N      | Frequency after divider N, at FF point       | 24        | 30        |
| 0      | VCO output frequency, input to the O divider | 640       | 1500      |

The N, M and O divider values are integer numbers and are automatically computed by the IP based on the input clock frequency and TX line rate. Due to the PLL divider requirements indicated in Table 2.4, there are certain configurations that the IP cannot support.

For the values of CN, CO, and CM, see tables in Appendix C. PLL Programming.



## 2.3. Design and Module Description

The top-level module instantiates the Packet Formatter, Tx Global Operation, and D-PHY Common Interface. There is an option to instantiate the internal oscillator when you do not choose an external reference clock for the D-PHY PLL.

There is also an option to disable the packet formatter module when the byte\_data\_i already has the header and footer.



Figure 2.9. D-PHY Transmitter Submodule Block Diagram

The Packet Formatter block wraps the packet header and packet footer modules.

The Packet header module generates and appends the packet header and footer to the data payload.

The byte data en i input and the byte data i bus are used together to identify when payload is available.

The header field and payload size is configurable by setting VC, WC, and DT parameters. End of Transmission Packet (EoTP) is supported by this module. The Packet footer module computes a CRC16 checksum based on incoming data and data enable. The data bus input is maximum 64 bits.

The Tx Global Operation block controls High Speed (HS) request path and timing using parameters. Currently Lower Power (LP) request, escape mode and turnaround path are not supported. This block follows the requirements described D-PHY Specification version 1.2 section 6 — operating modes for control and high-speed data transmission. DSI data goes into Lower-Power mode during vertical and horizontal blanking depending on the Soft IP design.

Example: HS-0/1 -> LP11(Stop) -> LP01(LP-Rqst) -> LP00(Bridge) -> HS-0/1

This module controls the timing entering HS and coming from HS entering to LP following the MIPI D-PHY Specification 1.1 Table 14. The delay parameters can be adjusted inside this module by changing its local parameter.

The DCI (D-PHY Common Interface) wrapper is used as the wrapper of MIPI D-PHY IP to make a connection between the PHY hard IP and higher protocol layers. The DCI wrapper serializes the incoming byte data and transmits it to D-PHY receiver. Based on the Tx global operation state, it determines how to enable HS or LP mode for data transfer.



# 3. Parameter Settings

Table 3.1 lists the parameters used to generate the D-PHY Transmitter Submodule IP. All parameters are either set automatically or input in the user interface during the D-PHY Transmitter Submodule IP generation.

Table 3.1. CSI-2/DSI D-PHY Tx Submodule IP Parameter Settings in User Interface

| Parameter                          | Attribute           | Options                            | Description                                                                                                                                     |
|------------------------------------|---------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Number of Tx Lanes                 | User-Input          | 1, 2, 3, 4                         | Generate I/O up to four HS Tx data lane. 3-lane configuration is only available when the packet formatter is off.                               |
| Tx Interface                       | User-Input          | DSI, CSI-2                         | Set the Tx interface.                                                                                                                           |
| Tx Gear                            | Read-Only           | 8, 16                              | Set the Tx gearing.                                                                                                                             |
| Target TX Line Rate                | User-Input          | 160-1500                           | The target data rate for each D-PHY data lane.                                                                                                  |
| Target TX Data Rate                | Read-Only           | <value></value>                    | The target total data rate of the D-PHY channel. This is the target line rate multiplied by the number of data lanes.                           |
| D-PHY Clock Mode                   | User-Input          | Continuous                         | In Continuous mode, the D-PHY Clock lanes are always in high speed.                                                                             |
|                                    |                     | Non-continuous                     | In Non-continuous mode, the clock lane goes back to LP-11 state in between high speed transactions. this reduces power when the lane is idle.   |
| Reference Clock Frequency          | User-Input          | 24–150                             | Reference clock for the D-PHy PLL. Refer to the D-PHY TX PLL section for more details regarding the PLL requirements.                           |
| Generated TX Line Rate             | Read-Only           | <value></value>                    | The actual line rate generated by the D-PHY PLL based on the target line rate and reference clock frequency                                     |
| Generated TX Data Rate             | Read-Only           | <value></value>                    | The actual line rate multiplied by the number of data lanes.                                                                                    |
| Generated D-PHY Clock<br>Frequency | Read-Only           | <value></value>                    | The expected frequency of the D-PHY clock when in high speed mode.                                                                              |
| Generated Byte Clock<br>Frequency  | Read-Only           | <value></value>                    | The actual line rate divided by the Tx gear. This is the clock used by the logic within the submodule IP                                        |
| Deviation from Target<br>Values    | Read-Only           | <value></value>                    | Shows the deviation of the actual from the target rates.                                                                                        |
| FIFO Depth                         | User-Input<br>(DSI) | Must be greater than or equal to 8 | FIFO depth of the DSI packet formatter data buffer. The FIFO width is the width of the parallel data (gear*number of lanes)                     |
| FIFO Type                          | User-Input<br>(DSI) | EBR, LUT                           | FIFO implementation of the DSI packet formatter data buffer.                                                                                    |
| tINIT_SLAVE Value                  | User-Input          | <value></value>                    | Specify delay time for Tx D-PHY tINIT requirement. Must satisfy Tx D-PHY tINIT minimum requirement of 100 $\mu$ s and is clocked by byte clock. |
| Disable tINIT counter              | User-Input          | Enable<br>Disable                  | Enable or disable tINIT counter for resource utilization.                                                                                       |
| Disable Packet formatter           | User-Input          | Enable<br>Disable                  | Enable or disable packet formatter module.                                                                                                      |
| Enable Frame number increment      | User-Input          | Enable<br>Disable                  | Enable or disable frame number increment in packet formatter for CSI-2 interface.                                                               |
| Enable Line number increment       | User-Input          | Enable<br>Disable                  | Enable or disable line number increment in packet formatter for CSI-2 interface.                                                                |



| Parameter     | Attribute  | Options         | Description                                                |
|---------------|------------|-----------------|------------------------------------------------------------|
| TLPX          | User-Input | <value></value> | D-PHY Global Operation Timing parameters. Refer to section |
| Clock Prepare |            |                 | 6.9 of MIPI D-PHY Specification v1.1.                      |
| Clock HS-zero |            |                 |                                                            |
| Clock Pre     |            |                 |                                                            |
| Clock Post    |            |                 |                                                            |
| Clock Trail   |            |                 |                                                            |
| Clock Exit    |            |                 |                                                            |
| Data Prepare  |            |                 |                                                            |
| Data HS-Zero  |            |                 |                                                            |
| Data Trail    |            |                 |                                                            |
| Data Exit     |            |                 |                                                            |



# 4. IP Generation and Evaluation

This section provides information on how to generate the Lattice D-PHY Transmitter Submodule IP code using the Lattice Diamond Clarity Designer and how to run simulation, synthesis, and hardware evaluation.

## 4.1. Licensing the IP

The D-PHY Transmitter IP is available free of charge, but an IP-specific license is required to enable full, unrestricted use of the D-PHY Transmitter IP in a complete, top level design.

Request your license by going to the link <a href="http://www.latticesemi.com/en/Support/Licensing">http://www.latticesemi.com/en/Support/Licensing</a> and request the free Lattice Diamond license. In this form, select the desired CrossLink/CrossLinkPlus IP for your design.

You may download and generate the D-PHY Transmitter IP and fully evaluate the IP through functional simulation and implementation (synthesis, map, place and route) without an IP license. The D-PHY Transmitter IP also supports Lattice IP hardware evaluation capability, see the Hardware Evaluation section for further details.

HOWEVER, THE IP LICENSE IS REQUIRED TO ENABLE TIMING SIMULATION, TO OPEN THE DESIGN IN DIAMOND EPIC TOOL, OR TO GENERATE BITSTREAMS THAT DO NOT INCLUDE THE HARDWARE EVALUATION TIMEOUT LIMITATION.

# 4.2. Getting Started

The D-PHY Transmitter IP is available for download from the Lattice IP Server using the Clarity Designer tool. The IP files are automatically installed using ispUPDATE technology in any customer-specified directory. After the IP is installed, the IP is available in the Clarity Designer user interface as shown in Figure 4.1.



Figure 4.1. Clarity Designer Window



## 4.3. Generating IP in Clarity Designer

The Clarity Designer tool is used to customize modules and IPs and place them into the device architecture. Besides configuration and generation of modules and IPs, Clarity Designer can also create a top module template in which all generated modules and IPs are instantiated.

The procedure for generating D-PHY Transmitter IP in Clarity Designer is described below.

Clarity Designer can be started from the Diamond design environment.

To start Clarity Designer:

- 1. Create a new Diamond project for CrossLink or CrossLinkPlus family devices.
- From the Diamond main window, choose Tools > Clarity Designer, or click in Diamond toolbox. The Clarity Designer project dialog box is displayed.
- 3. Select and/or fill out the following items as shown in Figure 4.2.
  - Create new Clarity design Select this to create a new Clarity Design project directory in which the D-PHY
    Transmitter IP is generated.
  - **Design Location** Clarity Design project directory path.
  - **Design Name** Clarity Design project name.
  - HDL Output Hardware Description Language Output Format (Verilog HDL).

The Clarity Designer project dialog box also allows you to open an existing Clarity Designer project by selecting the following:

- Open Clarity design Open an existing Clarity Design project.
- Design File Name of existing Clarity Design project file with .sbx extension.
- 4. Click the Create button. A new Clarity Designer project is created.



Figure 4.2. Starting Clarity Designer from Diamond Design Environment



#### To configure D-PHY Transmitter IP in Clarity Designer:

1. Double-click **csi-2/dsi d-phy transmitter** in the IP list of the System Catalog view. The **csi-2/dsi d-phy transmitter** dialog box is displayed as shown in Figure 4.3.



Figure 4.3. Configuring D-PHY Transmitter IP in Clarity Designer

- 2. Enter the Instance Name.
- 3. Click the **Customize** button. An IP configuration interface is displayed as shown in Figure 4.4. From this dialog box, you can select the IP configuration specific to your application.
- 4. Input valid values in the required fields in the **Configuration** tab.





Figure 4.4. Configuration Tab in IP User Interface

- 5. Go to **Protocol Timing Parameters** tab. The values shown are automatically computed. You can enter other valid values if customization is desired.
- 6. After selecting the required parameters, click the **Configure** button.
- 7. Click Close.
- 8. Click Generate in the toolbox. Clarity Designer generates all the IPs and modules, and creates a top module to wrap them.

For detailed instructions on how to use the Clarity Designer, refer to the Lattice Diamond software user guide.



FPGA-IPUG-02024-1.6



Figure 4.5. Protocol Timing Parameter Tab in IP User Interface

22



## 4.4. Generated IP Directory Structure and Files

Figure 4.6 shows the directory structure of generated IP and supporting files.



Figure 4.6. D-PHY Transmitter IP Directory Structure

The design flow for the IP created with Clarity Designer uses a post-synthesized module (NGO) for synthesis and a protected model for simulation. The post-synthesized module and protected model are customized when you configure the IP and created automatically when the IP is generated.

Table 4.1 provides a list of key files and directories created by Clarity Designer and how they are used. The post-synthesized module (NGO), the protected simulation model, and all other files are also generated based on your configuration and are provided as examples to use or evaluate the IP.

Table 4.1. Files Generated in Clarity Designer

| File                                               | Description                                                                                                                                                                                                                                                                                                                |
|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <instance_name>.v</instance_name>                  | Verilog top-level module of D-PHY Transmitter IP used for both synthesis and simulation.                                                                                                                                                                                                                                   |
| <instance_name>_*.v</instance_name>                | Verilog submodules for simulation. Files that do not have equivalent black box modules are also used for synthesis.                                                                                                                                                                                                        |
| <pre><instance_name>_*_beh.v</instance_name></pre> | Protected Verilog models for simulation.                                                                                                                                                                                                                                                                                   |
| <instance_name>_*_bb.v</instance_name>             | Verilog black box modules for synthesis.                                                                                                                                                                                                                                                                                   |
| <instance_name>_*.ngo</instance_name>              | User interface configured and synthesized modules for synthesis.                                                                                                                                                                                                                                                           |
| <instance_name>_params.v</instance_name>           | Verilog parameters file that contains required compiler directives to successfully configure IP during synthesis and simulation.                                                                                                                                                                                           |
| <instance_name>.lpc</instance_name>                | Lattice Parameters Configuration file. This file records all the IP configuration options set through Clarity Designer. It is used by IP generation script to generate configuration-specific IP. It is also used to reload parameter settings in the IP user interface in Clarity Designer when it is being reconfigured. |
| <instance_name>_wrap.v</instance_name>             | Evaluation top-level module for reduced number of pinlist. Use this as the top-level module for Map and PAR evaluation purposes only.                                                                                                                                                                                      |
| <instance_name>_inst.v/vhd</instance_name>         | Template for instantiating the generated soft IP top-level in another user-created top module.                                                                                                                                                                                                                             |

Aside from the files listed in the tables, most of the files required to evaluate the D-PHY Transmitter IP are available under the directory \<dphytx\_eval>. This includes the simulation model. Lattice Diamond project files are also included under the folder at \<dphytx\_eval>\<instance\_name>\impl\<device\_family>\<synthesis\_tool>\, where <device\_family> can either be lifmd for CrossLink or lifmdf for CrossLinkPlus devices.



The \<instance\_name> folder contains files/folders with content specific to the <instance\_name> configuration. This directory is created by Clarity Designer each time the IP is generated and regenerated with the same file name. A separate \<instance\_name> directory is generated for IPs with different names, such as \<my\_IP\_0>,\<my\_IP\_1>, and others.

The folder\<instance\_name>, the \dphytx\_eval and sub directories provide files supporting D-PHY Transmitter IP evaluation that includes files/folders with content that is constant for all configurations of the D-PHY Transmitter IP. The \dphytx\_eval directory is created by Clarity Designer the first time the IP is generated, when multiple D-PHY Transmitter IPs are generated in the same root directory and updated each time the IP is regenerated.

You can use the prebuilt Diamond projects provided at

\cproject\_root>\dphytx\_eval\<instance\_name>\impl\<device\_family>\<synthesis\_tool>\ to evaluate the implementation (synthesis, map, place and route) of the IP in Lattice Diamond tool. This replaces the <instance\_name>.v with the dummy evaluation module <instance\_name>\_wrap.v to reduce the pin list so that Map and PAR pass. The src directory contains the behavioral models of the black-boxed modules and the models directory provides library elements.



# 4.5. Running Functional Simulation

To run simulations using Active-HDL:

- 1. Under the Tools menu in Diamond, select Active-HDL.
- 2. In Active-HDL window, under the Tools tab, select Execute Macro.
- 3. Select the .do file \roject\_dir>\dphytx\_eval\<instance\_name>\sim\aldec\\*\_run.do.
- 4. Click OK.
- 5. Wait for simulation to finish.
- 6. To override default TB parameters, modify the \project\_dir>\dphytx\_eval\testbench\tb\_setup\_params.v file.

**Table 4.2. Testbench Compiler Directives** 

| Compiler Directive          | Description                                                                                             |
|-----------------------------|---------------------------------------------------------------------------------------------------------|
| NUM_BYTES                   | Number of bytes per line.                                                                               |
| NUM_LINES                   | Number of lines per frame.                                                                              |
| NUM_FRAMES                  | Number of frames to be transmitted.                                                                     |
| DATA_TYPE                   | 6-bits value of data type to be transmitted.                                                            |
| DEBUG_ON                    | Enable debug messages.                                                                                  |
| EOTP_ENABLE                 | Enable EoTP in DSI mode.                                                                                |
| LS_LE_EN                    | Enable model transmission of LS and LE short packet in CSI-2 mode.                                      |
| VIRTUAL_CHANNEL             | Set virtual channel.                                                                                    |
| HSYNC_PULSE_FRONT           | Number of HSYNC pulses before data transmission.                                                        |
| HSYNC_PULSE_BACK            | Number of HSYNC pulses after data transmission.                                                         |
| HS_RDY_NEG_TO_HS_CLK_EN_DLY | Delay from d_hs_en negation to next d_hs_rdy_o assertion.                                               |
| HS_RDY_TO_BYTE_DATA_EN_DLY  | Delay from d_hs_en assertion to byte_data_en assertion.                                                 |
| HS_RDY_TO_DPHY_PKTEN_DLY    | Delay from d_hs_en assertion to dphy_pkten assertion.                                                   |
| HS_RDY_TO_HSYNC_START_DLY   | Delay from d_hs_en assertion to hsync_start assertion.                                                  |
| HS_RDY_TO_VSYNC_START_DLY   | Delay from d_hs_en assertion to vsync_start assertion.                                                  |
| HS_RDY_TO_LP_EN_DLY         | Delay from d_hs_en assertion to lp_en assertion.                                                        |
| HS_RDY_TO_SP_EN_DLY         | Delay from d_hs_en assertion to sp_en assertion.                                                        |
| LP_EN_TO_BYTE_DATA_EN_DLY   | Delay from Ip_en pulse to byte_data_en assertion.                                                       |
| HSYNC_TO_HSYNC_DLY          | Delay from hsync to next hsync packet transmission.                                                     |
| VSYNC_TO_HSYNC_DLY          | Delay from vsync to next hsync packet transmission.                                                     |
| TINIT_DURATION              | Used when MISC_ON is not defined. This is for setting the wait time duration (in ps) of tINIT ROM done. |



## 4.6. Simulation Strategies

This section describes the simulation environment, which demonstrates basic D-PHY Transmitter functionality. Figure 4.7 shows the block diagram of simulation environment.

#### Testbench



Figure 4.7. Simulation Environment Block Diagram

### 4.7. Simulation Environment

The simulation environment is made up of an input driver instance connected to the input of CSI-2/DSI D-PHY Transmitter IP Core instance in the testbench. The input driver is configured based on CSI-2/DSI D-PHY Transmitter IP Core configurations and testbench parameters. It can be configured to drive data up to 8 bytes per clock cycle depending on the number of D-PHY Tx lanes and Tx gearing.

The input driver can also be configured to drive control signals specific to DSI and CSI-2. If miscellaneous signals are enabled, the testbench waits for tinit\_done assertion before transmitting byte data. Otherwise, a user-configurable delay (tinit\_duration) can be used to ensure that initialization is done before testbench transmits byte data. Refer to the *tb setup params.v* file for different testbench parameters that can be used to control the simulation.

Figure 4.8 shows the CSI-2/DSI D-PHY Transmitter IP core configured as CSI-2 transmitter. Packet transmissions are controlled by driving sp\_en for short packets such as frame start, frame end, line start and line end packets. The lp\_en signal is used to drive data packets together with byte\_data\_en, byte\_en and other control signals.



Figure 4.8 D-PHY Tx configured as CSI-2 Transmitter

Figure 4.9 shows the D-PHY Transmitter IP core configured as DSI transmitter. Sync packets are controlled by driving vsync\_start, hsync\_start signals. Data transmissions are controlled by driving byte\_data\_en, byte\_data input bus with other control signals.





Figure 4.9. D-PHY Tx configured as DSI Transmitter

## 4.8. Instantiating the IP

The core modules of the CSI-2/DSI D-PHY Transmitter IP are synthesized and provided in NGO format with black box Verilog source files for synthesis. A Verilog source file named <instance\_name>\_dphy\_tx.v instantiates the black box of core modules. The top-level file <instance\_name>.v instantiates <instance\_name>\_dphy\_tx.v.

A Verilog instance template <instance\_name>\_inst.v or VHDL instance template <instance\_name>\_inst.vhd is also provided as a guide if the design is to be included in another top level module.

You do not need to instantiate the IP instances one by one manually. The top-level file and other Verilog source files are provided in \project dir>. These files are refreshed each time the IP is regenerated.

# 4.9. Synthesizing and Implementing the IP

In Clarity Designer, the Clarity Designer project file (.sbx) is added to Lattice Diamond as a source file after all IPs are generated. Note that default Diamond strategy (.sty) and default Diamond preference file (.lpf) are used. When using the .sbx approach, import the recommended strategy and preferences from

\|c\_dir>\dphytx\_eval\<instance\_name>\impl\<device\_family>\lse or

\cproject\_dir>\dphytx\_eval\<instance\_name>\impl\<device\_family>\synplify directories. All required files are invoked automatically. You can directly synthesize, map and place/par the design in the Diamond design environment after the cores are generated.

Push-button implementation of this top-level design with either Synplify or Lattice Synthesis Engine is supported via the Diamond project files <instance\_name>\_top.ldf, which is located in the

\cproject\_dir>\dphytx\_eval\<instance\_name>\impl\<device\_family>\<synthesis\_tool>\ directory.

To use the pre-built Diamond project files:

- 1. Choose File > Open > Project.
- In the Open Project dialog box, browse to \<project\_dir>\dphytx\_eval\<instance\_name>\impl\<device\_family>\<synthesis\_tool>\.
- 3. Select and open <instance\_name>\_top.ldf. At this point, all of the files needed to support top-level synthesis and implementation are imported to the project.
- 4. Select the **Process** tab in the left-hand user interface window.
- 5. Implement the complete design via the standard Diamond user interface flow.



### 4.10. Hardware Evaluation

The CSI-2/DSI D-PHY Transmitter IP supports Lattice IP hardware evaluation capability. You can create versions of the IP that operate in hardware for a limited period of time without requiring the request of an IP license. It may also be used to evaluate the IP in hardware in user-defined designs.

#### 4.10.1. Enabling Hardware Evaluation in Diamond

Choose **Project** > **Active Strategy** > **Translate Design Settings**. The hardware evaluation capability may be enabled or disabled in the **Strategy** dialog box. It is enabled by default.

## 4.11. Updating/Regenerating the IP

The Clarity Designer interface allows you to update the local IPs from the Lattice IP server. The updated IP can be used to regenerate the IP in the design. To change the parameters of the IP used in the design, the IP must also be regenerated.

### 4.11.1. Regenerating an IP in Clarity Designer

To regenerate IP in Clarity Designer:

 In the Builder tab, right-click the IP instance to be regenerated and select Config from the menu as shown in Figure 4.10.



Figure 4.10. IP Regeneration in Clarity Designer

- 2. The IP Configuration user interface is displayed. Change the parameters as required and click the **Configure** button.
- 3. Click Senerate I in the toolbox. Clarity Designer regenerates all the instances which are reconfigured.



# References

For more information about CrossLink and CrossLinkPlus devices, refer to CrossLink Family Data Sheet (FPGA-DS-02007) and CrossLinkPlus Family Data Sheet (FPGA-DS-02054).

#### Software documentation:

- Clarity Designer User Manual
- Lattice Diamond User Guide

For further information on interface standards, refer to:

- MIPI Alliance Specification for D-PHY, version 1.1, November 7, 2011, www.mipi.org
- MIPI Alliance Specification for Display Serial Interface, version 1.1, November 22, 2011, www.mipi.org
- MIPI Alliance Specification for Camera Serial Interface 2 (CSI-2), version 1.1, July 18, 2012, www.mipi.org

# **Technical Support Assistance**

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



# **Appendix A. Resource Utilization**

Table A.1 lists resource utilization information for Lattice CrossLink FPGA using the CSI-2/DSI D-PHY Transmitter IP. Clarity Designer is the Lattice IP configuration utility, and is included as a standard feature of the Diamond tool. For details about the usage of Clarity Designer, refer to the Clarity Designer and Diamond help system.

For more information on the Diamond design tools, visit the Lattice web site at www.latticesemi.com/Products/DesignSoftwareAndIP.

Table A.1. Resource Utilization<sup>1, 3</sup>

| IP User-Configurable Parameters | Registers | Slices | LUTs | sysMEM<br>EBRs | MIPI<br>D-PHY | Target f <sub>MAX</sub> (MHz) <sup>2</sup> | Actual f <sub>MAX</sub><br>(MHz) <sup>2</sup> |
|---------------------------------|-----------|--------|------|----------------|---------------|--------------------------------------------|-----------------------------------------------|
| CSI-2 Gear 16                   | •         |        |      |                |               |                                            |                                               |
| 4-lane<br>Non-continuous clock  | 517       | 987    | 1496 | 0              | 1             | 93.75                                      | 114.71                                        |
| 2-lane<br>Non-continuous clock  | 364       | 605    | 936  | 0              | 1             | 93.75                                      | 103.91                                        |
| 1-lane<br>Non-continuous clock  | 309       | 484    | 758  | 0              | 1             | 93.75                                      | 133.35                                        |
| 4-lane<br>Continuous clock      | 509       | 937    | 1433 | 0              | 1             | 93.75                                      | 122.91                                        |
| 2-lane<br>Continuous clock      | 356       | 561    | 873  | 0              | 1             | 93.75                                      | 108.86                                        |
| 1-lane<br>Continuous clock      | 301       | 443    | 695  | 0              | 1             | 93.75                                      | 129.87                                        |
| CSI-2 Gear 8                    |           |        | •    |                | •             | •                                          |                                               |
| 4-lane<br>Non-continuous clock  | 519       | 648    | 989  | 0              | 1             | 150                                        | 152.55                                        |
| 2-lane<br>Non-continuous clock  | 336       | 452    | 699  | 0              | 1             | 150                                        | 154.27                                        |
| 1-lane<br>Non-continuous clock  | 276       | 385    | 587  | 0              | 1             | 150                                        | 149.99                                        |
| 4-lane<br>Continuous clock      | 511       | 620    | 947  | 0              | 1             | 150                                        | 152.93                                        |
| 2-lane<br>Continuous clock      | 328       | 424    | 657  | 0              | 1             | 150                                        | 153.61                                        |
| 1-lane<br>Continuous clock      | 268       | 357    | 545  | 0              | 1             | 150                                        | 150.83                                        |
| DSI Gear 16                     |           |        |      |                |               |                                            |                                               |
| 4-lane<br>Non-continuous clock  | 656       | 2901   | 5548 | 0              | 1             | 93.75                                      | 109                                           |
| 2-lane<br>Non-continuous clock  | 438       | 1617   | 2960 | 0              | 1             | 93.75                                      | 132.2                                         |
| 1-lane<br>Non-continuous clock  | 334       | 937    | 1683 | 0              | 1             | 93.75                                      | 117.84                                        |
| 4-lane<br>Continuous clock      | 648       | 2856   | 5485 | 0              | 1             | 93.75                                      | 109.23                                        |
| 2-lane<br>Continuous clock      | 430       | 1573   | 2897 | 0              | 1             | 93.75                                      | 135.46                                        |
| 1-lane<br>Continuous clock      | 326       | 896    | 1620 | 0              | 1             | 93.75                                      | 128.09                                        |



| IP User-Configurable<br>Parameters | Registers | Slices | LUTs | sysMEM<br>EBRs | MIPI<br>D-PHY | Target f <sub>MAX</sub><br>(MHz) <sup>2</sup> | Actual f <sub>MAX</sub><br>(MHz) <sup>2</sup> |
|------------------------------------|-----------|--------|------|----------------|---------------|-----------------------------------------------|-----------------------------------------------|
| DSI Gear 8                         | •         |        |      |                |               |                                               |                                               |
| 4-lane<br>Non-continuous clock     | 659       | 2676   | 5125 | 0              | 1             | 112.5                                         | 118                                           |
| 2-lane<br>Non-continuous clock     | 447       | 1546   | 2836 | 0              | 1             | 150                                           | 157.11                                        |
| 1-lane<br>Non-continuous clock     | 331       | 834    | 1513 | 0              | 1             | 93.75                                         | 120.12                                        |
| 4-lane<br>Continuous clock         | 651       | 2653   | 5083 | 0              | 1             | 93.75                                         | 103.85                                        |
| 2-lane<br>Continuous clock         | 439       | 1518   | 2794 | 0              | 1             | 150                                           | 150.92                                        |
| 1-lane<br>Continuous clock         | 323       | 806    | 1471 | 0              | 1             | 112.5                                         | 128.32                                        |

#### Notes:

- 1. Performance and utilization data target an LIF-MD6000-6MG81I device using Lattice Diamond 3.9 and Lattice Synthesis Engine software. Performance may vary when using a different software version or targeting a different device density or speed grade within the CrossLink family. This does not show all possible configurations of the D-PHY Transmitter IP.
- 2. The f<sub>MAX</sub> values are based on byte clock and may vary depending on the complete top level-design.
- 3. The distributed RAM utilization is accounted for in the total LUT4 utilization. The actual LUT4 utilization is distribution among logic, distributed RAM, and ripple logic.



# Appendix B. What is Not Supported

The IP does not support configuration through registers.

32



# **Appendix C. PLL Programming**

# Table C.1. 5-Bit Input Divider

| N  | CN[4:0] |
|----|---------|
| 1  | 11111   |
| 2  | 00000   |
| 3  | 10000   |
| 4  | 11000   |
| 5  | 11100   |
| 6  | 01110   |
| 7  | 00111   |
| 8  | 10011   |
| 9  | 01001   |
| 10 | 00100   |
| 11 | 00010   |
| 12 | 10001   |
| 13 | 01000   |
| 14 | 10100   |
| 15 | 01010   |
| 16 | 10101   |
| 17 | 11010   |
| 18 | 11101   |
| 19 | 11110   |
| 20 | 01111   |
| 21 | 10111   |
| 22 | 11011   |
| 23 | 01101   |
| 24 | 10110   |
| 25 | 01011   |
| 26 | 00101   |
| 27 | 10010   |
| 28 | 11001   |
| 29 | 01100   |
| 30 | 00110   |
| 31 | 00011   |
| 32 | 00001   |



Table C.2. 8-Bit Feedback Divider

| Table C | .2. 8-Bit Feedb |
|---------|-----------------|
| DVR     | CM[7:0]         |
| 16      | 111X0000        |
| 17      | 111X0001        |
| 18      | 111X0010        |
| 19      | 111X0011        |
| 20      | 111X0100        |
| 21      | 111X0101        |
| 22      | 111X0110        |
| 23      | 111X0111        |
| 24      | 111X1000        |
| 25      | 111X1001        |
| 26      | 111X1010        |
| 27      | 111X1011        |
| 28      | 111X1100        |
| 29      | 111X1101        |
| 30      | 111X1110        |
| 31      | 111X1111        |
| 32      | 11000000        |
| 33      | 11000001        |
| 34      | 1100001         |
| 35      | 11000011        |
| 36      | 1100011         |
| 37      | 11000100        |
| 38      | 11000101        |
| 39      |                 |
|         | 11000111        |
| 40      | 11001000        |
| 41      | 11001001        |
| 42      | 11001011        |
| 43      | 11001011        |
| 44      | 11001100        |
| 45      | 11001101        |
| 46      | 11001110        |
| 47      | 11001111        |
| 48      | 11010000        |
| 49      | 11010001        |
| 50      | 11010010        |
| 51      | 11010011        |
| 52      | 11010100        |
| 53      | 11010101        |
| 54      | 11010110        |
| 55      | 11010111        |
| 56      | 11011000        |
| 57      | 11011001        |
| 58      | 11011010        |
| 59      | 11011011        |
| 60      | 11011100        |
| 61      | 11011101        |
| 62      | 11011110        |
|         |                 |

| k Divide | r        |
|----------|----------|
| DVR      | CM[7:0]  |
| 64       | 10000000 |
| 65       | 10000001 |
| 66       | 10000010 |
| 67       | 10000011 |
| 68       | 10000100 |
| 69       | 10000101 |
| 70       | 10000110 |
| 71       | 10000111 |
| 72       | 10001000 |
| 73       | 10001001 |
| 74       | 10001010 |
| 75       | 10001011 |
| 76       | 10001100 |
| 77       | 10001101 |
| 78       | 10001110 |
| 79       | 10001111 |
| 80       | 10010000 |
| 81       | 10010001 |
| 82       | 10010010 |
| 83       | 10010011 |
| 84       | 10010100 |
| 85       | 10010101 |
| 86       | 10010110 |
| 87       | 10010111 |
| 88       | 10011000 |
| 89       | 10011001 |
| 90       | 10011010 |
| 91       | 10011011 |
| 92       | 10011100 |
| 93       | 10011101 |
| 94       | 10011110 |
| 95       | 10011111 |
| 96       | 10100000 |
| 97       | 10100001 |
| 98       | 10100010 |
| 99       | 10100011 |
| 100      | 10100100 |
| 101      | 10100101 |
| 102      | 10100110 |
| 103      | 10100111 |
| 104      | 10101000 |
| 105      | 10101001 |
| 106      | 10101010 |
| 107      | 10101011 |
| 108      | 10101100 |
| 109      | 10101101 |
| 110      | 10101110 |
|          |          |

| DVR | CM[7:0]   |
|-----|-----------|
| 112 | 10110000  |
| 113 | 10110001  |
| 114 | 10110010  |
| 115 | 10110011  |
| 116 | 10110100  |
| 117 | 10110101  |
| 118 | 10110110  |
| 119 | 10110111  |
| 120 | 10111000  |
| 121 | 10111001  |
| 122 | 10111010  |
| 123 | 10111011  |
| 124 | 10111100  |
| 125 | 10111101  |
| 126 | 10111110  |
| 127 | 10111111  |
| 128 | 00000000  |
| 129 | 00000001  |
| 130 | 00000010  |
| 131 | 00000011  |
| 132 | 00000100  |
| 133 | 00000101  |
| 134 | 00000110  |
| 135 | 00000111  |
| 136 | 00001000  |
| 137 | 00001001  |
| 138 | 00001010  |
| 139 | 00001011  |
| 140 | 000011100 |
| 141 | 00001100  |
| 142 | 00001101  |
| 143 | 00001110  |
| 143 | 0001111   |
| 145 | 00010000  |
| 145 | 00010001  |
| 146 | 00010010  |
| 147 |           |
|     | 00010100  |
| 149 | 00010101  |
| 150 | 00010110  |
| 151 | 00010111  |
| 152 | 00011000  |
| 153 | 00011001  |
| 154 | 00011010  |
| 155 | 00011011  |
| 156 | 00011100  |
| 157 | 00011101  |
| 158 | 00011110  |
|     |           |

| DVR         CM[7:0]           160         00100000           161         00100001           162         00100011           163         00100011           164         00100100           165         00100110           166         00100110           167         00101000           169         00101001           170         0010101           171         0010100           173         0010110           174         0010110           175         0010111           176         0011000           177         0011000           178         00110010           179         0011001           179         0011001           180         0011010           181         0011010           182         0011010           183         0011010           184         0011101           185         0011100           186         0011100           187         0011101           189         0011110           190         0011110           191         0010010 <t< th=""><th></th><th></th></t<>                          |     |          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------|
| 161         00100001           162         00100010           163         00100011           164         00100101           165         00100110           166         00100110           167         00100100           168         00101001           170         00101010           171         0010101           172         00101100           173         00101101           174         00101101           175         00101111           176         00110000           177         00110001           178         00110010           179         00110011           180         00110100           181         0011010           182         0011010           183         0011010           184         00111001           185         00111001           186         00111001           187         0011101           188         00111101           199         0100000           194         01000000           195         01000001           196         01000010                                             | DVR | CM[7:0]  |
| 162         00100010           163         00100011           164         00100100           165         00100101           166         00100110           167         00100110           168         00101000           169         00101001           170         00101010           171         00101100           173         00101101           174         00101101           175         00101110           176         0010000           177         00110000           178         00110010           180         00110010           181         0011010           182         0011010           183         0011010           184         0011010           185         0011100           186         0011100           187         0011101           188         00111101           189         00111101           190         00111110           191         0010000           193         01000001           194         01000001           195         01000010 <tr< td=""><td>160</td><td>00100000</td></tr<> | 160 | 00100000 |
| 163         00100011           164         00100100           165         00100101           166         00100110           167         00100110           168         00101000           169         00101001           170         00101001           171         00101100           173         00101101           174         00101101           175         00101111           176         00110000           177         00110001           178         00110010           179         00110010           180         00110100           181         0011010           182         0011010           183         0011010           184         00111000           185         00111001           186         00111001           187         0011101           188         00111101           199         0100000           193         01000000           193         01000001           194         01000010           195         01000101           199         01000110                                            | 161 | 00100001 |
| 164         00100100           165         00100101           166         00100110           167         00100110           168         00101000           169         00101001           170         00101001           171         00101100           173         00101101           174         00101101           175         00101111           176         00110000           177         00110001           178         00110010           179         00110010           181         0011010           182         0011010           183         0011010           184         0011010           185         00111001           186         00111001           187         0011101           188         00111001           189         00111101           190         00111110           191         00111111           192         01000000           193         01000000           194         01000010           195         01000010           197         01000010                                            | 162 | 00100010 |
| 165         00100101           166         00100110           167         00100110           168         00101000           169         00101001           170         00101010           171         00101010           173         00101101           174         00101101           175         00101111           176         00110000           177         00110010           178         00110010           179         00110010           181         0011010           182         00110110           183         00110110           184         00111000           185         00111001           186         00111001           187         00111001           188         00111101           189         00111101           190         00111110           191         00111111           192         01000000           193         01000001           194         01000010           195         01000011           196         01000100           197         01000101                                        | 163 | 00100011 |
| 166         00100110           167         00100110           168         00101000           169         00101001           170         00101001           171         00101100           173         00101101           174         00101101           175         00101111           176         00110000           177         00110001           178         00110010           179         00110010           179         0011010           180         00110100           181         0011010           182         0011010           183         00110110           184         00111000           185         00111001           186         00111010           187         0011101           188         00111101           199         00111101           190         00111110           191         00111111           192         01000000           193         01000001           194         01000010           195         01000010           197         01000101                                           | 164 | 00100100 |
| 167         00100110           168         00101000           169         00101001           170         00101001           171         00101100           172         00101100           173         00101101           174         00101111           175         00101111           176         00110000           177         00110010           178         00110010           179         00110010           180         00110100           181         0011010           182         0011010           183         0011010           184         00111000           185         00111001           186         00111001           187         0011101           188         0011100           189         00111101           190         00111110           191         00111111           192         01000000           193         01000001           194         01000010           195         01000011           196         01000100           197         01000101                                            | 165 | 00100101 |
| 168         00101000           169         00101001           170         00101010           171         00101010           172         00101100           173         00101101           174         00101111           175         00101111           176         00110000           177         00110010           178         00110010           179         00110010           181         00110100           182         0011010           183         0011010           184         00111001           185         00111001           186         00111001           187         0011101           188         0011100           189         00111101           190         00111101           191         00111101           192         01000000           193         01000000           194         01000001           195         01000010           197         01000010           198         01000110           199         01000101           201         01001001                                           | 166 | 00100110 |
| 169         00101001           170         00101010           171         00101010           172         00101100           173         00101101           174         00101111           175         00101111           176         00110000           177         00110010           178         00110010           180         0011010           181         0011010           182         00110110           183         00110110           184         00111001           185         00111001           187         00111010           188         00111010           189         00111101           190         00111101           191         00111110           192         01000000           193         01000000           194         01000000           195         01000010           196         01000100           197         01000101           198         01000110           199         01000110           201         01001001           202         01001001                                         | 167 | 00100110 |
| 170         00101010           171         00101011           172         00101100           173         00101101           174         00101111           175         00101111           176         00110000           177         00110001           178         00110010           179         00110010           180         00110100           181         0011010           182         00110110           183         00110101           184         00111000           185         00111001           186         00111010           187         00111011           188         00111101           199         00111101           190         00111110           191         00111111           192         01000000           193         01000000           194         01000001           195         01000010           197         01000101           198         01000110           199         01000110           201         01001000           201         01001001                                        | 168 | 00101000 |
| 171         00101011           172         00101100           173         00101101           174         00101111           175         00101111           176         00110000           177         00110010           178         00110010           179         0011010           181         0011010           182         00110110           183         00110110           184         00111001           185         00111001           186         00111010           187         00111011           188         00111101           199         00111110           191         00111111           192         01000000           193         01000000           193         01000001           195         01000010           197         01000010           198         01000110           199         01000111           200         01001000           201         01001001           202         01001001           203         01001011           204         01001100                                         | 169 | 00101001 |
| 172         00101100           173         00101101           174         00101111           175         00101111           176         00110000           177         00110010           178         00110010           179         00110100           181         00110100           182         00110110           183         00110110           184         00111000           185         00111001           186         00111001           187         00111011           188         00111101           190         00111101           191         00111110           192         01000000           193         01000000           194         01000010           195         01000011           196         01000100           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001001           203         01001010           204         01001100 <td>170</td> <td>00101010</td>        | 170 | 00101010 |
| 173         00101101           174         00101110           175         00101111           176         00110000           177         00110010           178         00110010           179         00110101           180         00110100           181         0011010           182         00110110           183         00110111           184         00111000           185         00111001           186         00111010           187         0011101           188         00111101           199         00111111           190         00111110           191         00111111           192         01000000           193         01000000           194         01000010           195         01000010           197         01000101           198         01000110           199         01000110           201         01001000           201         01001001           202         01001001           203         01001011           204         01001100                                         | 171 | 00101011 |
| 174         00101110           175         00101111           176         00110000           177         00110001           178         00110010           179         00110011           180         00110100           181         0011010           182         00110110           183         00110111           184         00111000           185         00111010           187         00111010           188         00111010           189         00111101           190         00111110           191         00111111           192         01000000           193         01000000           194         01000010           195         01000011           196         01000100           197         01000110           199         01000111           200         01001000           201         01001001           202         01001001           203         01001011           204         01001100           205         01001101                                                                       | 172 | 00101100 |
| 175         00101111           176         00110000           177         00110001           178         00110010           179         00110010           181         00110101           182         00110110           183         00110111           184         00111000           185         00111001           186         00111001           187         00111011           188         00111101           190         00111101           191         00111110           192         01000000           193         01000000           194         01000001           195         01000010           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001001           203         01001011           204         01001100           205         01001101                                                                                                                                    | 173 | 00101101 |
| 176         00110000           177         00110001           178         00110010           179         00110011           180         00110100           181         00110110           182         00110111           184         0011000           185         00111001           186         00111001           187         0011101           188         00111101           190         00111101           191         00111110           192         01000000           193         01000000           194         01000010           195         01000011           196         01000100           197         01000101           198         01000110           200         01001000           201         01001001           202         01001001           203         01001011           204         01001100           205         01001101                                                                                                                                                                     | 174 | 00101110 |
| 176         00110000           177         00110001           178         00110010           179         00110011           180         00110100           181         00110110           182         00110111           184         0011000           185         00111001           186         00111001           187         0011101           188         00111101           190         00111101           191         00111110           192         01000000           193         01000000           194         01000010           195         01000011           196         01000100           197         01000101           198         01000110           200         01001000           201         01001001           202         01001001           203         01001011           204         01001100           205         01001101                                                                                                                                                                     | 175 | 00101111 |
| 178         00110010           179         00110011           180         00110100           181         00110101           182         00110110           183         00110111           184         00111000           185         00111001           186         00111010           187         00111011           188         00111101           190         00111110           191         00111110           192         01000000           193         01000000           194         01000010           195         01000011           196         01000100           197         01000101           198         01000110           200         01001000           201         01001001           202         01001001           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                  |     |          |
| 179         00110011           180         00110100           181         00110101           182         00110110           183         00110111           184         00111001           185         00111001           186         00111010           187         0011101           188         00111101           190         00111101           191         00111110           192         01000000           193         01000000           194         01000010           195         01000010           197         01000100           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                  | 177 | 00110001 |
| 179         00110011           180         00110100           181         00110101           182         00110110           183         00110111           184         00111001           185         00111001           186         00111010           187         0011101           188         00111101           190         00111101           191         00111110           192         01000000           193         01000000           194         01000010           195         01000010           197         01000100           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                  | _   |          |
| 180         00110100           181         00110101           182         00110110           183         00110111           184         00111000           185         00111010           186         00111011           188         0011100           189         00111101           190         00111101           191         00111111           192         01000000           193         01000001           194         01000010           195         01000011           196         01000100           197         01000101           198         01000110           200         01001000           201         01001001           202         01001001           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                 |     |          |
| 181         00110101           182         00110110           183         00110111           184         00111000           185         00111001           186         00111010           187         00111011           188         00111101           190         00111101           191         00111110           192         01000000           193         01000000           194         01000010           195         01000011           196         01000100           197         01000110           198         01000110           200         01001000           201         01001001           202         01001001           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                               |     |          |
| 182         00110110           183         00110111           184         00111000           185         00111001           186         00111010           187         00111011           188         00111101           189         00111101           190         00111110           191         00111111           192         01000000           193         01000001           194         01000010           195         01000011           196         01000100           197         01000101           198         01000110           200         01001000           201         01001001           202         01001001           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                               |     |          |
| 183         00110111           184         00111000           185         00111001           186         00111011           187         00111001           188         00111101           190         00111101           191         00111111           192         01000000           193         01000001           194         01000010           195         01000011           196         01000100           197         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                             |     |          |
| 184         00111000           185         00111001           186         00111010           187         00111011           188         00111101           189         00111101           190         00111111           191         00111111           192         01000000           193         01000001           195         01000010           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                            |     |          |
| 185         00111001           186         00111010           187         00111011           188         00111100           189         00111101           190         00111110           191         00111111           192         01000000           193         01000001           194         01000010           195         01000010           197         01000100           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                            |     |          |
| 186         00111010           187         00111011           188         00111101           189         00111101           190         00111110           191         00111111           192         01000000           193         01000001           194         01000010           195         01000010           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                           |     |          |
| 187         00111011           188         00111100           189         00111101           190         00111110           191         00111111           192         01000000           193         01000001           195         01000010           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |          |
| 188         00111100           189         00111101           190         00111110           191         00111111           192         01000000           193         01000001           194         01000010           195         01000100           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |          |
| 189         00111101           190         00111110           191         00111111           192         01000000           193         01000001           194         01000010           195         01000010           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |
| 190         00111110           191         00111111           192         01000000           193         01000001           194         01000010           195         01000010           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |          |
| 191         00111111           192         01000000           193         01000001           194         01000010           195         01000010           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |          |
| 192         01000000           193         01000001           194         01000010           195         01000010           196         01000100           197         01000110           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |          |
| 193         01000001           194         01000010           195         01000011           196         01000100           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |          |
| 194         01000010           195         01000011           196         01000100           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |          |
| 195         01000011           196         01000100           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |          |
| 196         01000100           197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |          |
| 197         01000101           198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |          |
| 198         01000110           199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |          |
| 199         01000111           200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |          |
| 200         01001000           201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |          |
| 201         01001001           202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |          |
| 202         01001010           203         01001011           204         01001100           205         01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |          |
| 203     01001011       204     01001100       205     01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |          |
| 204     01001100       205     01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |          |
| 205 01001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 203 |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |          |
| 206 01001110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 205 |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 206 | 01001110 |

| DVR | CM[7:0]  |
|-----|----------|
| 208 | 01010000 |
| 209 | 01010001 |
| 210 | 01010010 |
| 211 | 01010011 |
| 212 | 01010100 |
| 213 | 01010101 |
| 214 | 01010110 |
| 215 | 01010111 |
| 216 | 01011000 |
| 217 | 01011001 |
| 218 | 01011010 |
| 219 | 01011011 |
| 220 | 01011100 |
| 221 | 01011101 |
| 222 | 01011110 |
| 223 | 01011111 |
| 224 | 01100000 |
| 225 | 01100001 |
| 226 | 01100010 |
| 227 | 01100011 |
| 228 | 01100100 |
| 229 | 01100101 |
| 230 | 01100110 |
| 231 | 01100111 |
| 232 | 01101000 |
| 233 | 01101001 |
| 234 | 01101010 |
| 235 | 01101011 |
| 236 | 01101100 |
| 237 | 01101101 |
| 238 | 01101110 |
| 239 | 01101111 |
| 240 | 01110000 |
| 241 | 01110001 |
| 242 | 01110010 |
| 243 | 01110011 |
| 244 | 01110100 |
| 245 | 01110101 |
| 246 | 01110110 |
| 247 | 01110111 |
| 248 | 01111000 |
| 249 | 01111001 |
| 250 | 01111010 |
| 251 | 01111011 |
| 252 | 01111100 |
|     | •        |

253

254

01111101

01111110



| DVR | CM[7:0]  |
|-----|----------|
| 63  | 11011111 |

| DVR | CM[7:0]  |
|-----|----------|
| 111 | 10101111 |

| DVR | CM[7:0]  |
|-----|----------|
| 159 | 00011111 |

| DVR | CM[7:0]  |
|-----|----------|
| 207 | 01001111 |

| DVR | CM[7:0]  |
|-----|----------|
| 255 | 01111111 |

### Table C.3. 2-Bit Output Divider

| 0 | CO1 | CO0 |
|---|-----|-----|
| 1 | 0   | 0   |
| 2 | 0   | 1   |
| 4 | 1   | 0   |
| 8 | 1   | 1   |



# **Revision History**

### Revision 1.6, IP Version 1.4, April 2021

| Section                      | Change Summary                                                                                                                     |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Acronyms in This Document    | Added this section.                                                                                                                |
| Introduction                 | Updated IP design version to 1.4.                                                                                                  |
|                              | Updated burst mode, non-burst mode feature.                                                                                        |
| Functional Description       | Updated steps in the Input Interface section.                                                                                      |
|                              | <ul> <li>Added Packet Transmission when Packet Formatter is Disabled heading and moved<br/>contents under this section.</li> </ul> |
|                              | Added reference to Table 2.2. Byte Data Bus Assignments.                                                                           |
|                              | Updated statement in the Reset and Initialization section as follows:                                                              |
|                              | When set in DSI, until the DCS commands are sent to the display, valid data from the Application Processor may be lost.            |
|                              | • Corrected LS mode to LP mode in the Design and Module Description section.                                                       |
| Parameter Settings           | Updated Table 3.1. CSI-2/DSI D-PHY Tx Submodule IP Parameter Settings in User Interface.                                           |
| IP Generation and Evaluation | Updated Figure 4.2 to Figure 4.5.                                                                                                  |

#### Revision 1.5, IP Version 1.3, April 2021

| Section                     | Change Summary                                                                 |
|-----------------------------|--------------------------------------------------------------------------------|
| Functional Description      | Added reference to Appendix C. PLL Programming tables in D-PHY TX PLL section. |
| Appendix C. PLL Programming | Added this section.                                                            |

#### Revision 1.4, IP Version 1.3, July 2020

| Section                          | Change Summary                                                                                                                           |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                     | <ul> <li>Updated Table 1.1. CSI-2/DSI D-PHY Transmitter Submodule IP Quick Facts.</li> <li>Updated LUTs and Registers values.</li> </ul> |
|                                  | <ul> <li>Updated note.</li> </ul>                                                                                                        |
| Functional Description           | Corrected text alignment in Figure 2.9. D-PHY Transmitter Submodule Block Diagram.                                                       |
| Parameter Settings               | Added DPHY Clock Mode parameter in Table 3.1. CSI-2/DSI D-PHY Tx Submodule IP Parameter Settings in User Interface.                      |
| Appendix A. Resource Utilization | Updated Table A.1. Resource Utilization1.                                                                                                |



#### Revision 1.3, IP Version 1.3, March 2020

| Section                          | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                     | <ul> <li>Changed IP design version from 1.x to 1.3.</li> <li>Updated Table 1.1. CSI-2/DSI D-PHY Transmitter Submodule IP Quick Facts.</li> <li>Updated LUTs and Registers values.</li> <li>Updated note.</li> <li>Changed feature to Supports 1, 2, 3, or 4 MIPI D-PHY data lanes.</li> <li>Update number of Tx lanes options in Table 1.2. CSI-2/DSI D-PHY Transmitter Submodule IP Features Summary.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Functional Description           | <ul> <li>Added frame_max_i in Figure 2.1. CSI-2/DSI D-PHY Transmitter Submodule Top-level Block Diagram.</li> <li>Updated Table 2.1. D-PHY Transmitter Submodule IP Pin Function Description</li> <li>Updated the Short Packet Transmission and the Long Packet Transmission procedures.</li> <li>Updated the following figures:         <ul> <li>Figure 2.2. D-PHY Tx Input Bus for Short Packet Transmission</li> <li>Figure 2.3. D-PHY Tx Input Bus for Long Packet Transmission in CSI-2 Interface</li> <li>Figure 2.4. D-PHY Tx Input Bus for Long Packet Transmission in DSI Interface</li> <li>Figure 2.5. D-PHY Tx Input Bus for Long Packet Transmission in DSI/CSI-2 Interface without pkt_formatter</li> </ul> </li> <li>Updated the following sections:         <ul> <li>Output Interface</li> <li>Clock Domains and Clock Domain Crossing</li> <li>Reset and Initialization</li> </ul> </li> <li>Updated Table 2.4. PLL Operating Frequencies.</li> <li>Added D-PHY TX PLL section.</li> <li>Removed Compiler Directives section.</li> </ul> |
| Parameter Settings               | <ul> <li>Updated section header.</li> <li>Updated Table 3.1. CSI-2/DSI D-PHY Tx Submodule IP Parameter Settings in User Interface.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| IP Generation and Evaluation     | Updated the following figures:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Appendix A. Resource Utilization | Updated Table A.1. Resource Utilization.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| _                                | Minor editorial changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

#### Revision 1.2, IP Version 1.3, October 2019

| 110101011 212) 11 Veloloti 210) 00000ci 2025 |                                            |
|----------------------------------------------|--------------------------------------------|
| Section                                      | Change Summary                             |
| Disclaimer                                   | Newly added section.                       |
| All                                          | Added CrossLinkPlus device support.        |
|                                              | Minor adjustments in style and formatting. |
| References                                   | Updated.                                   |

#### Revision 1.1, IP Version 1.0, April 2019

| Section                      | Change Summary                                                              |
|------------------------------|-----------------------------------------------------------------------------|
| Introduction                 | Specified that this user guide can be used for IP design versions 1.x.      |
| IP Generation and Evaluation | In Licensing the IP, modified the instructions for requesting free license. |
| Revision History             | Updated revision history table to new template.                             |
| All                          | Minor adjustments in style and formatting.                                  |

© 2017-2021 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



### Revision 1.0, IP Version 1.0, July 2017

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

38



www.latticesemi.com