

# D-PHY Testbench

## ( TX ⇌ RX )



twwang97

---

---

January 11, 2026

# Introduction

- D-PHY lanes switch between Low-Power (**LP**, single-ended) and High-Speed (**HS**, differential) electrical levels and states.
- D-PHY lanes are operated in three modes — **Control** (LP idle/stop), High-Speed **bursts** (data), and **Escape** (ultra-low-power commands).
- Lane states: E.g., LP-11 stop/idle, LP-00, LP-01/10, HS-0, HS-1). Lane levels refer to the electrical signaling: low-power single-ended levels (DP or DN pulled high/low relative to ground) and high-speed differential levels (DP/DN differential pair toggling). A lane is physically in Control (LP) when idle and enters HS during bursts of high-speed differential signaling.



## Lane state descriptions

| State Code | Line Voltage Levels |         | High-Speed     | Low-Power          |                    |
|------------|---------------------|---------|----------------|--------------------|--------------------|
|            | Dp-Line             | Dn-Line | Burst Mode     | Control Mode       | Escape Mode        |
| HS-0       | HS Low              | HS High | Differential-0 | N/A <sup>[1]</sup> | N/A <sup>[2]</sup> |
| HS-1       | HS High             | HS Low  | Differential-1 | N/A <sup>[3]</sup> | N/A <sup>[4]</sup> |
| LP-00      | LP Low              | LP Low  | N/A            | Bridge             | Space              |
| LP-01      | LP Low              | LP High | N/A            | HS-Request         | Mark-0             |
| LP-10      | LP High             | LP Low  | N/A            | LP-Request         | Mark-1             |
| LP-11      | LP High             | LP High | N/A            | Stop               | N/A <sup>[5]</sup> |

[1] During High-Speed transmission, the Low-Power receivers observe LP-00 on the Lines.

[2] During High-Speed transmission, the Low-Power receivers observe LP-00 on the Lines.

[3] During High-Speed transmission, the Low-Power receivers observe LP-00 on the Lines.

[4] During High-Speed transmission, the Low-Power receivers observe LP-00 on the Lines.

[5] If LP-11 occurs during Escape mode, the Lane returns to Stop state (Control Mode LP-11).



# start of transmission (SoT)

- The transition from a stop state (**LP-11**) into high-speed (**HS**) data transmission mode takes two steps. The clock lane (**cl**) enters HS clock mode before the data lane (**dl**) enters HS mode.



| TX side                                                                                    | RX side                                                                                                     |
|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| Drives Stop state (LP-11)                                                                  | Observes Stop state                                                                                         |
| Drives HS-Req state (LP-01) for time TLPX                                                  | Observes transition from LP-11 to LP-01 on the Lines                                                        |
| Drives Bridge state (LP-00) for time T <sub>CLK-PREPARE</sub>                              | Observes transition from LP-01 to LP-00 on the Lines.<br>Enables Line Termination after time TCLK-TERM-EN   |
| Enables High-Speed driver and disables Low-Power drivers simultaneously.                   | Enables HS-RX and waits for timer T <sub>CLK-SETTLE</sub> to expire in order to neglect transition effects. |
| Drives HS-0 for a time T <sub>CLK-ZERO</sub>                                               | Receives HS-signal                                                                                          |
| Drives the High-Speed Clock signal for time period TCLK-PRE before any Data Lane starts up | Receives High-Speed Clock signal                                                                            |

| TX side                                                                  | RX side                                                                                                 |
|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| Drives Stop state (LP-11)                                                | Observes Stop state                                                                                     |
| Drives HS-Req state (LP-01) for time TLPX                                | Observes transition from LP-11 to LP-01 on the Lines                                                    |
| Drives Bridge state (LP-00) for time THS-PREPARE                         | Observes transition from LP-01 to LP-00 on the Lines,<br>enables Line Termination after time TD-TERM-EN |
| Enables High-Speed driver and disables Low-Power drivers simultaneously. | Enables HS-RX and waits for timer THS-SETTLE to expire in order to neglect transition effects           |
| Drives HS-0 for a time THS-ZERO                                          | Starts looking for Leader-Sequence                                                                      |
| Inserts the HS Sync-Sequence '0001101' beginning on a rising Clock edge  | Synchronizes upon recognition of Leader Sequence<br><b>011101</b>                                       |
| Continues to Transmit High-Speed payload data                            | Receives payload data                                                                                   |



