# TI Designs High Speed

# Synchronization of JESD204B Giga-Sample ADCs using Xilinx Platform for Phased Array Radars



## **TI High Speed Designs**

TI High Speed Designs are analog solutions created by TI's analog experts. High Speed Designs offer the theory, component selection, simulation, complete PCB schematic & layout, bill of materials, and measured performance of useful circuits. Circuit modifications that help to meet alternate design goals are also discussed.

#### **Applications**

- Phased Array Radar
- Radio Telescope
- Beamforming Antenna
- Test and Measurement: Oscilloscope
- Software Defined Radios (SDR)

### **Circuit Description**

This system level design shows how two ADC12J4000 evaluation modules (EVMs) can be synchronized together using a Xilinx VC707 platform. The design document describes the required hardware modifications and device configurations, including the clocking scheme. Example configuration files are shown for each EVM. The FPGA firmware is described and the relevant Xilinx IP block configuration parameters are shown. Data taken on the actual hardware is shown and analyzed, showing synchronization within 50 ps without characterized cables or calibrated propagation delays.

## **Design Resources**

Design Archive ADC12J4000 LMK04828 All Design files Product Folder Product Folder



Ask The Analog Experts
WEBENCH® Design Center
TI Designs Library





An IMPORTANT NOTICE at the end of this TI reference design addresses authorized use, intellectual property matters and other important disclaimers and information.

TINA-TI is a trademark of Texas Instruments WEBENCH is a registered trademark of Texas Instruments



### 1 Design Introduction

Note: The ADC12J4000 EVM used for this design is labelled as "ADC12JXXXXEVM A", or alternatively with a sticker labeled "ADC12J4000". Previous versions of the ADC12J4000 EVM cannot be modified to work in this configuration.

The basic test setup involves a Xilinx VC707 development kit, two ADC12J4000 evaluation modules (EVM), and an LMK04828 EVM as shown in Figure 1 below. The VC707 platform interfaces to both ADC12J4000 EVMs through the two onboard FMC connectors. The FMC connectors are used for both the JESD204B data lines and SYNC signals. The FMC connectors also provide the clocks for the FPGA from the ADC12J4000 EVMs. A common phase-matched analog signal is provided to both ADC12J4000 EVMs through a 0 degree power splitter and matched length cables.



Figure 1: Hardware Block Diagram



The overall clocking scheme is shown in Figure 2 below. The LMK04828 EVM is used to create two phase-aligned SYSREF signals which are then sent to each ADC12J4000 EVM through matched length cables to maintain phase alignment at the input of the LMK04828 on each ADC EVM. The LMK04828 clock chip onboard each ADC EVM is setup in single loop 0-delay mode to create a SYSREF signal for each ADC that is phase aligned to the SYSREF input (see Section 3.1 for details). This also generates phase aligned device clocks for each ADC. In this way the LMK04828 EVM acts as a frequency and phase reference for each ADC12J4000 EVM and each ADC12J4000 EVM generates its own clocks from this reference.



Figure 2: Block Diagram of Clocking Scheme

The ADC12J4000 setup used for testing is below. Note that the design can easily be modified for all of the other available ADC12J4000 modes or for other sampling rates.

- JESD Mode: Decimate-by-10, DDR = 1, P54 = 0, LMF = 2,2,2
- K = 16
- Fs = 2949.12 Msps



# 2 Hardware Configuration

The VC707 and LMK04828 EVMs should be left in the default configurations, but the ADC12J4000 EVM needs be modified to accommodate the clocking solution.

### 2.1 ADC12J4000 EVM Setup

Figure 3 below shows a block diagram for the setup of the ADC12J4000 EVM. The LMK04828 provides both the device clock and SYSREF signals to the ADC12J4000. The LMK04828 is setup in single PLL 0-delay mode which phase locks the ADC's SYSREF signal with the reference SYSREF signal provided to the SMA connector labeled *LMKCLK*. This mode creates phase locked SYSREF and device clocks for each ADC on the separate ADC12J4000 EVMs.

