

## What is JESD204B?

JESD204B is a JEDEC standard for serial data interfacing. The standard defines a multi gigabit link between a converter device and a logic device such as FPGA or ASIC



Some of the important signals of interest to us are:

- **Device clock**: Each converter and transmitter receives their respective device clock from a clock generator circuit which is responsible for generating all device clocks from a common source.
- **ii. SYNCB** : it is a return path from receiver to the transmitter synchronous to receiver internal clocks. SYNCB signal is used to indicate receiver synchronization and also used for error reporting to the transmitter.
- **iii. SYSREF** : SYSREF is the global timing reference for all the components in the system. This signal is used to align all the clocks and also aligns jesd frames in each of the transmitters and converters. This helps in to ensure deterministic latency through the system. SYSREF can be one shot, periodic or gapped periodic.

# **JESD204B Deterministic Latency Verification with UVM Constrained Random Approaches ANALOG DEVICES** Girish Nadiger and Ashok Chandran, Analog Devices Inc

#### **Deterministic Latency**

In a JESD204B system, data is converted to serial and transmitted on the corresponding lanes. Clock relationship between the lanes can be random and each lane can have different delays. Also, there are various data processing elements distributed across different clock domains. These factors contribute to non repeatable latencies across the link from power up to power up cycles and link resynchronization.

Matching the latency variation of all converters in the system for application that use array of converters is a big concern. Any mismatch in latency can degrade the system performance. For systems that use interleaved samples also require the latency to be matched. Systems that use digital pre-distortion (DPD) loops require latency to be deterministic.

JESD204B provides mechanisms to establish deterministic latency for all converters in the system. Deterministic latency is defined as the time it takes for the parallel input data to propagate from transmitter input to parallel data output at the receiver. This time is measured in frame clocks or device clocks.



This latency is expected to be constant over power cycles and link resynchronization events and also the latency should be programmable.

SYSREF aligns all clocks in each of the converters and logic devices and the frame boundaries are communicated to the receiver by control characters. Each receiver can decode the placement of the transmitter frame relative to its own clocks and also relative to all transmitters. This enables the receiver to deskew the data on different links with different delays using delay buffers and the de-skewed data is sent out on the next frame boundary.

#### Verification Challenge

Since deterministic latency involve multiple modules like SYSREF sampling, clock generation, JESD Rx etc, verification of this feature is very critical and challenging.

Multi channel data path with multi phased clocking and clock gating, requires one to ensure latency is constant from Tx parallel input to DAC output across power cycles (i.e. extended deterministic latency)

Traditionally, this is verified by visually checking the waveform. This method is not scalable, tedious (especially when you have lot of JESD operational modes) and error prone.

System latency from JESD TX parallel data input to DAC output is characterized by using impulses. An impulse is sent on one of the randomly chosen channels. The time taken for the impulse to propagate through JESD TX, JESD RX, and data path and appear at the DAC output is the latency of the system. Same procedure is repeated couple of times. Hardware reset is asserted between each iterations and also link is re synchronized between the iterations.

SYSREF agent

### **Proposed Solution**

As the impulse propagates through the up-sampling filters in the data path, impulse becomes a sinc function since there are up sampling (low pass) filters in the data path.





device clock

## **Verification Flow**



| i.        | La<br>di<br>Sl<br>pa<br>ph<br>ur                                  |
|-----------|-------------------------------------------------------------------|
| ii.       | pe<br>Ra<br>De<br>la<br>Wa<br>st                                  |
| iii.      | JE<br>m<br>ol<br>JE<br>ag                                         |
| iv.       | in<br>lo<br>S`<br>th<br>(i.<br>ba                                 |
| V.        | pu<br>JE<br>a<br>re<br>na                                         |
|           |                                                                   |
| i.<br>ii. | Ti<br>S<br>co<br>is<br>ai<br>W<br>JE<br>de<br>D<br>co<br>re<br>vi |
| i.        |                                                                   |
| ii.       | C<br>T                                                            |
| iii.      | t                                                                 |
| iv.       | t                                                                 |
|           | C                                                                 |

## Verification Environment (contd)

ane delay modelling: Delay block models delays on ifferent lane. The delays may be due different wire lengths, ERDES uncertainties, different SERDES may start arallelizing data from different reference point, clock hasing related uncertainties, clock domain crossing ncertainties etc. The delay values are randomized within ermissible range every time the system is reset. Randomization also takes care of the skew among the lanes.

**Deterministic latency scoreboard:** Used for measuring the atency from JESD transmitter input to DAC output. henever an impulse is seen on the scoreboard input, it tarts a counter. At the DAC output, it looks for a sinc vaveform. Whenever a sinc waveform peak is detected, counter is stopped. This count value is the latency from ESD TX input to DAC output. This scoreboard also supports neasuring latencies from JESD TX input to JESD RX parallel utput

**ESD data scoreboard**: There is a data scoreboard at the JESD receiver output. This compares received user data gainst transmitted user data which helps in verifying data tegrity and data ordering. This helps in debugging and ocalizing errors.

**SYSREF agent:** SYSREF agent is responsible for generating ne SYSREF pulses. The period, width and SYSREF mode .e. one shot, periodic and gapped periodic) are randomized ased on the design modes. The agent generates SYSREF ulses using these random values.

**ESD TX agent**: JESD TX agent contains a JESD driver and JESD sequencers. Driver handle all JESD204B protocol elated stuff. It implements all 3 layers of the JESD204B amely transport layer, data link layer and physical layer.

#### Results

raditional approaches of manual verification of JESD204B Subclass1 deterministic latency does not scale for larger omplexity designs and poses huge risk. The new approach highly scalable and can be reused across multiple products and on JESD transmitter Designs as well

With this scoreboard approach we were able to find many ESD204B receiver data integrity RTL bugs early in the lesign cycle with less debug effort.

Deterministic latency scoreboard coupled with exhaustive overage of design modes helped us find critical clocking elated issues very easily which could have been missed with isual/directed verification.

#### Conclusion

Demonstrates an approach for the verification of deterministic latency systems.

This scheme can be easily extended for the board level testing of deterministic latency.

Any system/protocol that is invariant to lane delays can use this approach for the verification.

Same approach can be used for latency characterization. In our system, we use this scheme to characterize delay variation for different design modes.