# end of transmission (EoT)

- At the end of a High-Speed Data burst, a data lane leaves High-Speed (**HS**) transmission mode and enters the **stop state** with an End-of-Transmission (**EoT**) procedure.



| TX side                                                                                                      | RX side                                                                                         |
|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|
| Completes transmission of payload data                                                                       | Receives payload data                                                                           |
| Toggles differential state immediately after last payload data bit and keeps that state for a time THS-TRAIL |                                                                                                 |
| Disables the HS-TX, enables the LP-TX, and drives Stop state (LP-11) for a time THS-EXIT                     | Detects the Lines leaving LP-00 state and entering Stop state (LP-11) and disables Termination  |
|                                                                                                              | Neglect bits of last period THS-SKIP to hide transition effects                                 |
|                                                                                                              | Detect last transition in valid Data, determine last valid data byte, and skip trailer sequence |



# continuous clock mode

- Both the CSI-2 and DSI specifications support a continuous clock mode.
- For **continuous** clock behavior, the Clock Lane (CL) remains in high-speed mode generating active clock signals between HS data packet transmissions.
- For **non-continuous** clock behavior, the CL enters the **LP-11** state between HS data packet transmissions.
- Continuous clock mode allows for higher data rates, because the timing overhead of exiting and reentering HS-mode on the clock lane is eliminated.

# D-PHY Testbench in XSim





XI7792.090116



X26344-022522



# Platform