For this clocking mode, the ADC12J4000 EVM needs to be modified so that the onboard LMK04828 provides the device clock to the ADC12J4000. This can be accomplished by removing C32 and C33 and installing C262 and C263. Further, for single loop 0-delay mode the reference SYSREF signal needs to be applied to the OSCin+ pin of the LMK04828 by installing C85 and C86.

Finally, due to the low PFD frequency used in this mode, the loop filter for PLL2 needs to be modified to make the loop stable. Remove the installed components for LF1, LF2, and LF3 and install 12 nF, 0.22 nF, and 1 k $\Omega$ , respectively.



Figure 3: ADC12J4000 EVM Block Diagram

### 2.2 LMK04828 EVM Setup

The LMK04828 EVM does not need to be modified.



## 2.3 VC707 Development Kit

The VC707 development kit does not need to be modified.

## 3 Device Configurations

The specific device configurations for each board are presented below.

#### 3.1 ADC12J4000 EVM

Two devices need to be configured on the ADC12J4000, the ADC itself and the LMK04828. Note that the TRF3765 is not used in this clocking scheme and can therefore be powered down.

For the specific test performed, the ADC12J4000 was setup for decimate-by-10 using two serdes lanes (Decimate-by-10, DDR = 1, P54 = 0, LMF = 2,2,2). For synchronization, the SYSREF receiver and processor need to be enabled. Finally, the SYSREF timing was adjusted by using the dirty SYSREF capture bit to detect timing errors and then using the programmable delays to meet setup and hold times. Both ADC12J4000's were loaded with the same configuration. An example configuration file for the ADC12J4000 GUI is given in the appendix.

The LMK04828 needs to be setup for single loop 0-delay mode. Figure 4 below shows a block diagram of the configuration. Note that in this mode only PLL2 is used, so PLL1 can be disabled. The reference signal provided to the OSCin pin is the SYSREF signal from the LMK04828 EVM. Both the R and N dividers are set to 1. By tracing the signal from the phase detector back through the N divider it can be found that the VCO frequency is the reference frequency times the SYSREF divider. Since the output of the SYSREF divider is used as the feedback signal and both R and N dividers are set to 1 the phase detector will force the phase of the SYSREF divider output to match the phase of the reference signal.

The onboard LMK04828 also generates the device clock for the ADC12J4000. In this case, the device clock is running at 2949.12 MHz, the same frequency as the VCO. The LMK04828 from one of the boards also sends a device clock and SYSREF signal back to the FPGA through the FMC connector and each ADC board sends a reference clock to the related FPGA transceiver blocks (see section 3.3). The relevant output dividers are shown in Figure 4.

Better phase noise performance can likely be achieved by using the part in nested 0-delay dual loop mode with an external VCXO. The higher PFD frequency afforded by dual loop mode would improve the phase noise performance, however an external VCXO could not be used based on the EVM hardware.



Figure 4: LMK04828 in single loop 0-delay mode



No effort was put into matching the phase of the local multi-frame clocks (LMFCs) between the ADCs and the FPGAs. In many cases strict phase matching of the LMFCs between the data converter and logic element is not required. However, when the digital down converter (DDC) is used the timing of the SYNC signal becomes important because the start of the transmission of the initial lane alignment sequence (ILAS) is used for synchronization. In this case all ADCs must start transmitting the ILAS on the same LMFC edge. This is dependent on the SYNC signals meeting the required setup time with respect to the LMFC in the ADC. Since the SYNC signal is launched from the FPGA on an LMFC edge, the timing of the respective LMFCs becomes critical. The timing was sufficient in this case to achieve synchronization of the DDCs without the need to adjust the LMFC cycles.

#### 3.2 LMK04828 EVM

The LMK04828 EVM is configured for dual loop mode. The only clocks that are needed for this setup are two phase matched SYSREF clocks that are used as references for the ADC12J4000 EVMs. Alternatively a signal generator could provide these clocks through a phase matched power splitter. Note that any phase error between these clocks will result in skewed sampling instances in the ADCs. See an example configuration file for the LMK04828 EVM in the appendix.

#### 3.3 VC707

The firmware used for the VC707 platform is a modified version of the hardware demonstration design firmware provided by Xilinx for the VC709 platform. Figure 5 below shows a simplified block diagram of the firmware.