- Library: Xilinx **MIPI TX** and **MIPI RX** detailed in the official [PG202 document](#).
- Vivado Version: 2025.2.
- Testbench Language: Verilog-2001.
- Simulation: XSim (Vivado Simulator).

## MIPI D-PHY v4.3

### *LogiCORE IP Product Guide*

Vivado Design Suite

PG202 (v4.3) December 4, 2024

Component Name `xilinx_dphy_tx_v4_3`
**Core Configuration**   **Shared Logic**  
**Core Parameters**

D-PHY Lanes

Line Rate (Mbps)

Linerate supported by Device Datasheet

Data Flow

Esc Ck (MHz)

LPX Period (ns)

Resource optimization presets

**Control and Debug**

- Enable Active lanes support
- Infer OBUFTDS for 7-Series HS outputs
- Enable AXI-4 Lite Register I/F

**Protocol Watchdog Timers**

- Enable HS and ESC Timeout Counters/Registers

HS Timeout (Bytes)

Escape Timeout (ns)

**D-PHY Tx****D-PHY v4.3**Component Name `xilinx_dphy_rx_v4_3`

D-PHY Lanes

Line Rate (Mbps)

Linerate supported by Device Datasheet

Data Flow

Esc Ck (MHz)

LPX Period (ns)

D-PHY RX ULPS WAKEUP counter for 1 ms time

Resource optimization presets

**Control and Debug**

- Enable AXI-4 Lite Register I/F

**D-PHY Rx****Protocol Watchdog Timers**

- Enable HS and ESC Timeout Counters/Registers

HS Timeout (Bytes)

Escape Timeout (ns)

**Calibration Mode**

- NONE
- FIXED
- AUTO

# Write Verilog (\*.v) for simulation



# D-PHY Testbench in XSim



Simulation Sources (1)

- sim\_1 (1)
  - dphy\_top\_tb (dphy\_top\_tb.v) (4)
  - dphy\_tx\_tb\_i : dphy\_tx\_tb (dphy\_tx\_tb.v) (5)
  - dphy\_tx\_top\_i : dphy\_tx\_top (dphy\_tx\_top.v) (4)
    - u\_core\_rst\_coreclk\_sync\_tx\_i : reset\_sync\_chain (reset\_sync\_chain.v)
    - u\_dphy\_tx\_top\_i : xilinx\_dphy\_tx\_v4\_3 (xilinx\_dphy\_tx\_v4\_3.xci)
  - u\_tx\_clock\_support\_i : dphy\_tx\_clocking\_wrapper (dphy\_tx\_clocking\_wrapper.v) (1)
  - u\_tx\_rst\_logic\_support\_i : reset\_controller (reset\_controller.v) (1)
- genblk\_d10\_frm\_gen.dphy\_frame\_generator0\_i : dphy\_frm\_gen (dphy\_frm\_gen.v) (10)
  - hs\_data\_generator : dphy\_hsdata\_gen (dphy\_hsdata\_gen.v) (1)
  - core\_rst\_byteclk\_sync\_i : reset\_sync\_chain (reset\_sync\_chain.v)
  - core\_rst\_escclk\_sync\_i : reset\_sync\_chain (reset\_sync\_chain.v)
  - esc\_end\_div4clk\_sync\_i : cdc\_sync (cdc\_sync.v)
  - hs\_done\_escclk\_sync\_i : cdc\_sync (cdc\_sync.v)
  - hs\_done\_coreclk\_sync\_i : cdc\_sync (cdc\_sync.v)
  - ulps\_wakeup\_start\_coreclk\_sync\_i : cdc\_sync (cdc\_sync.v)
  - dl\_time\_out\_wakeup\_escclk\_sync\_i : cdc\_sync (cdc\_sync.v)
  - dl\_stopstate\_div4clk\_sync\_i : cdc\_sync (cdc\_sync.v)
  - dl\_w\_esc.gen\_dl\_txdataesc\_lfsr\_i : lfsr8 (lfsr8.v)
- genblk\_d11\_frm\_gen.dphy\_frame\_generator1\_i : dphy\_frm\_gen (dphy\_frm\_gen.v) (10)
- genblk\_d12\_frm\_gen.dphy\_frame\_generator2\_i : dphy\_frm\_gen (dphy\_frm\_gen.v) (10)
- genblk\_d13\_frm\_gen.dphy\_frame\_generator3\_i : dphy\_frm\_gen (dphy\_frm\_gen.v) (10)

- dphy\_rx\_tb\_i : dphy\_rx\_tb (dphy\_rx\_tb.v) (8)
  - sys\_rst\_byteclk\_sync\_rx\_i : reset\_sync\_chain (reset\_sync\_chain.v)
- dphy\_rx\_tb\_i : dphy\_rx\_top (dphy\_rx\_top.v) (1)
  - xilinx\_dphy\_rx\_v4\_3 : xilinx\_dphy\_rx\_v4\_3 (xilinx\_dphy\_rx\_v4\_3.xci)
  - genblk1.sys\_rst\_clk200m\_sync\_i : reset\_sync\_chain (reset\_sync\_chain.v)
- gen\_blk\_d10\_frm\_chk\_i.dphy\_frame\_check0\_i : dphy\_frm\_chk (dphy\_frm\_chk.v) (10)
- gen\_blk\_d11\_frm\_chk\_i.dphy\_frame\_check1\_i : dphy\_frm\_chk (dphy\_frm\_chk.v) (10)
- gen\_blk\_d12\_frm\_chk\_i.dphy\_frame\_check2\_i : dphy\_frm\_chk (dphy\_frm\_chk.v) (10)
- gen\_blk\_d13\_frm\_chk\_i.dphy\_frame\_check3\_i : dphy\_frm\_chk (dphy\_frm\_chk.v) (10)

- reset sync chain (reset sync chain.v)



# D-PHY Testbench in XSim



Simulation Sources (1)

- sim\_1 (1)
  - dphy\_top\_tb (dphy\_top\_tb.v) (4)
    - dphy\_tx\_tb\_i : dphy\_tx\_tb (dphy\_tx\_tb.v) (5)
      - dphy\_tx\_top\_i : dphy\_tx\_top (dphy\_tx\_top.v) (4)
        - u\_core\_rst\_coreclk\_sync\_tx\_i : reset\_sync\_chain (reset\_sync\_chain.v)
          - u\_dphy\_tx\_top\_i : xilinx\_dphy\_tx\_v4\_3 (xilinx\_dphy\_tx\_v4\_3.xci)
            - u\_tx\_clock\_support\_i : dphy\_tx\_clocking\_wrapper (dphy\_tx\_clocking\_wrapper.v) (1)
            - u\_tx\_rst\_logic\_support\_i : reset\_controller (reset\_controller.v) (1)
        - genblk\_d10\_frm\_gen.dphy\_frame\_generator0\_i : dphy\_frm\_gen (dphy\_frm\_gen.v) (10)
          - hs\_data\_generator : dphy\_hsdata\_gen (dphy\_hsdata\_gen.v) (1)
          - core\_rst\_byteclk\_sync\_i : reset\_sync\_chain (reset\_sync\_chain.v)
          - core\_rst\_escclk\_sync\_i : reset\_sync\_chain (reset\_sync\_chain.v)
          - esc\_end\_div4clk\_sync\_i : cdc\_sync (cdc\_sync.v)
          - hs\_done\_escclk\_sync\_i : cdc\_sync (cdc\_sync.v)
          - hs\_done\_coreclk\_sync\_i : cdc\_sync (cdc\_sync.v)
          - ulps\_wakeup\_start\_coreclk\_sync\_i : cdc\_sync (cdc\_sync.v)
          - dl\_time\_out\_wakeup\_escclk\_sync\_i : cdc\_sync (cdc\_sync.v)
          - dl\_stopstate\_div4clk\_sync\_i : cdc\_sync (cdc\_sync.v)
          - dl\_w\_esc.gen\_dl\_txdataesc\_lfsr\_i : lfsr8 (lfsr8.v)
        - genblk\_d11\_frm\_gen.dphy\_frame\_generator1\_i : dphy\_frm\_gen (dphy\_frm\_gen.v) (10)
        - genblk\_d12\_frm\_gen.dphy\_frame\_generator2\_i : dphy\_frm\_gen (dphy\_frm\_gen.v) (10)
        - genblk\_d13\_frm\_gen.dphy\_frame\_generator3\_i : dphy\_frm\_gen (dphy\_frm\_gen.v) (10)
      - dphy\_rx\_tb\_i : dphy\_rx\_tb (dphy\_rx\_tb.v) (8)
        - sys\_rst\_byteclk\_sync\_rx\_i : reset\_sync\_chain (reset\_sync\_chain.v)
        - dphy\_rx\_tb\_i : dphy\_rx\_top (dphy\_rx\_top.v) (1)
          - xilinx\_dphy\_rx\_v4\_3 : xilinx\_dphy\_rx\_v4\_3 (xilinx\_dphy\_rx\_v4\_3.xci)
            - genblk1.sys\_rst\_clk200m\_sync\_i : reset\_sync\_chain (reset\_sync\_chain.v)
            - gen\_blk\_dl0\_frm\_chk\_i.dphy\_frame\_check0\_i : dphy\_frm\_chk (dphy\_frm\_chk.v) (10)
            - gen\_blk\_dl1\_frm\_chk\_i.dphy\_frame\_check1\_i : dphy\_frm\_chk (dphy\_frm\_chk.v) (10)
            - gen\_blk\_dl2\_frm\_chk\_i.dphy\_frame\_check2\_i : dphy\_frm\_chk (dphy\_frm\_chk.v) (10)
            - gen\_blk\_dl3\_frm\_chk\_i.dphy\_frame\_check3\_i : dphy\_frm\_chk (dphy\_frm\_chk.v) (10)
            - reset sync chain (reset sync chain.v)



# XSim Passed: $\geq 15$ HS packets are collected!



**XSim Passed:  $\geq 15$  HS packets are collected!**

The figure displays a timing diagram with multiple signal traces. The x-axis represents time in microseconds, ranging from approximately 380,000,000 us to 460,000,000 us. The y-axis lists signal names. A vertical orange bar highlights a specific time interval between approximately 400,000,000 us and 420,000,000 us.

**Legend:**

- core\_clk\_r: 0 (green), 1 (red)
- clk\_300m\_r: 0 (green), 1 (red)
- tx\_div4\_clk\_r: 0 (green), 1 (red)
- txclkesc\_r: 0 (green), 1 (red)
- axi4\_clk\_r: 0 (green), 1 (red)
- config\_div4\_clk\_r: 0 (green), 1 (red)
- tx\_cl\_init\_done\_i: 0 (green), 1 (red)
- tx\_dl0\_init\_done\_i: 0 (green), 1 (red)
- tx\_dl1\_init\_done\_i: 0 (green), 1 (red)
- tx\_dl2\_init\_done\_i: 0 (green), 1 (red)
- tx\_dl3\_init\_done\_i: 0 (green), 1 (red)
- clk\_hs\_p\_i: 0 (green), 1 (red)
- clk\_hs\_n\_i: 0 (green), 1 (red)
- clk\_lp\_p\_i: 0 (green), 1 (red)
- clk\_lp\_n\_i: 0 (green), 1 (red)
- data\_hs\_p\_i[3:0]: f (green), 0 (red)
- data\_hs\_n\_i[3:0]: 0 (green), f (red)
- data\_lp\_p\_i[3:0]: 0 (green), f (red)
- data\_lp\_n\_i[3:0]: f (green), 0 (red)
- dl0\_hs\_pkt\_cnt\_i[3:0]: 0 (green), f (red)
- dl1\_hs\_pkt\_cnt\_i[3:0]: 0 (green), f (red)
- dl2\_hs\_pkt\_cnt\_i[3:0]: 0 (green), f (red)
- dl3\_hs\_pkt\_cnt\_i[3:0]: 0 (green), f (red)
- dl\_test\_pass\_all: 1 (green), 0 (red)
- dl\_test\_pass[3:0]: f (green), 0 (red)
- tx\_system\_rst\_i: 0 (green), 1 (red)
- rx\_system\_rst\_i: 0 (green), 1 (red)
- rx\_cl\_init\_done\_i: 0 (green), 1 (red)
- rx\_dl0\_init\_done\_i: 0 (green), 1 (red)
- rx\_dl1\_init\_done\_i: 0 (green), 1 (red)
- rx\_dl2\_init\_done\_i: 0 (green), 1 (red)

**Annotations:**

- A vertical orange bar highlights the time interval from approximately 400,000,000 us to 420,000,000 us.
- Hexadecimal values are shown for the data signals (data\_hs\_p\_i[3:0] to dl3\_hs\_pkt\_cnt\_i[3:0]) during the highlighted period, corresponding to the red waveform segments.

# XSim Passed: NO error message!



# D-PHY Testbench in XSim

The test pattern for generated TX HS data is defined in `dphy_hsdata_gen.v`, and such a sequence is `0xAA S4, 0x55 S30, 0x33 S30, 0xF0 S30, 0x7F S30, 0x55 S30, 0x33 S30, 0xF0 S30, 0x80 S30, 0xAA S2`.



# D-PHY Testbench in XSim

The test pattern for generated TX HS data is defined in `dphy_hsdata_gen.v`, and such a sequence is `0xAA S4, 0x55 S30, 0x33 S30, 0xF0 S30, 0x7F S30, 0x55 S30, 0x33 S30, 0xF0 S30, 0x80 S30, 0xAA S2`.



The figure shows the XSim Scope window with tabs for Scope, Sources, and Protocol Instances. The Protocol Instances tab is selected, displaying a list of generated Verilog modules: dphy\_top\_tb, dphy\_tx\_tb, dphy\_tx\_top, dphy\_frm\_gen, and hs\_data\_generator.

| Scope             | Sources         | Protocol Instances |
|-------------------|-----------------|--------------------|
| Search: Q-        |                 |                    |
| Name              | Design Unit     | Block Type         |
| dphy_top_tb       | dphy_top_tb     | Verilog Module     |
| dphy_tx_tb        | dphy_tx_tb      | Verilog Module     |
| dphy_tx_top       | dphy_tx_top     | Verilog Module     |
| dphy_frm_gen      | dphy_frm_gen    | Verilog Module     |
| hs_data_generator | dphy_hsdata_gen | Verilog Module     |

# D-PHY Testbench in XSim

The test pattern for generated TX HS data is defined in `dphy_hsdata_gen.v`, and such a sequence is `0xAA S4, 0x55 S30, 0x33 S30, 0xF0 S30, 0x7F S30, 0x55 S30, 0x33 S30, 0xF0 S30, 0x80 S30, 0xAA S2`.



→HS data for lane#0

| Name                                          | Design Unit     | Block Type     |
|-----------------------------------------------|-----------------|----------------|
| ↳ dphy_top_tb                                 | dphy_top_tb     | Verilog Module |
| ↳ dphy_tx_tb                                  | dphy_tx_tb      | Verilog Module |
| ↳ dphy_tx_top                                 | dphy_tx_top     | Verilog Module |
| ↳ genblk_dlio_frm_gen.dphy_frame_generator0_i | dphy_frm_gen    | Verilog Module |
| ↳ hs_data_generator                           | dphy_hsdata_gen | Verilog Module |

# D-PHY Testbench in XSim

dphy\_frm\_chk.v

The data (`dl_rxdatahs_r`) received by D-PHY Rx should also be verified. The received `dl_rxdatahs_r[7:0]` (on data lane #0) triggered by the clock `rxbyteclkhs` is compared with the expected `hs_gen_data[7:0]`.



# Application

**GMSL camera → FPGA (MIPI) Connection**

# MIPI



- **MIPI** (Mobile Industry Processor Interface)
- **CSI** (Camera Serial Interface)
- **DSI** (Display Serial Interface)
- **CCI** (Camera Control Interface) is a subset of the I2C protocol.



# MIPI CSI-2 Rx



Document: [PG232](#)

# MIPI CSI-2 Receiver Subsystem v6.0

## Product Guide

Vivado Design Suite

PG232 (v6.0) November 20, 2025



twwang97



### Subsystem Options

|                                                                       |                                            |                   |                                  |
|-----------------------------------------------------------------------|--------------------------------------------|-------------------|----------------------------------|
| Pixel Format                                                          | <input type="button" value="YUV422 8bit"/> | Serial Data Lanes | <input type="button" value="4"/> |
| <input checked="" type="checkbox"/> Include Video Format Bridge (VFB) |                                            |                   |                                  |
| <input checked="" type="checkbox"/> Support CSI Spec V2_0             |                                            |                   |                                  |
| <input type="checkbox"/> Support VCX Feature                          |                                            |                   |                                  |

# MIPI CSI-2 Rx

### PHY Options

|                                                                                  |                                                       |  |  |
|----------------------------------------------------------------------------------|-------------------------------------------------------|--|--|
| <input checked="" type="checkbox"/> Include PHY with subsystem                   |                                                       |  |  |
| Select PHY MODE (C-PHY or D-PHY)                                                 | <input type="button" value="DPHY"/>                   |  |  |
| IODELAY_GROUP Name                                                               | <input type="button" value="mipi_csi2rx_idly_group"/> |  |  |
| Line Rate (Mps-CPHY , Mbps-DPHY)                                                 | <input type="button" value="800"/> [80 - 1500]        |  |  |
| <input type="checkbox"/> Linerate supported by Device Datasheet                  |                                                       |  |  |
| <input checked="" type="checkbox"/> PHY Register Interface                       |                                                       |  |  |
| <input checked="" type="checkbox"/> Enable HS and ESC Timeout Counters/Registers |                                                       |  |  |

### Calibration Mode

NONE  FIXED  AUTO

IDELAY Tap Value  [1 - 31]

### CSI-2 Options

|                                                                        |  |  |  |
|------------------------------------------------------------------------|--|--|--|
| <input checked="" type="checkbox"/> CSI2 Controller Register Interface |  |  |  |
| <input checked="" type="checkbox"/> Embedded non-image Interface       |  |  |  |
| <input checked="" type="checkbox"/> Filter User Defined data types     |  |  |  |

Line Buffer Depth

### VFB Options

Allowed VC  Pixels Per Clock  TUSER Width

### Resource improvement options

Enable CRC  Enable Active Lanes

# How to map a GMSL camera → FPGA (MIPI) connection?

- Camera side: A GMSL camera contains a **serializer** that packages sensor output into a GMSL SerDes stream and sends it over coax/**FAKRA**/UTP. Power and control (I<sup>2</sup>C/MDIO) can be carried on the same cable in many implementations.
- Receiver side (near FPGA): The GMSL **deserializer** translates the long-reach **SerDes** into a standard **CSI-2** interface the FPGA can consume.

# How to map a GMSL camera → FPGA (MIPI) connection?

| Attribute       | GMSL                                                                     | MIPI CSI-2 (CSI2-Rx)                                        |
|-----------------|--------------------------------------------------------------------------|-------------------------------------------------------------|
| Purpose         | Long-reach serialized camera link;<br>cable/automotive use               | Chip-to-chip camera interface (PHY<br>+ packet protocol)    |
| Physical medium | Coax/UTP/flex; supports power over cable                                 | Short PCB traces or flex;<br>D-PHY/C-PHY lanes              |
| Distance        | Meters to tens of meters (automotive)                                    | Millimeters to centimeters                                  |
| Topology        | Serializer/Deserializer (SerDes) pair; often<br>with ARQ/robust features | Host receiver IP expecting CSI-2<br>packets                 |
| Error handling  | Link-level robustness, sometimes ARQ/CRC                                 | Packet framing, virtual channels, but<br>not long-cable ARQ |
| Typical use     | Cameras in vehicles, robotics where distance<br>and EMI matter           | Direct sensor → SoC/FPGA<br>connections on board            |



# References

- [https://docs.nxp.com/bundle/AN13573/page/topics/dsi\\_examples.html](https://docs.nxp.com/bundle/AN13573/page/topics/dsi_examples.html)
- <https://www.cnblogs.com/fuzidage/p/14107768.html>
- <https://docs.amd.com/r/en-US/pg202-mipi-dphy>