Figure 5: Block Diagram of the VC707 Firmware

### 3.3.1 Pin Assignments

Since this design makes use of two FMC connectors the appropriate signals for the second FMC connector need to be mapped. There are separate GT transceiver blocks for each FMC connector and each transceiver block receives its reference clock from the related FMC connector. The JESD core clock and SYSREF signals come from the first FMC connector. See table 1 and table 2 for the signal mappings between the ADC EVM and the VC707 platform for FMC1 and FMC2, respectively. Note that the serial lanes have inverted polarity that must be accounted for in the FPGA.

Table 1: FMC1 signals for ADC EVM #1

| Signal Name   | ADC12J4000 Pins | LMK04828 Pins | FMC Pins | Virtex 7 Pins |
|---------------|-----------------|---------------|----------|---------------|
| Lane0+        | DS0+            |               | C7       | D7            |
| Lane0-        | DS0-            |               | C6       | D8            |
| Lane1+        | DS1+            |               | A3       | C5            |
| Lane1-        | DS1-            |               | A2       | C6            |
| SYNC          | SYNC~           |               | H31      | L29           |
| GT Ref Clk 1+ |                 | DCLKout4+     | D4       | A10           |
| GT Ref Clk 1- |                 | DCLKout4-     | D5       | A9            |
| Core Clock+   |                 | DCLKout0+     | G6       | K39           |
| Core Clock-   |                 | DCLKout0-     | G7       | K40           |
| SYSREF+       |                 | SDCLKout3+    | G9       | M42           |
| SYSREF-       |                 | SDCLKout3-    | G10      | L42           |

Table 2: FMC2 signals for ADC EVM #2

| 1 abio 2: 1 in 02 oignato (0. 7.20 2 tim #2 |                 |               |          |               |
|---------------------------------------------|-----------------|---------------|----------|---------------|
| Signal                                      | ADC12J4000 Pins | LMK04828 Pins | FMC Pins | Virtex 7 Pins |
| Lane0+                                      | DS0+            |               | C7       | P7            |
| Lane0-                                      | DSO-            |               | C6       | P8            |
| Lane1+                                      | DS1+            |               | A3       | N5            |
| Lane1-                                      | DS1-            |               | A2       | N6            |
| SYNC                                        | SYNC~           |               | H31      | V35           |
| GT Ref Clk 2+                               |                 | DCLKout4+     | D4       | K8            |
| GT Ref Clk 2-                               |                 | DCLKout4-     | D5       | K7            |

### 3.3.2 JESD Core Implementation

A single JESD core implementation is used and it must be modified for the appropriate LMFS configuration. The JESD core was setup for eight lanes (L=8), although only two lanes from each ADC are used. In this case the additional four lanes out of the FPGA block will just output zeroes. The JESD core parameters that were used are listed in table 3.

**Table 3: Xilinx JESD core parameters** 

| rable of Allin Coop del alliotore |                                                       |  |  |  |
|-----------------------------------|-------------------------------------------------------|--|--|--|
| Parameter                         | Value                                                 |  |  |  |
| L                                 | 8 (extra 4 lanes ignored)                             |  |  |  |
| М                                 | Don't care, since transport layer is done in software |  |  |  |
| F                                 | 2                                                     |  |  |  |
| К                                 | 16                                                    |  |  |  |
| Scrambling                        | Enabled                                               |  |  |  |

Alternatively, the core could be setup for four lanes or as separate two lane cores. If the DDC is used, it is required that the two SYNC signals from the separate JESD blocks be ANDed together to create a single SYNC signal for distribution to both ADCs to properly synchronize the NCOs.



The transport layer was implemented in software, rather than firmware, to allow for simple changes without recompiling. The data coming out of the JESD block was captured using an integrated logic analyzer (ILA) block and captured using the Xilinx Chipscope software. The raw lane data was downloaded to the computer and remapped into samples using Matlab. The example program is shown in appendix A.3.

## 3.3.3 Transceiver Setup

The 8 transceivers (only 4 used) are setup as two separate GT transceiver blocks, each with its own reference clock. The line rate is 5.89824 Gbps and the reference clock is 147.456 MHz. Each transceiver block is dedicated to an FMC connector with the reference clock for each block coming from its own FCM connector. The transceiver properties used for this setup are shown in table 4.

**Table 4: Transceiver Setup** 

| Parameter                | Setting |  |
|--------------------------|---------|--|
| Protocol File            | JESD204 |  |
| RX Line Rate (Gbps)      | 5.89824 |  |
| RX Reference Clock (MHz) | 147.456 |  |
| Decoding                 | 8B/10B  |  |
| RX Internal Data Width   | 40      |  |
| RX External Data Width   | 32      |  |
| RXUSRCLK(MHz)            | 147.456 |  |
| RXUSRCLK2(MHz)           | 147.456 |  |
| RX Buffer Enabled        | TRUE    |  |

#### 4 Verification and Measured Performance

Measurements were taken by providing the same analog signal to each ADC using a phase matched power splitter. Only sine waves were tested. The performance of the system was evaluated by calculating the phase difference between signals captured from each ADC. Since sine waves were used, the phase difference was easily measured by comparing the phases of the signals using an FFT and converting to a time value. The complex mixer was enabled at different frequencies to show that the NCOs were also synchronized.

The data was captured by Chipscope and exported to a spreadsheet using the TCL command below.

write\_hw\_ila\_data my\_hw\_ila\_data\_file.zip [upload\_hw\_ila\_data hw\_ila\_1] -force

This command saves the data in a zip file which contains a file called waveform.csv. This CSV file was opened in Matlab and the data streams representing the I data from each ADC was extracted. The data from this CSV file represents the output directly from the JESD block which consists of frames of data, shown as the RX\_DATA streams in figure 5. A Matlab script was used to perform the transport layer functionality by reassembling the data into samples. The phase shift was analyzed by taking an FFT of each signal, finding the largest bin, and comparing the phases. Find an example of the Matlab script in the appendices.

Table 5 reports the measured skews between the two ADCs and figure 6, figure 7, and figure 8 show the time domain view of the captured samples. Skews can come from phase differences between either the sampling clock or the analog input. None of the cables used in the setup were characterized or phase matched and the phase matching of the splitters was not verified. Sampling clock skews can come from the cables used between the LMK04828EVM and the ADC12J4000EVMs or from mismatches in the onboard LMK04828 clock chips. Analog input skews can be from the short cables used between the splitter and the analog inputs, from the splitter itself, or from phase mismatches between the onboard baluns. Note that a different splitter was used for the measurement at 2140 MHz. Since all skews are much smaller than a sampling clock period, it can be concluded that deterministic latency has been achieved and the ADCs are synchronized.



**Table 5: Uncalibrated Skew Results** 

| Input Frequency (MHz) | NCO Frequency (MHz) | Phase Skew (Degrees) | Time Skew (ps) |
|-----------------------|---------------------|----------------------|----------------|
| 70                    | 0                   | 0.506                | 20.09          |
| 500                   | 430                 | 7.709                | 42.8           |
| 2140                  | 2070                | 9.406                | 12.2           |



Figure 6: Sampled Signals at 70 MHz Complex Mixer Disabled (NCO Frequency = 0)





Figure 7: Sampled Signals at 500 MHz with Complex Mixer Enabled (NCO Frequency = 430 MHz)



Figure 8: Sampled Signals at 2140 MHz with Complex Mixer Enabled (NCO Frequency = 2070 MHz)



# Appendix A.

# A.1 Example ADC12J4000EVM Config File

LMK04828 0x000 0x80 0x000 0x00 0x002 0x00 0x100 0x14

0x101 0x55 0x103 0x00

0x104 0x02 0x105 0x01

0x106 0x70 0x107 0x01

0x108 0x0A 0x109 0x55 0x10B 0x02

0x10D 0x02 0x10C 0x22 0x10D 0x00 0x10E 0xF0

0x10F 0x10 0x10F 0x10 0x110 0x14 0x111 0x55 0x113 0x00

0x114 0x02 0x115 0x01 0x116 0xF1 0x117 0x01

0x118 0x08 0x119 0x55 0x11B 0x00 0x11C 0x02

0x11D 0x00 0x11E 0xF9 0x11F 0x00 0x120 0x08 0x121 0x55

0x123 0x00 0x124 0x22 0x125 0x00 0x126 0xF8

0x127 0x00 0x128 0x01 0x129 0x55 0x12B 0x01 0x12C 0x22

0x12C 0x22 0x12D 0x00 0x12E 0xF0 0x12F 0x11 0x130 0x18 0x131 0x55

0x133 0x01 0x134 0x22 0x135 0x00

0x136 0xF9 0x137 0x00





0x138 0x20 0x139 0x03 0x13A 0x01 0x13B 0x40 0x13C 0x00 0x13D 0x08 0x13E 0x03 0x13F 0x15 0x140 0x00 0x141 0x00 0x142 0x08 0x143 0x11 0x144 0xFF 0x145 0x00 0x146 0x00 0x147 0x00 0x148 0x02 0x149 0x02 0x14A 0x02 0x14B 0x02 0x14C 0x00 0x14D 0x00 0x14E 0x00 0x14F 0x7F 0x150 0x01 0x151 0x02 0x152 0x00 0x153 0x00 0x154 0x78 0x155 0x00 0x156 0x78 0x157 0x00 0x158 0x78 0x159 0x00 0x15A 0x78 0x15B 0xF4 0x15C 0x20 0x15D 0x00 0x15E 0x00 0x15F 0x0B 0x160 0x00 0x161 0x01 0x162 0x80 0x163 0x00 0x164 0x00 0x165 0x50 0x17C 0x15 0x17D 0x33 0x166 0x00 0x167 0x00 0x168 0x01 0x169 0x58 0x16A 0x20 0x16B 0x00 0x16C 0x00 0x16D 0x00

Copyright © 2015, Texas Instruments Incorporated

0x16E 0x13



#### www.ti.com

```
0x139 0x00 // Set SYSREF_Mux to "Normal"
0x143 0x11 // Set SYNC MUX to "Pin"
0x140 0x00 // Turn on all the SYSREF blocks
0x144 0x74 // Enable syncing of all clock outputs
0x143 0x11 // Trigger SYNC event using "Pin" mode
0x143 0x31
0x143 0x11
0x144 0xFF // Disable syncing of all clock outputs
0x139 0x03 // Set SYSREF_MUX to "Continuous"
ADC12J4000
0x0021 0x00 // Initiate reset of all registers
0x0021 0x01 // De-assert reset
0x0030 0x00 // SYSREF receiver and processor off
0x0040 0x04 // Set serializer pre-emphasis for high speed PCB
0x0066 0x03 // Foreground calibration mode with timing optimization enabled
0x002B 0x13 // Change reserved register to proper setting
0x0208 0x07 // Change over-range processing to longest interval
0x0051 0x84 // Calibration optimized for large signals
0x0201 0xBE // Scrambler on, KM1 = 15, DDR, JESD disabled
0x0200 0x14 // 6.02dB gain, decimate-by-10
0x0202 0x40 // P54 PLL off, Differential SYNC, Normal data mode
0x0030 0xC0 // SYSREF receiver and processor on
0x0210 0x00 // Set NCO Preset 0 to 0
0x0211 0x00
0x0212 0x00
0x0213 0x00
0x0201 0xBF // Scrambler on, KM1 = 15, DDR, JESD enabled
0x0050 0x0E // Initiate a foreground calibration
```



# A.2 Example LMK04828EVM Config File

[SETUP]

ADDRESS=888

CLOCK=8

DATA=4

LE=2

PART=LMK04828B

PINPOSITION00=1

PINPOSITION01=10

PINPOSITION02=5

PINPOSITION03=6

PINPOSITION04=7

[MODES]

NAME00=R0 (INIT)

VALUE00=144

NAME01=R0

VALUE01=16

NAME02=R2

VALUE02=512

NAME03=R256

VALUE03=65539

NAME04=R257

VALUE04=65877

NAME05=R259

VALUE05=66305

NAME06=R260

VALUE06=66594

NAME07=R261

VALUE07=66816

NAME08=R262

VALUE08=67312

NAME09=R263

VALUE09=67408 NAME10=R264

VALUE10=67587

NAME11=R265

VALUE11=67925

NAME12=R267

VALUE12=68353

NAME13=R268

VALUE13=68642

NAME14=R269

VALUE14=68864

NAME15=R270

VALUE15=69360

NAME16=R271

VALUE16=69456

NAME17=R272

VALUE17=69640

NAME18=R273

VALUE18=69973

NAME19=R275

VALUE19=70400

NAME20=R276

VALUE20=70658 NAME21=R277

VALUE21=70912



#### www.ti.com

NAME22=R278

VALUE22=71417

NAME23=R279

VALUE23=71424

NAME24=R280

VALUE24=71704

NAME25=R281

VALUE25=72021

NAME26=R283

VALUE26=72448

NAME27=R284

VALUE27=72706

NAME28=R285

VALUE28=72960

NAME29=R286

VALUE29=73465

NAME30=R287

VALUE30=73472

NAME31=R288

VALUE31=73736

NAME32=R289

VALUE32=74069

NAME33=R291

VALUE33=74496

NAME34=R292

VALUE34=74754

NAME35=R293

VALUE35=75008

NAME36=R294

VALUE36=75513

NAME37=R295

VALUE37=75520

NAME38=R296

VALUE38=75784

NAME39=R297

VALUE39=76117

NAME40=R299

VALUE40=76544

NAME41=R300

VALUE41=76834

NAME42=R301

VALUE42=77056 NAME43=R302

VALUE43=77553

NAME44=R303

VALUE44=77584

NAME45=R304

VALUE45=77830

NAME46=R305

VALUE46=78165

NAME47=R307

VALUE47=78592

NAME48=R308

VALUE48=78850 NAME49=R309

VALUE49=79104

NAME50=R310



VALUE50=79609

NAME51=R311

VALUE51=79616

NAME52=R312

VALUE52=79909

NAME53=R313

VALUE53=80131

NAME54=R314

VALUE54=80385

NAME55=R315

VALUE55=80704

NAME56=R316

VALUE56=80896

NAME57=R317

VALUE57=81160

NAME58=R318

VALUE58=81411

NAME59=R319

MAINIESS=RS1S

VALUE59=81664

NAME60=R320

VALUE60=81922

NAME61=R321

VALUE61=82176

NAME62=R322 VALUE62=82432

NAME63=R323

VALUE63=82705

NAME64=R324

VALUE64=83199

NAME65=R325

VALUE65=83327

NAME66=R326

VALUE66=83480

NAME67=R327

VALUE67=83738

NAME68=R328

VALUE68=83970

NAME69=R329

VALUE69=84290

NAME70=R330

VALUE70=84482

NAME71=R331

VALUE71=84758

NAME72=R332

VALUE72=84992

NAME73=R333 VALUE73=85248

NAME74=R334

VALUE74=85696

NAME75=R335

VALUE75=85887

NAME76=R336

VALUE76=86019

NAME77=R337

VALUE77=86274

NAME78=R338

VALUE78=86528



#### www.ti.com

NAME79=R339

VALUE79=86784

NAME80=R340

VALUE80=87160

NAME81=R341

VALUE81=87296

NAME82=R342

VALUE82=87672

NAME83=R343

VALUE83=87808

NAME84=R344

VALUE84=88214

NAME85=R345

VALUE85=88320

NAME86=R346

VALUE86=88696

NAME87=R347

VALUE87=89076

NAME88=R348

VALUE88=89120

V/\LULUU-00120

NAME89=R349

VALUE89=89344

NAME90=R350

VALUE90=89600

NAME91=R351

VALUE91=89867

NAME92=R352

VALUE92=90112

NAME93=R353

VALUE93=90369

NAME94=R354

VALUE94=90692

NAME95=R355

VALUE95=90880

NAME96=R356

VALUE96=91136

NAME97=R357

VALUE97=91404

NAME98=R380

VALUE98=97301

NAME99=R381

VALUE99=97587

NAME100=R358 VALUE100=91648

NAME101=R359

VALUE101=91904

NAME102=R360

VALUE102=92172

NAME103=R361

VALUE103=92505

NAME104=R362

VALUE104=92704 NAME105=R363

VALUE105=92928

NAME106=R364

VALUE106=93184

NAME107=R365





NAME108=R366 VALUE108=93715 NAME109=R371 VALUE109=94976 NAME110=R8189 VALUE110=2096384 NAME111=R8190 VALUE111=2096640 NAME112=R8191 VALUE112=2096979 OSCIN00=122.88

VALUE107=93440

OSCIN00=122.88 EXTRA\_PLL\_N\_DIV\_1\_00=1 OSCIN01=122.88 EXTRA\_PLL\_N\_DIV\_1\_01=1 PINS=0



## A.3 Example Matlab Program for Analyzing Skew

```
% Import Data Saved from Chipscope
% Import the data from the Xilinx Chipscope capture. Import as a string
% rather than as a number for the routine below. Only import the columns
% that contain the I data for each board
   data1 = RX DATA[31:0] % Board 1 - I data
   data2 = RX_DATA[95:64] % Board 2 - I data
% Declare variables for imported data
Fs = 294.912e6;
Fin = 99.93e6;
N = length(data1)*2;
num bits = 15;
%----%
% Transport Layer Implementation
data = char(data1);
samples board 1 = zeros(length(data1)*2,1);
for i=1:length(data1)
   samples board 1((i-1)*2+1) = bin2dec([data(i,25:32),data(i,17:24)]);
   samples board 1(i*2) = bin2dec([data(i,9:16),data(i,1:8)]);
end
% Convert data to 2's complement number in Matlab and remove offset
samples board 1 = typecast(uint16(samples board 1),'int16');
samples board 1 = double(samples board 1);
samples board 1 = samples board 1 - mean(samples board 1);
data = char(data2);
samples board 2 = zeros(length(data2)*2,1);
for i=1:length(data1)
   samples board 2((i-1)*2+1) = bin2dec([data(i,25:32),data(i,17:24)]);
   samples board 2(i*2) = bin2dec([data(i,9:16),data(i,1:8)]);
end
\mbox{\%} Convert data to 2's complement number in Matlab and remove offset
samples board 2 = typecast(uint16(samples board 2),'int16');
samples_board_2 = double(samples_board_2);
samples board 2 = samples board 2 - mean(samples board 2);
%______%
% Analyze Skew
%______%
% Plot time domain data for each board.
figure(1)
plot(1:length(samples board 2), samples board 2,...
1:length(samples board 1), samples board 1)
% Get FFT of for each board.
```



```
window = blackman(N);
X=fftshift(fft(window.*samples board 2));
Y=fftshift(fft(window.*samples board 1));
X = X(N/2:end);
Y = Y(N/2:end);
A = 2^{(num bits-1)};
figure(2)
plot(20*log10(abs(X*2/N/A)));
figure(3)
plot(20*log10(abs(Y*2/N/A)));
% Find the bin with the largest amplitude. This is the sine wave.
[mag x index x] = max(abs(X));
[mag\ y\ index\ y] = max(abs(Y));
% Get the phase of each signal at the appropriate bin.
phase x = angle(X(index x));
phase y = angle(Y(index y));
% Calculate the phase difference and time skew.
phase_diff = phase_y - phase_x;
phase_diff_deg = phase_diff / pi * 180;
skew ps = phase diff / (2*pi*Fin) / 1e-12;
if(skew ps >= 0)
    fprintf('Board2 lags Board1 by %f degrees or %f ps\n',...
    phase diff deg, skew ps);
else
    fprintf('Board1 lags Board2 by %f degrees or %f ps\n',...
    -phase_diff_deg, -skew_ps);
end
```

#### IMPORTANT NOTICE FOR TI REFERENCE DESIGNS

Texas Instruments Incorporated ("TI") reference designs are solely intended to assist designers ("Buyers") who are developing systems that incorporate TI semiconductor products (also referred to herein as "components"). Buyer understands and agrees that Buyer remains responsible for using its independent analysis, evaluation and judgment in designing Buyer's systems and products.

TI reference designs have been created using standard laboratory conditions and engineering practices. TI has not conducted any testing other than that specifically described in the published documentation for a particular reference design. TI may make corrections, enhancements, improvements and other changes to its reference designs.

Buyers are authorized to use TI reference designs with the TI component(s) identified in each particular reference design and to modify the reference design in the development of their end products. HOWEVER, NO OTHER LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE TO ANY OTHER TI INTELLECTUAL PROPERTY RIGHT, AND NO LICENSE TO ANY THIRD PARTY TECHNOLOGY OR INTELLECTUAL PROPERTY RIGHT, IS GRANTED HEREIN, including but not limited to any patent right, copyright, mask work right, or other intellectual property right relating to any combination, machine, or process in which TI components or services are used. Information published by TI regarding third-party products or services does not constitute a license to use such products or services, or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

TI REFERENCE DESIGNS ARE PROVIDED "AS IS". TI MAKES NO WARRANTIES OR REPRESENTATIONS WITH REGARD TO THE REFERENCE DESIGNS OR USE OF THE REFERENCE DESIGNS, EXPRESS, IMPLIED OR STATUTORY, INCLUDING ACCURACY OR COMPLETENESS. TI DISCLAIMS ANY WARRANTY OF TITLE AND ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT, QUIET POSSESSION, AND NON-INFRINGEMENT OF ANY THIRD PARTY INTELLECTUAL PROPERTY RIGHTS WITH REGARD TO TI REFERENCE DESIGNS OR USE THEREOF. TI SHALL NOT BE LIABLE FOR AND SHALL NOT DEFEND OR INDEMNIFY BUYERS AGAINST ANY THIRD PARTY INFRINGEMENT CLAIM THAT RELATES TO OR IS BASED ON A COMBINATION OF COMPONENTS PROVIDED IN A TI REFERENCE DESIGN. IN NO EVENT SHALL TI BE LIABLE FOR ANY ACTUAL, SPECIAL, INCIDENTAL, CONSEQUENTIAL OR INDIRECT DAMAGES, HOWEVER CAUSED, ON ANY THEORY OF LIABILITY AND WHETHER OR NOT TI HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES, ARISING IN ANY WAY OUT OF TI REFERENCE DESIGNS OR BUYER'S USE OF TI REFERENCE DESIGNS.

TI reserves the right to make corrections, enhancements, improvements and other changes to its semiconductor products and services per JESD46, latest issue, and to discontinue any product or service per JESD48, latest issue. Buyers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All semiconductor products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its components to the specifications applicable at the time of sale, in accordance with the warranty in TI's terms and conditions of sale of semiconductor products. Testing and other quality control techniques for TI components are used to the extent TI deems necessary to support this warranty. Except where mandated by applicable law, testing of all parameters of each component is not necessarily performed.

TI assumes no liability for applications assistance or the design of Buyers' products. Buyers are responsible for their products and applications using TI components. To minimize the risks associated with Buyers' products and applications, Buyers should provide adequate design and operating safeguards.

Reproduction of significant portions of TI information in TI data books, data sheets or reference designs is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

Buyer acknowledges and agrees that it is solely responsible for compliance with all legal, regulatory and safety-related requirements concerning its products, and any use of TI components in its applications, notwithstanding any applications-related information or support that may be provided by TI. Buyer represents and agrees that it has all the necessary expertise to create and implement safeguards that anticipate dangerous failures, monitor failures and their consequences, lessen the likelihood of dangerous failures and take appropriate remedial actions. Buyer will fully indemnify TI and its representatives against any damages arising out of the use of any TI components in Buyer's safety-critical applications.

In some cases, TI components may be promoted specifically to facilitate safety-related applications. With such components, TI's goal is to help enable customers to design and create their own end-product solutions that meet applicable functional safety standards and requirements. Nonetheless, such components are subject to these terms.

No TI components are authorized for use in FDA Class III (or similar life-critical medical equipment) unless authorized officers of the parties have executed an agreement specifically governing such use.

Only those TI components that TI has specifically designated as military grade or "enhanced plastic" are designed and intended for use in military/aerospace applications or environments. Buyer acknowledges and agrees that any military or aerospace use of TI components that have *not* been so designated is solely at Buyer's risk, and Buyer is solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI has specifically designated certain components as meeting ISO/TS16949 requirements, mainly for automotive use. In any case of use of non-designated products, TI will not be responsible for any failure to meet ISO/TS16949.