## Data Sheet

## FEATURES

Supports input data rates up to 1.096 GSPS
Proprietary, low spurious and distortion design
Single carrier LTE 20 MHz bandwidth (BW), ACLR = $\mathbf{7 7} \mathbf{~ d B c}$ at
180 MHz IF
Six carrier GSM IMD $=\mathbf{7 8} \mathbf{~ d B c}, 600 \mathrm{kHz}$ carrier spacing at 180 MHz IF
SFDR = $\mathbf{7 2} \mathbf{~ d B c}$ at 180 MHz IF, $\mathbf{- 6} \mathbf{~ d B F S}$ single tone
Flexible 8-lane JESD204B interface
Multiple chip synchronization
Fixed latency
Data generator latency compensation
Input signal power detection
High performance, low noise phase-locked loop (PLL) clock multiplier
Digital inverse sinc filter
Digital quadrature modulation using a numerically controlled oscillator (NCO)
Nyquist band selection-mix mode
Selectable $1 \times, 2 \times, 4 \times$, and $8 \times$ interpolation filters
Low power: 2.11 W at 1.6 GSPS, full operating conditions
88-lead, exposed pad LFCSP

## APPLICATIONS

## Wireless communications

Multicarrier LTE and GSM base stations
Wideband repeaters
Software defined radios
Wideband communications
Point to point microwave radio
Transmit diversity, multiple input/multiple output (MIMO)
Instrumentation
Automated test equipment
GENERAL DESCRIPTION
The AD9154 is a quad, 16 -bit, high dynamic range digital-toanalog converter (DAC) that provides a maximum sample rate of 2.4 GSPS, permitting multicarrier generation up to the Nyquist frequency in baseband mode. The AD9154 includes features optimized for direct conversion transmit applications, including complex digital modulation, input signal power detection, and gain, phase, and offset compensation. The DAC outputs are optimized to interface seamlessly with the ADRF6720-27 radio frequency quadrature modulator (AQM) from Analog Devices, Inc. In mix mode, the AD9154 DAC can reconstruct carriers in the second and third Nyquist zones. A serial port interface (SPI) provides the programming/readback of internal parameters.

FUNCTIONAL BLOCK DIAGRAM


Figure 1.

The full-scale output current can be programmed over a range of 4 mA to 20 mA . The AD9154 is available in two different 88-lead LFCSP packages.

## PRODUCT HIGHLIGHTS

1. Ultrawide signal bandwidth enables emerging wideband and multiband wireless applications.
2. Advanced low spurious and distortion design techniques provide high quality synthesis of wideband signals from baseband to high intermediate frequencies.
3. JESD204B Subclass 1 support simplifies multichip synchronization.
4. Small package size with a $12 \mathrm{~mm} \times 12 \mathrm{~mm}$ footprint.

## TABLE OF CONTENTS

Features .....  1
Applications. ..... 1
Functional Block Diagram ..... 1
General Description .....  1
Product Highlights .....  1
Revision History ..... 3
Detailed Functional Block Diagram ..... 4
Specifications ..... 5
DC Specifications .....  5
Digital Specifications ..... 6
Maximum DAC Update Rate Speed Specifications by Supply. ..... 7
JESD204B Serial Interface Speed Specifications ..... 7
SYSREF to DAC Clock Timing Specifications .....  8
Digital Input Data Timing Specifications ..... 8
Latency Variation Specifications ..... 9
JESD204B Interface Electrical Specifications ..... 9
AC Specifications ..... 10
Absolute Maximum Ratings ..... 11
Thermal Resistance ..... 11
ESD Caution ..... 11
Pin Configuration and Function Descriptions ..... 12
Typical Performance Characteristics ..... 14
Terminology ..... 20
Theory of Operation ..... 21
Serial Port Operation ..... 22
Data Format ..... 22
Serial Port Pin Descriptions ..... 22
Serial Port Options ..... 22
Chip Information. ..... 24
Device Setup Guide ..... 25
Step 1: Start Up the DAC ..... 25
Step 2: Digital Datapath ..... 26
Step 3: Transport Layer ..... 26
Step 4: Physical Layer ..... 27
Step 5: Data Link Layer. ..... 28
Step 6: Error Monitoring ..... 28
DAC PLL Setup. ..... 28
Interpolation ..... 29
JESD204B Setup ..... 29
Equalization Mode Setup ..... 30
Link Latency Setup ..... 30
Crossbar Setup ..... 32
JESD204B Serial Data Interface. ..... 33
JESD204B Overview ..... 33
Physical Layer ..... 34
Data Link Layer ..... 37
Transport Layer ..... 45
JESD204B Test Modes ..... 58
JESD204B Error Monitoring. ..... 59
Digital Datapath ..... 62
Dual Paging. ..... 62
Data Format ..... 62
Interpolation Modes ..... 62
Digital Modulation ..... 63
Inverse Sinc ..... 64
Digital Gain, Phase Adjust, DC Offset, and Group Delay... ..... 64
I to Q Swap ..... 65
NCO Alignment ..... 65
Downstream Protection ..... 66
Datapath PRBS ..... 68
DC Test Mode ..... 69
Interrupt Request Operation ..... 70
Interrupt Service Routine. ..... 70
DAC Input Clock Configurations ..... 72
Driving the CLK $\pm$ Inputs ..... 72
DAC PLL Fixed Register Writes ..... 72
Condition Specific Register Writes ..... 72
Starting the PLL ..... 73
Analog Outputs ..... 75
Transmit DAC Operation. ..... 75
Normal and Mix Modes of Operation ..... 76
Temperature Sensor ..... 77
Example Start-Up Sequence. ..... 78
Step 1: Start Up the DAC. ..... 78
Step 2: Digital Datapath. ..... 78
Step 3: Transport Layer ..... 79
Step 4: Physical Layer ..... 79
Step 5: Data Link Layer ..... 80
Step 6: Error Monitoring ..... 80
Board Level Hardware Considerations ..... 81

Power Supply Recommendations81

JESD204B Serial Interface Inputs (SERDIN0 $\pm$ to SERDIN7 $\pm$ ) . 81
Register Summary ........................................................................... 84
Register Details .91

## REVISION HISTORY

2/2017—Rev. B to Rev. C
Change to Features Section .....  1
Change to Table 14 ..... 24
Change to Table 15 ..... 25
Change to Table 93 ..... 91
7/2015—Rev. A to Rev. B
Changes to General Description Section .....  .1
Changes to Figure 33 ..... 19
Added Figure 34; Renumbered Sequentially ..... 19
Changes to Figure 43 ..... 35
Outline Dimensions ..... 123
Ordering Guide ..... 124
Changes to SERDES PLL Fixed Register Writes Section ..... 36
Change to Table 87 .....  .79
Change to ERRWINDOW, Table 93 .....  .95
Updated Outline Dimensions. ..... 123
Changes to Ordering Guide. ..... 123
3/2015—Rev. 0 to Rev. A
Changes to Figure 1 and General Description Section .....  1

## DETAILED FUNCTIONAL BLOCK DIAGRAM



AD9154

## SPECIFICATIONS

## DC SPECIFICATIONS

AVDD33 $=3.3 \mathrm{~V}$, SIOVDD33 $=3.3 \mathrm{~V}, \mathrm{IOVDD}=1.8 \mathrm{~V}, \mathrm{DVDD} 12=1.2 \mathrm{~V}, \mathrm{CVDD} 12=1.2 \mathrm{~V}, \mathrm{PVDD} 12=1.2 \mathrm{~V}, \mathrm{SVDD} 12=1.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{TT}}=1.2 \mathrm{~V}$, $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Ioutrs $=20 \mathrm{~mA}$, unless otherwise noted.

Table 1.

| Parameter | Test Conditions/Comments | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RESOLUTION |  |  | 16 |  | Bits |
| ACCURACY <br> Differential Nonlinearity (DNL) Integral Nonlinearity (INL) |  |  | $\begin{aligned} & \pm 4.3 \\ & \pm 8.2 \end{aligned}$ |  | $\begin{aligned} & \text { LSB } \\ & \text { LSB } \end{aligned}$ |
| MAIN DAC OUTPUTS <br> Gain Error <br> Offset Error ${ }^{1}$ <br> I/Q Gain Mismatch <br> Full-Scale Output Current <br> Maximum Setting <br> Minimum Setting <br> Output Compliance Range <br> Output Resistance <br> Output Capacitance <br> Full-Scale Current DAC Monotonicity | With internal reference <br> Based on a $4 \mathrm{k} \Omega$ external resistor between I 120 and ground | $\begin{aligned} & -8.0 \\ & -3.0 \\ & 19.9 \\ & 3.9 \\ & 2.0 \end{aligned}$ | -3.01 2322 +0.54 20.85 4.17 2.8 15 3.0 Guaranteed | $\begin{aligned} & +8.0 \\ & +3.0 \\ & 21.3 \\ & 4.4 \\ & 3.37 \end{aligned}$ | $\begin{aligned} & \% \text { FSR } \\ & \mathrm{ppm} \\ & \% \mathrm{FSR} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~V} \\ & \mathrm{M} \Omega \\ & \mathrm{pF} \end{aligned}$ |
| MAIN DAC TEMPERATURE DRIFT Gain ${ }^{2}$ |  |  | -114 |  | ppm/ ${ }^{\circ} \mathrm{C}$ |
| REFERENCE Internal Reference Voltage |  |  | 1.2 |  | V |
| ANALOG SUPPLY VOLTAGES <br> AVDD33 <br> PVDD12 <br> CVDD12 | $\begin{aligned} & 5 \% \\ & 5 \% \\ & 2 \% \\ & 5 \% \\ & 2 \% \end{aligned}$ | $\begin{aligned} & 3.13 \\ & 1.14 \\ & 1.274 \\ & 1.14 \\ & 1.274 \end{aligned}$ | $\begin{aligned} & 3.3 \\ & 1.2 \\ & 1.3 \\ & 1.2 \\ & 1.3 \end{aligned}$ | $\begin{aligned} & 3.47 \\ & 1.26 \\ & 1.326 \\ & 1.26 \\ & 1.326 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ |
| DIGITAL SUPPLY VOLTAGES <br> SIOVDD33 <br> $V_{T T}$ <br> DVDD12 <br> SVDD12 <br> IOVDD | $\begin{aligned} & 5 \% \\ & 5 \% \\ & 5 \% \\ & 2 \% \\ & 5 \% \\ & \text { 2\% } \end{aligned}$ | $\begin{aligned} & 3.13 \\ & 1.1 \\ & 1.14 \\ & 1.274 \\ & 1.14 \\ & 1.274 \\ & 1.71 \end{aligned}$ | $\begin{aligned} & 3.3 \\ & 1.2 \\ & 1.2 \\ & 1.3 \\ & 1.2 \\ & 1.3 \\ & 1.8 \end{aligned}$ | $\begin{aligned} & 3.47 \\ & 1.37 \\ & 1.26 \\ & 1.326 \\ & 1.26 \\ & 1.326 \\ & 3.47 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ |
| POWER CONSUMPTION <br> $2 \times$ Interpolation Mode, JESD204B <br> Mode 4, Dual Link, 8 SERDES Lanes <br> AVDD33 <br> PVDD12 <br> CVDD12 <br> SVDD12 <br> DVDD12 <br> SIOVDD33 + IOVDD | $f_{\text {DAC }}=1.6$ GSPS, NCO on, IFout $=40 \mathrm{MHz}$, PLL on, DAC full-scale current $=20 \mathrm{~mA}$ <br> Includes $V_{T T}$ |  | $\begin{aligned} & 2.11 \\ & 159 \\ & 152 \\ & 355 \\ & 541.9 \\ & 264.5 \\ & 10.6 \end{aligned}$ | $\begin{aligned} & 2.63 \\ & 185 \\ & 174 \\ & 397 \\ & 682 \\ & 442 \\ & 11.4 \end{aligned}$ | W <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA |

[^0]
## DIGITAL SPECIFICATIONS

$\operatorname{AVDD} 33=3.3 \mathrm{~V}, \mathrm{SIOVDD} 33=3.3 \mathrm{~V}, \mathrm{IOVDD}=1.8 \mathrm{~V}, \mathrm{DVDD} 12=1.2 \mathrm{~V}, \mathrm{CVDD} 12=1.2 \mathrm{~V}, \mathrm{PVDD} 12=1.2 \mathrm{~V}, \mathrm{SVDD} 12=1.2 \mathrm{~V}, \mathrm{~V} \mathrm{TT}=1.2 \mathrm{~V}$, $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Ioutrs $=20 \mathrm{~mA}$, unless otherwise noted.

Table 2.

| Parameter | Symbol | Test Conditions/Comments | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMOS INPUT LOGIC LEVEL Input Voltage ( $\mathrm{V}_{\mathrm{IN}}$ ) Logic High Low |  | $\begin{aligned} & 1.8 \mathrm{~V} \leq \mathrm{IOVDD} \leq 3.3 \mathrm{~V} \\ & 1.8 \mathrm{~V} \leq \mathrm{IOVDD} \leq 3.3 \mathrm{~V} \end{aligned}$ | $0.7 \times$ IOVDD |  | $0.3 \times$ IOVDD | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| ```CMOS OUTPUT LOGIC LEVEL Output Voltage (Vout) Logic High Low``` |  | $\begin{aligned} & 1.8 \mathrm{~V} \leq \mathrm{IOVDD} \leq 3.3 \mathrm{~V} \\ & 1.8 \mathrm{~V} \leq \mathrm{IOVDD} \leq 3.3 \mathrm{~V} \end{aligned}$ | $0.7 \times$ IOVDD |  | $0.3 \times$ IOVDD |  |
| MAXIMUM DAC UPDATE RATE ${ }^{1}$ |  | ```1\times interpolation }\mp@subsup{}{}{2}\mathrm{ (see Table 4) 2x interpolation }\mp@subsup{}{}{3 4x interpolation 8x interpolation``` | $\begin{aligned} & 1096 \\ & 2192 \\ & 2400 \\ & 2400 \end{aligned}$ |  |  | MSPS <br> MSPS <br> MSPS <br> MSPS |
| ADJUSTED DAC UPDATE RATE |  | $1 \times$ interpolation <br> $2 \times$ interpolation <br> $4 \times$ interpolation <br> $8 \times$ interpolation | $\begin{aligned} & 1096 \\ & 1096 \\ & 600 \\ & 300 \end{aligned}$ |  |  | MSPS <br> MSPS <br> MSPS <br> MSPS |
| INTERFACE ${ }^{4}$ <br> Number of JESD204B Lanes JESD204B Serial Interface Speed Minimum Maximum |  | Per lane <br> Per lane, SVDD12 $=1.3 \mathrm{~V} \pm 2 \%$ | $10.96$ |  | 1.44 | Lanes <br> Gbps Gbps |
| DAC CLOCK INPUT (CLK $\pm$ ) <br> Differential Peak-to-Peak Voltage <br> Common-Mode Voltage <br> Maximum Clock Rate, DAC Clock Sourced Directly from CLK $\pm$ <br> PLL Multiplier Mode Clock Input Frequency ${ }^{5}$ |  | Self biased input, ac-coupled $\text { 6.0 GHz } \leq \text { fvco } \leq 12.0 \mathrm{GHz}$ | $\begin{aligned} & 400 \\ & 2400 \\ & 35 \end{aligned}$ | $\begin{aligned} & 1000 \\ & 600 \end{aligned}$ | $\begin{aligned} & 2000 \\ & 1000 \end{aligned}$ | mV <br> mV <br> MHz <br> MHz |
| SYSREF INPUT (SYSREF $\pm$ ) <br> Differential Peak-to-Peak Voltage Common-Mode Voltage SYSREF $\pm$ Frequency ${ }^{6}$ |  |  | $\begin{aligned} & 400 \\ & 0 \end{aligned}$ | 1000 | $\begin{aligned} & 2000 \\ & 2000 \\ & \mathrm{f}_{\text {Бат }} /(\mathrm{K} \times(\mathrm{F} / \mathrm{S})) \end{aligned}$ | $\begin{aligned} & \mathrm{mV} \\ & \mathrm{mV} \\ & \mathrm{~Hz} \\ & \hline \end{aligned}$ |
| $\text { SYSREF } \pm \text { TO DAC CLOCKㄱ }$ <br> Setup Time Hold Time | $\begin{aligned} & \mathrm{t}_{\mathrm{SSD}} \\ & \mathrm{t}_{\mathrm{HSD}} \end{aligned}$ | SYSREF $\pm$ differential swing $=0.4 \mathrm{~V}$, slew rate $=1.3 \mathrm{~V} / \mathrm{ns}$, (ac-coupled, and $0 \mathrm{~V}, 0.6 \mathrm{~V}, 1.25 \mathrm{~V}, 2.0 \mathrm{~V}$ dc-coupled common-mode voltages) | $\begin{aligned} & 111 \\ & 145 \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{ps} \\ & \mathrm{ps} \\ & \hline \end{aligned}$ |
| SPI <br> Maximum Clock Rate <br> Minimum SCLK Pulse Width <br> High <br> Low <br> SDIO to SCLK <br> Setup Time <br> Hold Time <br> SDO to SCLK <br> Data Valid Window | SCLK <br> tpwh <br> tpwL <br> tos <br> toh <br> tov | See timing diagrams shown in Figure 39 and Figure 40 IOVDD $=1.8 \mathrm{~V}$ | 10 <br> 5 <br> 2 <br> 25 |  | $\begin{aligned} & 8 \\ & 12 \end{aligned}$ | MHz <br> ns ns ns ns ns |


| Parameter | Symbol | Test Conditions/Comments | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CS}}$ to SCLK |  |  |  |  |  |  |
| Setup Time | tses |  | 5 |  |  | ns |
| Hold Time | $\mathrm{thcsics}^{\text {a }}$ |  | 2 |  |  | ns |

${ }^{1}$ See Table 3 for detailed specifications for DAC update rate conditions.
${ }^{2}$ Maximum speed for $1 \times$ interpolation is limited by the JESD204B interface. See Table 4 for details.
${ }^{3}$ Maximum speed for $2 \times$ interpolation is limited by the JESD204B interface. See Table 4 for details.
${ }^{4}$ See Table 4 for detailed specifications for JESD204B speed conditions.
${ }^{5}$ CLK+/CLK- serve as a reference oscillator input for the on-chip PLL clock multiplier when in use.
${ }^{6}$ K, F, and S are JESD204B transport layer parameters. See Table 42 for the full definitions.
${ }^{7}$ See Table 5 for detailed specifications for SYSREF to DAC clock timing conditions.

## MAXIMUM DAC UPDATE RATE SPEED SPECIFICATIONS BY SUPPLY

AVDD33 = 3.3 V, SIOVDD33 = 3.3 V, IOVDD = 1.8 V, DVDD12 = 1.2 V, CVDD12 = 1.2 V, PVDD12 = $1.2 \mathrm{~V}, \mathrm{SVDD} 12=1.2 \mathrm{~V}$, $\mathrm{V}_{\mathrm{TT}}=1.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Ioutrs $=20 \mathrm{~mA}$, unless otherwise noted.

Table 3.

| Parameter | Test Conditions/Comments | Min | Typ | Max |
| :--- | :--- | :--- | :--- | :--- |
| MAXIMUM DAC UPDATE RATE | DVDD12, CVDD12, PVDD12 $=1.2 \mathrm{~V} \pm 5 \%$ | 1.93 |  |  |
|  | DVDD12, CVDD12, PVDD12 $=1.2 \mathrm{~V} \pm 2 \%$ | 2.07 |  | GSPS |
|  | DVDD12, CVDD12, PVDD12 $=1.3 \mathrm{~V} \pm 2 \%$ | 2.4 | GSPS |  |

## JESD204B SERIAL INTERFACE SPEED SPECIFICATIONS

AVDD33 = 3.3 V, SIOVDD33 = 3.3 V, IOVDD = 1.8 V, DVDD12 = 1.2 V, CVDD12 = 1.2 V, PVDD12 = 1.2 V, SVDD12 $=1.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{TT}}=1.2 \mathrm{~V}$, $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Ioutrs $=20 \mathrm{~mA}$, unless otherwise noted.

Table 4.

| Parameter | Test Conditions/Comments | Min | Typ | Max |
| :--- | :--- | :--- | :--- | :--- |
| CLOCK AND DATA RECOVERY | SVDD12 $=1.2 \mathrm{~V} \pm 5 \%$ | 5.74 | 9.04 | Gbps |
| (CDR) HALF RATE MODE |  |  | 5.74 | 9.65 |
|  | SVDD12 $=1.2 \mathrm{~V} \pm 2 \%$ | 5.74 | Gbps |  |
|  | SVDD12 $=1.3 \mathrm{~V} \pm 2 \%$ | 2.87 | 4.96 | Gbps |
| CDR FULL RATE MODE | SVDD12 $=1.2 \mathrm{~V} \pm 5 \%$ | 2.87 | 4.79 | Gbps |
|  | SVDD12 $=1.2 \mathrm{~V} \pm 2 \%$ | 2.87 | Gbps |  |
|  | SVDD12 $=1.3 \mathrm{~V} \pm 2 \%$ | 1.44 | 5.93 | Gbps |
| CDR OVERSAMPLING MODE | SVDD12 $=1.2 \mathrm{~V} \pm 5 \%$ | 1.44 | 2.39 | Gbps |
|  | SVDD12 $=1.2 \mathrm{~V} \pm 2 \%$ | 2.50 | Gbps |  |
|  | SVDD12 $=1.3 \mathrm{~V} \pm 2 \%$ | 1.44 | 2.93 | Gbps |

## SYSREF TO DAC CLOCK TIMING SPECIFICATIONS

AVDD33 $=3.3 \mathrm{~V}, \mathrm{SIOVDD} 33=3.3 \mathrm{~V}, \mathrm{IOVDD}=1.8 \mathrm{~V}, \mathrm{DVDD} 12=1.2 \mathrm{~V}, \mathrm{CVDD} 12=1.2 \mathrm{~V}, \mathrm{PVDD} 12=1.2 \mathrm{~V}, \mathrm{SVDD} 12=1.2 \mathrm{~V}, \mathrm{~V}$ тT $=1.2 \mathrm{~V}$, $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Ioutrs $=20 \mathrm{~mA}$, SYSREF $\pm$ common-mode voltages $=0.0 \mathrm{~V}, 0.6 \mathrm{~V}, 1.25 \mathrm{~V}$, and 2.0 V , unless otherwise noted.

Table 5.

| Parameter | Test Conditions/Comments | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SYSREF | Differential swing $=0.4 \mathrm{~V}$, slew rate $=1.3 \mathrm{~V} / \mathrm{ns}$ |  |  |  |  |
| Setup Time | AC-coupled | 89 |  |  | ps |
|  | DC-coupled | 111 |  |  | ps |
| Hold Time | AC-coupled | 105 |  |  | ps |
|  | DC-coupled | 145 |  |  | ps |
|  | Differential swing $=0.7 \mathrm{~V}$, slew rate $=2.28 \mathrm{~V} / \mathrm{ns}$ |  |  |  |  |
| Setup Time | AC-coupled | 71 |  |  | ps |
|  | DC-coupled | 81 |  |  | ps |
| Hold Time | AC-coupled | 97 |  |  | ps |
|  | DC-coupled | 118 |  |  | ps |
|  | Differential swing $=1.0 \mathrm{~V}$, slew rate $=3.26 \mathrm{~V} / \mathrm{ns}$ |  |  |  |  |
| Setup Time | AC-coupled | 58 |  |  | ps |
|  | DC-coupled | 64 |  |  | ps |
| Hold Time | AC-coupled | 92 |  |  | ps |
|  | DC-coupled | 108 |  |  | ps |

## DIGITAL INPUT DATA TIMING SPECIFICATIONS

AVDD33 = 3.3 V, SIOVDD33 = 3.3 V, IOVDD = 1.8 V, DVDD12 = 1.2 V, CVDD12 = 1.2 V, PVDD12 = 1.2 V, SVDD12 = 1.2 V , $\mathrm{V}_{\mathrm{TT}}=1.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, Ioutfs $=20 \mathrm{~mA}$, unless otherwise noted.

Table 6.

| Parameter | Test Conditions/Comments | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| LATENCY |  | 17 |  |  | PClock ${ }^{1}$ cycles |
| Interface, Excluding Transport Layer Delay Buffer | With or without modulation |  |  |  |  |
| Interpolation |  |  |  |  |  |
| $1 \times$ |  |  | 94 |  | DAC clock cycles |
| $2 \times$ |  |  | 130 |  | DAC clock cycles |
| $4 \times$ |  |  | 250 |  | DAC clock cycles |
| $8 \times$ |  |  | 474 |  | DAC clock cycles |
| Inverse Sinc |  |  | 17 |  | DAC clock cycles |
| Fine Modulation |  |  | 20 |  | DAC clock cycles |
| Coarse Modulation |  |  |  |  |  |
| $\mathrm{f}_{5} / 8$ |  |  | 8 |  | DAC clock cycles |
| $\mathrm{f}_{\mathrm{s}} / 4$ |  |  | 4 |  | DAC clock cycles |
| Digital Phase Adjust |  |  | 12 |  | DAC clock cycles |
| Digital Gain Adjust |  |  | 12 |  | DAC clock cycles |
| Power-Up Time |  |  |  |  |  |
| Dual A Only | Register 0x011 from 0x60 to 0x00 |  | 30 |  | $\mu \mathrm{s}$ |
| Dual B Only | Register 0x011 from 0x18 to 0x00 |  | 30 |  | $\mu \mathrm{s}$ |
| All DACs | Register 0x011 from 0x78 to 0x00 |  | 30 |  | $\mu \mathrm{s}$ |

${ }^{1}$ PClock is the AD9154 internal processing clock running at the JESD204B lane rate $\div 40$.

AD9154

## LATENCY VARIATION SPECIFICATIONS

AVDD33 $=3.3 \mathrm{~V}$, SIOVDD33 $=3.3 \mathrm{~V}, \mathrm{IOVDD}=1.8 \mathrm{~V}, \mathrm{DVDD} 12=1.2 \mathrm{~V}, \mathrm{CVDD} 12=1.2 \mathrm{~V}, \mathrm{PVDD} 12=1.2 \mathrm{~V}, \mathrm{SVDD} 12=1.2 \mathrm{~V}$, $\mathrm{V}_{\mathrm{TT}}=1.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, Ioutrs $=20 \mathrm{~mA}$, unless otherwise noted.

Table 7.

| Parameter | Test Conditions/Comments | Min | Typ | Max | Unit |
| :--- | :--- | :--- | :---: | :---: | :---: |
| DAC LATENCY VARIATION |  |  |  |  |  |
| Subclass 1 |  |  |  |  |  |
| PLL Off |  | -1 | 0 | 1 | DACCLK cycles |
| PLL On |  | -1 | DACCLK cycles |  |  |

## JESD204B INTERFACE ELECTRICAL SPECIFICATIONS

AVDD33 = 3.3 V, SIOVDD33 = 3.3 V, IOVDD = 1.8 V, DVDD12 = 1.2 V, CVDD12 = 1.2 V, PVDD12 = $1.2 \mathrm{~V}, \mathrm{SVDD} 12=1.2 \mathrm{~V}$, $\mathrm{V}_{\mathrm{TT}}=1.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, Ioutfs $=20 \mathrm{~mA}$, unless otherwise noted.

Table 8.

| Parameter | Symbol | Test Conditions/Comments | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JESD204B DATA INPUTS |  |  |  |  |  |  |
| Input Leakage Current |  | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  |  |  |  |
| Logic High |  | Input level $=1.2 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{~V}_{\text {TT }}=1.2 \mathrm{~V}$ |  | 10 |  | $\mu \mathrm{A}$ |
| Logic Low |  | Input level $=0 \mathrm{~V}$ |  | -4 |  | $\mu \mathrm{A}$ |
| Unit Interval | UI |  | 94 |  | 714 | ps |
| Common-Mode Voltage | $\mathrm{V}_{\text {RCM }}$ | AC-coupled | -0.05 |  | +1.85 | V |
|  |  | $\mathrm{V}_{T T}=$ SVDD $^{\text {2 }}{ }^{1}$ |  |  |  |  |
| Differential Voltage | R_V ${ }_{\text {difF }}$ |  | 110 |  | 1050 | mV |
| $\mathrm{V}_{\text {TT }}$ Source Impedance | $\mathrm{Z}_{\mathrm{TT}}$ | At dc |  |  | 30 | $\Omega$ |
| Differential Impedance | $\mathrm{Z}_{\text {RDIFF }}$ | At dc | 80 | 100 | 120 | $\Omega$ |
| Differential Return Loss | RLRDIF |  |  | 8 |  | dB |
| Common-Mode Return Loss | RLrcm |  |  | 6 |  | dB |
| DIFFERENTIAL OUTPUTS ( $\overline{\text { SYNCOUT }})^{2}$ |  |  |  |  |  |  |
| Output Offset Voltage | Vos |  | 1.19 |  | 1.27 | V |
| DETERMINISTIC LATENCY |  |  |  |  |  |  |
| Fixed |  |  |  |  | 17 | PClock ${ }^{3}$ cycles |
| Variable |  |  |  |  | 2 | PClock ${ }^{3}$ cycles |
| SYSREF $\pm$ TO LOCAL MULTIFRAME CLOCK (LMFC) DELAY |  |  |  | 4 |  | DAC clock cycles |

${ }^{1}$ As measured on the input side of the ac coupling capacitor.
${ }^{2}$ IEEE Standard 1596.3 LVDS compatible.
${ }^{3}$ PClock is the AD9154 internal processing clock; its frequency is equal to the JESD204B lane rate $\div 40$.

## AC SPECIFICATIONS

AVDD33 $=3.3 \mathrm{~V}$, SIOVDD33 $=3.3 \mathrm{~V}, \mathrm{IOVDD}=1.8 \mathrm{~V}, \mathrm{DVDD} 12=1.2 \mathrm{~V}, \mathrm{CVDD} 12=1.2 \mathrm{~V}, \mathrm{PVDD} 12=1.2 \mathrm{~V}, \mathrm{SVDD} 12=1.2 \mathrm{~V}$, $\mathrm{V}_{\mathrm{TT}}=1.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, Ioutfs $=20 \mathrm{~mA}$, unless otherwise noted.

Table 9.

| Parameter | Test Conditions/Comments | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SPURIOUS-FREE DYNAMIC RANGE (SFDR) $\begin{aligned} & f_{D A C}=1966.08 \mathrm{MSPS} \\ & \mathrm{f}_{\mathrm{DAC}}=1966.08 \mathrm{MSPS} \\ & \mathrm{f}_{\mathrm{DAC}}=1966.08 \mathrm{MSPS} \end{aligned}$ | -6 dBFS single tone $\begin{aligned} & \text { fout }=20 \mathrm{MHz} \\ & \text { fout }=150 \mathrm{MHz} \\ & \text { fout }=180 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 76 \\ & 73 \\ & 72 \end{aligned}$ |  | dBc <br> dBc <br> dBc |
| $\begin{aligned} & \hline \text { TWO-TONE THIRD INTERMODULATION DISTORTION (IMD) } \\ & f_{D A C}=983.04 \mathrm{MSPS} \\ & \mathrm{f}_{\mathrm{DAC}}=983.04 \mathrm{MSPS} \\ & \mathrm{f}_{\mathrm{DAC}}=1966.08 \mathrm{MSPS} \\ & \mathrm{f}_{\mathrm{DAC}}=1966.08 \mathrm{MSPS} \\ & \hline \end{aligned}$ | $\begin{aligned} & -6 \mathrm{dBFS} \\ & \mathrm{f}_{\text {out }}=30 \mathrm{MHz} \\ & \mathrm{f}_{\text {out }}=150 \mathrm{MHz} \\ & \mathrm{f}_{\text {out }}=30 \mathrm{MHz} \\ & \text { fout }=180 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 87 \\ & 77 \\ & 86 \\ & 78 \end{aligned}$ |  | dBc <br> dBc <br> dBc <br> dBc |
| NOISE SPECTRAL DENSITY (NSD), SINGLE TONE $\begin{aligned} & \mathrm{f}_{\mathrm{DAC}}=983.04 \mathrm{MSPS} \\ & \mathrm{f}_{\mathrm{DAC}}=1966.08 \mathrm{MSPS} \end{aligned}$ | $\begin{aligned} & \hline 0 \mathrm{dBFS} \\ & \mathrm{fout}=150 \mathrm{MHz} \\ & \text { fout }=180 \mathrm{MHz} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & -164 \\ & -163 \end{aligned}$ |  | $\mathrm{dBm} / \mathrm{Hz}$ $\mathrm{dBm} / \mathrm{Hz}$ |
| 5 MHz BW LTE FIRST ADJACENT CHANNEL LEAKAGE RATIO (ACLR), SINGLE CARRIER $\begin{aligned} f_{D A C} & =1966.08 \mathrm{MSPS} \\ f_{D A C} & =1966.08 \mathrm{MSPS} \\ f_{D A C} & =1966.08 \mathrm{MSPS} \end{aligned}$ | 0 dBFS , PLL off $\begin{aligned} & \text { fout }=50 \mathrm{MHz} \\ & \text { fout }=150 \mathrm{MHz} \\ & \text { fout }=180 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 79 \\ & 77 \\ & 77 \end{aligned}$ |  | dBc <br> dBc <br> dBc |
| 5 MHz BW LTE SECOND ACLR, SINGLE CARRIER $\begin{aligned} f_{D A C} & =1966.08 \mathrm{MSPS} \\ f_{D A C} & =1966.08 \mathrm{MSPS} \\ f_{D A C} & =1966.08 \mathrm{MSPS} \end{aligned}$ | $\begin{aligned} & 0 \mathrm{dBFS}, \mathrm{PLL} \text { off } \\ & \mathrm{f}_{\text {out }}=50 \mathrm{MHz} \\ & \mathrm{f}_{\text {out }}=150 \mathrm{MHz} \\ & \text { fout }=180 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 82 \\ & 81 \\ & 81 \end{aligned}$ |  | dBc <br> dBc <br> dBc |

## ABSOLUTE MAXIMUM RATINGS

Table 10.

| Parameter | Rating |
| :---: | :---: |
| 1120 to Ground | -0.3 V to AVDD33 + 0.3 V |
| SERDINx $\pm, V_{\pi}, \overline{\text { SYNCOUTx } \pm}$, and TXENx | -0.3 V to SIOVDD33 +0.3 V |
| OUTx $\pm$ | -0.3 V to AVDD33 + 0.3 V |
| SYSREF $\pm$ | GND - 0.5V |
| CLK $\pm$ to Ground | -0.3 V to PVDD12 +0.3 V |
| $\overline{\mathrm{RESET}}, \overline{\mathrm{IRQ}}, \overline{\mathrm{CS}}, \mathrm{SCLK}, \mathrm{SDIO}, \mathrm{SDO}$, and PDP OUTx to Ground | -0.3 V to IOVDD +0.3 V |
| LDO_BYP1 | -0.3 V to SVDD12 +0.3 V |
| LDO_BYP2 | -0.3 V to PVDD12 +0.3 V |
| Ambient Operating Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Junction Temperature | $125^{\circ} \mathrm{C}$ |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

Stresses at or above those listed under Absolute Maximum Ratings may cause permanent damage to the product. This is a stress rating only; functional operation of the product at these or any other conditions above those indicated in the operational section of this specification is not implied. Operation beyond the maximum operating conditions for extended periods may affect product reliability.

## THERMAL RESISTANCE

The exposed pad (EPAD) must be soldered to the ground plane for the 88-lead LFCSP. The EPAD provides an electrical, thermal, and mechanical connection to the board.

Typical $\theta_{\mathrm{JA}}, \theta_{\mathrm{JB}}$, and $\theta_{\mathrm{JC}}$ values are specified for a 4-layer, JESD51-7 high effective thermal conductivity test board for leaded surface-mount packages. $\theta_{\mathrm{JA}}$ is obtained in still air conditions (JESD51-2). Airflow increases heat dissipation, effectively reducing $\theta_{\mathrm{JA}} . \theta_{\mathrm{JB}}$ is obtained following double-ring cold plate test conditions (JESD51-8). $\theta_{\mathrm{JC}}$ is obtained with the test case temperature monitored at the bottom of the exposed pad.
$\Psi_{\text {IT }}$ and $\Psi_{\text {IB }}$ are thermal characteristic parameters obtained with $\theta_{\mathrm{JA}}$ in still air test conditions.

Junction temperature ( $\mathrm{T}_{\mathrm{J}}$ ) can be estimated using the following equations:

$$
\begin{aligned}
& T_{J}=T_{T}+\left(\Psi_{I T} \times P\right), \\
& \text { or } \\
& T_{J}=T_{B}+\left(\Psi_{I B} \times P\right)
\end{aligned}
$$

where:
$T_{T}$ is the temperature measured at the top of the package.
$P$ is the total device power dissipation.
$T_{B}$ is the temperature measured at the board.
Table 11. Thermal Resistance

| Package | $\boldsymbol{\theta}_{\text {JA }}$ | $\boldsymbol{\theta}_{\text {JB }}$ | $\boldsymbol{\theta}_{\mathbf{J C}}$ | $\boldsymbol{\Psi}_{\text {JT }}$ | $\boldsymbol{\Psi}_{\text {JB }}$ | Unit |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 88-Lead LFCSP |  |  |  |  |  |  |

${ }^{1}$ The exposed pad must be securely connected to the ground plane.

## ESD CAUTION



## PIN CONFIGURATION AND FUNCTION DESCRIPTIONS



NOTES

1. THE EXPOSED PAD MUST BE SECURELY CONNECTED TO THE GROUND PLANE. 2. $D N C=$ DO NOT CONNECT.

Figure 3. Pin Configuration
Table 12. Pin Function Descriptions

| Pin No. | Mnemonic | Description |
| :---: | :---: | :---: |
| $\begin{aligned} & 1,4,7,8,9,10, \\ & 56,57 \end{aligned}$ | PVDD12 | 1.2 V Clock Supplies. |
| 2 | CLK+ | PLL Reference/Clock Input, Positive. When the PLL is used, this pin is the positive reference clock input. When the PLL is not used, this pin is the positive device clock input. This pin is self biased and must be ac-coupled. |
| 3 | CLK- | PLL Reference/Clock Input, Negative. When the PLL is used, this pin is the negative reference clock input. When the PLL is not used, this pin is the negative device clock input. This pin is self biased and must be ac-coupled. |
| 5 | SYSREF+ | Timing Reference Input, Positive. This pin is used in JESD204B Subclass 1 systems and is self biased, ac-coupled, or dc-coupled. |
| 6 | SYSREF- | Timing Reference Input, Negative. This pin is used in JESD204B Subclass 1 systems and is self biased, ac-coupled, or dc-coupled. |
| 11 | TXENO | Transmit enable for DAC0 and DAC1. CMOS levels are determined with respect to IOVDD. |
| 12 | TXEN1 | Transmit Enable for DAC2 and DAC3. CMOS levels are determined with respect to IOVDD. |
| 13, 14, 53 | DVDD12 | 1.2 V Digital Supplies. |
| 15 | SERDINO+ | Serial Channel Input 0, Positive. CML compliant. SERDINO+ is internally terminated to the $\mathrm{V}_{\mathrm{TT}}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 16 | SERDIN0- | Serial Channel Input 0, Negative. CML compliant. SERDINO- is internally terminated to the $\mathrm{V}_{\mathrm{TT}}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| $\begin{aligned} & 17,20,22,28, \\ & 31,32,33,36, \\ & 39,45,47,50 \end{aligned}$ | SVDD12 | 1.2 V JESD204B Receiver Supplies. |
| 18 | SERDIN1+ | Serial Channel Input 1, Positive. CML compliant. SERDIN1+ is internally terminated to the $\mathrm{V}_{\mathrm{TT}}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 19 | SERDIN1- | Serial Channel Input 1, Negative. CML compliant. SERDIN1- is internally terminated to the $\mathrm{V}_{\mathrm{TT}}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 21, 25, 42, 46 | $V_{T T}$ | 1.2 V Termination Voltage Pins. |


| Pin No. | Mnemonic | Description |
| :---: | :---: | :---: |
| 23 | SYNCOUTO+ | Positive LVDS Synchronization Output Signal for Channel Link 0. |
| 24 | $\overline{\text { SYNCOUTO- }}$ | Negative LVDS Synchronization Output Signal for Channel Link 0. |
| 26 | SERDIN2+ | Serial Channel Input 2, Positive. CML compliant. SERDIN2+ is internally terminated to the $\mathrm{V}_{\mathrm{TT}}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 27 | SERDIN2- | Serial Channel Input 2, Negative. CML compliant. SERDIN2- is internally terminated to the $V_{T T}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 29 | SERDIN3+ | Serial Channel Input 3, Positive. CML compliant. SERDIN3+ is internally terminated to the $V_{T T}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 30 | SERDIN3- | Serial Channel Input 3, Negative. CML compliant. SERDIN3- is internally terminated to the $V_{T T}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 34 | LDO_BYP1 | LDO SERDES Bypass. This pin requires a $1 \Omega$ resistor in series with a $1 \mu \mathrm{~F}$ capacitor to ground. |
| 35 | SIOVDD33 | SERDES Ports Input/Output Supply. |
| 37 | SERDIN4- | Serial Channel Input 4, Negative. CML compliant. SERDIN4- is internally terminated to the $V_{T T}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 38 | SERDIN4+ | Serial Channel Input 4, Positive. CML compliant. SERDIN4+ is internally terminated to the $V_{T T}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 40 | SERDIN5- | Serial Channel Input 5, Negative. CML compliant. SERDIN5-is internally terminated to the $V_{T T}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 41 | SERDIN5+ | Serial Channel Input 5, Positive. CML compliant. SERDIN5+ is internally terminated to the $V_{T T}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 43 | $\overline{\text { SYNCOUT1- }}$ | Negative LVDS Synchronization Output Signal for Channel Link 1. |
| 44 | $\overline{\text { SYNCOUT1+ }}$ | Positive LVDS Synchronization Output Signal for Channel Link 1. |
| 48 | SERDIN6- | Serial Channel Input 6, Negative. CML compliant. SERDIN6- is internally terminated to the $V_{T T}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 49 | SERDIN6+ | Serial Channel Input 6, Positive. CML compliant. SERDIN6+ is internally terminated to the $V_{T T}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 51 | SERDIN7- | Serial Channel Input 7, Negative. CML compliant. SERDIN7- is internally terminated to the $V_{T T}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 52 | SERDIN7+ | Serial Channel Input 7, Positive. CML compliant. SERDIN7+ is internally terminated to the $\mathrm{V}_{\text {TT }}$ pin voltage using a calibrated $50 \Omega$ resistor. This pin is ac-coupled only. |
| 54, 55 | DNC | Do Not Connect. Do not connect to this pin. |
| 58 | PDP OUT1 | Power Detection and Protection (PDP) Indicator for DAC2 and DAC3. |
| 59 | PDP OUTO | PDP Indicator for DAC0 and DAC1. |
| 60 | $\overline{\mathrm{IRQ}}$ | Interrupt Request (Active Low, Open Drain). |
| 61 | $\overline{\text { RESET }}$ | Reset (Active Low). CMOS levels with are determined with respect to IOVDD. |
| 62 | SDO | Serial Port Data Output. CMOS levels with are determined with respect to IOVDD. |
| 63 | SDIO | Serial Port Data Input/Output. CMOS levels with are determined with respect to IOVDD. |
| 64 | SCLK | Serial Port Clock Input. CMOS levels with are determined with respect to IOVDD. |
| 65 | $\overline{C S}$ | Serial Port Chip Select (Active Low). CMOS levels with are determined with respect to IOVDD. |
| 66 | IOVDD | CMOS Input/Output and SPI Pin Supply. |
| $\begin{aligned} & 67,70,72,75, \\ & 77,80,82,85 \end{aligned}$ | AVDD33 | 3.3V Analog Supplies for the DAC Cores. |
| 68 | OUT3+ | DAC3 Positive Current Output. |
| 69 | OUT3- | DAC3 Negative Current Output. |
| 71, 76, 81, 87 | CVDD12 | 1.2 V Clock Supplies. |
| 73 | OUT2- | DAC2 Negative Current Output. |
| 74 | OUT2+ | DAC2 Positive Current Output. |
| 78 | OUT1+ | DAC1 Positive Current Output. |
| 79 | OUT1- | DAC1 Negative Current Output. |
| 83 | OUT0- | DAC0 Negative Current Output. |
| 84 | OUT0+ | DAC0 Positive Current Output. |
| 86 | 1120 | Output Current Generation Pin for DAC Full-Scale Current. Tie a $4 \mathrm{k} \Omega$ resistor from this pin to ground. |
| 88 | $\begin{aligned} & \text { LDO_BYP2 } \\ & \text { EPAD } \end{aligned}$ | LDO Clock Bypass for the DAC PLL. Tie a $1 \Omega$ resistor in series with a $1 \mu \mathrm{~F}$ capacitor from this pin to ground. Exposed Pad. The exposed pad must be securely connected to the ground plane. |

## TYPICAL PERFORMANCE CHARACTERISTICS



Figure 4. Single Tone ( 0 dBFS ) SFDR vs. fout in the First Nyquist Zone over $f_{D A C}=1966.08 \mathrm{MHz}$ and 1228.80 MHz , All Four DAC Outputs


Figure 5. Single Tone (0 dBFS) SFDR vs. fout in the First Nyquist Zone over $f_{D A C}=1474.56 \mathrm{MHz}$ and 983.04 MHz , All Four DAC Outputs


Figure 6. Single Tone (0 dBFS) SFDR vs. fout in the First Nyquist Zone over $f_{D A C}=1966.08 \mathrm{MHz}, 1474.56 \mathrm{MHz}, 1228.8 \mathrm{MHz}$, and 983.04 MHz


Figure 7. Single Tone SFDR vs. fout in the First Nyquist Zone over Digital Back Off, $f_{D A C}=1966.08 \mathrm{MHz}$


Figure 8. In-Band Second Harmonic vs. fout in the First Nyquist Zone over Digital Back Off, $f_{D A C}=1966.08 \mathrm{MHz}$


Figure 9. In-Band Third Harmonic vs. fout in the First Nyquist Zone,
$f_{D A C}=1966.08 \mathrm{MHz}$


Figure 10. In-Band Second Harmonic vs. fout in the
First Nyquist Zone over Analog Full-Scale Current, $f_{D A C}=1966.08 \mathrm{MHz}$


Figure 11. In-Band Third Harmonic vs. fout in the First Nyquist Zone over Analog Full-Scale Current, $f_{D A C}=1966.08 \mathrm{MHz}$


Figure 12. Two-Tone Third Harmonic (IMD3) vs. $f_{\text {OUT }}, f_{D A C}=1966.08 \mathrm{MHz}$, 1474.56 MHz, 1228.8 MHz, and 983.04 MHz


Figure 13. Two-Tone Third Harmonic (IMD3) vs. fout over Digital Backoff


Figure 14. Two-Tone Third Harmonic (IMD3) vs. fout over Analog Full-Scale Current, $f_{D A C}=1966.08 \mathrm{MHz}$


Figure 15. Single Tone (0 dBFS) NSD vs. fout over $f_{\text {DAC }}=1966.08 \mathrm{MHz}$, 1474.56 MHz, 1228.8 MHz, and 983.04 MHz at 70 MHz


Figure 16. Single Tone ( 0 dBFS ) NSD vs. fout over $f_{D A C}$ 20 MHz Offset from Carrier


Figure 17. Single Tone NSD vs. fout over Digital Back Off, $f_{D A C}=1966.08 \mathrm{MHz}$, Measured at 70 MHz


Figure 18. Single Tone NSD vs. fout, $f_{D A C}=1966.08 \mathrm{MHz}$, Measured at 70 MHz , PLL On and Off


Figure 19. 1-Channel (1C) 5 MHz BW LTE, First Adjacent ACLR vs. fout, PLL On and Off


Figure 20.1C 5 MHz BW LTE, Second Adjacent ACLR vs. fout, PLL On and Off


Figure 21. Two-Tone, Third IMD Performance, IF $=180 \mathrm{MHz}$
$f_{D A C}=1966.08 \mathrm{MHz}$


Figure 22. 1C 5 MHz BW LTE ACLR Performance, $I F=180 \mathrm{MHz}$, $f_{D A C}=1966.08 \mathrm{MHz}$


Figure 23. 1C 20 MHz BW LTE ACLR Performance, $I F=180 \mathrm{MHz}$, $f_{D A C}=1966.08 \mathrm{MHz}$


Figure 24. Single Tone $f_{\text {DAC }}=1966.08 \mathrm{MHz}, f_{\text {OUT }}=280 \mathrm{MHz},-14 \mathrm{dBFS}$


Figure 25. 2-Channel (2C) 5 MHz BW with 5 MHz Gap, LTE ACLR Performance, $I F=180 \mathrm{MHz}, f_{D A C}=1966.08 \mathrm{MHz}$ (Total LTE Carrier Power is 20.982 dBm)


Figure 26. Single Tone SFDR $f_{D A C}=1966.08 \mathrm{MHz}, 4 \times$ Interpolation, $f_{\text {OUT }}=10 \mathrm{MHz},-14 \mathrm{dBFS}$


Figure 27. 6-Channel (6C) Spaced by 600 kHz GSM, Enhanced Data Rates for GSM Evolution (EDGE) Adjacent Channel Power (ACP) IMD Performance, IF $=180 \mathrm{MHz}, f_{D A C}=1966.08 \mathrm{MHz}$


Figure 28. Total Power Consumption vs. $f_{D A C}$ over Interpolation


Figure 29. DVDD12 Supply Current vs. $f_{D A C}$ over Interpolation


Figure 30. Additive DVDD12 Supply Current vs. fDAC over Digital Functions


Figure 31. AVDD33, CVDD12, and PVDD12 Supply Current vs. $f_{D A C}$


Figure 32. Total SERDES Supply Current (SVDD12) vs. Lane Rate: 2, 4, and 8 Lanes


Figure 33. Single Tone Phase Noise vs. Offset Frequency at Four Different fout Rates, $f_{D A C}=2.0 \mathrm{GHz}$, PLL Off


Figure 34. Single Tone Phase Noise vs. Offset Frequency at Four Different fout Rates, $f_{D A C}=2.0 \mathrm{GHz}$, PLL On


Figure 35. 1C 256 Point Quadrature Amplitude Modulation (QAM) Signal ACLR Performance, $I F=180 \mathrm{MHz}, f_{D A C}=1966.08 \mathrm{MHz}$

## TERMINOLOGY

## Integral Nonlinearity (INL)

INL is the maximum deviation of the actual analog output from the ideal output, determined by a straight line drawn from zero scale to full scale.

## Differential Nonlinearity (DNL)

DNL is the measure of the variation in analog value, normalized to full scale, associated with a 1 LSB change in digital input code.

## Offset Error

Offset error is a measure of how far from full-scale range (FSR) the DAC output current is at $25^{\circ} \mathrm{C}$ (in ppm).

## Gain Error

Gain error is the difference between the actual and ideal output span. The actual span is determined by the difference between the output when the input is at its minimum code and the output when the input is at its maximum code.

## Output Compliance Range

The output compliance range is the range of allowable voltages at the output of a current output DAC. Operation beyond the maximum compliance limits can cause either output stage saturation or breakdown, resulting in nonlinear performance.

## Temperature Drift

Temperature drift is specified as the maximum change from the ambient value $\left(25^{\circ} \mathrm{C}\right)$ to the value at either $\mathrm{T}_{\text {MIN }}$ or $\mathrm{T}_{\text {MAX }}$. For offset and gain drift, the drift is reported in ppm of FSR per degree Celsius.

## Settling Time

Settling time is the time required for the output to reach and remain within a specified error band around its final value, measured from the start of the output transition.

## Spurious-Free Dynamic Range (SFDR)

SFDR is the difference, in decibels, between the peak amplitude of the output signal and the peak spurious signal within the dc to Nyquist frequency of the DAC. Typically, energy in this band is rejected by the interpolation filters. This specification, therefore, defines how well the interpolation filters work and the effect of other parasitic coupling paths on the DAC output.

## Interpolation Filter

If the digital inputs to the DAC are sampled at a multiple rate of $\mathrm{f}_{\text {DATA }}$ (interpolation rate), a digital filter can be constructed that has a sharp transition band near $\mathrm{f}_{\mathrm{DATA}} / 2$. Images that typically appear around $f_{D A C}$ (output data rate) can be greatly suppressed.

## Adjacent Channel Leakage Ratio (ACLR)

ACLR is the ratio in decibels relative to the carrier ( dBc ) between the measured power within a channel relative to its adjacent channel.

## Complex Image Rejection

In a single sideband upconversion, two images are created around the second IF frequency; the desired signal is on one of these images. The other signal is unwanted, and a complex modulator rejects this unwanted image.

## Adjusted DAC Update Rate

The adjusted DAC update rate the DAC update rate divided by the selected interpolation factor.

## Physical Lane

Physical Lane x refers to SERDINx $\pm$.
Logical Lane
Logical Lane x refers to physical lanes after optionally being remapped by the crossbar block (Register 0x308 to Register 0x30B).

## Link Lane

Link Lane x refers to logical lanes considered per link. When paging Link 0 (Register 0x300, Bit $2=0$ ), Link Lane $\mathrm{x}=$ Logical Lane x . When paging Link 1 (Register 0x300, Bit $2=1$, dual link only), Link Lane $\mathrm{x}=$ Logical Lane $\mathrm{x}+4$.

## THEORY OF OPERATION

The AD9154 is a 16-bit, quad DAC with a SERDES interface. Figure 2 shows a detailed functional block diagram of the AD9154. Eight high speed serial lanes carry data into the AD9154.
The clock for the input data is derived from the device clock (as called out in the JESD204B specification). This device clock can be sourced with a phase-locked loop (PLL) reference clock used by the on-chip PLL to generate a DAC clock or a high fidelity direct external DAC sampling clock. The device can be configured to operate in one-, two-, four-, or eight-lane modes, depending on the required input data rate. The quad DAC can be configured as a dual link device with each JESD204B link providing data for a dual DAC pair to add application flexibility.
The signal processing datapath of the AD9154 offers four interpolation modes ( $1 \times, 2 \times, 4 \times$, and $8 \times$ ) through three half-band filters. An inverse sinc filter compensates for DAC output sinc rolloff. A digital inphase and quadrature modulator upcoverts a pair of DAC input signals to an IF frequency within the first Nyquist zone of the DAC programmed into an NCO. Gain, phase, dc offset, and group delay adjustments can programmably predistort the DAC input signals to improve LO feedthrough and unwanted sideband cancellation performance of an analog quadrature modulator following the AD9154 in a transmitter signal chain.

The AD9154 DAC cores provide a differential current output with a nominal full-scale current of 20 mA . The differential current outputs are optimized for integration with the Analog Devices ADRF6720-27 wideband quadrature modulator. The AD9154 has a mechanism for multichip synchronization, as well as a mechanism for achieving deterministic latency (latency locking). The latency for each DAC remains constant from link establishment to link establishment. The AD9154 makes use of the JESD204B Subclass 1 SYSREF signal to establish multichip synchronization.
The various functional blocks and the data interface must be set up in a specific sequence for proper operation (see the Device Setup Guide section). This data sheet describes the various blocks of the AD9154 in detail, including descriptions of the JESD204B interface, the control parameters, and the various registers that set up and monitor the device. The recommended start-up routine reliably sets up the data link.

## SERIAL PORT OPERATION

The serial port interface (SPI) is a flexible, synchronous serial communications port that allows easy interfacing with many industry-standard microcontrollers and microprocessors. The interface facilitates read/write access to all registers that configure the AD9154. MSB first or LSB first transfer formats are supported. The SPI is configurable as a 4 -wire interface or a 3-wire interface in which the input and output share a single-pin I/O, SDIO.


There are two phases to a communication cycle with the AD9154. Phase 1 is the instruction cycle (the writing of an instruction byte into the device), coincident with the first 16 SCLK rising edges. The instruction word provides the serial port controller with information regarding the data transfer cycle, Phase 2 of the communication cycle. The Phase 1 instruction word defines whether the upcoming data transfer is a read or write, along with the starting register address for the following data transfer.
A logic high on the $\overline{\mathrm{CS}}$ pin, followed by a logic low, resets the serial port timing to the initial state of the instruction cycle. From this state, the next 16 rising SCLK edges represent the instruction bits of the current input/output (I/O) operation.
The remaining SCLK edges are for Phase 2 of the communication cycle. Phase 2 is the actual data transfer between the device and the system controller. Phase 2 of the communication cycle is a transfer of one or more data bytes. Eight $\times$ N SCLK cycles are needed to transfer N bytes during the transfer cycle. Registers change immediately upon writing to the last bit of each transfer byte, except for the frequency tuning word (FTW) and numerically controlled oscillator (NCO) phase offsets, which change only when the frequency tuning word FTW_UPDATE_REQ bit is set.

## DATA FORMAT

The instruction byte contains the information shown in Table 13.
Table 13. Serial Port Instruction Word

| I15 (MSB) | $\mathrm{I}[14: 0]$ |
| :--- | :--- |
| $\mathrm{R} / \overline{\mathrm{W}}$ | $\mathrm{A}[14: 0]$ |

$\mathrm{R} / \overline{\mathrm{W}}$, Bit 15 of the instruction word, determines whether a read or a write data transfer occurs after the instruction word write. Logic 1 indicates a read operation, and Logic 0 indicates a write operation.
A14 to A0, Bit 14 to Bit 0 of the instruction word, determine the register accessed during the data transfer portion of the communication cycle. For multibyte transfers, $\mathrm{A}[14: 0]$ is the starting address. The device generates the remaining register addresses based on the address increment bits. If the address increment bits are set high (Register 0x000, Bit 5 and Bit 2), multibyte SPI writes start on $\mathrm{A}[14: 0]$ and increment by 1 every eight bits sent/ received. If the address increment bits are set to 0 , the address decrements by 1 every eight bits.

## SERIAL PORT PIN DESCRIPTIONS

## Serial Clock (SCLK)

The serial clock pin synchronizes data to and from the device and runs the internal state machines. The maximum frequency of SCLK is specified in Table 2. All data input is registered on the rising edge of SCLK. All data is driven out on the falling edge of SCLK.

## Chip Select ( $\overline{C S}$ )

An active low input starts and gates a communication cycle. It allows the use of more than one device on the same serial communications lines. The SDIO pin goes to a high impedance state when this input is high. During the communication cycle, chip select must stay low.

## Serial Data I/O (SDIO)

This pin is a bidirectional data line. In 4-wire mode, this pin acts as the data input and SDO acts as the data output.

## SERIAL PORT OPTIONS

The serial port can support both MSB first and LSB first data formats. The LSB first bits (Register 0x000, Bit 6 and Bit 1) control this functionality. The default is MSB first (the LSB first bits $=0$ ).

When the LSB first bits $=0$ (MSB first), the instruction and data bits must be written from MSB to LSB. R/W is followed by A [14:0] as the instruction word, and $\mathrm{D}[7: 0]$ is the data-word. When the LSB first bits =1 (LSB first), the opposite is true. $\mathrm{A}[0: 14]$ is followed by $\mathrm{R} / \overline{\mathrm{W}}$, which is subsequently followed by $\mathrm{D}[0: 7]$.
The serial port supports a 3-wire or 4 -wire interface. When the SDO active bits $=1$ (Register 0x000, Bit 4 and Bit 3), a 4 -wire interface with a separate input pin (SDIO) and output pin (SDO) is used. When the SDO active bits $=0$, the SDO pin is unused and the SDIO pin is used for both input and output.

Multibyte data transfers can be performed as well. Hold the $\overline{\mathrm{CS}}$ pin low for multiple data transfer cycles (eight SCLKs) after the first data transfer word following the instruction cycle. The first eight SCLKs following the instruction cycle read from or write to the register provided in the instruction cycle. For each additional eight SCLK cycles, the address is either incremented or decremented and the read/write occurs on the new register. Set the direction of the address using the address increment bits (Register 0x000, Bit 5 and Bit 2).

When the address increment bits $=1$, the multicycle addresses are incremented. When the address increment bits $=0$, the addresses are decremented. A new write cycle can always be initiated by bringing $\overline{\mathrm{CS}}$ high and then low again.
During writes to Register 0x0000 only, the chip tests the first nibble following the address phase, ignoring the second nibble. This is completed independently from the LSB first bit and ensures that there are extra clock cycles following the soft reset bits (Register 0x000, Bit 0 and Bit 7).


Figure 37. Serial Register Interface Timing, MSB First, Address Increment Bits $=0$


Figure 38. Serial Register Interface Timing, LSB First, Address Increment Bits $=1$


Figure 39. Timing Diagram for Serial Port Register Read


Figure 40. Timing Diagram for Serial Port Register Write

## CHIP INFORMATION

Register 0x003 to Register 0x006 contain chip information, as shown in Table 14.
Table 14. Chip Information

| Information | Description |
| :--- | :--- |
| Chip Type | The product is a high speed DAC represented by a code of 0x04 in Register 0x003. |
| Product ID | 8 MSBs in Register 0x005 and 8 LSBs in Register 0x004. The product ID is 0x9154. |
| Product Grade | Register 0x006, Bits[7:4]. The product grade is 0x9. |
| Device Revision | Register 0x006, Bits[3:0]. The device revision is 0x9. |

## DEVICE SETUP GUIDE

Follow these steps to properly set up the AD9154:

1. Set up the SPI interface, power up necessary circuit blocks, make required writes to the configuration registers, and set up the DAC clocks (see Step 1: Start Up the DAC).
2. Set the digital features of the AD9154 (see Step 2: Digital Datapath).
3. Set up the JESD204B links (see Step 3: Transport Layer).
4. Set up the physical layer of the SERDES interface (see Step 4: Physical Layer).
5. Set up the data link layer of the SERDES interface (see Step 5: Data Link Layer).
6. Check for errors (see Step 6: Error Monitoring).
7. Enable any additional datapath features needed as described in Table 19.

A specific working start-up sequence example is given in the Example Start-Up Sequence section.
The register writes listed in Table 15 to Table 22 are necessary writes to set up the AD9154. Consider printing out this setup guide and filling in the Value column with appropriate variable values for the conditions of the desired application.

The value notation 0 x without a specified value setting indicates register settings that must be filled in by the user. To fill in the unknown register values, select the correct settings for each variable listed in the Variable column of Table 15 to Table 22. The Description column describes how to set variables, or provides a link to a section where this procedure is described. Register settings with specified values are fixed settings to be used in all cases.

A variable is noted by concatenating multiple terms. For example, PdDACs is a variable corresponding to the value that is determined for Register 0x011[6:3] in the Device Setup Guide section.

## STEP 1: START UP THE DAC

This section describes how to set up the SPI interface, power up necessary circuit blocks, as well as the required writes to the configuration registers, and how to set up the DAC clocks.

Table 15. Power-Up and DAC Initialization Settings

| Addr. | Bit <br> No. | Value $^{\mathbf{1}}$ | Variable | Description |
| :--- | :--- | :--- | :--- | :--- |
|  |  | $0 \times B D$ |  | Soft reset. |
| $0 \times 000$ |  | $0 \times 3 C$ |  | Deassert reset, set 4-wire SPI. |
| $0 \times 011$ |  | $0 x$ |  | Power-up band gap. |
|  | 7 | 0 |  | PdDACs |
|  | $[6: 3]$ |  | PdDACs = if all four DACs are <br> being used. If not, see the DAC <br> Power-Down Setup section. |  |
| $0 \times 080$ | $[7: 6]$ | PdClocks | PdClocks = 0 if all four DACs are <br> being used. If not, see the DAC <br> Power-Down Setup section. |  |
| $0 \times 081$ | 1 | $0 x 1$ | DUTY_EN | Always set DUTY_EN = 2 |
|  |  | PdSysref | PdSysref = 0x00 for Subclass 1. <br> PdSysref = 0x10 for Subclass 0. <br> See the Subclass Setup section <br> for details on subclass. |  |

${ }^{1} 0 x$ denotes a register value that the user must fill in. See the Variable and Description columns for information on selecting the appropriate register value.

The registers in Table 16 must be written to and the values changed from default for the device to work correctly. These registers must be written to after any soft reset, hard reset, or on a power-up.

Table 16. Required Device Configurations

| Addr. | Value | Description |
| :--- | :--- | :--- |
| $0 \times 12 \mathrm{D}$ | $0 \times 8 \mathrm{~B}$ | Digital datapath configuration |
| $0 \times 146$ | $0 \times 01$ | Digital datapath configuration |
| $0 \times 333$ | $0 \times 01$ | JESD interface configuration |

If using the optional DAC PLL, also set the registers in Table 17.
Table 17. Optional DAC PLL Configuration Procedure

| Addr. | Value ${ }^{1}$ | Variable | Description |
| :---: | :---: | :---: | :---: |
| 0x087 | 0x62 |  | Optimal DAC PLL loop filter settings |
| 0x088 | $0 \times C 9$ |  | Optimal DAC PLL loop filter settings |
| 0x089 | OxOE |  | Optimal DAC PLL loop filter settings |
| 0x08A | $0 \times 12$ |  | Optimal DAC PLL CP settings |
| 0x08D | $0 \times 7 B$ |  | Optimal DAC LDO settings for DAC PLL |
| 0x1B0 | $0 \times 00$ |  | Power DAC PLL blocks when power machine disabled |
| 0x1B5 | 0xC9 |  | Optimal DAC PLL VCO settings |
| 0x1B9 | 0x24 |  | Optimal DAC PLL calibration options settings |
| 0x1BC | 0x0D |  | Optimal DAC PLL block control settings |
| 0x1BE | $0 \times 02$ |  | Optimal DAC PLL VCO power control settings |
| 0x1BF | 0x8E |  | Optimal DAC PLL VCO calibration settings |
| $0 \times 1 \mathrm{C} 0$ | $0 \times 2 \mathrm{~A}$ |  | Optimal DAC PLL lock counter length setting |
| 0x1C1 | $0 \times 2 \mathrm{~A}$ |  | Optimal DAC PLL charge pump setting |
| 0x1C4 | 0x7E |  | Optimal DAC PLL varactor settings |
| 0x1C5 | 0x06 |  | Optimal DAC PLL VCO settings |
| 0x08B | 0x | LODivMode | See the DAC PLL Setup section |
| 0x08C | 0x | RefDivMode | See the DAC PLL Setup section |
| 0x085 | 0x | BCount | See the DAC PLL Setup section |
| Various | 0x | LookUpVals | See the DAC PLL Setup section |
| 0x083 | 0x10 |  | Enable DAC PLL ${ }^{2}$ |

${ }^{1} 0 x$ denotes a register value that the user must fill in. See the Variable and Description columns for information on selecting the appropriate register value.
${ }^{2}$ Verify that Register 0x084[1] reads back 1 after enabling the DAC PLL to indicate that the DAC PLL has locked.

## STEP 2: DIGITAL DATAPATH

The digital datapath selects interpolation mode and the data format. Additional digital datapath capabilities are shown in Table 19.

Table 18. Digital Datapath Settings

| Addr. | Bit No. | Value $^{\mathbf{1}}$ | Variable | Description |
| :--- | :--- | :--- | :--- | :--- |
| $0 \times 112$ |  | $0 x$ | InterpMode | Select the interpolation <br> mode; see the Interpolation <br> section. |
| $0 \times 110$ | 7 | $0 x$ | DataFmt | DataFmt $=0$ if twos <br> complement; DataFmt $=1$ <br> if unsigned binary. |

${ }^{1} 0 x$ denotes a register value that the user must fill in. See the Variable and Description columns for information on selecting the appropriate register value.

There are a number of signal processing functions to be enabled if needed; these are in addition to the interpolation mode.

Table 19. Digital Datapath Signal Processing Functions

| Feature | Default | Description |
| :--- | :--- | :--- |
| Digital <br> Modulation <br> Inverse Sinc | Off | Modulates the data with a desired IF carrier. <br> See the Digital Datapath section. <br> Improves pass-band flatness. See the Digital <br> Digital Gain |
| Ond | Datapath section. <br> Multiplies data by a factor to compensate <br> inverse sinc usage or balance I/Q amplitude. <br> See the Digital Datapath section. |  |
| Phase Adjust | Off | Balances I/Q phase. See the Digital Datapath <br> section. <br> Cancels LO leakage. See the Digital Datapath |
| Group Delay | 0 | section. <br> Controls overall latency. See the Digital <br> Datapath section. |
| Downstream <br> Protection | Off | Protects downstream components. See the <br> Digital Datapath section. |

## STEP 3: TRANSPORT LAYER

This section describes how to set up the JESD204B links. The desired JESD204B operating mode determines the parameters. See the JESD204B Setup section for details.

Table 20. Transport Layer Settings

| Addr. | Bit <br> No. | Value ${ }^{1}$ | Variable | Description |
| :---: | :---: | :---: | :---: | :---: |
| 0x200 |  | 0x00 |  | Power up the interface. |
| 0x201 |  | 0x | UnusedLanes | See the JESD204B Setup section. |
| 0x300 |  | 0x |  |  |
|  | 6 |  | CheckSumMode | See the JESD204B Setup section. |
|  | 3 |  | DualLink | See the JESD204B Setup section. |
|  | 2 |  | CurrentLink | See the JESD204B Setup section. |
| 0x450 |  | 0x | DID | Set DID to match the device ID sent by the transmitter. |
| 0x451 |  | 0x | BID | Set BID to match the bank ID sent by the transmitter. |
| 0x452 |  | 0x | LID | Set LID to match the lane ID sent by the transmitter. |
| 0x453 |  | 0x |  |  |
|  | 7 |  | Scrambling | See the JESD204B Setup section. |
|  | [4:0] |  | $\mathrm{L}-1^{2}$ | See the JESD204B Setup section. |
| 0x454 |  | 0x | $\mathrm{F}-1^{2}$ | See the JESD204B Setup section. |
| 0x455 |  | 0x | $\mathrm{K}-1^{2}$ | See the JESD204B Setup section. |
| 0x456 |  | 0x | $\mathrm{M}-1^{2}$ | See the JESD204B Setup section. |
| 0x457 |  | 0x | $\mathrm{N}-1^{2}$ | $\mathrm{N}=16$. |
| 0x458 |  | 0x |  |  |
|  | 5 |  | Subclass | See the JESD204B Setup section. |
|  | [4:0] |  | Np-12 | Np $=16$. |


| Addr. | Bit <br> No. | Value ${ }^{1}$ | Variable | Description |
| :--- | :--- | :--- | :--- | :--- |
| $0 \times 459$ |  | $0 x$ |  |  |
|  | $[7: 5]$ |  | JESDVer | JESDVer $=1$ for JESD204B, <br> JESDVer = 0 for JESD204A. |
|  | $[4: 0]$ |  | $\mathrm{S}-1^{2}$ | See the JESD204B Setup <br> section. |
| $0 \times 45 \mathrm{~A}$ | 7 | $0 x$ | HD | See the JESD204B Setup <br> section. |
|  | $[4: 0]$ |  | CF | CF =0 |
| $0 \times 45 \mathrm{D}$ |  | $0 x$ | Lane0Checksum | See the JESD204B Setup <br> section. |
| $0 \times 46 \mathrm{C}$ |  | $0 x$ | Lanes | Deskew lanes. |
| $0 \times 476$ |  | $0 x$ | F | See the JESD204B Setup <br> section. |
| $0 \times 47 \mathrm{D}$ |  | $0 x$ | Lanes | Enable lanes. See the <br> JESD204B Setup section. |

${ }^{1} 0 x$ denotes a register value that the user must fill in. See the Variable and Description columns for information on selecting the appropriate register value.
${ }^{2}$ This JESD204B link parameter is programmed in $\mathrm{n}-1$ notation as noted. For example, if the setup requires $L=8$ ( 8 lanes per link), program $L-1$ or 7 into Register 0x453, Bits[4:0].

If using dual link, perform writes from Register 0x300 to Register 0x47D with CurrentLink $=0$, and then repeat the same set of register writes with CurrentLink $=1$. Write to Register 0x200 and Register 0x201 only once.

## STEP 4: PHYSICAL LAYER

This section describes how to set up the physical layer of the SERDES interface. In this section, the input termination settings are configured along with the CDR sampling and SERDES PLL.

Table 21. Device Configurations and Physical Layer Settings

| Addr. | Bit No. | Value ${ }^{1}$ | Variable | Description |
| :---: | :---: | :---: | :---: | :---: |
| 0x2A7 |  | 0x01 |  | Autotune PHY setting |
| 0x2AE |  | 0x01 |  | Autotune PHY setting |
| 0x314 |  | 0x01 |  | SERDES SPI configuration |
| 0x230 |  | 0x |  |  |
|  | 5 |  | Halfrate | Set up the CDR; see the SERDES Clocks Setup section |
|  | [4:2] | 0x2 |  |  |
|  | [2:1] |  | OvSmp | Set up the CDR; see the SERDES Clocks Setup section |
| 0x206 |  | 0x00 |  | Reset the CDR |
| 0x206 |  | 0x01 |  | Release the CDR reset |
| 0x289 |  | 0x |  |  |
|  | 2 | 1 |  | SERDES PLL configuration |
|  | [1:0] |  | PLLDiv | Set the CDR oversampling for PLL; see the SERDES Clocks Setup section |
| 0x284 |  | 0x62 |  | Optimal SERDES PLL loop filter |
| 0x285 |  | 0xC9 |  | Optimal SERDES PLL loop filter |
| 0x286 |  | 0x0E |  | Optimal SERDES PLL loop filter |
| 0x287 |  | 0x12 |  | Optimal SERDES PLL CP |
| 0x28A |  | 0x7B |  | Optimal SERDES PLL VCO LDO |
| 0x28B |  | 0x00 |  | Optimal SERDES PLL PD |
| 0x290 |  | 0x89 |  | Optimal SERDES PLL VCO |
| 0x291 |  | 0x4C |  | Optimal SERDES PLL VCO |
| 0x294 |  | 0x24 |  | Optimal SERDES PLL CP |
| 0x296 |  | 0x1B |  | Optimal SERDES PLL VCO |
| 0x297 |  | 0x0D |  | Optimal SERDES PLL VCO |
| 0x299 |  | 0x02 |  | Optimal SERDES PLL PD |
| 0x29A |  | 0x8E |  | Optimal SERDES PLL VCO |
| 0X29C |  | 0x2A |  | Optimal SERDES PLL CP |
| 0x29F |  | 0x7E |  | Optimal SERDES PLL VCO |
| 0x2A0 |  | 0x06 |  | Configure SERDES PLL VCO |
| 0x280 |  | 0x01 |  | Enable SERDES PLL ${ }^{2}$ |
| 0x268 |  | 0x |  |  |
|  | [7:6] |  | EqMode | See the Equalization Mode Setup section |
|  | [5:0] | $0 \times 22$ |  | Required value (default) |

${ }^{1} 0 x$ denotes a register value that the user must fill in. See the Variable and Description columns for information on selecting the appropriate register value.
${ }^{2}$ Verify that Register 0x281, Bit 0 reads back 1 after enabling the SERDES PLL to indicate that the SERDES PLL has locked.

## STEP 5: DATA LINK LAYER

This section describes how to set up the data link layer of the SERDES interface. This section deals with SYSREF processing, setting deterministic latency, and establishing the link.

Table 22. Data Link Layer Settings

| Address | Bit No. | Value ${ }^{1}$ | Variable | Description |
| :---: | :---: | :---: | :---: | :---: |
| 0x301 |  | 0x | Subclass | See the JESD204B Setup section. |
| 0x304 |  | 0x | LMFCDel | See the Link Latency Setup section. |
| 0x305 |  | 0x | LMFCDel | See the Link Latency section. |
| 0x306 |  | 0x | LMFCVar | See the Link Latency Setup section. |
| 0x307 |  | 0x | LMFCVar | See the Link Latency Setup section. |
| 0x03A |  | 0x01 |  | Set sync mode = oneshot sync; see the Syncing LMFC Signals section for other sync options. |
| 0x03A |  | 0x81 |  | Enable the sync machine. |
| 0x03A |  | $0 \times C 1$ |  | Arm the sync machine. |
| SYSREF $\pm$ |  |  |  | If Subclass $=1$, ensure that at least one SYSREF $\pm$ edge is sent to the device. ${ }{ }^{2}$ |
| $\begin{aligned} & 0 \times 308 \text { to } \\ & 0 \times 30 B \end{aligned}$ |  | 0x | XBarVals | If remapping lanes, set up crossbar; see the Crossbar Setup section. |
| 0x334 |  | 0x | InvLanes | Invert the polarity of desired logical lanes. Bit x of InvLanes must be a 1 for each Logical Lane x to invert. |
| $0 \times 300$ |  | 0x |  | Enable the links. |
|  | 6 |  | CheckSum Mode | See the JESD204B Setup section. |
|  | 3 |  | DualLink | See the JESD204B Setup section. |
|  | [1:0] |  | EnLinks | EnLinks = 3 if DualLink $=1$ (enables Link 0 and Link 1); EnLinks = 1 if DualLink $=0$ (enables Link 0 only). |

${ }^{1} 0 x$ denotes a register value that the user must fill in. See the Variable and Description columns for information on selecting the appropriate register value.
${ }^{2}$ Verify that Register 0x03B, Bit 3 reads back 1 after sending at least one SYSREF $\pm$ edge to the device to indicate that the LMFC sync machine has properly locked.

## STEP 6: ERROR MONITORING

For JESD204B error monitoring, see the JESD204B Error Monitoring section. For other error checks, see the Interrupt Request Operation section.

## DAC PLL SETUP

This section explains how to select appropriate LODivMode, RefDivMode, and BCount in the Step 1: Start Up the DAC section. These parameters depend on the desired DAC clock frequency ( $\mathrm{f}_{\mathrm{DACCLK}}$ ) and DAC reference clock frequency ( $\mathrm{f}_{\text {REF }}$ ). When using the DAC PLL, the reference clock signal is applied to the CLK $\pm$ differential pins, Pin 2 and Pin 3.

Table 23. DAC PLL LODivMode Settings

|  | LODIVMODE, |
| :--- | :--- |
| DAC Frequency Range (MHz) | Register 0x08B[1:0] |
| 1500 to 2400 | 1 |
| 750 to 1500 | 2 |
| 420 to 750 | 3 |

Table 24. DAC PLL RefDivMode Settings

| DAC PLL Reference <br> Frequency $\left(\mathbf{f}_{\text {REF }}\right)(\mathbf{M H z})$ | Divide by <br> (RefDivFactor) | REFDIVMODE, <br> Register 0x08C[2:0] |
| :--- | :--- | :--- |
| 35 to 80 | 1 | 0 |
| 80 to 160 | 2 | 1 |
| 160 to 320 | 4 | 2 |
| 320 to 640 | 8 | 3 |
| 640 to 1000 | 16 | 4 |

The VCO frequency ( $\mathrm{f}_{\mathrm{vco}}$ ) is related to the DAC clock frequency according to the following equation:

$$
f_{V C O}=f_{D A C C L K} \times 2^{\text {LODivMode }+1}
$$

where $6 \mathrm{GHz} \leq \mathrm{fvco} \leq 12 \mathrm{GHz}$.
BCount must be between 6 and 127 and is calculated based on $f_{\text {DACCLK }}$ and $f_{\text {REF }}$ as follows:

$$
\text { BCount }=\text { floor }\left(\left(f_{\text {DACCLK }}\right) /\left(2 \times f_{\text {REF }} / \text { RefDivFactor }\right)\right)
$$

where RefDivFactor $=2^{\text {RefDivMode }}$ (see Table 24).
Finally, to finish configuring the DAC PLL, set the VCO control registers up as described in Table 80 based on the VCO frequency ( $\mathrm{f}_{\mathrm{Vco}}$ ).
For more information on the DAC PLL, see the DAC Input Clock Configurations section.

## INTERPOLATION

The transmit path can use zero to three cascaded interpolation filters, which each provide a $2 \times$ increase in output data rate and a low-pass function. Table 25 shows the different interpolation modes and the respective usable bandwidth, along with the maximum $f_{\text {DATA }}$ rate attainable.

Table 25. Interpolation Modes and Their Usable Bandwidth

| Interpolation Mode | InterpMode | Usable Bandwidth |
| :--- | :--- | :--- |
| $1 \times$ (bypass) | $0 \times 00$ | $0.5 \times f_{\text {DATA }}$ |
| $2 \times$ | $0 \times 01$ | $0.4 \times f_{\text {DATA }}$ |
| $4 \times$ | $0 \times 03$ | $0.4 \times f_{\text {DATA }}$ |
| $8 \times$ | $0 \times 04$ | $0.4 \times f_{\text {DATA }}$ |

The usable bandwidth is defined for $1 \times, 2 \times, 4 \times$, and $8 \times$ modes as the frequency band over which the filters have a pass-band ripple of less than $\pm 0.001 \mathrm{~dB}$ and an image rejection of greater than 85 dB . For more information, see the Interpolation section.

## JESD204B SETUP

This section explains how to select a JESD204B operating mode for a desired application. This in turn defines appropriate values for CheckSumMode, UnusedLanes, DualLink, CurrentLink, Scrambling, L, F, K, M, N, Np, Subclass, S, HD, Lane0Checksum, and Lanes needed for the Step 3: Transport Layer section.

Note that DualLink, Scrambling, L, F, K, M, N, Np, S, HD, and Subclass must have the same settings on the transmit side.
For a summary of how a JESD204B system works and what each parameter means, see the JESD204B Serial Data Interface section.

## Available Operating Modes

Table 26. JESD204B Operating Modes (Single Link Only)

| Parameter | Mode |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
|  | $\mathbf{0}$ | $\mathbf{1}$ | $\mathbf{2}$ | $\mathbf{3}$ |
| M (Converter Count) | 4 | 4 | 4 | 4 |
| L (Lane Count) | 8 | 8 | 4 | 2 |
| S ((Samples per Converter) per Frame) | 1 | 2 | 1 | 1 |
| F ((Octets per Frame) per Lane) | 1 | 2 | 2 | 4 |

Table 27. JESD204B Operating Modes (Single or Dual Link)

| Parameter | Mode |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{4}$ | $\mathbf{5}$ | $\mathbf{6}$ | $\mathbf{7}$ | $\mathbf{9}$ | $\mathbf{1 0}$ |
|  | 2 | 2 | 2 | 2 | 1 | 1 |
| L (Lane Count) | 4 | 4 | 2 | 1 | 2 | 1 |
| S ((Samples per Converter) per Frame) | 1 | 2 | 1 | 1 | 1 | 1 |
| F ((Octets per Frame) per Lane) | 1 | 2 | 2 | 4 | 1 | 2 |

For a particular application, the number of converters to use (M) and the foata (DataRate) are known. The LaneRate and number of lanes (L) can be traded off as follows:

$$
\begin{aligned}
& \text { DataRate }=(\text { DACRate }) /(\text { InterpolationFactor }) \\
& \text { LaneRate }=(20 \times \text { DataRate } \times M) / L
\end{aligned}
$$

where LaneRate is specified in Table 4.
Octets per frame per lane ( F ) and samples per convertor per frame (S) define how the data is packed. If $\mathrm{F}=1$, the high density (HD) setting must be set to $1(\mathrm{HD}=1)$. Otherwise, set $\mathrm{HD}=0$.

Both the converter resolution (N) and the bits per sample ( Np ) must be set to 16 . K must be set to 32 for Mode 0 , Mode 4 and Mode 9. Other modes may use either $\mathrm{K}=16$ or $\mathrm{K}=32$.

## DualLink

DualLink sets up two independent JESD204B links; each link can be reset independently. If DualLink is desired, set it to 1 ; if a single link is desired, set DualLink to 0 . Note that Link 0 and Link 1 must have identical parameters. The operating modes available when using dual link mode are shown in Table 26. In addition to these operating modes, the modes in Table 27 may also be used when using single link mode.

## Scrambling

Scrambling is a feature that makes the spectrum of the link data independent. This avoids spectral peaking and provides some protection against data dependent errors caused by frequency selective effects in the electrical interface. Set Scrambling to 1 if scrambling is being used, or to 0 if it is not.

## Subclass

Subclass determines whether the latency of the device is deterministic, meaning it requires an external synchronization signal. See the Subclass Setup section for more information.

## CurrentLink

To configure Link 0 or Link 1, set CurrentLink to either 0 or 1, respectively.

## Lanes

Lanes enables and deskews particular lanes in two thermometer coded registers.

$$
\text { Lanes }=\left(2^{L}\right)-1
$$

## UnusedLanes

UnusedLanes turns off unused circuit blocks to save power. Each physical lane not being used (SERDINx $\pm$ ) must be powered off by writing a 1 to the corresponding bit of Register 0x201.
For example, if using Mode 6 in dual link mode and sending data on SERDIN0 $\pm$, SERDIN1 $\pm$, SERDIN4 $\pm$, and SERDIN5 $\pm$, set UnusedLanes $=0 \times \mathrm{xCC}$ to power off Physical Lane 2, Physical Lane 3, Physical Lane 6, and Physical Lane 7.

## CheckSumMode

CheckSumMode must match the checksum mode used on the transmit side. If the checksum used is the sum of fields in the link configuration table, CheckSumMode $=0$. If summing the registers containing the packed link configuration fields, CheckSumMode $=1$. For more information on the how to calculate the two checksum modes, see the Lane0Checksum section.

## Lane0Checksum

Lane0Checksum is used for error checking purposes to ensure that the transmitter is set up as expected.

If CheckSumMode $=0$, the checksum is the lower 8 bits of the sum of the $\mathrm{L}-1, \mathrm{M}-1, \mathrm{~K}-1, \mathrm{~N}-1, \mathrm{~Np}-1, \mathrm{~S}-1$, Scrambling, HD, Subclass, and JESDVer variables.
If CheckSumMode $=1$, Lane0Checksum is the lower 8 bits of the sum of Register 0x450 to Register 0x45A. Select whether to sum by fields or by registers, matching the setting on the transmitter.

## DAC Power-Down Setup

As described in the Step 1: Start Up the DAC section, PdDACs must be set to 0 if all four converters are being used. If fewer than four converters are in use, the unused converters can be powered down. Use Table 28 determine which DACs are powered down based on the number of converters per link (M) and whether the device is in DualLink mode.

Table 28. DAC Power-Down Configuration Settings

| M (Converters <br> per Link) | DualLink | DACs to Power Down |  |  |  | PdDACs |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | $\mathbf{1}$ | $\mathbf{2}$ | $\mathbf{3}$ | PdD |  |
| 1 |  | 0 | 1 | 1 | 1 | $0 b 0111$ |
| 1 | 1 | 0 | 1 | 1 | 0 | $0 b 0110$ |
| 2 | 0 | 0 | 0 | 1 | 1 | $0 b 0011$ |
| 2 | 1 | 0 | 0 | 0 | 0 | $0 b 0000$ |
| 4 | 0 | 0 | 0 | 0 | 0 | $0 b 0000$ |

When using $\mathrm{M}=1$ in DualLink mode, set the I_TO_Q bit high to ensure data entering DAC Dual B is sent to the DAC 3 output.

## PdClocks

If both DACs in DAC Dual B (DAC2 and DAC3) are powered down, the clock for DAC Dual B can be powered down. In this case, Register 0x080, Bits[7:6] = 0x1; otherwise, Register 0x080, Bits[7:6] $=0 x 0$.

## SERDES Clocks Setup

This section describes how to select the appropriate Halfrate, OvSmp, and PLLDiv settings in the Step 4: Physical Layer section. These parameters depend solely on the lane rate. The lane rate is established in the JESD204B Setup section.

Table 29. SERDES Lane Rate Configuration Settings

| Lane Rate (Gbps) (see Table 4) | Halfrate | OvSmp | PLLDiv |
| :--- | :--- | :--- | :--- |
| CDR Oversampling Mode | 0 | 1 | 2 |
| CDR Full Rate Mode | 0 | 0 | 1 |
| CDR Half Rate Mode | 1 | 0 | 0 |

Halfrate and OvSmp set how the clock detect and recover (CDR) circuit samples. See the SERDES PLL section for an explanation of how this circuit blocks works and the role of PLLDiv in the block.

## EQUALIZATION MODE SETUP

Set EqMode $=1$ for a low power setting. Select this mode if the insertion loss in the printed circuit board (PCB) is less than 12 dB . For insertion losses greater than 12 dB but less than 17.5 dB , set EqMode $=0$. See the Equalization section for more information.

## LINK LATENCY SETUP

This section describes the steps necessary to guarantee multichip deterministic latency in Subclass 1 and guarantee synchronization of links within a device in Subclass 0 . Use this section to fill in LMFCDel, LMFCVar, and Subclass in the Step 5: Data Link Layer section. For more information, see the Syncing LMFC Signals section.

## Subclass Setup

The AD9154 supports JESD204B Subclass 0 and Subclass 1 operation.

## Subclass 1

Subclass 1 mode achieves deterministic latency and allows the synchronization of links to within the limits called out in Table 7. It requires an external SYSREF $\pm$ signal accurately phase aligned to the DAC clock.

## Subclass 0

Subclass 0 mode does not require any signal on the SYSREF $\pm$ pins; leave these pins disconnected.
Subclass 0 still requires that all lanes arrive within the same LMFC cycle and the dual DACs must be synchronized to each other (they are synchronized to an internal clock instead of the SYSREF $\pm$ signal when in Subclass 0 mode).

Set Subclass to 0 or 1 as desired.

## Link Delay Setup

LMFCVar and LMFCDel impose delays such that all lanes in a system arrive in the same LMFC cycle.
The unit used internally for delays is the period of the internal processing clock (PClock), with a rate $1 / 40^{\text {th }}$ of the lane rate. Delays that are not in PClock cycles must be converted before they are used.

Some useful internal relationships are defined below:

[^1]The PClockPeriod converts from time to PClock cycles when needed.

## PClockFactor $=4 / F($ Frames per PClock $)$

The PClockFactor converts from units of PClock cycles to frame clock cycles, which is required to set LMFCDel in Subclass 1.

$$
\text { PClocksPerMF }=\text { K/PClockFactor (PClocks per LMFC Cycle) }
$$

where PClocksPerMF is the number of PClock cycles in a multiframe cycle.

The values for PClockFactor and PClockPerMF are given per JESD204B mode in Table 30 and Table 31.

Table 30. PClockFactor and PClockPerMF Per LMFC

| JESD204B Mode ID | $\mathbf{0}$ | $\mathbf{1}$ | $\mathbf{2}$ | $\mathbf{3}$ |
| :--- | :--- | :--- | :--- | :--- |
| PClockFactor | 4 | 2 | 2 | 1 |
| PClockPerMF $(\mathrm{K}=32)$ | 8 | 16 | 16 | 32 |
| PClockPerMF $(\mathrm{K}=16)$ | Not applicable | 8 | 8 | 16 |

Table 31. PClockFactor and PClockPerMF Per LMFC

| JESD204B Mode ID | $\mathbf{4}$ | $\mathbf{5}$ | $\mathbf{6}$ | $\mathbf{7}$ | $\mathbf{9}$ | $\mathbf{1 0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| PClockFactor | 4 | 2 | 2 | 1 | 4 | 2 |
| PClockPerMF $(\mathrm{K}=32)$ | 8 | 16 | 16 | 32 | 8 | 16 |
| PClockPerMF $(\mathrm{K}=16)$ | $\mathrm{N} / \mathrm{A}^{1}$ | 8 | 8 | 16 | $\mathrm{~N} / \mathrm{A}^{1}$ | 8 |

${ }^{1} \mathrm{~N} /$ A means not applicable.

## With Known Delays

LMFCVar and LMFCDel can be calculated directly with information about all the system delays.

RxFixed (the fixed receiver delay in PClock cycles) and RxVar (the variable receiver delay in PClock cycles) are found in Table 8. TxFixed (the fixed transmitter delay in PClock cycles) and TxVar (the variable receiver delay in PClock cycles) can be found in the data sheet of the transmitter used. PCBFixed (the fixed PCB trace delay in PClock cycles) is extracted from the software. Because PCBFixed is generally much smaller than a PClock cycle, it can be omitted. For both the PCB and transmitter delays, convert the delays into PClock cycles.
For each lane,

> MinDelayLane $=$ floor $($ RxFixed + TxFixed + PCBFixed $)$ FALL_COUNT_DelayLane $=$ ceiling $($ RxFixed + RxVar + TxFixed + TxVar + PCBFixed $))$
where, across lanes, links, and devices:
MinDelayLane is the minimum of all MinDelayLane values.
FALL_COUNT_Delay is the maximum of all
FALL_COUNT_DelayLane values.
For safety, add a guard band of 1 PClock cycle to each end of the link delay, as shown in the following equations:

$$
\text { LMFCVar }=(\text { FALL_COUNT_Delay }+1)-(\text { MinDelay }-1)
$$

Note that if LMFCVar must be more than 10, the AD9154 cannot tolerate the variable delay in the system.

For Subclass 1,

$$
\text { LMFCDel }=((\text { MinDelay }-1) \times \text { PClockFactor }) \% K
$$

For Subclass 0,

$$
\text { LMFCDel }=(\text { MinDelay }-1) \% \text { PClockPerMF }
$$

Program the same LMFCDel and LMFCVar across all links and devices.

See the Link Delay Setup Example, With Known Delays section for an example calculation.

## Without Known Delays

If comprehensive delay information is not available or known, the AD9154 can read back the link latency between the LMFC $_{R x}$ and the last arriving LMFC boundary in PClock cycles. Use this information to calculate LMFCVar and LMFCDel.

For each link on each device,

1. Power up the board.
2. Follow the steps in Table 15 through Table 22 in the Device Setup Guide section.
3. Set the subclass and perform a sync. For a one-shot sync, perform the writes in Table 32. See the Syncing LMFC Signals section for alternate sync modes.
4. Record DYN_LINK_LATENCY_0 (Register 0x302) as a value of Delay for that link and power cycle.
5. Record DYN_LINK_LATENCY_1 (Register 0x303) as a value of Delay for that link and power cycle.

Repeat Step 1 through Step 5 twenty times for each device in the system. Keep a single list of the Delay values across all runs and devices.

Table 32. Register Configuration and Procedure for One-Shot Sync

| Addr. | Bit. <br> No. | Value ${ }^{1}$ | Variable | Description |
| :--- | :--- | :--- | :--- | :--- |
| $0 \times 301$ |  | $0 x$ | Subclass | Set subclass |
| $0 \times 03 A$ |  | $0 \times 01$ |  | Set sync mode $=$ one-shot <br> sync |
| $0 \times 03 A$ |  | $0 \times 81$ |  | Enable the sync machine |
| $0 \times 03 A$ |  | $0 \times C 1$ |  | Arm the sync machine |
| SYSREF $\pm$ |  |  |  | If Subclass $=1$, ensure <br> that at least one SYSREF $\pm$ <br> edge is sent to the device |
| $0 \times 300$ |  | $0 x$ |  | Enable the links |
|  | 6 |  | ChkSmMd | See the JESD204B Setup <br> section |
|  | 3 | Dual Link | See the JESD204B Setup <br> section |  |
|  | $[1: 0]$ | EnLinks | EnLinks $=3$ if in DualLink <br> mode to enable Link 0 <br> and Link 1; EnLinks 1 if <br> not in DualLink mode to <br> enable Link 0 |  |

[^2]Use the list of delay values to calculate LMFCDel and LMFCVar, but note that some of the delay values may need to be remapped first.
The maximum possible value for DYN_LINK_LATENCY_x is one less than the number of PClocks in a multiframe (PClocksPerMF). A rollover condition may be encountered, meaning the set of recorded delay values may roll over the edge of a multiframe. If so, Delay values may be near both 0 and PClocksPerMF. If this occurs, add PClocksPerMF to the set of values near 0 .
For example, for Delay value readbacks of $6,7,0$, and 1 , the 0 and 1 Delay values must be remapped to 8 and 9 , making the new set of Delay values $6,7,8$, and 9 .

Across power cycles, links, and devices,

- MinDelay is the minimum of all delay measurements.
- FALL_COUNT_Delay is the maximum of all delay measurements.

For safety, add a guard band of 1 PClock cycle to each end of the link delay and calculate LMFCVar and LMFCDel with the following equation:

$$
L M F C V a r=\left(F A L L \_C O U N T \_D e l a y+1\right)-(\text { MinDelay }-1)
$$

Note that if LMFCVar must be more than 10, the AD9154 cannot tolerate the variable delay in the system.

For Subclass 1,

$$
\text { LMFCDel }=((\text { MinDelay }-1) \times \text { PClockFactor }) \% K
$$

For Subclass 0

$$
\text { LMFCDel }=(\text { MinDelay }-1) \% \text { PClockPerMF }
$$

Program the same LMFCDel and LMFCVar across all links and devices.

See the Link Delay Setup Example, Without Known Delay section for an example calculation.

## CROSSBAR SETUP

Registers 0x308 to Register 0x30B allow arbitrary mapping of physical lanes (SERDINx $\pm$ ) to logical lanes used by the SERDES deframers.

Table 33. Crossbar Registers

| Address | Bits | Logical Lane |
| :--- | :--- | :--- |
| $0 \times 308$ | $[2: 0]$ | XBARVALO |
| $0 \times 308$ | $[5: 3]$ | XBARVAL1 |
| $0 \times 309$ | $[2: 0]$ | XBARVAL2 |
| $0 \times 309$ | $[5: 3]$ | XBARVAL3 |
| $0 \times 30 A$ | $[2: 0]$ | XBARVAL4 |
| $0 \times 30 A$ | $[5: 3]$ | XBARVAL5 |
| $0 \times 30 B$ | $[2: 0]$ | XBARVAL6 |
| $0 \times 30 B$ | $[5: 3]$ | XBARVAL7 |

Write each XBARVALy with the number ( x ) of the desired physical lane (SERDINx $\pm$ ) from which to get data. By default, all logical lanes use the corresponding physical lane as their data source. For example, by default, XBARVAL0 $=0$, meaning Logical Lane 0 receives data from Physical Lane 0 (SERDIN0 $\pm$ ). If instead the user wants to use SERDIN4 $\pm$ as the source for Logical Lane 0, the user must write XBARVAL0 $=4$.

## JESD204B SERIAL DATA INTERFACE JESD204B OVERVIEW

The JESD204B Setup section explains how to select a JESD204B operating mode. This section presents an overview of the inner workings of the AD9154 JESD204B receiver implementation.
The AD9154 has eight JESD204B data ports that receive data. The eight JESD204B ports can be configured as part of a single JESD204B link or as part of two separate JESD204B links (dual link mode) that share a single system reference (SYSREF $\pm$ ) and device clock (CLK $\pm$ ).
The JESD204B hardware protocol stack consists of three layers: the physical layer, the data link layer, and the transport layer. These sections of the hardware are described in subsequent sections, including information for configuring every aspect of the interface. Figure 41 shows the communication layers implemented in the AD9154 serial data interface to recover the clock and deserialize, descramble, and deframe the data before it is sent to the digital signal processing section of the device.
The physical layer establishes a reliable channel between the transmitter and the receiver, the data link layer unpacks the data into frames of octets and descrambles the data, and the transport layer receives the descrambled JESD204B frames and converts them to DAC input samples.

A number of JESD204B parameters (L, F, K, M, N, Np, S, and HD) define how the data is packed and instruct the device on how to turn the serial data into samples. These parameters are defined in detail in the Transport Layer section.

Only certain combinations of parameters are supported. Each supported combination is called a JESD204B operating mode. In total, there are 10 single link modes supported by the AD9154, as described in Table 34. In dual link mode, there are six supported modes, as described in Table 35.
Each of these tables shows the associated clock rates when the lane rate is 10 Gbps .

For a particular application, the number of converters to use (M) and the DataRate are known. The LaneRate and number of lanes (L) can be traded off as follows:

$$
\begin{aligned}
& \text { DataRate }=(\text { DACRate }) /(\text { InterpolationFactor }) \\
& \text { LaneRate }=(20 \times \text { DataRate } \times M) / L
\end{aligned}
$$

where LaneRate must be between 1.42 Gbps and 10.64 Gbps .
Achieving and recovering synchronization of the lanes is very important. To simplify the interface to the transmitter, the AD9154 designates a master synchronization signal for each JESD204B link. In single link mode, $\overline{\mathrm{SYNCOUT0} \pm}$ is the master signal for all lanes; in dual link mode, $\overline{\text { SYNCOUT0 } \pm \text { is the master signal for }}$ Link 0 , and SYNCOUT1 $\pm$ is used as the master signal for Link 1 . If is sent to the transmitter via the SYNCOUT signal of the link. The transmitter stops sending data and instead sends synchronization characters to all lanes in that link until resynchronization is achieved.


Figure 41. Functional Block Diagram of Serial Link Receiver
Table 34. Single Link JESD204B Operating Modes

|  |  |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Parameter | $\mathbf{0}$ | $\mathbf{1}$ | $\mathbf{2}$ | $\mathbf{3}$ | $\mathbf{4}$ | $\mathbf{5}$ | $\mathbf{6}$ | $\mathbf{7}$ | $\mathbf{9}$ | $\mathbf{1 0}$ |
| M (Converter Counts) | 4 | 4 | 4 | 4 | 2 | 2 | 2 | 2 | 1 | 1 |
| L (Lane Counts) | 8 | 8 | 4 | 2 | 4 | 4 | 2 | 1 | 2 | 1 |
| S (Samples per Converter per Frame) | 1 | 2 | 1 | 1 | 1 | 2 | 1 | 1 | 1 | 1 |
| F (Octets per Frame per Lane) | 1 | 2 | 2 | 4 | 1 | 2 | 2 | 4 | 1 | 2 |
| Example Clocks for 10 Gbps Lane Rate |  |  |  |  |  |  |  |  |  |  |
| $\quad$ PClock (MHz) | 250 | 250 | 250 | 250 | 250 | 250 | 250 | 250 | 250 | 250 |
| Frame Clock (MHz) | 1000 | 500 | 500 | 250 | 1000 | 500 | 500 | 250 | 1000 | 500 |
| Sample Clock (MHz) | 1000 | 1000 | 500 | 250 | 1000 | 1000 | 500 | 250 | 1000 | 500 |

Table 35. Dual Link JESD204B Operating Modes for Link 0 and Link 1

| Parameter | Mode |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 4 | 5 | 6 | 7 | 9 | 10 |
| M (Converter Counts) | 2 | 2 | 2 | 2 | 1 | 1 |
| L (Lane Counts) | 4 | 4 | 2 | 1 | 2 | 1 |
| S (Samples per Converter per Frame) | 1 | 2 | 1 | 1 | 1 | 1 |
| F (Octets/Frame per Lane) | 1 | 2 | 2 | 4 | 1 | 2 |
| Example Clock for 10 Gbps Lane Rate |  |  |  |  |  |  |
| PClock (MHz) | 250 | 250 | 250 | 250 | 250 | 250 |
| Frame Clock (MHz) | 1000 | 500 | 500 | 250 | 1000 | 500 |
| Sample Clock (MHz) | 1000 | 1000 | 500 | 250 | 1000 | 500 |



Figure 42. Deserializer Block Diagram

## PHYSICAL LAYER

The physical layer of the JESD204B interface, hereafter referred to as the deserializer, has eight identical channels. Each channel consists of the terminators, an equalizer, a CDR circuit, and the 1:40 demux function (see Figure 42).

JESD204B data is input to the AD9154 via the SERDINx $\pm 1.2 \mathrm{~V}$ differential input pins as per the JESD204B specification.

## Power-Down Unused PHYs

Note that any unused and enabled lanes unnecessarily consume extra power. Each lane that is not in use (SERDINx $\pm$ ) must be powered off by writing a 1 to the corresponding bit of PHY_PD (Register 0x201).

## Interface Power-Up and Input Termination

Before using the JESD204B interface, it must be powered up by setting Register $0 \times 200[0]=0$. In addition, each physical lane that is not being used (SERDINx $\pm$ ) must be powered down. To do so, set the corresponding Bit x for Physical Lane x in Register 0x201 to 0 if the physical lane is being used, and to 1 if it is not being used.

The AD9154 autocalibrates the input termination to $50 \Omega$. Register 0x2A7 controls autocalibration for PHY 0, PHY 1, PHY 6, and PHY 7. Register 0x2AE controls autocalibration for PHY 2, PHY 3, PHY 4, and PHY 5. The PHY termination autocalibration routine is shown in Table 36.

Table 36. PHY Termination Autocalibration Routine

| Address | Value | Description |
| :--- | :--- | :--- |
| $0 \times 2 \mathrm{~A} 7$ | $0 \times 01$ | Autotune PHY terminations |
| $0 \times 2 \mathrm{AE}$ | $0 \times 01$ | Autotune PHY terminations |

The input termination voltage of the DAC is sourced externally via the $V_{\text {TT }}$ pins (Pin 21, Pin 25, Pin 42, and Pin 46). Set $V_{\text {TT }}$ by connecting it to SVDD12. It is recommended that the JESD204B inputs be ac-coupled to the JESD204B transmit device using 100 nF capacitors.

## Receiver Eye Mask

The AD9154 complies with the JESD204B specification regarding the receiver eye mask and can capture data that complies with this mask without equalization. With equalization enabled, the AD9154 can reliably capture from signals with much smaller eye openings. Figure 43 shows the receiver eye mask normalized to the data rate interval with a $600 \mathrm{mV} \mathrm{V}_{\text {тт }}$ swing. See the JESD204B specification for more information regarding the eye mask and permitted receiver eye opening.


Figure 43. Receiver Eye Mask

## Equalization

To compensate for signal integrity distortions for each PHY channel due to insertion loss caused by PCB trace characteristics, the AD9154 employs an easy to use, low power equalizer on each JESD204B channel. The AD9154 equalizers can compensate for insertion losses far greater than required by the JESD204B specification. The equalizers have two modes of operation determined by the EQ_POWER_MODE register setting in Register 0x268, Bits[7:6]. In low power mode (Register 0x268, $\left.\operatorname{Bits}[7: 6]=2 b^{\prime} 01\right)$ and operating at the maximum lane rate, the equalizer can compensate for up to 12 dB of insertion loss. In normal mode (Register 0x268, Bits[7:6] = 2b'00), the equalizer can compensate for up to 17.5 dB of insertion loss. This performance is shown in Figure 44 as an overlay to the JESD204B specification for insertion loss. Figure 44 shows the equalization performance at 10.0 Gbps , near the maximum baud rate for the AD9154.

Figure 45 and Figure 46 are provided as points of reference for hardware designers and show the insertion loss for various lengths of well laid out stripline and microstrip transmission lines on FR-4 material.

Low power mode is recommended if the insertion loss of the JESD204B PCB channels is less than that of the most lossy supported channel for lower power mode (shown in Figure 44). If the insertion loss is greater than that, but still less than that of the most lossy supported channel for normal mode (shown in Figure 44), use normal mode. At 10 Gbps operation, the equalizer in normal mode consumes about 4 mW more power per lane used than in low power equalizer mode. Note that either mode can be used in conjunction with transmitter preemphasis to ensure functionality and/or to optimize for power.


Figure 44. Insertion Loss Allowed


Figure 45. Insertion Loss of $50 \Omega$ Striplines on FR-4


Figure 46. Insertion Loss of $50 \Omega$ Microstrips on FR-4

## Clock Multiplication Relationships

The following clocks rates are used throughout the rest of the JESD204B section. The relationship between any of the clocks can be derived from the following equations:

$$
\begin{aligned}
& \text { DataRate }=(\text { DACRate }) /(\text { InterpolationFactor }) \\
& \text { LaneRate }=(20 \times \text { DataRate } \times M) / L \\
& \text { ByteRate }=\text { LaneRate } / 10
\end{aligned}
$$

where:
$M$ is the JESD204B parameter for converters per link. $L$ is the JESD204B parameter for lanes per link.
$F$ is the JESD204B parameter for octets per frame per lane.
This comes from 8-bit/10-bit encoding, where each byte is represented by 10 bits.

PClockRate $=$ ByteRate $/ 4$
The processing clock is used for a quad-byte decoder.
FrameRate $=$ ByteRate $/ F$
where $F$ is defined as (bytes per frame) per lane.

$$
\text { PClockFactor }=\text { FrameRate } / \text { PClockRate }=4 / F
$$

## SERDES PLL

## Functional Overview of the SERDES PLL

The independent SERDES PLL uses integer-N techniques to achieve clock synthesis. The entire SERDES PLL is integrated on chip, including the VCO and the loop filter. The SERDES PLL VCO operates over the range of 5.65 GHz to 12 GHz .
In the SERDES PLL, a VCO divider block divides the VCO clock by 2 to generate a 2.825 GHz to 6 GHz quadrature clock for the deserializer cores. This clock is the input to the CDR block described in the Clock and Data Recovery section.
The reference clock to the SERDES PLL is always running at a frequency of $f_{\text {REF }}=1 / 40$ of the lane rate $=$ PClockRate. This clock is divided by a DivFactor to deliver a clock to the PFD block that is between 35 MHz and 80 MHz . Table 37 includes the respective SERDES_PLL_DIV_MODE register settings for each of the desired DivFactor options available.

Table 37. SERDES PLL Divider Settings

| LaneRate (Gbps) <br> (see Table 4) | Divide by <br> (DivFactor) | SPI_CDR_OVERSAMP <br> Register 0x289, Bits[1:0] |
| :--- | :--- | :--- |
| CDR <br> Oversampling <br> Mode | 1 | 2 |
| CDR Full Rate <br> Mode | 2 | 1 |
| CDR Half Rate <br> Mode | 4 | 0 |

Register 0x280 controls the synthesizer enable and recalibration.
To enable the SERDES PLL, first set the PLL divider register according to Table 37, then enable the SERDES PLL by writing Register 0x280, Bit 0 to 1.

Confirm that the SERDES PLL is working by reading Register 0x281. If Register 0x281, Bit $0=1$, the SERDES PLL is locked. If Register 0x281, Bit $3=1$, the SERDES PLL is successfully calibrated. If Register 0x281, Bit 4 or Register 0x281, Bit 5 are high, the PLL hits the upper or lower end of its calibration band and must be recalibrated by writing 0 and then 1 to Register 0x280, Bit 2.

## SERDES PLL Fixed Register Writes

To optimize the SERDES PLL across all operating conditions, the following register writes to the following locations are recommended: 0x284, 0x285, 0x286, 0x287, 0x28A, 0x28B, 0x290, 0x291, 0x294, 0x296, 0x297, 0x299, 0x29A, 0x29C, $0 \times 29 \mathrm{~F}$, and $0 \times 2 \mathrm{~A} 0$ as shown in Table 21.

## SERDES PLL IRQ

SERDES PLL lock and lost signals are available as IRQ events. Use Register 0x01F, Bit 3 and Bit2 to enable these signals, and then use Register 0x023, Bit 3 and Bit 2 to read back their statuses and reset the IRQ signals. See the Interrupt Request Operation section for more information.


Figure 47. SERDES PLL Synthesizer Block Diagram Including VCO Divider Block

## Clock and Data Recovery

The deserializer is equipped with a CDR circuit. Instead of recovering the clock from the JESD204B serial lanes, the CDR recovers the clocks from the SERDES PLL. The 2.825 GHz to 6 GHz output from the SERDES PLL, shown in Figure 47, is the input to the CDR.
Select a CDR sampling mode to generate the lane rate clock inside the device. If the desired lane rate is greater than 5.65 GHz , half rate CDR operation must be used. If the desired lane rate is less than 5.65 GHz , disable half rate operation. If the lane rate is less than 2.825 GHz , disable half rate and enable $2 \times$ oversampling to recover the appropriate lane rate clock. Table 38 breaks down the CDR sampling settings that must be set dependent on the LaneRate.

Table 38. CDR Operating Modes

| LaneRate (Gbps) <br> (See Table 4) | HALFRATE, <br> Register 0x230, <br> Bit 5 | CDR_OVERSAMP, <br> Register 0x230, <br> Bit 1 |
| :--- | :--- | :--- |
| CDR Oversampling <br> Mode | 0 | 1 |
| CDR Full Rate Mode <br> CDR Half Rate Mode | 0 | 0 |

The CDR circuit synchronizes the phase that samples the data on each serial lane independently. This independent phase adjustment per serial interface ensures accurate data sampling and eases the implementation of multiple serial interfaces on a PCB.

After configuring the CDR circuit, reset it and then release the reset by writing 1 and then 0 to Register 0x206, Bit 0 .

## DATA LINK LAYER

The data link layer of the AD9154 JESD204B interface accepts the deserialized data from the PHYs and deframes and descrambles them so that data octets are presented to the transport layer to be put into DAC samples. The architecture of the data link layer is shown in Figure 48. It consists of a synchronization FIFO for each lane, a crossbar switch, a deframer, and descrambler.

The AD9154 can operate as a single link or dual link, high speed JESD204B serial data interface. When operating in dual link mode, configure both links with the same JESD204B parameters because they share a common device clock and system reference. All eight lanes of the JESD204B interface handle link layer communications such as code group synchronization, frame alignment, and frame synchronization.

The AD9154 decodes 8-bit/10-bit control characters, allowing marking of the start and end of the frame and alignment between serial lanes. Each AD9154 serial interface link can issue a synchronization request by setting its $\overline{\text { SYNCOUT0 } \pm /}$
SYNCOUT1 $\pm$ signal low. The synchronization protocol follows Section 4.9 of the JESD204B standard. When a stream of four consecutive $/ \mathrm{K} /$ symbols is received, the AD9154 deactivates the synchronization request by setting the $\overline{\text { SYNCOUT0 }} \pm$ /
SYNCOUT1 $\pm$ signal high at the next internal LMFC rising edge. Then, it waits for the transmitter to issue a lane alignment sequence (ILAS). During the ILAS sequence, all lanes are aligned using the /A/ to / $\mathrm{R} /$ character transition as described in the JESD204B Serial Link Establishment section. Elastic buffers hold early arriving lane data until the alignment character of the latest lane arrives. At this point, the buffers for all lanes are released and all lanes are aligned (see Figure 49).


## AD9154



Figure 49. Lane Alignment During ILAS

## JESD204B Serial Link Establishment

A brief summary of the high speed serial link establishment process for Subclass 1 is provided. See Section 5.3.3 of the JESD204B specifications document for complete details.

## Step 1: Code Group Synchronization

Each receiver must locate K (K28.5) characters in its input data stream. After four consecutive K characters are detected on all link lanes, the receiver block deasserts the $\overline{\text { SYNCOUTx } \pm}$ signal to the transmitter block at the LMFC edge.
The transmitter captures the change in the $\overline{\text { SYNCOUTx } \pm}$ signal, and at a future transmitter LMFC rising edge, starts the initial ILAS.

## Step 2: Initial Lane Alignment Sequence

The main purposes of this phase are to align all the lanes of the link and verify the parameters of the link.

Before the link is established, write each of the link parameters to the receiver device to designate how data is sent to the receiver block.
The ILAS consists of four or more multiframes. The last character of each multiframe is a multiframe alignment character, /A/. The first, third, and fourth multiframes are populated with predetermined data values. Note that Section 8.2 of the JESD204B specifications document describes the data ramp expected during ILAS. By default, the AD9154 does not require this ramp. Register 0x47E[0] can be set high to require the data ramp. The deframer uses the final /A/ of each lane to align the ends of the multiframes within the receiver. The second multiframe contains an R (K.28.0), Q (K.28.4), and then data corresponding to the link parameters. Additional multiframes can be added to the ILAS if needed by the receiver. By default, the AD9154 uses four multiframes in the ILAS (this can be changed in Register 0x478). If using Subclass 1, exactly four multiframes must be used.

After the last /A/ character of the last ILAS, the multiframe data begins streaming. The receiver adjusts the position of the /A/ character such that it aligns with the internal LMFC of the receiver at this point.

## Step 3: Data Streaming

In this phase, data is streamed from the transmitter block to the receiver block.
Optionally, data can be scrambled. Scrambling does not start until the very first octet following the ILAS.

The receiver block processes and monitors the data it receives for errors, including

- Bad running disparity (8-bit/10-bit error)
- Not in table (8-bit/10-bit error)
- Unexpected control character
- Bad ILAS
- Interlane skew error (through character replacement)

If any of these errors exist, they are reported back to the transmitter in one of a few ways (see the JESD204B Error Monitoring section for details):

- Signal assertion. Resynchronization (SYNCOUTx $\pm$ signal pulled low) is requested at each error for the last two errors. For the first three errors, an optional resynchronization request can be asserted when the error counter reaches a set error threshold.
- For the first three errors, each multiframe with an error in it causes a small pulse of programmable width on SYNCOUTx $\pm$.
- Errors can optionally trigger an IRQ event, which can be sent to the transmitter.

See to the JESD204B Test Modes section for various test modes for verifying the link integrity.

## Lane FIFO

The FIFOs in front of the crossbar switch and deframer synchronize the samples sent on the high speed serial data interface with the deframer clock by adjusting the phase of the incoming data. The FIFO absorbs timing variations between the data source and the deframer; this allows up to two PClock cycles of drift from the transmitter. The FIFO_STATUS_REG_0 register and FIFO_STATUS_REG_1 register (Register 0x30C and Register 0x30D, respectively) can be monitored to identify whether the FIFOs are full or empty.

## Lane FIFO IRQ

An aggregate lane FIFO error bit is also available as an IRQ event. Use Register 0x01F[1] to enable the FIFO error bit, and then use Register 0x023[1] to read back its status and reset the IRQ signal. See the Interrupt Request Operation section for more information.

## Crossbar Switch

Register 0x308 to Register 0x30B allow arbitrary mapping of physical lanes (SERDINx $\pm$ ) to logical lanes used by the SERDES deframers.

Table 39. Crossbar Registers

| Address | Bits | Logical Lane |
| :--- | :--- | :--- |
| $0 \times 308$ | $[2: 0]$ | XBARVALO |
| $0 \times 308$ | $[5: 3]$ | XBARVAL1 |
| $0 \times 309$ | $[2: 0]$ | XBARVAL2 |
| $0 \times 309$ | $[5: 3]$ | XBARVAL3 |
| $0 \times 30 A$ | $[2: 0]$ | XBARVAL4 |
| $0 \times 30 A$ | $[5: 3]$ | XBARVAL5 |
| $0 \times 30 B$ | $[2: 0]$ | XBARVAL6 |
| $0 \times 30 B$ | $[5: 3]$ | XBARVAL7 |

Write each XBARVALx with the number ( x ) of the desired physical lane (SERDINx $\pm$ ) from which to get data. By default, all logical lanes use the corresponding physical lane as their data source. For example, by default XBARVALx $=0$, so Logical Lane 0 gets data from Physical Lane 0 (SERDIN0 $\pm$ ). If instead the user wants to use SERDIN4 $\pm$ as the source for Logical Lane 0 , the user must write XBARVALx $=4$.

## Lane Inversion

Register 0x334 allows the inversion of desired logical lanes, which can ease routing of the SERDINx $\pm$ signals. For each Logical Lane x , set Bit x of Register 0x334 to 1 to invert the lane.

## Deframers

The AD9154 consists of two quad byte deframers (QBDs). Each deframer takes in the 8 -bit/10-bit encoded data from the deserializer (via the crossbar switch), decodes it, and descrambles it into JESD204B frames before passing it to the transport layer to be converted to DAC samples. The deframer processes four symbols (or octets) per processing clock (PClock) cycle.

In single link mode, Deframer 0 is used exclusively and Deframer 1 remains inactive. In dual link mode, both QBDs are active and must be configured separately using the SEL_REG_MAP_1 bit (Register 0x300[2]) to select the link to be configured. The DUALLINK bit (Register 0x300[3]) $=1$ for dual link, or 0 for single link.

Each deframer uses the JESD204B parameters that the user has programmed into the register map to identify how the data has been packed and how to unpack it. The JESD204B parameters are discussed in detail in the Transport Layer section; many of the parameters are also needed in the transport layer to convert JESD204B frames into samples.

## Descrambler

The AD9154 provides an optional descrambler block using a self synchronous descrambler with a polynomial: $1+x^{14}+x^{15}$.
Enabling data scrambling reduces the spectral peaks produced when the same data octets repeat from frame to frame. It also makes the spectrum data independent so that possible frequency selective effects on the electrical interface do not cause data dependent errors. Descrambling of the data is enabled by setting the SCR bit (Register 0x453[7]) to 1 .

## Syncing LMFC Signals

The first step in guaranteeing synchronization across links and devices begins with syncing the LMFC signals. Each DAC dual (DAC Dual A = DAC0/DAC1 and DAC Dual B = DAC2/DAC3) has its own LMFC signal. In Subclass 0, the LMFC signals for each of the two links are synchronized to an internal processing clock. In Subclass 1, all LMFC signals (for all duals and devices) are synchronized to an external SYSREF signal.

## SYSREF Signal

The SYSREF $\pm$ signal is a differential source synchronous input that synchronizes the LMFC signals in both the transmitter and receiver in a JESD204B Subclass 1 system to achieve deterministic latency.

The SYSREF $\pm$ signal is an active high signal sampled by the device clock rising edge. It is best practice that the device clock and the SYSREF $\pm$ signals be generated by the same source, such as a device from the AD9516-0, AD9516-1, AD9516-2, AD9516-3, AD9516-4, and AD9516-5 family of clock generators, so that the phase alignment between the signals is fixed. When designing for optimum deterministic latency operation, consider the timing distribution skew of the SYSREF $\pm$ signal in a multipoint link system (multichip).

The AD9154 supports a single pulse or step, or a periodic SYSREF $\pm$ signal. The periodicity can be continuous, strobed, or gapped periodic.

To avoid this common-mode current draw, use a $50 \%$ dutycycle periodic SYSREF $\pm$ signal with ac coupling capacitors. If ac-coupled, the ac coupling capacitors combine with the resistors shown in Figure 50 to create a high-pass filter with an RC time constant of $\tau=R C$. Select $C$ such that $\tau>4 /$ SYSREF frequency. In addition, the edge rate must be sufficiently fastat least $1.3 \mathrm{~V} / \mathrm{ns}$ is recommended per Table 5.


Figure 50. SYSREF $\pm$ Input Circuit

## LMFC Synchronization Modes Overview

The AD9154 supports various LMFC sync processing modes. These modes are one-shot, continuous, windowed continuous, and monitor modes. All sync processing modes perform a phase check to see that the LMFC is phase aligned to an alignment edge. In Subclass 1, the SYSREF $\pm$ pulse acts as the alignment edge; in Subclass 0 , an internal processing clock acts as the alignment edge. If the signals are not in phase, a clock rotation occurs to align the signals. The sync modes are described in the following sections. See the LMFC Synchronization Procedure section for details on the procedure for syncing the LMFC signals.

## One-Shot Sync Mode (SYNCMODE = 0x1)

In one-shot sync mode, a phase check occurs on only the first alignment edge received after the sync machine is armed. If the phase error is larger than a specified window error tolerance, a phase adjustment occurs. Though an LMFC synchronization occurs only once, the SYSREF $\pm$ signal can still be continuous.

## Continuous Sync Mode (SYNCMODE = 0x2)

Continuous mode must only be used in Subclass 1 with a periodic SYSREF $\pm$ signal. In continuous mode, a phase check/alignment occurs on every alignment edge.
Continuous mode differs from the one-shot mode in two ways. First, no SPI cycle is required to arm the device; the alignment edge seen after continuous mode is enabled results in a phase check. Second, a phase check (and when necessary, clock rotation) occurs on every alignment edge in continuous mode. The one caveat to the previous statement is that when a phase rotation cycle is underway, subsequent alignment edges are ignored until the logic lane is ready again.
The maximum acceptable phase error (in DAC clock cycles) between the alignment edge and the LMFC edge is set in the error window tolerance register. If continuous sync mode is used with a nonzero error window tolerance, then a phase
check occurs on every SYSREF $\pm$ pulse, but an alignment occurs only if the phase error is greater than the specified error window tolerance. If the jitter of the SYSREF $\pm$ signal violates the setup and hold time specifications given in Table 5, and therefore causes phase error uncertainty, the error tolerance can be increased to avoid constant clock rotations. Note that this means that the latency is less deterministic by the size of the window. If the error window tolerance must be set above 3, Subclass 0 with a one-shot sync is recommended.
For debug purposes, SYNCARM (Register 0x03A, Bit 6) informs the user that alignment edges are being received in continuous mode. Because the SYNCARM bit is self cleared after an alignment edge is received, the user can arm the sync (SYNCARM (Register 0x03A, Bit 6) $=1$ ), and then read back SYNCARM. If SYNCARM $=0$, the alignment edges are being received and phase checks are occurring. Arming the sync machine in this mode does not affect the operation of the device.
One-Shot Then Monitor Sync Mode (SYNCMODE = 0x9)
In one-shot then monitor mode, the user can monitor the phase error in real time. Use this sync mode with a periodic SYSREF $\pm$ signal. A phase check and alignment occurs on the first alignment edge received after the sync machine is armed. On all subsequent alignment edges, the phase is monitored and reported, but no clock phase adjustment occurs.
The phase error can be monitored on the CURRERR_L register, (Register 0x03C, Bits[7:0]). Immediately after an alignment occurs, CURRERRx $=0$ to indicate that there is no difference between the alignment edge and the LMFC edge. On every subsequent alignment edge, the phase is checked. If the alignment is lost, the phase error is reported in the CURRERR_L register in DAC clock cycles. If the phase error is beyond the selected window tolerance (Register 0x034, Bits[2:0]), one bit of Register 0x03D, Bits[7:6] is set high, depending on whether the phase error is on low or high side.
When an alignment occurs, snapshots of the last phase error (Register 0x03C, Bits[3:0]) and the corresponding error flags (Register 0x03D, Bit 7 and Bit 6]) are placed into readable registers for reference (Register 0x038 and Register 0x039, respectively).

## LMFC Synchronization Procedure

The procedure for enabling the LMFC sync is as follows:

1. Set Register 0x008 to 0x03 to sync the LMFC for both DAC duals (DAC0/DAC1 and DAC2/DAC3)
2. Set the desired sync processing mode. The sync processing mode settings are listed in Table 40.
3. For Subclass 1 , set the error window according to the uncertainty of the SYSREF $\pm$ signal relative to the DAC clock and the tolerance of the application for deterministic latency uncertainty. The sync window tolerance settings are given in Table 41.
4. Enable sync by writing 1 to SYNCENABLE (Register 0x03A, Bit 7).
5. If in one-shot mode, arm the sync machine by writing 1 to SYNCARM (Register 0x03A, Bit 6).
6. If in Subclass 1, ensure that at least one SYSREF $\pm$ pulse is sent to the device.
7. Check the status by reading the following bit fields:
a) REF_BUSY (Register 0x03B, Bit 7) $=0$ to indicate that the sync logic is no longer busy.
b) REF_LOCK (Register 0x03B, Bit 3) $=1$ to indicate that the signals are aligned. This bit updates on every phase check.
c) REF_WLIM (Register 0x03B, Bit 1 ) $=0$ to indicate that the phase error is not beyond the specified error window. This bit updates on every phase check.
d) REFROTA (Register 0x03B, Bit 2) $=1$ if the phases were not aligned before the sync and an alignment occurred, this indicates that a clock alignment occurred. This bit is sticky and can be cleared only by writing to the SYNCCLRSTKY control bit (Register 0x03A, Bit 5).
e) REF_TRIP (Register 0x03B, Bit 0 ) $=1$ to indicate alignment edge received and phase check occurred. This bit is sticky and can be cleared only by writing to the SYNCCLRSTKY control bit (Register 0x03A, Bit 5).

Table 40. Sync Processing Modes

| Sync Processing <br> Mode | SYNCMODE (Register 0x03A, <br> Bits[3:0]) |
| :--- | :--- |
| One-shot | $0 \times 01$ |
| Continuous | $0 \times 02$ |
| One-shot then monitor | $0 \times 09$ |

Table 41. Sync Window Tolerance

| Sync Error Window <br> Tolerance | ERRWINDOW (Register 0x034, <br> Bits[2:0]) |
| :--- | :--- |
| $\pm 1 / 2$ DAC clock cycles | $0 \times 00$ |
| $\pm 1$ DAC clock cycles | $0 \times 01$ |
| $\pm 2$ DAC clock cycles | $0 \times 02$ |
| $\pm 3$ DAC clock cycles | $0 \times 03$ |

## LMFC Sync IRQ

The sync status bits (REFLOCK, REFROTA, REFTRIP, and REFWLIM) are available as IRQ events.
Use Register 0x021, Bits[3:0] to enable the sync status bits for DAC Dual A (DAC0 and DAC1), and then use Register 0x025, Bits[3:0] to read back their statuses and reset the IRQ signals.
Use Register 0x022, Bits[3:0] to enable the sync status bits for DAC Dual B (DAC2 and DAC3), and then use Register 0x026, Bits[3:0] read back their statuses and reset the IRQ signals.

## Deterministic Latency

JESD204B systems contain various clock domains distributed throughout each system. Data traversing from one clock domain to a different clock domain can lead to ambiguous delays in the JESD204B link. These ambiguities lead to nonrepeatable latencies across the link from power cycle to power cycle with each new link establishment. Section 6 of the JESD204B specification addresses the issue of deterministic latency with mechanisms defined as Subclass 1 and Subclass 2.
The AD9154 supports JESD204B Subclass 0 and Subclass 1 operation, but not Subclass 2. Write the subclass to Register 0x301, Bits[2:0] and once per link to Register 0x458, Bits[7:5].

## Subclass 0

This mode does not require any signal on the SYSREF $\pm$ pins, which can be left disconnected.

Subclass 0 still requires that all lanes arrive within the same LMFC cycle and the dual DACs must be synchronized to each other.

## Minor Subclass 0 Caveats

Because the AD9154 requires an ILAS, the nonmultiple converter single lane (NMCDA-SL) case from the JESD204A specification is only supported when using the optional ILAS. Error reporting using SYNCOUTx $\pm$ is not supported when using Subclass 0 with $\mathrm{F}=1$.

## Subclass 1

This mode gives deterministic latency and allows links to be synced to within $1 / 2$ a DAC clock period. It requires an external SYSREF $\pm$ signal that is accurately phase aligned to the DAC clock.

## Deterministic Latency Requirements

Several key factors are required for achieving deterministic latency in a JESD204B Subclass 1 system.

- The SYSREF $\pm$ signal distribution skew within the system must be less than the desired uncertainty.
- The SYSREF $\pm$ setup and hold time requirements must be met for each device in the system.
- The total latency variation across all lanes, links and devices must be $\leq 10$ PClock periods. This includes both variable delays and the variation in fixed delays from lane to lane, link to link, and device to device in the system.


## Link Delay

The link delay of a JESD204B system is the sum of fixed and variable delays from the transmitter, channel and receiver, as shown in Figure 53.
For proper functioning, all lanes on a link must be read during the same LMFC period. Section 6.1 of the JESD204B
specification states that the LMFC period must be larger than the maximum link delay.

For the AD9154, this is not necessarily the case; instead, the AD9154 uses a local LMFC for each link ( LMFC $_{\text {Rx }}$ ) that can be delayed from the SYSREF aligned LMFC. Because the LMFC is periodic, this can account for any amount of fixed delay. As a result, the LMFC period must only be larger than the variation in the link delays, and the AD9154 can achieve proper performance with a smaller total latency. Figure 51 and Figure 52 show a case where the link delay is larger than an LMFC period. Note that it can be accommodated by delaying LMFC $_{\mathrm{Rx}}$.


Figure 51. Link Delay > LMFC Period Example


FRAME CLOCK $\square \square \square \square \square \square \square \square \square \square \square \square \square \square \square L$
Figure 52. LMFC DELAY to Compensate for Link Delay > LMFC


Figure 53. JESD204B Link Delay = Fixed Delay + Variable Delay

The method for setting the LMFCDel and LMFCVar is described in the Link Delay Setup section.
Setting LMFCDel appropriately ensures that all the corresponding data samples arrive in the same LMFC period. Then LMFCVar is written into the receive buffer delay (RBD) to absorb all link delay variation. This ensures that all data samples have arrived before reading. By setting these to fixed values across runs and devices, deterministic latency is achieved.
The RBD described in the JESD204B specification takes values from 1 to K frame clock cycles, while the RBD of the AD9154 takes values from 0 PClock cycles to 10 PClock cycles. As a result, up to 10 PClock cycles of total delay variation can be absorbed. Because LMFCVar is in PClock cycles, and LMFCDel is in frame clock cycles, a conversion between these two units is needed. The PClockFactor, or number of frame clock cycles per PClock cycle, is equal to $4 / \mathrm{F}$. For more information on this relationship, see the Clock Multiplication Relationships section.

Two examples follow that show how to determine LMFCVar and LMFCDel. After they are calculated, write LMFCDel into both Register 0x304 and Register 0x305 for all devices in the system, and write LMFCVar to both Register 0x306 and Register 0x307 for all devices in the system.

## Link Delay Setup Example, With Known Delays

All the known system delays can calculate LMFCVar and LMFCDel as described in the Link Delay Setup section.
The example shown in Figure 54 is demonstrated in the following steps according to the procedure outlined in the Link Delay Setup section. Note that this example is in Subclass 1 to achieve deterministic latency, which has a PClockFactor (4/F) of 2 frame clock cycles per PClock cycle, and uses $\mathrm{K}=32$ (frames per multiframe). Because PCBFixed < PClockPeriod, PCBFixed is negligible in this example and is not included in the calculations.

1. Find the receiver delays using Table 8.

$$
\begin{aligned}
& \text { RxFixed }=17 \text { PClock cycles } \\
& \text { RxVar }=2 \text { PClock cycles }
\end{aligned}
$$

2. Find the transmitter delays. The equivalent table in the example JESD204B core (implemented on a GTH or GTX transceiver on a Virtex-6 FPGA) states that the delay is $56 \pm 2$ byte clock cycles.
Because the PClockRate $=$ ByteRate $/ 4$ as described in the Clock Multiplication Relationships section, the transmitter delays in PClock cycles are:

TxFixed $=54 / 4=13.5$ PClock cycles
TxVar $=4 / 4=1$ PClock cycle
3. Calculate MinDelayLane as follows:

MinDelayLane $=$ floor $($ RxFixed + TxFixed + PCBFixed $)$
$=$ floor $(17+13.5+0)$

$$
=\text { floor }(30.5)
$$

MinDelayLane $=30$
4. Calculate FALL_COUNT_DelayLane as follows:

FALL_COUNT_DelayLane $=\operatorname{ceiling}($ RxFixed + RxVar +
TxFixed + TxVar + PCBFixed) $)$

$$
=\text { ceiling }(17+2+13.5+1+0)
$$

$$
=\text { ceiling(33.5) }
$$

FALL_COUNT_DelayLane $=34$
5. Calculate LMFCVar as follows:

LMFCVar $=($ FALL_COUNT_DelayLane +1$)-($ MinDelay 1)

$$
=(34+1)-(30-1)=35-29
$$

$L M F C V a r=6$ PClock cycles
6. Calculate LMFCDel as follows:

LMFCDel $=(($ MinDelay -1$) \times$ PClockFactor $) \% \mathrm{~K}$
$=((30-1) \times 2) \% 32=(29 \times 2) \% 32$
$=58 \% 32$
$L M F C D e l=26$ frame clock cycles
7. Write LMFCDel to both Register 0x304 and Register 0x305 for all devices in the system. Write LMFCVar to both Register 0x306 and Register 0x307 for all devices in the


Figure 54. LMFC_DELAY Calculation Example

## Link Delay Setup Example, Without Known Delay

If the system delays are not known, the AD9154 can read back the link latency between $\mathrm{LMFC}_{\mathrm{Rx}}$ for each link and the SYSREF aligned LMFC. This information calculates LMFCVar and LMFCDel, as shown in the Without Known Delays section.

Figure 56 shows how DYN_LINK_LATENCY_x (Register 0x302 and Register 0x303) provides a readback showing the delay (in PClock cycles) between $\mathrm{LMFC}_{\mathrm{RX}}$ and the transition from ILAS to the first data sample. By repeatedly power-cycling and taking this measurement, the minimum and maximum delays across power cycles can be determined and calculate LMFCVar and LMFCDel.

The example shown in Figure 56 is demonstrated in the following steps according to the procedure outlined in the Without Known Delays section. Note that this example is in Subclass 1 to achieve deterministic latency, which has a PClockFactor (FrameClockRate/ PClkRate) of 2 and uses $\mathrm{K}=16$; therefore PClocksPerMF $=8$.

1. In Figure 56, for Link A, Link B, and Link C, the system containing the AD9154 (including the transmitter) is power cycled and configured 20 times. The AD9154 is configured as described in the Device Setup Guide section. As the point of this exercise is to determine LMFCDel and LMFCVar, the LMFCDel is programmed to 0 and the DYN_LINK_LATENCY_x is read from Register 0x302 and Register $0 \times 303$ for Link 0 and Link 1, respectively. The
variation in the link latency over the 20 runs is shown in Figure 56 in gray.

- Link A gives readbacks of $6,7,0$, and 1 . Note that the set of recorded delay values rolls over the edge of a multiframe at the boundary K/PClockFactor $=8$. Add PClocksPerMF $=8$ to low set. Delay values range from 6 to 9.
- Link B gives Delay values from 5 to 7 .
- Link C gives Delay values from 4 to 7.

2. Calculate the minimum of all Delay measurements across all power cycles, links, and devices:
MinDelay $=\min ($ all Delay values $)=4$
3. Calculate the maximum of all Delay measurements across all power cycles, links, and devices: FALL_COUNT_Delay $=\max ($ all Delay values $)=9$
4. Calculate the total Delay variation (with guard band) across all power cycles, links, and devices: LMFCVar $=($ FALL_COUNT_Delay +1$)-($ MinDelay -1$)$

$$
=(9+1)-(4-1)=10-3=7 \text { PClock cycles }
$$

5. Calculate the minimum delay in frame clock cycles (with guard band) across all power cycles, links, and devices:

$$
\begin{aligned}
\text { LMFCDel } & =((\text { MinDelay }-1) \times \text { PClockFactor }) \% \mathrm{~K} \\
& =((4-1) \times 2) \% 16=(3 \times 2) \% 16 \\
& =6 \% 16=6 \text { frame clock cycles }
\end{aligned}
$$

6. Write LMFCDel to both Register and Register 0x305 for all devices in the system. Write LMFCVar to both Register 0x306 and Register $0 \times 307$ for all devices in the system.


Figure 55. DYN_LINK_LATENCY Illustration


Figure 56. Multilink Synchronization Settings, Derived Method Example

## TRANSPORT LAYER



Figure 57. Transport Layer Block Diagram

The transport layer receives the descrambled JESD204B frames and converts them to DAC samples based on the programmed JESD204B parameters shown in Table 42. A number of device parameters are defined in Table 43.

Table 42. JESD204B Transport Layer Parameters

| Parameter | Description |
| :---: | :---: |
| F | Number of octets per frame per lane: 1, 2, or 4. |
| K | Number of frames per multiframe. $K=32$ if $F=1, K=16$ or 32 otherwise. |
| L | Number of lanes per converter device (per link), as follows. <br> 1, 2, 4, or 8 (single link mode). <br> 1,2 , or 4 (dual link mode). |
| M | Number of converters per device (per link), as follows. 1,2 , or 4 (single link mode). <br> 1 or 2 (dual link mode). |
| S | Number of samples per converter, per frame: 1 or 2. |

Table 43. JESD204B Device Parameters

| Parameter | Description |
| :--- | :--- |
| CF | Number of control words per device clock per link. <br> Not supported, must be 0. <br> Number of control bits per conversion sample. Not <br> supported, must be 0. |
| HD | High density user data format. Used when samples <br> must be split across lanes. Set to 1 when $\mathrm{F}=1$, <br> otherwise 0. |
| N Prime (N') | Converter resolution $=16$. <br> Total number of bits per sample $=16$. |

Certain combinations of these parameters, called JESD204B operating modes, are supported by the AD9154. See Table 44 and Table 45 for a list of supported modes, along with their associated clock relationships.

## AD9154

Table 44. Single Link JESD204B Operating Modes

| Parameter | Mode |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 9 | 10 |
| M (Converter Count) | 4 | 4 | 4 | 4 | 2 | 2 | 2 | 2 | 1 | 1 |
| L (Lane Count) | 8 | 8 | 4 | 2 | 4 | 4 | 2 | 1 | 2 | 1 |
| S (Samples per Converter per Frame) | 1 | 2 | 1 | 1 | 1 | 2 | 1 | 1 | 1 | 1 |
| F (Octets per Frame, per Lane) | 1 | 2 | 2 | 4 | 1 | 2 | 2 | 4 | 1 | 2 |
| K ${ }^{1}$ (Frames per Multiframe) | 32 | 16/32 | 16/32 | 16/32 | 32 | 16/32 | 16/32 | 16/32 | 32 | 16/32 |
| HD (High Density) | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 |
| N (Converter Resolution) | 16 | 16 | 16 | 16 | 16 | 16 | 16 | 16 | 16 | 16 |
| NP (Bits per Sample) | 16 | 16 | 16 | 16 | 16 | 16 | 16 | 16 | 16 | 16 |
| Example Clocks for 10 Gbps Lane Rate |  |  |  |  |  |  |  |  |  |  |
| PClock Rate (MHz) | 250 | 250 | 250 | 250 | 250 | 250 | 250 | 250 | 250 | 250 |
| Frame Clock Rate (MHz) | 1000 | 500 | 500 | 250 | 1000 | 500 | 500 | 250 | 1000 | 500 |
| Data Rate (MHz) | 1000 | 1000 | 500 | 250 | 1000 | 1000 | 500 | 250 | 1000 | 500 |

${ }^{1} \mathrm{~K}$ must be 32 in Mode 0 , Mode 4, and Mode $9 . \mathrm{K}$ can be 16 or 32 in all other modes.

Table 45. Dual Link JESD204B Operating Modes for Link 0 and Link 1

| Parameter | Mode |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 4 | 5 | 6 | 7 | 9 | 10 |
| M (Converter Count) | 2 | 2 | 2 | 2 | 1 | 1 |
| L (Lane Count) | 4 | 4 | 2 | 1 | 2 | 1 |
| S (Samples per Converter per Frame) | 1 | 2 | 1 | 1 | 1 | 1 |
| F (Octets per Frame per Lane) | 1 | 2 | 2 | 4 | 1 | 2 |
| K ${ }^{1}$ (Frames per Multiframe) | 32 | 16/32 | 16/32 | 16/32 | 32 | 16/32 |
| HD (High Density) | 1 | 0 | 0 | 0 | 1 | 0 |
| N (Converter Resolution) | 16 | 16 | 16 | 16 | 16 | 16 |
| NP (Bits per Sample) | 16 | 16 | 16 | 16 | 16 | 16 |
| Example Clocks for 10 Gbps Lane Rate |  |  |  |  |  |  |
| PClock Rate (MHz) | 250 | 250 | 250 | 250 | 250 | 250 |
| Frame Clock Rate (MHz) | 1000 | 500 | 500 | 250 | 1000 | 500 |
| Data Rate (MHz) | 1000 | 1000 | 500 | 250 | 1000 | 500 |

[^3]
## Configuration Parameters

The AD9154 modes refer to the link configuration parameters for L, K, M, N, NP, S, and F. Table 46 provides the description and addresses for these settings.

Table 46. Configuration Parameters

| JESD204B Setting | Description | Address [Bits] |
| :---: | :---: | :---: |
| L-1 | Number of lanes - 1. | 0x453[4:0] |
| $\mathrm{F}^{1}-1$ | Number of ((octets per frame) per lane) - 1 . | 0x454[7:0] |
| K-1 | Number of frames per multiframe-1. | 0x455[4:0] |
| M-1 | Number of converters - 1. | 0x456[7:0] |
| N-1 | Converter bit resolution-1. | 0x457[4:0] |
| NP - 1 | Bit packing per sample - 1 . | 0x458[4:0] |
| S-1 | Number of ((samples per converter) per frame) - 1 . | 0x459[4:0] |
| HD | High density format. Set to 1 if $F=1$. Leave at 0 if $\mathrm{F} \neq 1$. | 0x45A[7] |
| $\mathrm{F}^{1}$ | F parameter, in ((octets per frame) per lane). | 0x476[7:0] |
| DID | Device ID. Match the device ID sent by the transmitter. | 0x450[7:0] |
| BID | Bank ID. Match the bank ID sent by the transmitter. | 0x451[3:0] |
| LIDO | Lane ID for Lane 0. Match the lane ID sent by the transmitter on Logical Lane 0 . | 0x452[4:0] |
| JESDVER | JESD Version. Match the version sent by the transmitter ( $0 \times 0=$ JESD204A, $0 \times 1=$ JESD204B). | 0x459[7:5] |

[^4]
## Data Flow Through the JESD204B Receiver

The link configuration parameters determine how the serial bits on the JESD204B receiver interface are deframed and passed on to the DACs as data samples. Figure 58 shows a detailed flow of the data through the various hardware blocks for Mode 4 ( $\mathrm{L}=4$, $M=2, S=1, F=1$ ). Simplified flow diagrams for all other modes are provided in Figure 59 through Figure 67.

## Single and Dual Link Configuration

The AD9154 uses the settings contained in Table 44 and Table 45. Mode 0 to Mode 10 can be used for single link operation. Mode 4 to Mode 10 can also be used for dual link operation.
To use dual link mode, set DUALLINK (Register 0x300, Bit 3) to 1 . In dual link mode, Link 1 must be programmed with identical parameters to Link 0 . To write to Link 1 , set SEL_REG_MAP_1 (Register 0x300, Bit 2) to 1.

If single link mode is being used, a small amount of power can be saved by powering down the output buffer for SYNCOUT1 $\pm$, which can be done by setting Register 0x203, Bit $0=1$.

## Checking Proper Configuration

As a convenience, the AD9154 provides some quick configuration checks. Register 0x030, Bit 5 is high if an illegal LMFCDELx is used. Register 0x030, Bit 3 is high if an unsupported combination of $L, M, F$, or $S$ is used. Register $0 \times 030$, Bit 2 is high if an illegal K is used. Register $0 \times 030$, Bit 1 is high if an illegal SUBCLASSV is used.

## Deskewing and Enabling Logical Lanes

After proper configuration, the logical lanes must be deskewed and enabled to capture data.
Set Bit x in Register 0x46C to 1 to deskew Logical Lane x and to 0 if that logical lane is not being used. Then, set Bit x in Register 0x47D to 1 to enable Logical Lane x and to 0 if that logical lane is not being used.


Figure 58. JESD204B Mode 4 Data Deframing

## Mode Configuration Maps

Table 47 through Table 56 contain the SPI configuration maps for each mode shown in Figure 59 through Figure 67. Figure 59 through Figure 67 show the associated data flow through the deframing process of the JESD204B receiver for each of the modes.

Mode 0 to Mode 10 apply to single link operation. Mode 4 to Mode 10 also apply to dual link operation. Register 0x300 must be set accordingly for single or dual link operation.
Additional details regarding all the SPI registers can be found in the Register Summary and Register Details sections.

Table 47. SPI Configuration Map—Register Settings for JESD204B Parameters for Mode 0

| Address | Setting | Description |
| :---: | :---: | :---: |
| 0x453 | 0x07 or 0x87 | Register 0x453, Bit 7 = 0 or 1: scrambling disabled or enabled; Register 0x453[4:0] $=0 \times 7$ : L = 8 lanes per link |
| 0x454 | 0x00 | Register $0 \times 454, \operatorname{Bits}[7: 0]=0 \times 00: F=1$ octet per frame |
| 0x455 | 0x1F | Register 0x455, Bits[4:0] = 0x1F: $\mathrm{K}=32$ frames per multiframe |
| 0x456 | $0 \times 03$ | Register 0x456, Bits[7:0] = 0x03: $\mathrm{M}=4$ converters per link |
| 0x457 | 0x0F | Register 0x457, Bits[7:6] = 0x0: always set $\overline{C S}=0$; Register $0 \times 457$, Bits [4:0] $=0 \times F: \mathrm{N}=16$, always set to 16-bit resolution |
| 0x458 | $0 \times 0 \mathrm{~F}$ or $0 \times 2 \mathrm{~F}$ | Register 0x458, Bits[7:5] = 0x0 or 0x1: Subclass 0 or Subclass 1; Register 0x458, Bits[4:0] = 0xF: NP = 16 bits per sample |
| 0x459 | 0x20 | Register 0x459, Bits[7:5] = 0x1: JESD204B version; Register 0x459, Bits[4:0] $=0 \times 0: S=1$ sample per converter per frame |
| 0x45A | 0x80 | Register 0x45A, Bit $7=1$ : HD $=1$; Register 0x45A, Bits[4:0] = 0x00: always set CF $=0$ |
| 0x46C | 0xFF | Register 0x46C, Bits[7:0] = 0xFF: Deskew Link Lane 0 to Link Lane 7 |
| 0x476 | 0x01 | Register 0x476, Bits[7:0] = 0x01: F = 1 octet per frame |
| 0x47D | 0xFF | Register 0x47D, Bits[7:0] = 0xFF: Enable Link Lane 0 to Link Lane 7 |



Figure 59. JESD204B Mode 0 Data Deframing

Table 48. SPI Configuration Map-Register Settings for JESD204B Parameters for Mode 1

| Address | Setting | Description |
| :---: | :---: | :---: |
| 0x453 | 0x07 or 0x87 | Register $0 \times 453$, Bit $7=0$ or 1: scrambling disabled or enabled; Register $0 \times 453$, Bits[4:0] $=0 \times 7$ : L = 8 lanes per link |
| 0x454 | $0 \times 01$ | Register $0 \times 454, \operatorname{Bits}[7: 0]=0 \times 01: F=2$ octets per frame |
| $0 \times 455$ | $0 \times 0 \mathrm{~F}$ or 0x1F | Register $0 \times 455, \operatorname{Bits}[4: 0]=0 \times 0 F$ or $0 \times 1 \mathrm{~F}$ : $\mathrm{K}=16$ or 32 frames per multiframe |
| $0 \times 456$ | $0 \times 03$ | Register $0 \times 456, \operatorname{Bits}[7: 0]=0 \times 03: M=4$ converters per link |
| $0 \times 457$ | 0x0F | Register $0 \times 457$, Bits[7:6] = 0x0: always set $C S=0$; Register $0 \times 457$, Bits[4:0] $=0 \times 0 \mathrm{~F}: \mathrm{N}=16$, always set to 16-bit resolution |
| $0 \times 458$ | $0 \times 0 \mathrm{~F}$ or $0 \times 2 \mathrm{~F}$ | Register $0 \times 458$, Bits[7:5] $=0 \times 0$ or $0 \times 1$ : Subclass 0 or Subclass 1, Register $0 \times 458, \mathrm{Bits}[4: 0]=0 \times F$ : NP $=16$ bits per sample |
| 0x459 | 0x21 | Register 0x459, Bits[7:5] = 0x1: set to JESD204B version, Register 0x459, Bits[4:0] = 0x1:S = 2 samples per converter per frame |
| $0 \times 45 \mathrm{~A}$ | 0x00 | Register $0 \times 45 \mathrm{~A}$, Bit $7=0$ : $\mathrm{HD}=0$; Register $0 \times 45 \mathrm{~A}$, Bits[4:0] $=0 \times 00$ : always set $\mathrm{CF}=0$ |
| $0 \times 46 \mathrm{C}$ | 0xFF | Register 0x46C, Bits[7:0] = 0xFF: deskew Link Lane 0 to Link Lane 7 |
| $0 \times 476$ | 0x02 | Register $0 \times 476, \operatorname{Bits}[7: 0]=0 \times 02: F=2$ octets per frame |
| 0x47D | 0xFF | Register 0x47D, Bits[7:0] = 0xFF: 8 lanes enabled, set one bit per lane to enable |


$11389-160$
Figure 60. JESD204B Mode 1 Data Deframing

Table 49. SPI Configuration Map-Register Settings for JESD204B Parameters for Mode 2

| Address | Setting | Description |
| :---: | :---: | :---: |
| 0x453 | 0x03 or 0x83 | Register 0x453, Bit $7=0$ or 1: scrambling disabled or enabled; Register $0 \times 453$, Bits[4:0] $=0 \times 3$ : L = 4 lanes per link |
| 0x454 | $0 \times 01$ | Register 0x454, Bits[7:0] = 0x01: F = 2 octets per frame |
| 0x455 | $0 \times 0 \mathrm{~F}$ or 0x1F | Register $0 \times 455$, Bits[4:0] $=0 \times 0 \mathrm{~F}$ or $0 \times 1 \mathrm{~F}$ : $\mathrm{K}=16$ or 32 frames per multiframe |
| $0 \times 456$ | $0 \times 03$ | Register $0 \times 456, \operatorname{Bits}[7: 0]=0 \times 03: M=4$ converters per link |
| $0 \times 457$ | 0x0F | Register 0x457, Bits[7:6] = 0x0: always set CS = 0; Register $0 \times 457$, Bits[4:0] = 0x0F: $\mathrm{N}=16$, always set to 16-bit resolution |
| $0 \times 458$ | $0 \times 0 \mathrm{~F}$ or $0 \times 2 \mathrm{~F}$ | Register $0 \times 458$, Bits[7:5] $=0 \times 0$ or $0 \times 1$ : Subclass 0 or Subclass 1, Register $0 \times 458$, Bits[4:0] $=0 \times F$ : NP = 16 bits per sample |
| 0x459 | $0 \times 20$ | Register $0 \times 459$, Bits[7:5] $=0 \times 1$ : set to JESD204B version, Register $0 \times 459$, Bits[4:0] $=0 \times 0: S=1$ sample per converter per frame |
| $0 \times 45 \mathrm{~A}$ | $0 \times 00$ | Register 0x45A, Bit 7 = 0: HD = 0; Register $0 \times 45 \mathrm{~A}$, Bits[4:0] = 0x00: always set CF $=0$ |
| 0x46C | 0x0F | Register 0x46C, Bits[7:0] = 0xFF: Deskew Link Lane 0 to Link Lane 3 |
| $0 \times 476$ | 0x02 | Register $0 \times 476$, Bits[7:0] $=0 \times 02$ F $=2$ octets per frame |
| 0x47D | 0x0F | Register 0x47D, Bits[7:0] = 0x0F: enable Link Lane 0 to Link Lane 3 |



Figure 61. JESD204B Mode 2 Data Deframing

## AD9154

Table 50. SPI Configuration Map-Register Settings for JESD204B Parameters for Mode 3

| Address | Setting | Description |
| :---: | :---: | :---: |
| 0x453 | 0x01 or 0x81 | Register 0x453, Bit 7 = 0 or 1: scrambling disabled or enabled; Register 0x453, Bits[4:0] $=0 \times 1$ : L = 2 lanes per link |
| 0x454 | 0x03 | Register 0x454, Bits[7:0] = 0x03: F = 4 octets per frame |
| 0x455 | $0 \times 0 \mathrm{~F}$ or 0x1F | Register 0x455, Bits[4:0] = 0x0F or 0x1F: $\mathrm{K}=16$ or 32 frames per multiframe |
| 0x456 | 0x03 | Register $0 \times 456, \operatorname{Bits}[7: 0]=0 \times 03: M=4$ converters per link |
| $0 \times 457$ | 0x0F | Register 0x457, Bits[7:6] = 0x0: always set CS $=0$; Register $0 \times 457$, Bits[4:0] $=0 \times 0 \mathrm{~F}$ : $\mathrm{N}=16$, always set to 16-bit resolution |
| $0 \times 458$ | 0x0F or 0x2F | Register 0x458, Bits[7:5] $=0 \times 0$ or 0x1: Subclass 0 or Subclass 1, Register $0 \times 458, \mathrm{Bits}[4: 0]=0 \times \mathrm{F}$ : NP $=16$ bits per sample |
| 0x459 | 0x20 | Register 0x459, Bits[7:5] = 0x1: set to JESD204B version, Register 0x459, Bits[4:0] = 0x0: S = 1 sample per converter per frame |
| 0x45A | 0x00 | Register 0x45A, Bit 7 = 0: HD = 0; Register 0x45A, Bits[4:0] = 0x00: always set CF $=0$ |
| $0 \times 46 \mathrm{C}$ | 0x03 | Register 0x46C, Bits[7:0] = 0xFF: deskew Link Lane 0 and Link Lane 1 |
| 0x476 | 0x04 | Register 0x476, Bits[7:0] $=0 \times 04$ : $\mathrm{F}=4$ octets per frame |
| 0x47D | 0x03 | Register 0x47D, Bits[7:0] = 0x03: enable Link Lane 0 and Link Lane 1 |



Figure 62. JESD204B Mode 3 Data Deframing
Table 51. SPI Configuration Map-Register Settings for JESD204B Parameters for Mode 4

| Address | Setting | Description |
| :---: | :---: | :---: |
| 0x453 | 0x03 or 0x83 | Register 0x453, Bit $7=0$ or 1: scrambling disabled or enabled; Register 0x453, Bits[4:0] = 0x3: L = 4 lanes per link |
| 0x454 | 0x00 | Register $0 \times 454, \operatorname{Bits}[7: 0]=0 \times 00: F=1$ octet per frame |
| 0x455 | 0x0F or 0x1F | Register $0 \times 455, \mathrm{Bits}[4: 0]=0 \times 0 \mathrm{~F}$ or $0 \times 1 \mathrm{~F}$ : $\mathrm{K}=16$ or 32 frames per multiframe |
| 0x456 | 0x01 | Register $0 \times 456, \operatorname{Bits}[7: 0]=0 \times 01: M=2$ converters per link |
| 0x457 | 0x0F | Register 0x457, Bits[7:6] = 0x0: always set CS $=0$; Register $0 \times 457$, Bits[4:0] $=0 \times 0 F: \mathrm{N}=16$, always set to 16-bit resolution |
| 0x458 | 0x0F or 0x2F | Register 0x458, Bits[7:5] = 0x0 or 0x1: Subclass 0 or Subclass 1, Register 0x458, Bits[4:0] $=0 \times \mathrm{F}$ : NP $=16$ bits per sample |
| 0x459 | 0x20 | Register $0 \times 459$, Bits $[7: 5]=0 \times 1$ : set to JESD204B version, Register $0 \times 459$, Bits[4:0] $=0 \times 0: S=1$ sample per converter per frame |
| 0x45A | 0x01 | Register 0x45A, Bit $7=1$ : HD = 1; Register 0x45A, Bits[4:0] = 0x00: always set CF $=0$ |
| 0x46C | 0x0F | Register 0x46C, Bits[7:0] = 0xFF: deskew Link Lane 0 to Link Lane 3 |
| 0x476 | 0x01 | Register 0x476, Bits [7:0] = 0x01:F = 1 octet per frame |
| 0x47D | 0x0F | Register 0x47D, Bits[7:0] = 0x0F: Enable Link Lane 0 to Link Lane 3 |

See Figure 58 for an illustration of the AD9154 JESD204B Mode 4 data deframing process.
Table 52. SPI Configuration Map-Register Settings for JESD204B Parameters for Mode 5

| Address | Setting | Description |
| :---: | :---: | :---: |
| 0x453 | 0x03 or 0x83 | Register 0x453, Bit 7 = 0 or 1: scrambling disabled or enabled; Register 0x453, Bits[4:0] $=0 \times 3$ : L = 4 lanes per link |
| 0x454 | 0x01 | Register $0 \times 454, \operatorname{Bits}[7: 0]=0 \times 01: \mathrm{F}=2$ octets per frame |
| 0x455 | 0x0F or 0x1F | Register $0 \times 455, \operatorname{Bits}[4: 0]=0 \times 0 \mathrm{~F}$ or $0 \times 1 \mathrm{~F}: \mathrm{K}=16$ or 32 frames per multiframe |
| 0x456 | 0x01 | Register 0x456, Bits[7:0] = 0x01: $\mathrm{M}=2$ converters per link |
| $0 \times 457$ | 0x0F | Register 0x457, Bits[7:6] = 0x0: always set CS $=0$; Register 0x457, Bits[4:0] = 0x0F: $\mathrm{N}=16$, always set to 16-bit resolution |
| 0x458 | 0x0F or 0x2F | Register 0x458, Bits[7:5] = 0x0 or 0x1: Subclass 0 or Subclass 1, Register 0x458, Bits[4:0] $=0 \times \mathrm{F}$ : NP $=16$ bits per sample |
| 0x459 | 0x21 | Register $0 \times 459$, Bits $[7: 5]=0 \times 1$ : set to JESD204B version, Register $0 \times 459$, $\mathrm{Bits}[4: 0]=0 \times 1: S=2$ samples per converter per frame |
| 0x45A | 0x00 | Register 0x45A, Bit $7=0$ : $\mathrm{HD}=0$; Register $0 \times 45 \mathrm{~A}, \mathrm{Bits}[4: 0]=0 \times 00$ : always set $\mathrm{CF}=0$ |
| 0x46C | 0x0F | Register 0x46C, Bits[7:0] = 0xFF: deskew Link Lane 0 to Link Lane 3 |
| 0x476 | 0x02 | Register 0x476, Bits[7:0] $=0 \times 02: \mathrm{F}=2$ octets per frame |
| 0x47D | 0x0F | Register 0x47D, Bits[7:0] = 0x0F: Enable Link Lane 0 to Link Lane 3 |



Figure 63. JESD204B Mode 5 Data Deframing

Table 53. SPI Configuration Map-Register Settings for JESD204B Parameters for Mode 6

| Address | Setting | Description |
| :---: | :---: | :---: |
| 0x453 | 0x01 or 0x81 | Register 0x453, Bit 7 = 0 or 1: scrambling disabled or enabled, Register 0x453, Bits[4:0] = 0x1:L = 2 lanes per link |
| 0x454 | 0x01 | Register 0x454, Bits[7:0] = 0x01: F = 2 octets per frame |
| 0x455 | 0x0F or 0x1F | Register $0 \times 455, \operatorname{Bits}[4: 0]=0 \times 0 \mathrm{~F}$ or $0 \times 1 \mathrm{~F}: \mathrm{K}=16$ or 32 frames per multiframe |
| 0x456 | 0x01 | Register 0x456, Bits[7:0] = 0x01: $\mathrm{M}=2$ converters per link |
| 0x457 | 0x0F | Register 0x457, Bits[7:6] = 0x0: always set CS $=0$; Register 0x457, Bits[4:0] = 0x0F: $\mathrm{N}=16$, always set to 16-bit resolution |
| 0x458 | 0x0F or 0x2F | Register 0x458, Bits[7:5] = 0x0 or 0x1: Subclass 0 or Subclass 1, Register 0x458, Bits[4:0] $=0 \times \mathrm{F}$ : NP $=16$ bits per sample |
| 0x459 | 0x20 | Register 0x459, Bits[7:5] = 0x1: set to JESD204B version, Register $0 \times 459, \mathrm{Bits}[4: 0]=0 \times 0: S=1$ sample per frame |
| 0x45A | 0x00 | Register 0x45A, Bit 7 = 0: HD = 0; Register 0x45A, Bits[4:0] = 0x00: always set CF = 0 |
| 0x46C | $0 \times 03$ | Register 0x46C, Bits[7:0] = 0xFF: deskew Link Lane 0 and Link Lane 1 |
| 0x476 | $0 \times 02$ | Register $0 \times 476, \operatorname{Bits}[7: 0]=0 \times 02: \mathrm{F}=2$ octets per frame |
| 0x47D | 0x03 | Register 0x47D, Bits[7:0] = 0x03: Enable Link Lane 0 and Link Lane 1 |



Figure 64. JESD204B Mode 6 Data Deframing

AD9154

Table 54. SPI Configuration Map-Register Settings for JESD204B Parameters for Mode 7

| Address | Setting | Description |
| :---: | :---: | :---: |
| 0x453 | 0x00 or 0x80 | Register $0 \times 453$, Bit $7=0$ or 1: scrambling disabled or enabled, Register $0 \times 453$, Bits[4:0] $=0 \times 0$ : L = 1 lane per link |
| 0x454 | 0x03 | Register $0 \times 454, \operatorname{Bits}[7: 0]=0 \times 03: \mathrm{F}=4$ octets per frame |
| 0x455 | 0x0F or 0x1F | Register $0 \times 455, \mathrm{Bits}[4: 0]=0 \times 0 \mathrm{~F}$ or $0 \times 1 \mathrm{~F}: \mathrm{K}=16$ or 32 frames per multiframe |
| 0x456 | 0x01 | Register $0 \times 456$, Bits[7:0] $=0 \times 01: M=2$ converters per link |
| 0x457 | 0x0F | Register $0 \times 457, \operatorname{Bits}[7: 6]=0 \times 0$ : always set CS $=0$; Register $0 \times 457$, Bits [4:0] $=0 \times 0 \mathrm{~F}: \mathrm{N}=16$, always set to 16-bit resolution |
| 0x458 | 0x0F or 0x2F | Register 0x458, Bits[7:5] = 0x0 or 0x1: Subclass 0 or Subclass 1, Register $0 \times 458$, Bits[4:0] $=0 \times \mathrm{F}$ : NP $=16$ bits per sample |
| 0x459 | 0x20 | Register 0x459, Bits[7:5] $=0 \times 1$ : set to JESD204B version, Register $0 \times 459$, Bits[4:0] $=0 \times 0: S=1$ sample per converter per frame |
| 0x45A | 0x00 | Register 0x45A, Bit 7 = 0: HD = 0; Register 0x45A, Bits[4:0] = 0x00: always set CF = 0 |
| 0x46C | 0x01 | Register 0x46C, Bits[7:0] = 0xFF: Deskew Link Lane 0 |
| 0x476 | 0x04 | Register 0x476, Bits[7:0] = 0x04: F = 4 octets per frame |
| 0x47D | $0 \times 01$ | Register 0x47D, Bits[7:0] = 0x01: Enable Link Lane 0 |



Figure 65. JESD204B Mode 7 Data Deframing

Table 55. SPI Configuration Map-Register Settings for JESD204B Parameters for Mode 9

| Address | Setting | Description |
| :---: | :---: | :---: |
| 0x453 | 0x01 or 0x81 | Register 0x453, Bit $7=0$ or 1: scrambling disabled or enabled, Register 0x453, Bits[4:0] = 0x1:L = 2 lanes per link |
| $0 \times 454$ | 0x00 | Register 0x454, Bits [7:0] = 0x00: F = 1 octet per frame |
| 0x455 | 0x1F | Register 0x455, Bits[4:0] = 0x1F: $\mathrm{K}=32$ frames per multiframe |
| 0x456 | 0x00 | Register 0x456, Bits[7:0] = 0x00: $\mathrm{M}=1$ converter per link |
| $0 \times 457$ | 0x0F | Register 0x457, Bits[7:6] = 0x0: always set CS = 0; Register 0x457, Bits[4:0] = 0x0F: $\mathrm{N}=16$, alway set to 16-bit resolution |
| 0x458 | 0x0F or 0x2F | Register 0x458, Bits[7:5] = 0x0 or 0x1: Subclass 0 or Subclass 1, Register $0 \times 458$, Bits[4:0] $=0 \times F$ : NP $=16$ bits per sample |
| 0x459 | 0x20 | Register 0x459, Bits[7:5] = 0x1: Set to JESD204B version, Register 0x459, Bits[4:0] = 0x0:S = 1 sample per converter per frame |
| 0x45A | 0x01 | Register 0x45A, Bit $7=1$ : HD = 1; Register 0x45A, Bits[4:0] = 0x00: always set CF $=0$ |
| 0x46C | 0x03 | Register 0x46C, Bits[7:0] = 0xFF: Deskew Link Lane 0 and Link Lane 1 |
| 0x476 | 0x01 | Register 0x476, Bits[7:0] = 0x01: F = 1 octet per frame |
| 0x47D | 0x03 | Register 0x47D, Bits[7:0] = 0x03: Enable Link Lane 0 and Link Lane 1 |



Figure 66. JESD204B Mode 9 Data Deframing

AD9154

Table 56. SPI Configuration Map-Register Settings for JESD204B Parameters for Mode 10

| Address | Setting | Description |
| :---: | :---: | :---: |
| 0x453 | 0x00 or 0x80 | Register $0 \times 453$, Bit $7=0$ or 1: scrambling disabled or enabled, Register $0 \times 453, \mathrm{Bits}[4: 0]=0 \times 0: \mathrm{L}=1$ lane per link |
| 0x454 | 0x01 | Register $0 \times 454, \operatorname{Bits}[7: 0]=0 \times 01: \mathrm{F}=2$ octets per frame |
| 0x455 | 0x0F or 0x1F | Register $0 \times 455, \operatorname{Bits}[4: 0]=0 \times 0 \mathrm{~F}$ or $0 \times 1 \mathrm{~F}: \mathrm{K}=16$ or 32 frames per multiframe |
| 0x456 | 0x00 | Register 0x456, Bits[7:0] = 0x00: $M=1$ converter per link |
| 0x457 | 0x0F | Register $0 \times 457, \operatorname{Bits}[7: 6]=0 \times 0$ : always set CS $=0$; Register $0 \times 457$, Bits[4:0] $=0 \times 0 \mathrm{~F}: \mathrm{N}=16$, always set to 16-bit resolution |
| 0x458 | 0x0F or 0x2F | Register $0 \times 458$, Bits $[7: 5]=0 \times 0$ or $0 \times 1$ : Subclass 0 or Subclass 1, Register $0 \times 458$, Bits $[4: 0]=0 \times F:$ NP $=16$ bits per sample |
| 0x459 | 0x20 | Register 0x459, Bits[7:5] = 0x1: set to JESD204B version, Register 0x459, Bits[4:0] = 0x0: S = 1 sample per converter per frame |
| 0x45A | 0x00 | Register 0x45A, Bit 7 = 0: HD = 0; Register $0 \times 45 \mathrm{~A}, \mathrm{Bits}[4: 0]=0 \times 00$ : always set CF $=0$ |
| 0x46C | 0x01 | Register 0x46C, Bits[7:0] = 0x01: Deskew Link Lane 0 to Link Lane 7 |
| 0x476 | 0x02 | Register $0 \times 476, \operatorname{Bits}[7: 0]=0 \times 02: \mathrm{F}=2$ octets per frame |
| 0x47D | 0x01 | Register 0x47D, Bits[7:0] = 0x01: Enable Link Lane 0 |



Figure 67. JESD204B Mode 10 Data Deframing

## JESD204B TEST MODES

## PHY PRBS Testing

The JESD204B receiver on the AD9154 includes a pseudorandom binary sequence (PRBS) pattern checker on the back end of its physical layer. This functionality enables bit error rate (BER) testing of each physical lane of the JESD204B link. The PHY PRBS pattern checker does not require that the JESD204B link be established. It can synchronize with a PRBS7, PRBS15, or PRBS31 data pattern. PRBS pattern verification can be performed on multiple lanes at once. The error counts for failing lanes are reported for one JESD204B lane at a time. The process for performing PRBS testing on the AD9154 is as follows:

1. Start sending a PRBS7, PRBS15, or PRBS31 pattern from the JESD204B transmitter.
2. Select and write the appropriate PRBS pattern to Register 0x316, Bits[3:2], as shown in Table 57.
3. Enable the PHY test for all lanes being tested by writing to PHY_TEST_EN (Register 0x315). Each bit of Register 0x315 enables the PRBS test for the corresponding lane. For example, writing a 1 to Bit 0 enables the PRBS test for Physical Lane 0.
4. Toggle PHY_TEST_RESET (Register 0x316, Bit 0) from 0 to 1 , then back to 0 .
5. Set PHY_PRBS_ERROR_THRESHOLD (Register 0x319 to Register 0x317) as desired.
6. Write a 0 and then a 1 to PHY_TEST_START (Register 0x316, Bit 1). The rising edge of PHY_TEST_START starts the test.
7. Wait 500 ms .
8. Stop the test by writing 0 to PHY_TEST_START (Register 0x316, Bit 1).
9. Read the PRBS test results.
a. Each bit of PHY_PRBS_TEST_STATUS (Register $0 \times 31 \mathrm{D}$ ) corresponds to one SERDES lane. $0=$ fail, 1 = pass.
b. The number of PRBS errors seen on each failing lane can be read by writing the lane number to check ( 0 to 7) in the PHY_SRC_ERR_CNT (Register 0x316, Bits[6:4]) and reading PHY_PRBS_ERR_COUNT (Register 0x31A to Register 0x31C). The maximum error count is $2^{24-1}$. If all bits of Register $0 \times 31 \mathrm{~A}$ to Register 0x31C are high, the maximum error count on the selected lane has been exceeded.

Table 57. PHY PRBS Pattern Selection

| PHY_PRBS_PAT_SEL Setting <br> (Register 0x316[3:2]) |  |
| :--- | :--- |
| Ob00 (default) | PRBS Pattern |
| 0b01 | PRBS715 |
| 0b10 | PRBS31 |

## Transport Layer Testing

The JESD204B receiver in the AD9154 supports the short transport layer (STPL) test as described in the JESD204B standard. Use this test to verify the data mapping between the JESD204B transmitter and receiver.
The STPL test ensures that each sample from each converter is mapped appropriately according to the number of converters $(M)$ and the number of samples per converter (S). As specified in the JESD204B standard, the converter manufacturer specifies what test samples are transmitted. Each sample must have a unique value. For example, if $M=2$ and $S=2$, four unique samples are transmitted repeatedly until the test is stopped. The expected sample must be programmed into the device and the expected sample is compared to the received sample one sample at a time until all have been tested. The process for performing this test on the AD9154 is described as follows:

1. Synchronize the JESD204B link.
2. Enable the STPL test at the JESD204B Tx.
3. Select Converter 0 Sample 0 for testing. Write SHORT_TPL_M_SEL (Register 0x32C, Bits[3:2]) $=0$ and SHORT_TPL_SP_SEL (Register 0x32C, Bits[5:4]) $=0$.
4. Set the expected test sample for Converter 0 , Sample 0. Program the expected 16-bit test sample into the SHORT_TPL_REF_SP_x registers (Register 0x32E and Register 0x32D).
5. Enable the STPL test. Write 1 to SHORT_TPL_TEST_EN (Register 0x32C, Bit 0).
6. Toggle the STPL reset, SHORT_TPL_TEST_RESET (Register $0 \times 32 \mathrm{C}$, Bit 1 ), from 0 to 1 , then back to 0 .
7. Check for failures. Read SHORT_TPL_FAIL (Register 0x32F, Bit 0 ), $0=$ pass, $1=$ fail.
8. Repeat Steps 3 to Step 7 for each sample of each converter.


## Repeated CGS and ILAS Test

As per Section 5.3.3.8.2 of the JESD204B specification, the AD9154 can check that a constant stream of /K28.5/ characters is being received, or that a CGS followed by a constant stream of ILAS is being received.
To run a repeated CGS test, send a constant stream of /K28.5/ characters to the AD9154 SERDES inputs. Next, set up the device and enable the links as described in the Device Setup Guide section. Ensure that the /K28.5/ characters are being received by verifying that the $\overline{\text { SYNCOUTx } \pm}$ signal has been deasserted and that CGS has passed for all enabled link lanes by reading Register 0x470. Program Register 0x300, Bit $2=0$ to monitor the status of lanes on Link 0 , and Register 0x300, Bit $2=1$ to monitor the status of lanes on Link 1 for dual link mode.

To run the CGS followed by a repeated ILAS sequence test, follow the Device Setup Guide section, but before performing the last write (enabling the links), enable the ILAS test mode by writing a 1 to Register 0x477, Bit 7. Then, enable the links. When the device recognizes 4 CGS characters on each lane, it deasserts the $\overline{\text { SYNCOUTx } \pm}$ signal. At this point, the transmitter starts sending a repeated ILAS sequence.
Read Register 0x473 to verify that initial lane synchronization has passed for all enabled link lanes. Program Register 0x300, Bit $2=0$ to monitor the status of lanes on Link 0 , and Register 0x300, Bit $2=$ 1 to monitor the status of lanes on Link 1 for dual link mode.

## JESD204B ERROR MONITORING

Disparity, Not in Table, and Unexpected Control Character Errors
Per Section 7.6 of the JESD204B specification, the AD9154 can detect disparity errors, not in table errors, and unexpected control character errors, and can optionally issue a sync request and reinitialize the link when errors occur.

Note that the disparity error counter counts all characters with invalid disparity, regardless of whether they are in the 8 -bit/10-bit decoding table. This is a minor deviation from the JESD204B specification, which only counts disparity errors when they are in the 8 -bit/10-bit decoding table.

## Checking Error Counts

The error count can be checked for disparity errors, not in table errors, and unexpected control character errors. The error counts are on a per lane and per error type basis. Note that the lane select and counter select are programmed into Register 0x46B and the error count is read back from the same address. To check the error count, complete the following steps:

1. Select the desired link lane and error type of the counter to view. Write these to Register 0x46B according to Table 58. To select a link lane, first select a link (Register 0x300, Bit 2 $=0$ to select Link 0 or Register $0 \times 300$, Bit $2=1$ to select Link 1 [dual link only]). Note that, when using Link 1, Link Lane x refers to Logical Lane $\mathrm{x}+4$.
2. Read the error count from Register $0 x 46 B$. Note the maximum error count is equal to the error threshold set in Register 0x47C.

Table 58. Error Counters

| Addr. | Bits | Variable | Description |
| :--- | :--- | :--- | :--- |
| $0 \times 46 \mathrm{~B}$ | $[6: 4]$ | LaneSel | LaneSel = $x$ to monitor the error <br> count of Link Lane x. See the notes <br> on link lane in Step 1 of the Checking <br> Error Counts section. |
| $[1: 0]$ | CntrSel | CntrSel = Ob00 for bad running <br> disparity counter. |  |
| CntrSel = 0b01 for not in table error |  |  |  |
| counter. |  |  |  |
| CntrSel = 0b10 for unexpected control |  |  |  |
| character counter. |  |  |  |

## Check for Error Count Over Threshold

In addition to reading the error count per lane and error type as described in the Checking Error Counts section, the user can check a register to see if the error count for a given error type has reached a programmable threshold.

The same error threshold is used for the three error types: disparity, not in table, and unexpected control character. The error counters are on a per error type basis. To use this feature, complete the following steps:

1. Program the desired error count threshold into ERRORTHRES (Register 0x47C).
2. Read back the error status for each error type to see if the error count has reached the error threshold.
Disparity errors are reported in Register 0x46D.
Not in table errors are reported in Register 0x46E.
Unexpected control character errors are reported in Register 0x46F.

## Error Counter and IRQ Control

Write to Register 0x46D and Register 0x46F to reset or disable the error counts and to reset the IRQ for a given lane. Note that these are the same registers that report error count over threshold (see the Check for Error Count Over Threshold section); thus, the readback is not the value that was written. For each error type,

1. Select the link lane to access. To select a link lane, first select a link (Register 0x300, Bit $2=0$ to select Link 0 , Register $0 \times 300$, Bit $2=1$ to select Link 1 [dual link only]). Note that, when using Link 1, Link Lane x refers to Logical Lane $\mathrm{x}+4$.
2. Decide whether to reset the IRQ, disable the error count, and/or reset the error count for the given lane and error type.
3. Write the link lane and desired reset or disable action to Register 0x46D to Register 0x46F according to Table 59.

Table 59. Error Counter and IRQ Control: Disparity (Register 0x46D), Not In Table (Register 0x46E), Unexpected Control Character (Register 0x46F)

| Bits | Variable | Description |
| :--- | :--- | :--- |
| 7 | RstIRQ | RstIRQ = 1 to reset IRQ for the lane <br> selected in Bits[2:0]. |
| 6 | Disable_ErrCnt | Disable_ErrCnt = 1 to disable the error <br> count for the lane selected in Bits[2:0]. |
| 5 | RstErrCntr | RsteErrCntr $=1$ to reset the error <br> count for the lane selected in Bits[2:0]. |
| $[2: 0]$ | LaneAddr | LaneAddr $=x$ to monitor the error <br> count of Link Lane $x$. See the notes on <br> link lane in Step 1 of the Checking <br> Error Counts section. |

## Monitoring Errors via $\overline{\text { SYNCOUTx } \pm}$

When one or more disparity, not in table, or unexpected control character error occurs, the error is reported on the SYNCOUTx $\pm$ pins as per Section 7.6 of the JESD204B specification. The JESD204B specification states that the SYNCOUTx $\pm$ signal is asserted for exactly 2 frame periods when an error occurs. For the AD9154, the width of the $\overline{\text { SYNCOUTx } \pm}$ pulse can be programmed. The settings to achieve a $\overline{\text { SYNCOUTx } \pm}$ pulse of 2 frame clock cycles are given in Table 60.

Table 60. Setting $\overline{\text { SYNCOUTx } \pm}$ Error Pulse Duration

| JESD204B <br> Mode IDs | PClockFactor <br> (Frames/PClock) | SYNCB_ERR_DUR <br> (Register 0x312[5:4]) Setting ${ }^{1}$ |
| :--- | :--- | :--- |
| $0,4,9$ | 4 | 0 (default) |
| $1,2,5,6,10$ | 2 | 1 |
| 3,7 | 1 | 2 |

${ }^{1}$ These register settings assert the $\overline{\text { SYNCOUTX } \pm}$ signal for 2 frame clock cycles pulse widths.

## Disparity, NIT, Unexpected Control Character IRQs

For disparity, not in table, and unexpected control character errors, error count over the threshold events are available as IRQ events. Enable these events by writing to Register 0x47A, Bits[7:5]. The IRQ event status can be read at the same address (Register 0x47A, Bits[7:5]) after the IRQs are enabled.

## Errors Requiring Reinitializing

A link reinitialization automatically occurs when four invalid disparity characters are received as per Section 7.1 of the JESD specification. When a link reinitialization occurs, the resync request is 5 frames and 9 octets long.
The user can optionally reinitialize the link when the error count for disparity errors, not in table errors, or unexpected control characters reaches a programmable error threshold. The process to enable the reinitialization feature for certain error types is as follows:

1. Set THRESHOLD_MASK_EN (Register 0x477, Bit 3) $=1$. Note that when this bit is set, unmasked errors do not saturate at either threshold or maximum value.
2. Enable the sync assertion mask for each type of error by writing to the SYNC_ASSERTION_MASK register (Register 0x47B, Bits[7:5]) according to Table 61.
3. Program the desired error counter threshold into ERRORTHRES (Register 0x47C).
4. For each error type enabled in the SYNC_ASSERTION_ MASK register, if the error counter on any lane reaches the programmed threshold, $\overline{\text { SYNCOUTx } \pm \text { falls, issuing a sync }}$ request. Note that all error counts are reset when a link reinitialization occurs. The IRQ does not reset and must be reset manually.

Table 61. Sync Assertion Mask

| Addr. | Bit No. | Bit Name | Description |
| :--- | :--- | :--- | :--- |
| $0 \times 47 B$ | 7 | BADDIS_S | Set to 1 to assert $\overline{\text { SYNCOUTx } \pm}$ <br> if the disparity error count <br> reaches the threshold |
|  | 6 | NIT_S | Set to 1 to assert $\overline{\text { SYNCOUTx } \pm}$ <br> if the not in table error count <br> reaches the threshold |
|  | 5 | UCC_S | Set to 1 to assert $\overline{\text { SYNCOUTx } \pm}$ <br> if the unexpected control <br> character count reaches the <br> threshold |

## CGS, Frame Sync, Checksum, and ILAS Monitoring

Register 0x470 to Register 0x473 can be monitored to verify that each stage of JESD204B link establishment has occurred. Program Register 0x300, Bit $2=0$ to monitor the status of the lanes on Link 0, and Register 0x300, Bit $2=1$ to monitor the status of the lanes on Link 1.
Bit x of CODEGRPSYNCFLAG (Register 0x470) is high if Link Lane x received at least 4 K 28.5 characters and passed code group synchronization.
Bit x of FRAMESYNCFLAG (Register 0x471) is high if Link Lane x completed initial frame synchronization.
Bit x of GOODCHKSUMFLG (Register 0x472) is high if the checksum sent over the lane matches the sum of the JESD204B parameters sent over the lane during ILAS for Link Lane x . The parameters can be added either by summing the individual fields in registers or summing the packed register. If Register 0x300, Bit $6=0$ (default), the calculated checksums are the lower 8 bits of the sum of the following fields: DID, BID, LID, SCR, $\mathrm{L}-1, \mathrm{~F}-1$, $\mathrm{K}-1, \mathrm{M}-1, \mathrm{~N}-1$, SUBCLASSV, NP -1 , JESDV, $\mathrm{S}-1$, and HD. If Register $0 \times 300$, Bit $6=1$, the calculated checksums are the lower 8 bits of the sum of Register 0x400 to Register 0x40C and LID.
Bit x of INITIALLANESYNC (Register 0x473) is high if Link Lane x passed the initial lane alignment sequence.

## CGS, Frame Sync, Checksum, and ILAS IRQs

Fail signals for CGS, frame sync, checksum, and ILAS are available as IRQ events. Enable them by writing to Register 0x47A, Bits[3:0]. The IRQ event status can be read at the same address (Register 0x47A, Bits[3:0]) after the IRQs are enabled. Write a 1 to Register 0x470, Bit 7 to reset the CGS IRQ. Write a 1 to Register 0x471 to reset the frame sync IRQ. Write a 1 to Register 0x472 to reset the checksum IRQ. Write a 1 to Register 0x473 to reset the ILAS IRQ.

## Configuration Mismatch IRQ

The AD9154 has a configuration mismatch flag that is available as an IRQ event. Use Register 0x47B, Bit 3 to enable the mismatch flag (it is enabled by default), and then use Register 0x47B, Bit 4 to read back its status and reset the IRQ signal. See the Interrupt Request Operation section for more information.

The configuration mismatch event flag is high when the link configuration settings (in Register 0x450 to Register 0x45D) do not match the JESD204B transmitted settings (Register 0x400 to

Register 0x40D). All these registers are paged per link (in Register 0x300).
Note that this function is different from the good checksum flags in Register 0x472. The good checksum flags ensure that the transmitted checksum matches a calculated checksum based on the transmitted settings. The configuration mismatch event ensures that the transmitted settings match the configured settings.

## DIGITAL DATAPATH



Figure 68. Block Diagram of the Digital Datapath

Figure 68 shows a block diagram of the signal processing digital datapath. The digital processing includes an input power detection block, three half-band interpolation filters, a quadrature modulator consisting of a fine resolution NCO modulator and $\mathrm{f}_{\mathrm{DAC}} / 4$ and $\mathrm{f}_{\mathrm{DAC}} / 8$ coarse modulator blocks, an inverse sinc filter, and gain, phase, offset, and group delay adjustment blocks.
The datapath is organized into two identical paths. Each path processes a pair of digital signals input from the JESD204B transport layer block. The digital signals are processed by a datapath and input to a pair of DAC cores. Interpolation modes process the pair of signals as independent data streams. The coarse and fine modulation block requires that a data stream to be upconverted be an I/Q pair of signals

## DUAL PAGING

The digital datapath registers are paged to allow configuration of either DAC dual independently or both simultaneously. Table 62 shows how to use the dual paging register.

Table 62. Paging Modes

| PAGEINDX | Duals |  |
| :--- | :--- | :--- |
| Reg. 0x008[1:0] | Paged | DACs Updated |
| 1 | A | DAC0 and DAC1 |
| 2 | B | DAC2 and DAC3 |
| 3 (default) | A and B | DAC0, DAC1, DAC2, and DAC3 |

Several functions are paged by DAC dual, such as input data format, downstream protection, interpolation, modulation, inverse sinc, digital gain, phase offset, dc offset, group delay, IQ swap, datapath PRBS, LMFC sync, and NCO alignment.

## DATA FORMAT

BINARY_FORMAT (Register 0x110, Bit 7), paged as described in the Dual Paging section) controls the expected input data format. By default it is 0 , which means the input data must be in twos complement. It can also be set to 1 , which means input data is in offset binary ( $0 \times 0000$ is negative full scale and $0 \times \mathrm{xFFFF}$ is positive full scale).

## INTERPOLATION MODES

Interpolation increases the sampling rate of a digital signal and can be bypassed. The transmit path contains three half-band interpolation filters, which each provide a $2 \times$ increase in the output sampling rate and a low-pass function. Table 63 shows how to select each available interpolation mode, their usable bandwidths, and their maximum data rates. Note that

$$
f_{D A T A}=f_{D A C} / \text { InterpolationFactor }
$$

The maximum values of $f_{\text {DATA }}$ for interpolator bypass and the three interpolation factors are listed in Table 2 as adjusted DAC update rates; $\mathrm{f}_{\text {DATA }}$ is another name for the adjusted DAC update rate. Interpolation mode is paged as described in the Dual Paging section. Register $0 \times 030$, Bit 0 is high if an unsupported interpolation mode is selected.
Table 63. Interpolation Modes and Usable Bandwidth

| Interpolation Mode | INTERPMODE <br> Reg. 0x112[2:0] | Usable Bandwidth |
| :--- | :--- | :--- |
| $1 \times$ (bypass) | $0 \times 00$ | $0.5 \times f_{\text {DATA }}$ |
| $2 \times$ | $0 \times 01$ | $0.4 \times f_{\text {DATA }}$ |
| $4 \times$ | $0 \times 03$ | $0.4 \times f_{\text {DATA }}$ |
| $8 \times$ | $0 \times 04$ | $0.4 \times f_{\text {DATA }}$ |

${ }^{1}$ The maximum speed for $1 \times$ interpolation is limited by the JESD204B interface.

## Filter Performance

Interpolation modes increase the sampling rate of a digital signal by a factor of 2,4 , or 8 . As part of the process, a digital low-pass filter is applied. The filter magnitude response for each interpolation mode is shown in Figure 69.
The usable bandwidth (as shown in Table 63) is defined as the frequency band over which the filters have a pass-band ripple of less than $\pm 0.001 \mathrm{~dB}$ and an image rejection of greater than 85 dB .


Figure 69. All Band Responses of Interpolation Filters

## Filter Performance Beyond Specified Bandwidth

The usable pass band of the interpolation filter is specified as $0.4 \times \mathrm{f}_{\text {DATA }}$. The filters can be used slightly beyond this ratio at the expense of increased pass-band ripple and decreased interpolation image rejection.


Figure 70. Interpolation Filter Performance Beyond Specified Bandwidth
Figure 70 shows the performance of the interpolation filters beyond $0.4 \times \mathrm{f}_{\text {DATA }}$. Note that the ripple increases much slower than the image rejection decreases. This means that if the application can tolerate degraded image rejection from the interpolation filters, more bandwidth can be used.

## DIGITAL MODULATION

The AD9154 includes modulation blocks that upconvert I/Q quadrature signal pairs to an IF frequency in the digital domain.
The coarse modulation modes ( $\mathrm{f}_{\text {DAC }} / 4$ and $\mathrm{f}_{\text {DAC }} / 8$ ) upconvert an I/Q pair of digital signals to one of the selected IFs. The NCO fine modulation mode upconverts an I/Q signal pair to an IF frequency programmed into the NCO. Modulation mode is selected as shown in Table 64 and is paged as described in the Dual Paging section.

Table 64. Modulation Mode Selection

| Modulation Mode | MODULATION_TYPE <br> Register 0x111, Bits[3:2] |
| :--- | :--- |
| None | $0 b 00$ |
| NCO Fine Modulation | $0 b 01$ |
| Coarse $-\mathrm{f}_{\text {DAC }} / 4$ | $0 b 10$ |
| Coarse $-\mathrm{f}_{\text {DAC }} / 8$ | $0 b 11$ |

## NCO Fine Modulation

This modulation mode uses the NCO, a phase shifter, and a complex modulator to upconvert an I/Q digital signal pair to an IF frequency within the first Nyquist zone of the DAC cores. Figure 71 shows a block diagram of the NCO modulator. This allows output signals to be placed anywhere in the output spectrum with very fine frequency resolution. The NCO produces a quadrature carrier to translate the input signal to a new center frequency. A quadrature carrier is a pair of sinusoidal waveforms of the same frequency, offset $90^{\circ}$ from each other.

The frequency of the quadrature carrier is set via an FTW. The quadrature carrier is mixed with the I and Q data and then summed into the I and Q datapaths, as shown in Figure 71.

$$
\begin{aligned}
& -\mathrm{f}_{\text {DAC }} / 2 \leq f_{\text {CARRIER }}<+f_{\text {DAC }} / 2 \\
& F T W=\left(f_{\text {CARRIER }} / f_{\text {DAC }}\right) \times 2^{48}
\end{aligned}
$$

where $F T W$ is a 48 -bit twos complement number.
The frequency tuning word is set as shown in Table 65 and paged as described in the Dual Paging section.

Table 65. NCO FTW Registers

| Address | Value | Description |
| :--- | :--- | :--- |
| $0 \times 114$ | FTW[7:0] | 8 LSBs of FTW |
| $0 \times 115$ | FTW[15:8] | Next 8 bits of FTW |
| $0 \times 116$ | FTW[23:16] | Next 8 bits of FTW |
| $0 \times 117$ | FTW[31:24] | Next 8 bits of FTW |
| $0 \times 118$ | FTW[39:32] | Next 8 bits of FTW |
| $0 \times 119$ | FTW[47:40] | 8 MSBs of FTW |

Unlike other registers, the FTW registers are not updated immediately upon writing. Instead, the FTW registers update on the rising edge of FTW_UPDATE_REQ (Register 0x113[0]). After an update request, FTW_UPDATE_ACK (Register 0x113[1]) must be high to acknowledge that the FTW has updated.
SEL_SIDEBAND (Register 0x111, Bit 1; paged as described in the Dual Paging section) is a convenience bit that can be set to use the negative modulation result. This is equivalent to flipping the sign of FTW.


Figure 71. NCO Modulator Block Diagram

## NCO Phase Offset

The NCO phase offset feature allows rotation of the I and Q phases. Unlike phase adjust, this feature moves the phases of both I and Q channels together. NCO phase offset can be used only when using NCO fine modulation.

$$
\begin{aligned}
& -180^{\circ} \leq \text { DegreesOffset }<+180^{\circ} \\
& \text { PhaseOffset }=\left(\text { DegreesOffset } 180^{\circ}\right) \times 2^{15}
\end{aligned}
$$

where PhaseOffset is a 16-bit twos complement number.

The NCO phase offset is set as shown in Table 66 and paged as described in the Dual Paging section. Because this function is part of the fine modulation block, phase offset is not updated immediately upon writing. Instead, it updates on the rising edge of FTW_UPDATE_REQ (Register 0x113, Bit 0 ) along with the FTW.

Table 66. NCO Phase Offset Registers

| Address | Value |
| :--- | :--- |
| $0 \times 11 \mathrm{~A}$ | NCO_PHASE_OFFSET[7:0] |
| $0 \times 11 \mathrm{~B}$ | NCO_PHASE_OFFSET[15:8] |

## INVERSE SINC

DACs have a $\sin (\mathrm{x}) / \mathrm{x}$ amplitude roll-off as a function frequency. This characteristic is shown in blue in Figure 72. The AD9154 provides a digital inverse sinc function to compensate for this roll-off over frequency. The filter is enabled by setting the INVSINC_ENABLE bit (Register 0x111, Bit 7, paged as described in the Dual Paging section). Inverse sinc is enabled by default.
Figure 72 shows the frequency response of $\sin (\mathrm{x}) / \mathrm{x}$ roll-off, the inverse sinc filter, and the composite response. The composite response has less than $\pm 0.05 \mathrm{~dB}$ pass-band ripple up to a frequency of $0.4 \times \mathrm{f}_{\text {DACCLK }}$. To provide the necessary peaking at the upper end of the pass band, the inverse sinc filter shown has an intrinsic insertion loss of about 3.8 dB ; in many cases, this can be partially compensated as described in the Digital Gain section.


Figure 72. Responses of $\sin (x) / x$ Roll-Off, the Sinc ${ }^{-1}$ Filter, and the Composite of the Two Input Signal Power Detection and Protection

## DIGITAL GAIN, PHASE ADJUST, DC OFFSET, AND GROUP DELAY

Digital gain, phase adjust, and dc offset (as described in the Digital Gain section, Phase Adjust section, and DC Offset section) allow compensation of imbalances in the $I$ and $Q$ paths due to analog mismatches between DAC I/Q outputs, quadrature modulator I/Q baseband inputs, and DAC/modulator interface I/Q paths. These imbalances can cause the two following issues:

- An unwanted sideband signal appears at the quadrature modulator output with significant energy. Cancel this signal using digital gain and phase adjust.

Tuning the quadrature gain and phase adjust values can optimize complex image rejection in single sideband radios or can optimize the error vector magnitude (EVM) in zero IF (ZIF) architectures.

- The LO leakage at the output of a quadrature modulator following the AD9154 in a signal chain can be cancelled by adjusting the dc current output of each DAC driving modulator signal inputs.


## Digital Gain

Digital gain independently adjusts the digital signal magnitude being fed into each DAC. The digital gain code can be left at its default value where it provides 0 dB of digital backoff (in other words, a gain of 1 ), or it can be programmed to provide larger digital backoff. Digital gain can be programmed to introduce an I/Q pair gain imbalance to help a quadrature modulator following the AD9154 in a signal chain cancel an unwanted SSB sideband. Digital gain is enabled by default and must not be disabled.
The amount of digital gain (GainCode) desired can be programmed in the registers shown in Table 67. The digital gain settings are described in the following equations:

$$
\begin{aligned}
& 0 \leq \text { Gain } \leq 4095 / 2048 \\
& -\infty \mathrm{dB} \leq \text { dBGain } \leq 6.018 \mathrm{~dB} \\
& \text { Gain }=\text { GainCode } \times(1 / 2048) \\
& \text { dBGain }=20 \times \log 10(\text { Gain }) \\
& \text { GainCode }=2048 \times \text { Gain }=2048 \times 10^{\text {dBGain/20 }}
\end{aligned}
$$

where GainCode is a 12 -bit unsigned binary number.
The I/Q digital gain is set as shown in Table 67 and paged as described in the Dual Paging section.

Table 67. Digital Gain Registers

| Addr. | Value | Description |
| :--- | :--- | :--- |
| $0 \times 111[5]$ | DIG_GAIN_ENABLE | Set to 1 to enable digital gain <br> at reset |
| $0 \times 13 C$ | GAINCODEI[7:0] | I DAC LSB gain code |
| $0 \times 13 D$ | GAINCODEI[11:8] | I DAC MSB gain code |
| $0 \times 13 E$ | GAINCODEQ[7:0] | Q DAC LSB gain code |
| $0 \times 13 F$ | GAINCODEQ[11:8] | Q DAC MSB gain code |

## Phase Adjust

Ordinarily, the I and Q channels of each DAC pair have an angle of $90^{\circ}$ between them. The phase adjust feature changes the angle between the I and Q channels, which balances the phase into a modulator.
$-14 \leq$ DegreesAdjust $<14$
PhaseAdj $=($ DegreesAdjust $/ 14) \times 2^{12}$
where PhaseAdj is a 13 -bit twos complement number.
The phase adjust is set as shown in Table 68 and paged as described in the Dual Paging section.

Table 68. I/Q Phase Adjustment Registers

| Addr. | Value | Description |
| :--- | :--- | :--- |
| $0 \times 111[4]$ | PHASE_ADJ_ENABLE | Set to 1 to enable phase <br> adjust |
| $0 \times 11 \mathrm{C}$ | PHASEADJ[7:0] | LSB phase adjust code <br> $0 \times 11 \mathrm{D}$ |
| PHASEADJ[12:8] | MSB phase adjust code |  |

## DC Offset

The dc offset feature individually offsets the data into the I or Q DACs. This feature cancels LO leakage at the modulator output.
The offset is programmed individually for I and Q as a 16 -bit twos complement number in LSBs, plus a 5-bit twos complement number in sixteenths of an LSB, as shown in Table 69. DC offset is paged as described in the Dual Paging section.

```
-2 }\mp@subsup{}{}{15}\leqL\mathrm{ LSBsOffset < 2 }\mp@subsup{}{}{15
-16 \leq SixteenthsOffset \leq 15
```

Table 69. DC Offset Registers

| Addr. | Value | Description |
| :--- | :--- | :--- |
| $0 \times 135[0]$ | DC_OFFSET_ON | Set to 1 to enable dc offset |
| $0 \times 136$ | LSBSOFFSETI[7:0] | I DAC LSB dc offset code |
| $0 \times 137$ | LSBSOFFSETI[15:8] | I DAC MSB dc offset code |
| $0 \times 138$ | LSBSOFFSETQ[7:0] | Q DAC LSB dc offset code |
| $0 \times 139$ | LSBSOFFSETQ[15:8] | Q DAC MSB dc offset code |
| $0 \times 13 A[4: 0]$ | SIXTEENTHSOFFSETI | IDAC sub-LSB dc offset code |
| $0 \times 13 B[4: 0]$ | SIXTEENTHSOFFSETQ | Q DAC sub-LSB dc offset code |

## Coarse Group Delay

Coarse group delay is a global adjustment of the DAC latency, and it is programmed to identically affect both DACs in an I/Q signal pair. The coarse group delay range is in $+7 /-8$ steps. Each step is $1 / 2$ DAC clock cycle. The default value of $0 \times 8$ sets the delay to zero. This is useful in applications where the user needs to tune the latency of the DAC path with some accuracy (for example, in DPD loop delay adjust).
Write the value to COARSE_GROUP_DLY (Register 0x014). This is paged as described in the Dual Paging section.

## Group Delay Compensation

Group delay compensation provides separate delay tunability to either an I or Q channel within each dual digital signal pair. The user can delay either the I or Q output to align their quadrature. Table 70 shows the register settings used for group delay compensation. The group delay compensation bypass register is located at Register 0x046. The GROUPDELAYCOMP (Bits[7:0]) values are binary, and the default value of 0 x 00 is a delay compensation of zero. The difference between this mode and the phase adjust mode is that group delay compensation can correct for delay differences between the I and Q channels, while phase adjust cannot. Group delay compensation is paged as described in the Dual Paging section.

Table 70. Group Delay Compensation Registers

| Addr. | Value | Description |
| :--- | :--- | :--- |
| $0 \times 046$ | GROUP DELAY <br> COMP BYPASS | Set to 3 to bypass both I and Q <br> compensation <br> $0 \times 044$ |
| GROUP DELAY <br> COMP I [7:0] <br> $0 \times 045$ | GROUP DELAY <br> COMP Q [7:0] | $\pm 85$ ps nominal range range |

## I TO Q SWAP

I_TO_Q (Register 0x111, Bit 0; paged as described in the Dual Paging section) is a convenience bit that can be set to send the I datapath to the Q DAC. Note that this swap occurs at the end of the datapath (after any modulation, digital gain, phase adjust, and phase offset). If using $\mathrm{M}=1 \mathrm{DACs}$ in DualLink mode (as described in the DAC Power-Down Setup section), set this bit to direct data to the DAC3 output.

## NCO ALIGNMENT

The NCO alignment block phase aligns the NCO output from multiple converters. Two NCO alignment modes are supported by the AD9154. The first is a SYSREF $\pm$ alignment mode that phase aligns the NCO outputs to the rising edge of a SYSREF $\pm$ pulse. The second alignment mode is a data key alignment; when this mode is enabled, the AD9154 aligns the NCO outputs when a user specified data pattern arrives at the DAC input. Note that the NCO alignment is per dual, and is paged as described in the Dual Paging section.

## SYSREF $\pm$ NCO Alignment

As with the LMFC alignment, in Subclass 1, a SYSREF $\pm$ pulse can phase align the NCO outputs of multiple devices in a system and multiple channels on the same device. Note that in Subclass 0 , this alignment mode can align the NCO outputs within a device to an internal processing clock edge. No SYSREF $\pm$ edge is needed in Subclass 0 , but multichip alignment cannot be achieved. The steps to achieve a SYSREF NCO alignment are as follows:

1. Set NCOCLRMODE (Register 0x050, Bits[1:0]) $=0 \mathrm{~b} 01$ for SYSREF NCO alignment mode.
2. Set NCOCLRARM to 1 (Register 0x050, Bit 7).
3. Perform an LMFC alignment to force the NCO phase align (see the Syncing LMFC Signals section). The phase alignment occurs on the next SYSREF $\pm$ edge. Note that if in one shot sync mode, the LMFC alignment block must be armed by setting Register 0x03A, Bit $6=1$. If in continuous mode or one shot then monitor mode, the LMFC align block does not need to be armed; the NCO align automatically trips on the next SYSREF $\pm$ edge.
4. Check the alignment status. If NCO phase alignment was successful, NCOCLRPASS (Register 0x050, Bit 4 ) $=1$. If phase alignment failed, NCOCLRFAIL (Register 0x050, Bit 3) $=1$.

## Data Key NCO Alignment

In addition to supporting the SYSREF $\pm$ alignment mode, the AD9154 supports a mode where the NCO phase alignment occurs when a user-specified pattern is seen at the DAC input. The steps to achieve a data key NCO alignment are as follows:

1. Set NCOCLRMODE (Register 0x050, Bits[1:0]) $=0 \mathrm{~b} 10$.
2. Write the expected 16 -bit data key for the $I$ and $Q$ datapath into NCOKEYIx (Register 0x051 to Register 0x052) and NCOKEYQ (Register 0x053 to Register 0x054), respectively.
3. Set NCOCLRARM (Register 0x050, Bit 7$)=1$.
4. Send the expected 16 -bit I and Q data keys to the device to achieve NCO alignment.
5. Check the alignment status. If the expected data key was seen at the DAC input, then NCOCLRMTCH (Register 0x050, Bit 5$)=1$. If NCO phase alignment was successful, NCOCLRPASS (Register 0x050, Bit 4) $=1$. If phase alignment failed, NCO_ALIGN_FAIL (Register 0x050, Bit 3) $=1$.

Multiple device NCO alignment can be achieved with the data key alignment mode. To achieve multichip NCO alignment, program the same expected data key on all devices, arm all devices, and then send the data key to all devices/channels at the same time.

## NCO Alignment IRQ

An IRQ event showing whether the NCO align was tripped is available.
Use Register 0x021, Bit 4 to enable DAC Dual A (DAC0 and DAC1), and then use Register 0x025, Bit 4 to read back its status and reset the IRQ signal.
Use Register 0x022, Bit 4 to enable DAC Dual B (DAC2 and DAC3), and then use Register 0x026, Bit 4 to read back its status and reset the IRQ signal.
See the Interrupt Request Operation section for more information.

## DOWNSTREAM PROTECTION

The AD9154 has several blocks designed to protect the power amplifier (PA) in its board level signal chain, as well as other downstream blocks. It consists of a power detection and protection (PDP) block, a blanking state machine (BSM), and a transmit enable state machine (Tx ENSM).

The PDP block monitors incoming data. If a moving average of the data power goes above a threshold, the PDP block provides a signal (PDP_PROTECT) that can be routed externally on the PDP OUT0 and PDP OUT1 pins.
The Tx ENSM is a simpler block that controls delay between TXENx and the Tx_PROTECT signal. The Tx_PROTECT signal is used as an input to the BSM and its inverse can optionally be routed externally. Optionally, the Tx ENSM can also power down its associated DAC dual.
The BSM gently ramps data entering the DAC and flushes the datapath. The BSM is activated by the $\overline{\text { Tx_PROTECT }}$ signal or automatically by the LMFC sync logic during a rotation. Digital gain must be enabled for proper function. Finally, some simple logic takes the outputs from each of those blocks and uses them to generate a desired PDP OUTx signal on an external pin. This signal can enable/disable downstream components, such as a PA.

## Power Detection and Protection

The input signal PDP block detects the average power of the DAC input signal and to prevent overrange signals from being passed to the next stage, which may potentially cause destructive breakdown on power sensitive devices, such as PAs. The protection function provides a signal (PDP_PROTECT) that can be routed externally to shut down a PA.
The PDP block uses a separate path with a shorter latency than the datapath to ensure that PDP_PROTECT gets triggered before the overrange signal reaches the analog DAC cores. The sum of the $\mathrm{I}^{2}$ and $\mathrm{Q}^{2}$ are calculated as a representation of the input signal power (only the top seven MSBs of data samples are used). The calculated sample power numbers are accumulated through a moving average filter whose output is the average of the input signal power in a certain number of samples. When the output of the averaging filter is larger than the threshold, the internal signal PDP_PROTECT goes high, which can optionally be configured to trigger a signal on the PDP OUTx pins. The PDP block is configured as shown in Table 71 and paged as described in the Dual Paging section.
The choice of PDP_AVG_TIME (Register 0x062) and PDP_THRESHOLD[12:0] (Register 0x060 to Register 0x061) for effective protection are application dependent. Experiment with real-world vectors to ensure proper configuration. The PDP_POWER[12:0] readback (Register 0x063 to Register 0x064) can help by storing the maximum power when a set threshold passes.


Figure 73. Downstream Protection Block Diagram

Table 71. PDP Registers

| Addr. | Bit No. | Value | Description |
| :---: | :---: | :---: | :---: |
| 0x060 | [7:0] | PDP_THRESHOLD[7:0] | Power that triggers PDP_PROTECT. 8 LSBs. |
| 0x061 | [4:0] | PDP_THRESHOLD[12:8] | 5 MSBs. |
| 0x062 | 7 | PDP_ENABLE | Set to 1 to enable PDP. |
|  | [3:0] | PDP_AVG_TIME | Can be set from 0 to 10. Averages across $2^{(9+\text { PDP_AVG_TIME) }, ~ I Q ~}$ sample pairs. |
| 0x063 | [7:0] | PDP_POWER[7:0] | If PDP_THRESHOLD is crossed, this reads back the maximum power seen. If not, this reads back the instantaneous power. 8 LSBs. |
| 0x064 | [4:0] | PDP_POWER[12:8] | 5 MSBs . |

## Power Detection and Protection IRQ

The PDP_PROTECT signal is available as an IRQ event.
Use Register 0x021, Bit 7 to enable PDP_PROTECT for Dual A (DAC0 and DAC1), and then use Register 0x025, Bit 7 to read back its status and reset the IRQ signal.
Use Register 0x022, Bit 7 to enable PDP_PROTECT for Dual B (DAC2 and DAC3), and then use Register 0x026, Bit 7 to read back its status and reset the IRQ signal.

See the Interrupt Request Operation section for more information.

## Transmit Enable State Machine

The Tx ENSM is a simple block that controls the delay between the TXENx signal and the TX_PROTECT signal. This signal is used as an input to the BSM and its inverse can be routed to an
external pin (PDP_OUTx) to turn downstream components on or off as desired.
The TXENx signal can power down their associated DAC duals. If DACA_MASK (Register 0x012, Bit 6) $=1$, a falling edge of TXENx causes DAC Dual A (DAC0 and DAC1) to power down. If DACB MASK (Register 0x012, Bit 7) $=1$, a falling edge of TXENx causes DAC Dual B (DAC2 and DAC3) to power down. On a rising edge of TXENx, without DACA_MASK and DACB_MASK enabled, the output is valid after the BSM settles (see the Blanking State Machine (BSM) section). If the masks are enabled, an additional delay is imposed; the output is not valid until the BSM settles and the DACs fully power on (nominally an additional $\sim 35 \mu \mathrm{~s}$ ).

The Tx ENSM is configured as shown in Table 72 and is paged as described in the Dual Paging section.

Table 72. Tx ENSM Registers

| Addr. | Bit No. | Value | Description |
| :--- | :--- | :--- | :--- |
| $0 \times 11 \mathrm{~F}$ | $[7: 6]$ | PA_FALL | Number of fall counters <br> to use (1 to 2). |
|  | $[5: 4]$ | PA_RISE | Number of rise counters <br> to use (0 to 2). |
| $0 \times 121$ | $[7: 0]$ | RISE_COUNT_0 | Delay TX_PROTECT rise <br> from TXENx rising edge <br> by 32 $\times$ RISE_COUNT_0 <br> DAC clock cycles. |
| $0 \times 122$ | $[7: 0]$ | RISE_COUNT_1 | Delay TX_PROTECT rise <br> from TXENx rising edge <br> by 32 $\times$ RISE_COUNT_1 <br> DAC clock cycles. |
| $0 \times 123$ | $[7: 0]$ | FALL_COUNT_0 | Delay TX_PROTECT rise <br> from TXENx rising edge <br> by 32 $\times$ FALL_COUNT_0 <br> DAC clock cycles. Must <br> be at least 0x12. |
| $0 \times 124$ | $[7: 0]$ | FALL_COUNT_1 | Delay TX_PROTECT rise <br> from TXENx rising edge <br> by 32 $\times$ FALL_COUNT_1 <br> DAC clock cycles. |

## Blanking State Machine (BSM)

The BSM gently ramps data entering the DAC and flushes the datapath.
On a falling edge of TX_PROTECT (the TXENx signal delayed by the Tx ENSM), the datapath holds the latest data value and the digital gain gently ramps from its set value to 0 . At the same time, the datapath is flushed with zeroes.
On a rising edge of TX_PROTECT, the TXENx signal is delayed by the Tx ENSM; data is allowed to flow through the datapath again and the digital gain gently ramps the data from 0 up to the set digital gain.

Both of the above functions are also triggered automatically by the LMFC sync logic during a rotation to prevent glitching on the output.

## Ramping

The step size to use when ramping gain to 0 or its assigned value can be controlled via the GAIN_RAMP_DOWN_STEPx registers (Register 0x142 and Register 0x143) and the GAIN_RAMP_ UP_STEPx registers (Register 0x140 and Register 0x141). These registers are paged as described in the Dual Paging section.
The current BSM state can be read back as shown in Table 73.
Table 73. Blanking State Machine Ramping Readbacks

| Address | Value | Description |
| :--- | :--- | :--- |
| $0 \times 147[7: 6]$ | 0b00 | Data is being held at midscale. <br> Ob01 <br> Ramping gain to 0. Data ramping to <br> midscale. |
|  | 0b10 | Ramping gain to assigned value. Data <br> ramping to normal amplitude. <br> Data at normal amplitude. |

## Blanking State Machine IRQ

Blanking completion is available as an IRQ event.
Use Register 0x021, Bit 5 to enable blanking completion for DAC Dual A (DAC0 and DAC1), and then use Register 0x025, Bit 5 to read back its status and reset the IRQ signal.
Use Register 0x022, Bit 5 to enable blanking completion for DAC Dual B (DAC2 and DAC3), and then use Register 0x026, Bit 5 to read back its status and reset the IRQ signal.

See the Interrupt Request Operation section for more information.

## PDP OUTx Generation

Register 0x013 controls which signals are OR'ed into the external PDP OUTx signal. Register 0x11F, Bit 2 can invert the PDP OUTx signal, By default, PDP OUTx is high when output is valid. Both of these registers are paged as described in the Dual Paging section.

Table 74. PDP OUTx Registers

| Addr. | Bit No. | Description |
| :--- | :--- | :--- |
| $0 \times 013$ | 6 | $1:$ PDP block triggers PDP_OUT |
|  | 5 | 1:Tx ENSM triggers PDP_OUT |
|  | 3 | 1: SPI_PROTECT triggers PDP_OUT |
|  | 2 | Sets SPI_PROTECT |
| $0 \times 11 \mathrm{~F}$ | 2 | Inverts PDP OUTx |

## DATAPATH PRBS

The datapath PRBS can verify that the AD9154 datapath is receiving and correctly decoding data. The datapath PRBS verifies that the JESD204B parameters of the transmitter and receiver match, the lanes of the receiver are mapped appropriately, lanes have been appropriately inverted, if necessary, and in general that the start-up routine has been implemented correctly.
The datapath PRBS is paged as described in the Dual Paging section. To run the datapath PRBS test, complete the following steps:

1. Set up the device in the desired operating mode. See the Device Setup Guide section for details on setting up the device.
2. Send PRBS7 or PRBS15 data.
3. Write Register 0x14B, Bit $2=0$ for PRBS7 or 1 for PRBS15.
4. Write Register $0 \times 14 \mathrm{~B}$, Bit 1 and Bit $0=0 \mathrm{~b} 11$ to enable and reset the PRBS test.
5. Write Register 0x14B, Bit 1 and Bit $0=0 \mathrm{~b} 01$ to enable the PRBS test and release reset.
6. Wait 500 ms .
7. Check the status by checking the IRQ for DAC0 to DAC3 PRBS as described in the Datapath PRBS IRQ section.
8. If there are failures, set Register $0 \times 008=0 \times 01$ to view the status of Dual A (DAC0/DAC1). Set Register 0x08 $=0 \times 02$ to view the status of Dual B (DAC2/DAC3).
9. Read Register 0x14B, Bit 7 and Bit 6 . Bit 6 is 0 if the I DAC of the selected dual has any errors. Bit 7 is 0 if the Q DAC of the selected dual has any errors. This must match the IRQ.
10. Read Register 0x14C to read the error count for the I DAC of the selected dual. Read Register 0x14D to read the error count for the Q DAC of the selected dual.

Note that the PRBS processes 32 bits at a time, and compares the 32 new bits to the previous set of 32 bits. It detects (and reports) only 1 error in every group of 32 bits, so the error count partly depends on when the errors are seen. For example,

- Bits: 32 good, 31 good, 1 bad; 32 good (2 errors)
- Bits: 32 good, 22 good, 10 bad; 32 good ( 2 errors)
- Bits: 32 good, 31 good, 1 bad; 31 good, 1 bad; 32 good (3 errors)


## Datapath PRBS IRQ

The PRBS fail signals for each DAC are available as IRQ events. Use Register 0x020, Bits[3:0] to enable the fail signals, and then use Register 0x024, Bits[3:0] to read back their statuses and reset the IRQ signals. See the Interrupt Request Operation section for more information.

## DC TEST MODE

The AD9154 provides a dc test mode. When dc test mode is activated, the input to the digital data paths is set to a midscale DAC input dc level in place of data from the JESD204B transport layer.

DC test mode is enabled by setting Register $0 \times 520$, Bit 1 and clearing Register 0x146, Bit 0 . Register 0x146, Bit 0 must be set to 1 for all other modes of operation.
In dc test mode, the digital modulator can generate a sine wave at a fixed amplitude. Digital gain, dc offset, and phase adjustment can be applied to the sine wave on its way to each DAC core input.

## INTERRUPT REQUEST OPERATION



Figure 74. Simplified Schematic of $\overline{I R Q}$ Circuitry

The AD9154 provides an interrupt request output signal on Pin 60 (IRQ) that can notify an external host processor of significant device events. On assertion of the interrupt, query the device to determine the precise event that occurred. The $\overline{\text { IRQ }}$ pin is an open-drain, active low output. Pull the $\overline{\mathrm{IRQ}}$ pin high external to the device. This pin can be tied to the interrupt pins of other devices with open-drain outputs to wire; OR these pins together. Figure 74 shows a simplified block diagram of how the IRQ blocks works. If IRQ_EN is low, the INTERRUPT_SOURCE signal is set to 0 . If IRQ_EN is high, any rising edge of EVENT causes the INTERRUPT_SOURCE signal to be set high. If any INTERRUPT_ SOURCE signal is high, the $\overline{\mathrm{IRQ}} \mathrm{pin}$ is pulled low. INTERRUPT_ SOURCE can be reset to 0 by either an IRQ_RESET signal or a DEVICE_RESET.
Depending on STATUS_MODE, the EVENT_STATUS bit reads back event or INTERRUPT_SOURCE. The AD9154 has several IRQ register blocks, which can monitor up to 75 events (depending on device configuration). Certain details vary by IRQ register block as described in Table 75. Table 76 shows which registers the IRQ_EN, IRQ_RESET, and STATUS_MODE signals in Figure 74 are coming from, as well as the address where EVENT_STATUS is read back.

Table 75. IRQ Register Block Details

| Register Block | EVENT <br> Reported | EVENT_STATUS |
| :--- | :--- | :--- |
| $0 \times 01 \mathrm{~F}$ to 0x026 | Per chip | INTERRUPT_SOURCE if <br> IRQ is enabled, if not, it <br> is EVENT |
| 0x46D to 0x46F; 0x470 <br> to 0x473; 0x47A | Per link and <br> lane | INTERRUPT_SOURCE if <br> IRQ is enabled, if not, 0 |
| $0 \times 47 \mathrm{~B}[4]$ | Per link | INTERRUPT_SOURCE if <br> IRQ is enabled, if not, 0 |

## INTERRUPT SERVICE ROUTINE

Interrupt request management starts by selecting the set of event flags that require host intervention or monitoring. Enable the events that require host action so that the host is notified when they occur. For events requiring host intervention upon $\overline{\text { IRQ }}$ activation, run the following routine to clear an interrupt request:

1. Read the status of the event flag bits that are being monitored.
2. Disable the interrupt by writing 0 to IRQ_EN.
3. Read the event source. For Register 0x01F to Register 0x026, EVENT_STATUS has a live readback. For other events, see their registers.
4. Perform any actions that may be required to clear the cause of the event. In many cases, no specific actions may be required.
5. Verify that the event source is functioning as expected.
6. Clear the interrupt by writing 1 to IRQ_RESET.
7. Enable the interrupt by writing 1 to IRQ_EN.

Table 76. IRQ Register Block Address of IRQ Signal Details

| Register Block | Address of IRQ Signals |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | IRQ_EN | IRQ_RESET | STATUS_MODE | EVENT_STATUS |
| 0x01F to 0x026 | 0x01F to 0x022; R/W per chip | 0x023 to 0x026; W per chip | STATUS_MODE = IRQ_EN | 0x023 to 0x26; R per chip |
| $0 \times 46 \mathrm{D}$ to $0 \times 46 \mathrm{~F}$ | 0x47A; W per link | $0 \times 46 \mathrm{D}$ to $0 \times 46 \mathrm{~F}$; W per link and lane | Not applicable, STATUS_MODE = 1 | 0x47A; R per link |
| $0 \times 470$ to $0 \times 473$ | 0x47A; W per link | $0 \times 470$ to $0 \times 473$; W per link | Not applicable, STATUS_MODE = 1 | 0x47A; R per link |
| 0x47B[4] | $0 \times 47 \mathrm{~B}[3] ; \mathrm{R} / \mathrm{W}$ per link; 1 by default | 0x47B[4]; W per link | Not applicable, STATUS_MODE = 1 | 0x47B[4]; R per link |

## DAC INPUT CLOCK CONFIGURATIONS

The AD9154 DAC sample clock or device clock (DACCLK) can be sourced directly through CLK $\pm$ (Pin 2 and Pin 3) or by using on-chip clock multiplication with the same CLK $\pm$ differential input serving as the reference. Clock multiplying employs the on-chip DAC PLL that accepts a reference clock operating at a submultiple of the desired DACCLK rate. The PLL then multiplies the reference clock up to the desired DACCLK frequency, which then generates all the clocks within the AD9154.

## DRIVING THE CLK $\pm$ INPUTS

The CLK $\pm$ differential input is shown in Figure 75. The on-chip clock receiver has a differential input impedance of $10 \mathrm{k} \Omega$. CLK $\pm$ are not terminated on chip; the inputs are self biased to a commonmode voltage of 600 mV . The inputs can be driven by differential PECL or LVDS drivers with ac coupling between the clock source and the receiver. A typical $100 \Omega$ differential board level termination resistor is placed between the ac coupling capacitors and the CLK $\pm$ pins.


Figure 75. Clock Receiver Input Simplified Equivalent Circuit

## DAC PLL FIXED REGISTER WRITES

To optimize the PLL across all operating conditions, the following SPI writes are recommended: $0 \times 087=0 \times 62,0 \times 088=$ $0 \times C 9,0 \times 089=0 \times 0 \mathrm{E}, 0 \times 08 \mathrm{~A}=0 \times 12,0 \times 08 \mathrm{D}=0 \mathrm{x} 7 \mathrm{~B}, 0 \times 1 \mathrm{~B} 0=$ $0 \times 00,0 \times 1 \mathrm{~B} 5=0 \times \mathrm{C} 9,0 \times 1 \mathrm{~B} 9=0 \times 24,0 \times 1 \mathrm{BC}=0 \times 0 \mathrm{D}, 0 \times 1 \mathrm{BE}=$ $0 \times 02,0 \times 1 B F=0 \times 8 \mathrm{E}, 0 \times 1 \mathrm{C} 0=0 \times 2 \mathrm{~A}, 0 \times 1 \mathrm{C} 4=0 \times 7 \mathrm{E}$, and $0 \times 1 \mathrm{C} 5$ $=0 \times 06$.

These writes properly set up the DAC PLL, including the loop filter and the charge pump.

## Loop Filter

The RF PLL filter is fully integrated on-chip and is a standard passive third-order filter with five 4-bit programmable components (see Figure 76). The C1, C2, C3, R1, and R3 filter components are programmed in as listed in DAC PLL fixed register writes in the DAC PLL Fixed Register Writes section to Register 0x087, Register 0x088, and Register 0x089.


Figure 76. Loop Filter

## Charge Pump

The charge pump current is 6-bit programmable variable with a range of 0.1 mA to 6.4 mA . It is programmed in Register 0x08A, Bits[5:0] as shown in the DAC PLL Fixed Register Writes section.
The charge pump is automatically calibrated the first time the DAC PLL is enabled. The charge pump calibration raises Bit 5 of Register 0x084 after it is complete and valid.


## CONDITION SPECIFIC REGISTER WRITES

## Clock Multiplication Relationships

The on-chip PLL clock multiplier circuit can generate the DAC sample rate clock from a lower frequency reference clock. The PLL is integrated on chip. The PLL VCO operates over a frequency range of 6 GHz to 12 GHz . The PLL configuration parameters must be programmed before the PLL is enabled. Step by step instructions on how to program the PLL can be found in the Starting the PLL section. A functional block diagram of the clock multiplier is shown in Figure 78.
When in use, the clock multiplication circuit generates the DAC sampling clock from the reference clock (REFCLK) input. The frequency of the REFCLK (CLK $\pm$ ) input is referred to as $\mathrm{f}_{\text {REF }}$.

The REFCLK input is divided by the variable RefDivFactor. Select the RefDivFactor variable to ensure that the frequency into the phase frequency detector (PFD) block is between 35 MHz and 80 MHz . The valid values for RefDivFactor are $1,2,4,8,16$, or 32 . Each RefDivFactor maps to the appropriate REFDIVMODE register control according to Table 77. The REFDIVMODE register is programmed through Register 0x08C, Bits[2:0].

Table 77. Mapping of RefDivFactor to REFDIVMODE

| DAC Reference <br> Frequency Range (MHz) | Divide by <br> (RefDivFactor) | REFDIVMODE <br> Register 0x08C, <br> Bits[2:0] |
| :--- | :--- | :--- |
| 35 to 80 | 1 | 0 |
| 80 to 160 | 2 | 1 |
| 160 to 320 | 4 | 2 |
| 320 to 640 | 8 | 3 |
| 640 to 1000 | 16 | 4 |

Use the following equation to determine the RefDivFactor:

$$
\begin{equation*}
35 \mathrm{MHz}<\frac{f_{\text {REF }}}{\text { RefDivFactor }}<80 \mathrm{MHz} \tag{1}
\end{equation*}
$$

where:
RefDivFactor is the reference divider division ratio.
$f_{\text {REF }}$ is the reference frequency on the CLK $\pm$ input pins.
The BCount value is the divide ratio of the loop divider. It is set to divide the $f_{\text {DACCLK }}$ to frequency match the $f_{\text {REF }} /$ RefDivFactor. Select BCount so that the following equation is true:

$$
\begin{equation*}
\frac{f_{\text {DACCLK }}}{2 \times \text { BCount }}=\frac{f_{\text {REF }}}{\text { RefDivFactor }} \tag{2}
\end{equation*}
$$

where:
BCount is the feedback loop divider ratio.
$f_{\text {DACCLK }}$ is the DAC sample clock frequency.
The BCount value is programmed using Bits[7:0] of Register 0x085. It is programmable from 6 to 127.

The PFD compares $\mathrm{f}_{\text {REF }} /$ RefDivRate to $\mathrm{f}_{\text {DAC }} /(2 \times$ BCount $)$ and pulses the charge pump up or down to control the frequency of the VCO. The clock multiplication circuit operates such that the VCO outputs a frequency, fyco.

$$
\begin{equation*}
f_{V C O}=f_{\text {DACCLK }} \times \text { LoDivFactor } \tag{3}
\end{equation*}
$$

and from Equation 2, the DAC sample clock frequency, $f_{\text {DACCLK }}$, is equal to

$$
\begin{equation*}
f_{\text {DACCLK }}=2 \times \text { BCount } \times \frac{f_{\text {REF }}}{\text { RefDivFact or }} \tag{4}
\end{equation*}
$$

The LODivFactor is chosen to keep $f_{v c o}$ in the operating range between 6 GHz and 12 GHz . The valid values for LODivFactor are 4, 8, and 16. Each LODivFactor maps to a LODIVMODE value. The LODIVMODE (Register 0x08B[1:0]) is programmed as described in Table 78.

Table 78. DAC VCO Divider Selection

| DAC Frequency <br> Range (MHz) | Divide by <br> (LODivFactor) | LODIVMODE <br> Register 0x08B, Bits[1:0] |
| :--- | :--- | :--- |
| $>1500$ | 4 | 1 |
| 750 to 1500 | 8 | 2 |
| 420 to 750 | 16 | 3 |

Table 79 lists some common frequency examples for the RefDivFactor, LODivFactor, and BCount values that are needed to configure the PLL properly.

Table 79. Common Frequency Examples

| Frequency <br> $(\mathbf{M H z})$ | $\mathbf{f}_{\text {DAccuk }}$ <br> $(\mathbf{M H z})$ | fvco <br> $(\mathbf{M H z})$ | RefDiv- <br> Factor | LODiv- <br> Factor | BCount |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 368.64 | 1474.56 | 11796.48 | 8 | 8 | 16 |
| 184.32 | 1474.56 | 11796.48 | 4 | 8 | 16 |
| 307.2 | 1228.88 | 9831.04 | 8 | 8 | 16 |
| 122.88 | 983.04 | 7864.35 | 2 | 8 | 8 |
| 61.44 | 983.04 | 7864.35 | 1 | 8 | 8 |
| 491.52 | 1966.08 | 7864.35 | 8 | 4 | 16 |
| 245.76 | 1966.08 | 7864.35 | 4 | 4 | 16 |

Table 79 includes different parameter sets based on fvco. The correct value to use is determined by the frequency into the phase frequency detector block of the PLL.

## Temperature Tracking

When properly configured, the device automatically selects one of the 512 VCO bands. The PLL settings selected by the device ensure that the PLL remains locked over the full $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ operating temperature range of the device without further adjustment. The PLL remains locked over the full temperature range even if the temperature during initialization is at one of the temperature extremes.
To properly configure temperature tracking, follow the settings in the DAC PLL Fixed Register Writes section and the $\mathrm{f}_{\mathrm{yco}}$ dependent SPI writes shown in Table 80.

Table 80. VCO Control Lookup Table Reference

| VCO Frequency <br> Range (GHz) | Register <br> 0x1B4 <br> Setting | Register <br> 0x1B6 <br> Setting | Register <br> 0x1BB <br> Setting |
| :--- | :--- | :--- | :--- |
| $\mathrm{f}_{\mathrm{vco}}<6.85$ | $0 \times 60$ | $0 \times 49$ | $0 \times 15$ |
| $6.85 \leq \mathrm{fyco}^{2}<8.72$ | $0 \times 60$ | $0 \times 49$ | $0 \times 13$ |
| $8.72 \leq \mathrm{fvco}^{2} 10.7$ | $0 \times 60$ | $0 \times 4 \mathrm{D}$ | $0 \times 13$ |
| $\mathrm{f}_{\mathrm{yco}} \geq 10.7$ | $0 \times 78$ | $0 \times 4 \mathrm{D}$ | $0 \times 04$ |

## STARTING THE PLL

The programming sequence for the DAC PLL is as follows:

1. Use the equations in the Clock Multiplication Relationships section to find $f_{\mathrm{VCO}}, \mathrm{f}_{\text {REF }}, \mathrm{BCount}$, REFDIVMODE, and LODIVMODE .
2. Program the registers in the DAC PLL Fixed Register Writes section.
3. Program LODIVMODE into Register 0x08B, Bits[1:0].
4. Program the BCount in Register 0x085, Bits[7:0].
5. Program REFDIVMODE in Register 0x08C, Bits[2:0].
6. Based on the fyco found in Step 1, write the temperature tracking registers as shown in Table 80.
7. Enable the DAC PLL synthesizer by setting Register 0x083, Bit 4 to 1 .

Register 0x084, Bit 5 notifies the user that the DAC PLL calibration is completed and is valid.
Register 0x084, Bit 1 notifies the user that the PLL has locked.
Register 0x084, Bits[7:6] and Register 0x084, Bit 5 notify the user that the DAC PLL hit the upper or lower edge of its operating band, respectively. If either of these bits are high, recalibrate the DAC PLL by setting Register 0x083, Bit 7 to 0 and then 1.

## DAC PLL IRQ

The DAC PLL lock and lost signals are available as IRQ events. Use Register 0x01F, Bit 5 and Bit 4 to enable these signals, and then use Register 0x023, Bit 5 and Bit 4 to read back their statuses and reset the IRQ signals. See the Interrupt Request Operation section.


Figure 78. Device Clock PLL Block Diagram

## ANALOG OUTPUTS

## TRANSMIT DAC OPERATION

Figure 79 shows a simplified block diagram of the transmit path DAC cores. There are four DAC cores: DAC0 and DAC2 are designated I DACs; DAC1 and DAC3 are designated Q DACs. The DAC cores consist of a current switch array, digital control logic, and full-scale output current control. The DAC full-scale output current (Ioutrs) is defined in Table 1. The output currents from the OUTx $\pm$ pins are complementary, meaning that the sum of the two currents always equals the full-scale current of the DAC. OUTx $\pm$ are current sinks. Current flows into the OUTx $\pm$ ports. The digital input code to the DAC determines the differential current output.


Figure 79. Simplified Block Diagram of the DAC Core
A $4 \mathrm{k} \Omega$ external resistor, $\mathrm{R}_{\text {SET }}$, must be connected from the I 120 pin to ground. This resistor, along with the reference control amplifier, sets up the correct internal bias currents for each DAC core.

The full-scale current equation, where the DAC gain is set for each I DAC core pair and each Q DAC core pair in Registers 0x040 through Register 0x043 is as follows:

$$
\begin{equation*}
I_{\text {OUTFS }}=\frac{V_{\text {REF }}}{R_{\text {SET }}} \times\left(13.33+\left(\frac{1}{19.19} \times \text { DAC gain }\right)\right) \tag{5}
\end{equation*}
$$

Figure 80 is a plot of Ioutrs as a function of DAC_GAIN_Ix and DAC_GAIN_Qx


Figure 80. DAC Full-Scale Current (loutrs) vs. DAC Gain Code

## Transmit DAC Transfer Function

The output currents drawn by the OUTx+ and OUTx- pins are complementary, meaning that the sum of the two (positive plus negative) currents always equals the full-scale current of the DAC, Ioutrs. The digital input code to a DAC determines the differential current output. The OUTx+ pins provide the maximum output current when all bits are high. The output currents vs. DACCODE for the DAC outputs are expressed as

$$
\begin{align*}
& I_{\text {OUTP }}=\left[\frac{D A C C O D E}{2^{N}}\right] \times I_{\text {OUTFS }}  \tag{6}\\
& I_{\text {OUTN }}=I_{\text {OUTFS }}-I_{\text {OUTP }} \tag{7}
\end{align*}
$$

where $D A C C O D E=0$ to $2^{N}-1$ and is the digital signal input to a DAC core consisting of a stream of 16 bit samples.

NORMAL AND MIX MODES OF OPERATION




Figure 81. Two-Switch and Quad-Switch DAC Waveforms
The DAC cores have a quad-switch architecture. During each DACCLK cycle, one input sample is presented twice. Figure 81 shows the time domain DAC core output when operating in normal mode (default). In normal mode, the same output signal is presented twice during each DAC clock cycle. The DAC output mode is selected using Bit 0 of Register 0x04A.
Figure 82 depicts a time domain DAC output signal in mix mode. During each DACCLK cycle, the input sample is presented at the output on the rising edge and the inverse of the input sample is presented at the output on the falling edge of DACCLK.




Figure 82. Mix Mode Waveform

Figure 83 is a depiction of the uncompensated DAC SINC roll-off for normal (or baseband) mode and for mix mode. In normal mode, the first Nyquist zone copy of the output signal has the highest amplitude. The output sampling images in the second and third Nyquist zones are attenuated. In MIX mode, the second and third Nyquist zone sampling images are emphasized, and the first Nyquist zone signal is attenuated.

This ability to change modes provides the user the flexibility to place a carrier anywhere in the first three Nyquist zones, depending on the operating mode selected. Switching between baseband and mix mode reshapes the sinc roll-off inherent at the DAC output.


Figure 83. Sinc Roll-Off for Normal Mode and Mix-Mode Operation

## TEMPERATURE SENSOR

The AD9154 has a band gap temperature sensor for monitoring junction temperature changes on the AD9154 die. The temperature must be calibrated against a known temperature to remove the device-to-device variation in the band gap circuit that senses the temperature.
To monitor temperature change, the user must take a reading at a known ambient temperature for a single-point calibration of each AD9154 device.

$$
T x=T_{\text {REF }}+7.3 \times\left(C O D E \_X-C O D E \_R E F\right) / 1000
$$

where:
CODE_X is the DIE_TEMP readback code from Register 0x132 and Register 0x133 at the unknown temperature, $T x$. $C O D E \_R E F$ is the DIE_TEMP readback from the same addresses at the calibrated temperature, $T_{\text {REF }}$.

To use the temperature sensor, it must be enabled by setting Register 0x12F, Bit 0, to 1 . The user must write a 1 to Register 0x134, Bit 0 before reading back the die temperature from Register 0x132 and Register 0x133.

## EXAMPLE START-UP SEQUENCE

Table 81 through Table 90 show the register writes needed to set up the AD9154 with $\mathrm{f}_{\mathrm{DAC}}=1474.56 \mathrm{MHz}, 2 \times$ interpolation, and the DAC PLL enabled with a 368.64 MHz reference clock. The JESD204B interface is configured in Mode 4, dual link mode, Subclass 1, and scrambling is enabled with all eight SERDES lanes running at 7.3728 Gbps , inputting twos complement formatted data. No remapping of lanes with the crossbar is performed in this example.
The sequence of steps to properly start up the AD9154 is as follows:

1. Set up the SPI interface, power up necessary circuit blocks, make required writes to the configuration register, and set up the DAC clocks (see Step 1: Start Up the DAC).
2. Set the digital features of the AD9154 (see Step 2: Digital Datapath).
3. Set up the JESD204B links (see Step 3: Transport Layer).
4. Set up the physical layer of the SERDES interface (see
5. Step 4: Physical Layer).
6. Set up the data link layer of the SERDES interface. This procedure is for quick startup or debug only and does not guarantee deterministic latency (see Step 5: Data Link Layer).
7. Check for errors on Link 0 and Link 1 (see Step 6: Error Monitoring).

These steps are outlined in detail in the following sections, within tables that list the required register write and read commands.
STEP 1: START UP THE DAC
Power-Up and DAC Initialization
Table 81. Power-Up and DAC Initialization
$\left.\begin{array}{l|l|l|l}\hline \text { Command } & \text { Address } & \text { Value } & \text { Description } \\ \hline \text { W } & 0 \times 000 & 0 \times B D & \text { Soft reset } \\ \text { W } & 0 \times 000 & 0 \times 3 \text { C } & \begin{array}{l}\text { Deassert reset, set 4-wire SPI } \\ \text { W }\end{array} \\ \text { Wnable reference, DAC }\end{array}\right\}$

## Required Device Configurations

Table 82. Required Device Configuration

| Command | Address | Value | Description |
| :--- | :--- | :--- | :--- |
| W | $0 \times 12 \mathrm{D}$ | $0 \times 8 \mathrm{~B}$ | Digital datapath configuration |
| W | $0 \times 146$ | $0 \times 01$ | Digital datapath configuration |
| W | $0 \times 333$ | $0 \times 01$ | JESD interface configuration |

## Configure the DAC PLL

Table 83. Configure DAC PLL

| Command | Address | Value | Description |
| :---: | :---: | :---: | :---: |
| W | 0x087 | 0x62 | Optimal DAC PLL loop filter settings |
| W | 0x088 | 0xC9 | Optimal DAC PLL loop filter settings |
| W | 0x089 | Ox0E | Optimal DAC PLL loop filter settings |
| W | 0x08A | 0x12 | Optimal DAC PLL CP settings |
| W | 0x08D | 0x7B | Optimal DAC LDO settings for DAC PLL |
| W | 0x1B0 | $0 \times 00$ | Power DAC PLL blocks when power machine disabled |
| W | 0x1B5 | 0xC9 | Optimal DAC PLL VCO settings |
| W | 0x1B9 | 0x24 | Optimal DAC PLL calibration options settings |
| W | 0x1BC | 0x0D | Optimal DAC PLL block control settings |
| W | 0x1BE | $0 \times 02$ | Optimal DAC PLL VCO power control settings |
| W | 0x1BF | 0x8E | Optimal DAC PLL VCO calibration settings |
| W | 0x1C0 | $0 \times 2 \mathrm{~A}$ | Optimal DAC PLL lock counter length setting |
| W | 0x1C1 | 0x2A | Optimal DAC PLL CP setting |
| W | 0x1C4 | 0x7E | Optimal DAC PLL varactor settings |
| W | 0x1C5 | 0x06 | Optimal DAC PLL VCO settings |
| W | 0x08B | $0 \times 02$ | Set the VCO LO divider to 8 so that $6 \mathrm{GHz} \leq \mathrm{f}_{\text {VCO }}=\mathrm{f}_{\text {DACCLK }} \times$ $2^{\text {(LODivMode }+1)} \leq 12 \mathrm{GHz}$ |
| W | 0x08C | $0 \times 03$ | Set the reference clock divider |
| W | 0x085 | 0x10 | Set the B counter to 16 to divide the DAC clock down to $2 \times$ the reference clock |
| W | 0x1B6 | 0x4D | Write VCO Varactor settings from Table 80 |
| W | $0 \times 1 \mathrm{BB}$ | 0x04 | Write VCO bias reference and TC from Table 80 |
| W | 0x1B4 | 0x78 | Write VCO calibration offset from Table 80 |
| W | 0x1C5 | 0x06 | Write VCO Varactor reference |
| W | 0x083 | 0x10 | Enable DAC PLL |
| R | 0x084 | 0x01 | Verify that Bit 1 reads back high for PLL locked |

## STEP 2: DIGITAL DATAPATH

Table 84. Digital Datapath

| Command | Address | Value | Description |
| :--- | :--- | :--- | :--- |
| W | $0 \times 112$ | $0 \times 01$ | Set the interpolation to $2 \times$ <br> Wet twos complement data <br> W format |

## STEP 3: TRANSPORT LAYER

Table 85. Link 0 Transport Layer

| Command | Address | Value | Description |
| :---: | :---: | :---: | :---: |
| W | 0x200 | $0 \times 00$ | Power up the interface |
| W | 0x201 | $0 \times 00$ | Enable all lanes |
| W | 0x300 | 0x08 | Bit $3=1$ for dual link, Bit $2=0$ to access Link 0 registers |
| W | 0x450 | 0x00 | Set the device ID to match Tx (0x00 in this example) |
| W | 0x451 | $0 \times 00$ | Set the bank ID to match Tx ( $0 \times 00$ in this example) |
| W | 0x452 | 0x00 | Set the lane ID to match Tx ( $0 \times 00$ in this example) |
| W | 0x453 | $0 \times 83$ | Set descrambling and $\mathrm{L}=4$ (in $\mathrm{n}-1$ notation) |
| W | 0x454 | 0x00 | Set $\mathrm{F}=1$ (in $\mathrm{n}-1$ notation) |
| W | 0x455 | 0x1F | Set $\mathrm{K}=32$ (in $\mathrm{n}-1$ notation) |
| W | 0x456 | 0x01 | Set $M=2$ (in $\mathrm{n}-1$ notation) |
| W | 0x457 | 0x0F | Set $\mathrm{N}=16$ (in $\mathrm{n}-1$ notation) |
| W | 0x458 | 0x2F | Set Subclass 1 and $N P=16$ (in $\mathrm{n}-1$ notation) |
| W | 0x459 | $0 \times 20$ | Set JESD 204B Version and S = 1 (in $\mathrm{n}-1$ notation) |
| W | 0x45A | $0 \times 80$ | Set HD $=1$ |
| W | 0x45D | 0x45 | Set checksum for Lane 0 |
| W | 0x46C | 0x0F | Deskew Lane 0 to Lane3 |
| W | 0x476 | 0x01 | Set F (not in $\mathrm{n}-1$ notation) |
| W | 0x47D | 0x0F | Enable Lane 0 to Lane 3 |


| Command | Address | Value | Description |
| :---: | :---: | :---: | :---: |
| W | 0x300 | 0x0C | Bit $3=1$ for dual link, Bit $2=1$ to access registers for Link 1 |
| W | 0x450 | 0x00 | Set the device ID to match Tx ( $0 \times 00$ in this example) |
| w | 0x451 | 0x00 | Set the bank ID to match Tx (0x00 in this example) |
| W | 0x452 | 0x04 | Set the lane ID to match Tx ( $0 \times 04$ in this example) |
| W | 0x453 | $0 \times 83$ | Set descrambling and $L=4$ (in $\mathrm{n}-1$ notation) |
| W | 0x454 | 0x00 | Set $\mathrm{F}=1$ (in $\mathrm{n}-1$ notation) |
| W | 0x455 | 0x1F | Set $\mathrm{K}=32$ (in $\mathrm{n}-1$ notation) |
| W | 0x456 | $0 \times 01$ | Set M $=2$ (in $\mathrm{n}-1$ notation) |
| W | 0x457 | 0x0F | Set $\mathrm{N}=16$ (in $\mathrm{n}-1$ notation) |
| W | 0x458 | 0x2F | Set Subclass 1 and NP $=16$ (in n-1 notation) |
| W | 0x459 | 0x20 | Set JESD 204B and S = 1 (in n - 1 notation) |
| W | 0x45A | 0x80 | Set HD |
| W | 0x45D | 0x45 | Set checksum for Lane 0 |
| W | 0x46C | 0x0F | Deskew Lane 4 to Lane 7 |
|  | 0x476 | 0x01 | Set F (not in $\mathrm{n}-1$ notation) |
| W | 0x47D | 0x0F | Enable Lane 4 to Lane 7 |

## STEP 4: PHYSICAL LAYER

Table 87. Physical Layer

| Command | Address | Value | Description |
| :--- | :--- | :--- | :--- |
| W | $0 \times 2$ A7 | $0 \times 01$ | Autotune PHY setting |
| W | $0 \times 2$ AE | $0 \times 01$ | Autotune PHY setting |
| W | $0 \times 314$ | $0 \times 01$ | SERDES SPI configuration |
| W | $0 \times 230$ | $0 \times 28$ | Configure CDRs in half rate mode |
| W | $0 \times 206$ | $0 \times 00$ | Resets CDR logic |
| W | $0 \times 206$ | $0 \times 01$ | Release CDR logic reset |
| W | $0 \times 289$ | $0 \times 04$ | Configure PLL divider to 1 along |
|  |  |  | with PLL required configuration |
| W | $0 \times 284$ | $0 \times 62$ | Optimal SERDES PLL loop filter |
| W | $0 \times 285$ | $0 \times C 9$ | Optimal SERDES PLL loop filter |
| W | $0 \times 286$ | $0 \times 0$ E | Optimal SERDES PLL loop filter |
| W | $0 \times 287$ | $0 \times 12$ | Optimal SERDES PLL charge pump |
| W | $0 \times 28$ A | $0 \times 7 B$ | Optimal SERDES PLL VCO LDO |
| W | $0 \times 28$ B | $0 \times 00$ | Optimal SERDES PLL PD |
| W | $0 \times 290$ | $0 \times 89$ | Optimal SERDES PLL VCO |
| W | $0 \times 291$ | $0 \times 4 C$ | Optimal SERDES PLL VCO |
| W | $0 \times 294$ | $0 \times 24$ | Optimal SERDES PLL charge pump |
| W | $0 \times 296$ | $0 \times 1$ B | Optimal SERDES PLL VCO |
| W | $0 \times 297$ | $0 \times 0 D$ | Optimal SERDES PLL VCO |
| W | $0 \times 299$ | $0 \times 02$ | Optimal SERDES PLL PD |
| W | $0 \times 29$ A | $0 \times 8 E$ | Optimal SERDES PLL VCO |
| W | $0 \times 29$ C | $0 \times 2 A$ | Optimal SERDES PLL charge pump |
| W | $0 \times 29$ F | $0 \times 7 E$ | Optimal SERDES PLL VCO |
| W | $0 \times 2 A 0$ | $0 \times 06$ | Configure SERDES PLL VCO |
| W | $0 \times 280$ | $0 \times 01$ | Enable SERDES PLL |
| R | $0 \times 281$ | $0 \times 01$ | Verify that Bit 0 reads back high |
|  |  |  | for SERDES PLL lock |
| W | $0 \times 268$ | $0 \times 62$ | Set equalizer mode to low power |

## STEP 5: DATA LINK LAYER

Note that this procedure does not guarantee deterministic latency.
Table 88. Data Link Layer (Does Not Guarantee Deterministic Latency)

| Command | Address | Value | Description |
| :--- | :--- | :--- | :--- |
| W | $0 \times 301$ | $0 \times 01$ | Set subclass $=1$ |
| W | $0 \times 304$ | $0 \times 00$ | Set the LMFC delay setting to 0 |
| W | $0 \times 305$ | $0 \times 00$ | Set the LMFC delay setting to 0 |
| W | $0 \times 306$ | $0 \times 0$ A | Set the LMFC receive buffer delay to 10 |
| W | $0 \times 307$ | $0 \times 03 A$ | Set the LMFC receive buffer delay to 10 |
| W | $0 \times 03 A$ | Set sync mode to one-shot sync |  |
| W | $0 \times 03 \mathrm{~A}$ | $0 \times 81$ | Enable the sync machine |
| W |  | $0 \times C 1$ | Arm the sync machine |
| SYSREF $\pm$ |  |  | Ensure that at least one SYSREF $\pm$ edge is sent to the device |
| W |  | Bit 1 and Bit $0=1$ to enable Link 0 and Link 1, Bit $2=0$ to access Link 0 |  |

## STEP 6: ERROR MONITORING

## Link 0 Checks

Confirm that the registers in Table 89 read back as noted and system tasks are completed as described.
Table 89. Link 0 Checks

| Command | Address | Value | Description |
| :--- | :--- | :--- | :--- |
| $R$ | $0 \times 470$ | $0 \times 0 \mathrm{~F}$ | Acknowledge that four consecutive K28.5 characters have been detected on Lane 0 to Lane 3. |
| SYNCOUTO $\pm$ |  |  | Confirm that SYNCOUTO $\pm$ is high. |
| SERDINx $\pm$ |  |  | Apply ILAS and data to the SERDES input pins. |
| $R$ | $0 \times 471$ | $0 \times 0 \mathrm{~F}$ | Check for frame sync on all lanes. |
| $R$ | $0 \times 472$ | $0 \times 0 \mathrm{~F}$ | Check for good checksum. |
| $R$ | $0 \times 473$ | $0 \times 0 \mathrm{~F}$ | Check for ILAS. |

## Link 1 Checks

Confirm that the registers in Table 90 read back as noted and system tasks are completed as described.
Table 90. Link 1 Checks

| Command | Address | Value | Description |
| :--- | :--- | :--- | :--- |
| W | $0 \times 300$ | $0 \times 0 \mathrm{~F}$ | Bit 2 = 1 to access Link 1. |
| R | $0 \times 470$ | $0 \times 0 \mathrm{~F}$ | Acknowledge that four consecutive K28.5 characters have been detected on Lane 4 to Lane 7. |
| $\overline{\text { SYNCOUT1 } \pm}$ |  |  | Confirm that $\overline{\text { SYNCOUT1 } \pm \text { is high. }}$ |
| SERDINx $\pm$ |  |  | Apply ILAS and data to the SERDES input pins. |
| R | $0 \times 471$ | $0 \times 0 \mathrm{~F}$ | Check for frame sync on all lanes. |
| R | $0 \times 472$ | $0 \times 0 \mathrm{~F}$ | Check for good checksum. |
| R | $0 \times 473$ | $0 \times 0 \mathrm{~F}$ | Check for ILAS. |

## BOARD LEVEL HARDWARE CONSIDERATIONS

## POWER SUPPLY RECOMMENDATIONS



Figure 84. Power Supply Connections
Table 91. Power Supplies

| Power Supply Domain | Voltage (V) | Circuitry |
| :--- | :--- | :--- |
| DVDD12 $^{1}$ | 1.2 | Digital core |
| PVDD12 $^{2}$ | 1.2 | DAC PLL |
| SVDD12 $^{3}$ | 1.2 | JESD204B receiver interface |
| CVDD12 $^{1}$ | 1.2 | DAC clocking |
| IOVDD $^{V_{T \pi^{4}}}$ | 3.3 | SPI interface |
| SIOVDD33 $_{\text {AVDD33 }}$ | 1.2 | $V_{\pi T}$ |

${ }^{1}$ This supply requires a 1.3 V supply when operating at maximum DAC sample rates. See Table 3 for details.
${ }^{2}$ This supply may be combined with CVDD12 on the same regulator with a separate supply filter network and sufficient bypass capacitors near the pins.
${ }^{3}$ This supply requires a 1.3 V supply when operating at maximum interface rates. See Table 4 for details.
${ }^{4}$ This supply is connected to SVDD12 and does not need separate circuitry.

The power supply domains are described in Table 91. The power supplies can be grouped into separate PCB domains as show in Figure 84. All the AD9154 supply domains must remain as noise free as possible. Optimal DAC output NSD and DAC output phase noise performance can be achieved using linear regulators that provide excellent power supply rejection. AVDD33, PVDD12, and CVDD12 are particularly sensitive to supply noise.

## JESD204B SERIAL INTERFACE INPUTS (SERDINO $\pm$ TO SERDIN7 $\pm$ )

When considering the layout of the JESD204B serial interface transmission lines, there are many factors to consider to maintain optimal link performance. Among these factors are insertion loss, return loss, signal skew, and the topology of the differential traces.

## Insertion Loss

The JESD204B specification limits the amount of insertion loss allowed in the transmission channel (see Figure 44). The AD9154 equalization circuitry allows significantly more loss in the channel than is required by the JESD204B specification. It is still important that the designer of the PCB minimize the amount of insertion loss by adhering to the following guidelines:

- Keep the differential traces short by placing the AD9154 as near to the transmitting logic device as possible and routing the trace as directly as possible between the devices.
- Route the differential pairs on a single plane using a solid ground plane as a reference.
- Use a PCB material with a low dielectric constant $(<4)$ to minimize loss, if possible.

When choosing between stripline and microstrip techniques, consider the following: stripline has less loss (see Figure 45) and emits less EMI, but requires the use of vias that can add complexity to the task of controlling the impedance, whereas microstrip (see Figure 46) is easier to implement if the component placement and density allow routing on the top layer and eases the task of controlling the impedance.
If using the top layer of the PCB is problematic or the advantages of stripline are desirable, follow these recommendations:

- Minimize the number of vias.
- If possible, use blind vias to eliminate via stub effects and use micro vias to minimize via inductance.
- If using standard vias, use the maximum via length to minimize the stub size. For example, on an 8-layer board, use Layer 7 for the stripline pair (see Figure 85).
- For each via pair, place a pair of ground vias adjacent to them to minimize the impedance discontinuity (see Figure 85).


Figure 85. Minimizing Stub Effect and Adding Ground Vias for Differential Stripline Traces

## Return Loss

The JESD204B specification limits the amount of return loss allowed in a converter device and a logic device, but does not specify return loss for the channel. However, every effort must be made to maintain a continuous impedance on the transmission line between the transmitting logic device and the AD9154. As mentioned in the Insertion Loss section, minimizing the use of vias, or eliminating them all together, reduces one of the primary sources for impedance mismatches on a transmission line. Maintain a solid reference beneath (for microstrip) or above and below (for stripline) the differential traces to ensure continuity in the impedance of the transmission line. If the stripline technique is used, follow the guidelines listed in the Insertion Loss section to minimize impedance mismatches and stub effects.
Another primary source for impedance mismatch is at either end of the transmission line, where care must be taken to match the impedance of the termination to that of the transmission line. The AD9154 handles this internally with a calibrated termination scheme for the receiving end of the line. See the Interface Power-Up and Input Termination section for details on this circuit and the calibration routine.

## Signal Skew

There are many sources for signal skew, but the two sources to consider when laying out a PCB are interconnect skew within a single JESD204B link and skew between multiple JESD204B links. In each case, keeping the channel lengths matched to within 15 mm is adequate for operating the JESD204B link at speeds of up to 10.6 Gbps. Managing the interconnect skew within a single link is fairly straightforward. Managing multiple links across multiple devices is more complex. However, follow the 15 mm guideline for length matching.

## Topology

Structure the differential SERDINx $\pm$ pairs to achieve $50 \Omega$ to ground for each half of the pair. Stripline vs. microstrip tradeoffs are described in the Insertion Loss section. In either case, it is important to keep these transmission lines separated from potential noise sources such as high speed digital signals and noisy supplies. If using stripline differential traces, route them using a coplanar method, with both traces on the same layer. Although this does not offer more noise immunity than the broadside routing method (traces routed on adjacent layers), it is easier to route and manufacture so that the impedance continuity is maintained. An illustration of broadside vs. coplanar is shown in Figure 86.


Figure 86. Broadside vs. Coplanar Differential Stripline Routing Techniques
When considering the trace width vs. copper weight and thickness, the speed of the interface must be considered. At multigigabit speeds, the skin effect of the conducting material confines the current flow to the surface. Maximize the surface area of the conductor by making the trace width made wider to reduce the losses. Additionally, loosely couple differential traces to accommodate the wider trace widths. This helps reduce the crosstalk and minimize the impedance mismatch when the traces must separate to accommodate components, vias, connectors, or other routing obstacles. Tightly coupled vs. loosely coupled differential traces are shown in Figure 87.


## AC Coupling Capacitors

The AD9154 requires that the JESD204B input signals be ac-coupled to the source. These capacitors must be 100 nF and placed as close as possible to the transmitting logic device. To minimize the impedance mismatch at the pads, select the package size of the capacitor so that the pad size on the PCB matches the trace width as closely as possible.

## $\overline{\text { SYNCOUTX } \pm, ~ S Y S R E F ~} \pm$, and CLK $\pm$ Signals

The $\overline{\text { SYNCOUTx } \pm}$ and SYSREF $\pm$ signals on the AD9154 are low speed LVDS differential signals. Use controlled impedance traces routed with $100 \Omega$ differential impedance and $50 \Omega$ to ground when routing these signals. As with the SERDIN0 $\pm$ to SERDIN7 $\pm$ data pairs, it is important to keep these signals separated from potential noise sources such as high speed digital signals and noisy supplies.

Separate the SYNCOUTx $\pm$ signal from other noisy signals, because noise on the SYNCOUTx $\pm$ might be interpreted as a request for K characters.
It is important to keep similar trace lengths for the CLK $\pm$ and SYSREF $\pm$ signals from the clock source to each of the devices on either end of the JESD204B links, see Figure 88. If using a clock chip that can tightly control the phase of CLK $\pm$ and SYSREF $\pm$, the trace length matching requirements are greatly reduced.


Figure 88. SYSREF $\pm$ Signal and Device Clock Trace Length

## REGISTER SUMMARY

Table 92. AD9154 Register Summary

| Reg. | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | R/W |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x000 | SPI_INTFCONFA | SOFTRESET_M | LSBFIRST_M | ADDRINC_M | SDOACTIVE_M | SDOACTIVE | ADDRINC | LSBFIRST | SOFTRESET | 0x00 | R/W |
| $0 \times 003$ | SPI_CHIPTYPE | CHIPTYPE |  |  |  |  |  |  |  | 0x04 | R |
| 0x004 | SPI_PRODIDL | PRODIDL |  |  |  |  |  |  |  | 0x54 | R |
| $0 \times 005$ | SPI_PRODIDH | PRODIDH |  |  |  |  |  |  |  | 0x91 | R |
| $0 \times 006$ | SPI_CHIPGRADE | PROD_GRADE |  |  |  | DEV_REVISION |  |  |  | 0x99 | R |
| $0 \times 008$ | DUAL_PAGE | RESERVED |  |  |  |  |  | PAGEINDX |  | 0x03 | R/W |
| $0 \times 011$ | PWRCNTRLO | PD_BG | PDDAC0 | PDDAC1 | PDDAC2 | PDDAC3 | RESERVED |  |  | 0xF8 | R/W |
| $0 \times 012$ | TXENMASK1 | DACB_MASK | DACA_MASK | RESERVED |  |  |  |  |  | 0x00 | R/W |
| 0x013 | PWRCNTRL3 | RESERVED | $\begin{aligned} & \text { ENA_PA_CTRL } \\ & \text { FROM_ } \\ & \hline \text { PAPROT_ERR } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ENA_PA_CTRL } \\ & \text { FROM_- } \\ & \text { TXENSM } \end{aligned}$ | ENA_PA_CTRL FROM_BLSM | $\begin{aligned} & \text { ENA_PA_- } \\ & \text { CTRL_FROM_ } \\ & \text { SPI } \end{aligned}$ | SPI_PA_ <br> CTRL | $\begin{aligned} & \text { ENA_SPI_ } \\ & \text { TXEN } \end{aligned}$ | SPI_TXEN | 0x20 | R/W |
| 0x014 | COARSE GROUP_DLY | RESERVED |  |  |  | COARSE_GROUP_DLY |  |  |  | 0x88 | R/W |
| 0x01F | IRQ_ENABLE0 | RESERVED |  | $\begin{array}{\|l\|l\|} \hline \text { EN_DAC } \\ \text { PLLLOST } \\ \hline \end{array}$ | $\begin{aligned} & \hline \text { EN_DAC } \\ & \text { PLLLOCK } \end{aligned}$ | $\begin{aligned} & \text { EN_SER- } \\ & \text { PLLLOST } \end{aligned}$ | $\begin{array}{\|l} \hline \text { EN_SER- } \\ \text { PLLLOCK } \end{array}$ | EN_LANEFIFOERR | RESERVED | $0 \times 00$ | R/W |
| 0x020 | IRQ_ENABLE1 | RESERVED |  |  |  | EN_PRBSQ1 | EN_PRBSI1 | $\begin{array}{\|l\|} \hline \mathrm{EN} \\ \hline \text { PRBSQO } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \mathrm{EN} \\ \hline \mathrm{PRBSIO} \\ \hline \end{array}$ | $0 \times 00$ | R/W |
| 0x021 | IRQ_ENABLE2 | EN_PAERR0 | RESERVED | $\begin{array}{\|l\|} \hline \text { EN_ } \\ \text { BLNKDONEO } \end{array}$ | $\begin{aligned} & \text { EN } \\ & \text { REFNCOCLRO } \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { EN_ } \\ \text { REFLOCKO } \\ \hline \end{array}$ | EN REFROTAO | EN REFWLIMO | EN REFTRIPO | $0 \times 00$ | R/W |
| 0x022 | IRQ_ENABLE3 | EN_PAErr1 | RESERVED | $\mathrm{EN}_{-}$ <br> BLNKDONE1 | $\begin{array}{\|l\|} \hline E N- \\ \text { REFNCOCLR1 } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \text { EN_ } \\ \text { REFLOCK1 } \\ \hline \end{array}$ | $\begin{aligned} & \hline \text { EN_ } \\ & \text { REFROTA1 } \end{aligned}$ | $\begin{aligned} & \hline \text { EN_ } \\ & \text { REFWLIM1 } \end{aligned}$ | $\begin{aligned} & \text { EN_ } \\ & \text { REFTRIP1 } \end{aligned}$ | 0x00 | R/W |
| 0x023 | IRQ_STATUS0 | RESERVED |  | IRQ_DACPLLLOST | IRQ_DACPLLLOCK | $\begin{aligned} & \mathrm{IRQ} \\ & \mathrm{SERPLLLOST} \end{aligned}$ | $\begin{aligned} & \mathrm{IRQ} \\ & \mathrm{SERPLLLOCK} \end{aligned}$ | IRQ_LANE FIFOERR | RESERVED | 0x00 | R |
| 0x024 | IRQ_STATUS1 | RESERVED |  |  |  | IRQ_PRBSQ1 | IRQ_PRBSI1 | $\begin{array}{\|l\|} \hline \mathrm{IRQ} \\ \hline \text { PRBSQO } \\ \hline \end{array}$ | $\begin{aligned} & \mid \mathrm{IRQ} \\ & \mathrm{PRBS} I 0 \end{aligned}$ | 0x00 | R |
| 0x025 | IRQ_STATUS2 | IRQ_PAErr0 | RESERVED | $\begin{array}{\|l\|} \hline \text { IRQ } \\ \text { BLNKDONEO } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \text { IRQ } \\ \text { REFNCOCLRO } \\ \hline \end{array}$ | $\begin{aligned} & \text { IRQ_REF- } \\ & \text { LOCKO } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mid \mathrm{RQQ} \\ & \mathrm{REFROTAO} \end{aligned}$ | IRQ REFWLIMO | $\begin{aligned} & \text { IRQ } \\ & \text { REFTRIPO } \end{aligned}$ | 0x00 | R |
| 0x026 | IRQ_STATUS3 | IRQ_PAErr1 | RESERVED | $\begin{array}{\|l\|} \hline \text { IRQ } \\ \text { BLNKDONE1 } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \text { IRQ } \\ \text { REFNCOCLR1 } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \text { IRQ_ } \\ \text { REFLOCK1 } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \text { IRQ } \\ \text { REFROTA1 } \end{array}$ | $\begin{array}{\|l\|} \hline \text { IRQ } \\ \text { REFWLIM1 } \end{array}$ | $\begin{array}{\|l\|} \hline \mathrm{IRQ} \\ \mathrm{REFTRIP} 1 \\ \hline \end{array}$ | 0x00 | R |
| 0x030 | JESD_CHECKS | RESERVED |  | ERR_DLYOVER | ERR_WINLIMIT | $\begin{array}{\|l\|} \hline \text { ERR_- } \\ \hline \text { JESDBAD } \\ \hline \end{array}$ | ERR_ KUNSUPP | ERR_ SUBCLASS | ERR INTSUPP | 0x00 | R |
| 0x034 | SYNC_ ERRWINDOW | RESERVED |  |  |  |  | ERRWINDOW |  |  | 0x00 | R/W |
| 0x038 | SYNC LASTERR_L | LASTERROR_L |  |  |  |  |  |  |  | 0x00 | R |
| 0x039 | SYNC_ LASTERR_H | LASTUNDER | LASTOVER | RESERVED |  |  |  |  | $\begin{array}{\|l\|} \hline \text { LAST } \\ \text { ERROR_H } \\ \hline \end{array}$ | $0 \times 00$ | R |
| 0x03A | SYNC CONTROL | SYNCENABLE | SYNCARM | SYNCCLRSTKY | SYNCCLRLAST | SYNCMODE |  |  |  | 0x00 | R/W |
| $0 \times 03 \mathrm{~B}$ | SYNC_STATUS | REFBUSY | RESERVED |  |  | REFLOCK | REFROTA | REFWLIM | REFTRIP | 0x00 | R |
| 0x03C | SYNC_ CURRERR_L | CURRERROR_L |  |  |  |  |  |  |  | 0x00 | R |
| 0x03D | SYNC_ CURRERR_H | CURRUNDER | CURROVER | RESERVED |  |  |  |  | CURRERROR_H | $0 \times 00$ | R |
| $0 \times 040$ | DAC_GAINO_I | RESERVED |  |  |  |  |  | DAC_GAIN_I1 |  | 0x03 | R/W |
| 0x041 | DAC_GAIN1_I | DAC_GAIN_I0 |  |  |  |  |  |  |  | 0xFF | R/W |
| $0 \times 042$ | DAC_GAINO_Q | RESERVED |  |  |  |  |  | DAC_GAIN_Q1 |  | 0x03 | R/W |
| 0x043 | DAC_GAIN1_Q | DAC_GAIN_Q0 |  |  |  |  |  |  |  | 0xFF | R/W |
| 0x044 | $\begin{aligned} & \text { GROUPDELAY } \\ & \text { COMP_I } \\ & \hline \end{aligned}$ | GROUP DELAY COMP I [7:0] |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x045 | $\begin{aligned} & \text { GROUPDELAY } \\ & \text { COMP_Q } \end{aligned}$ | GROUP DELAY COMP Q [7:0] |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x046 | GROUPDELAY COMP_BYP | RESERVED |  |  |  |  |  | $\begin{aligned} & \text { GROUP- } \\ & \text { COMP_ } \\ & \text { BYPI } \end{aligned}$ | GROUPCOMP BYPQ | 0x03 | R/W |
| 0x04A | MIX_MODE | RESERVED |  |  |  |  |  |  | MIX MODE | 0x00 | R/W |
| 0x050 | NCO_CLRMODE | NCOCLRARM | RESERVED | NCOCLRMTCH | NCOCLRPASS | NCOCLRFAIL | RESERVED | NCOCLRMODE |  | 0x00 | R/W |
| $0 \times 051$ | NCOKEY_ILSB | NCOKEYILSB |  |  |  |  |  |  |  | 0x00 | R/W |
| $0 \times 052$ | NCOKEY_IMSB | NCOKEYIMSB |  |  |  |  |  |  |  | 0x00 | R/W |
| $0 \times 053$ | NCOKEY_QLSB | NCOKEYQLSB |  |  |  |  |  |  |  | 0x00 | R/W |


| Reg. | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | R/W |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x054 | NCOKEY_QMSB | NCOKEYQMSB |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x060 | PA_THRES0 | PDP_THRESHOLD[7:0] |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x061 | PA_THRES1 | RESERVED |  |  | PDP_THRESHOLD[12:8] |  |  |  |  | 0x00 | R/W |
| 0x062 | PDP_AVG_TIME | PDP_ENABLE | $\begin{aligned} & \text { PA_BUS_ } \\ & \text { SWAP } \end{aligned}$ | RESERVED |  | PDP_AVG_TIME |  |  |  | 0x00 | R/W |
| 0x063 | PA_POWERO | PDP_POWER[7:0] |  |  |  |  |  |  |  | 0x00 | R |
| 0x064 | PA_POWER1 | RESERVED |  | PDP_POWER[12:8] |  |  |  |  |  | 0x00 | R |
| 0x080 | CLKCFG0 | PD_CLK01 | PD_CLK23 | PDCLOCKDIG | PD_PCLK | $\begin{aligned} & \text { PDCLOCK- } \\ & \text { REC } \end{aligned}$ |  | $\begin{aligned} & \text { RF_SYNC_ } \\ & \text { EN } \end{aligned}$ | $\begin{aligned} & \mathrm{RF}_{-} \\ & \text {CLKDIV_EN } \end{aligned}$ | 0xFE | R/W |
| 0x081 | SYSREF_ACTRLO | RESERVED |  |  | PDSYSREF | HYS_ON | SYSREF_RISE | HYS_CNTRL1 |  | 0x10 | R/W |
| 0x082 | SYSREF_ACTRL1 | HYS_CNTRLO |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x083 | DACPLLCNTRL | $\begin{aligned} & \text { SYNTH_ } \\ & \text { RECAL } \end{aligned}$ | RESERVED |  | $\begin{gathered} \hline \text { ENABLE_- } \\ \text { SYNTH } \end{gathered}$ | RESERVED |  |  |  | 0x00 | R/W |
| 0x084 | DACPLLSTATUS | CP_OVERRANGE_H |  | $\begin{aligned} & \text { CP_ } \\ & \text { OVERRANGE_L } \end{aligned}$ | CP_CAL_VALID | $\begin{aligned} & \text { VCO_CAL_ } \\ & \text { PROGRESS } \end{aligned}$ | RESERVED | $\begin{aligned} & \text { RFPLL_ } \\ & \text { LOCK } \end{aligned}$ | RESERVED | 0x00 | R/W |
| 0x085 | DACINTEGERWORDO | BCOUNT |  |  |  |  |  |  |  | 0x06 | R/W |
| 0x087 | DACLOOPFILT1 | LF_C2_WORD |  |  |  | LF_C1_WORD |  |  |  | 0x88 | R/W |
| 0x088 | DACLOOPFILT2 | LF_R1_WORD |  |  |  | LF_C3_WORD |  |  |  | 0x88 | R/W |
| 0x089 | DACLOOPFILT3 | $\begin{aligned} & \text { LF_BYPASS_ } \\ & \text { R3 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { LF_BYPASS_ } \\ & \text { R1 } \\ & \hline \end{aligned}$ | LF_BYPASS_C2 | LF_BYPASS_C1 | LF_R3_WORD |  |  |  | 0x08 | R/W |
| 0x08A | DACCPCNTRL | RESERVED | VT_FORCE | CP_CURRENT |  |  |  |  |  | 0x20 | R/W |
| 0x08B | DACLOGENCNTRL | RESERVED |  | LO_POWER_MODE |  | RESERVED |  | LODIVMODE |  | 0x00 | R/W |
| 0x08C | DACLDOCNTRL1 | LDO_REF_SEL | $\begin{aligned} & \text { LDO_BYPASS_ } \\ & \text { FILT } \end{aligned}$ | RESERVED |  |  | REFDIVMODE |  |  | 0x00 | R/W |
| 0x08D | DACLDOCNTRL2 | LDO_BYPASS | LDO_INRUSH |  | LDO_SEL |  |  | LDO_VDROP |  | 0x2B | R/W |
| 0x110 | DATA_FORMAT | DATA_FMT | RESERVED |  |  |  |  |  |  | 0x00 | R/W |
| 0x111 | $\begin{aligned} & \text { DATAPATH_ } \\ & \text { CTRL } \end{aligned}$ | $\begin{aligned} & \left\lvert\, \begin{array}{l} \text { INVSINC_- } \\ \text { ENABLE } \end{array}\right. \end{aligned}$ | RESERVED | DIG_GAIN_ ENABLE | $\begin{aligned} & \text { PHASE_ADJ_ } \\ & \text { ENABLE } \end{aligned}$ | MODULATION_TYPE |  | $\begin{aligned} & \text { SEL_} \\ & \text { SIDEBAND } \end{aligned}$ | TO_Q | 0xA0 | R/W |
| 0x112 | INTERPMODE | RESERVED |  |  |  |  | INTERPMODE |  |  | 0x01 | R/W |
| 0x113 | NCO_FTW_ UPDATE | RESERVED |  |  |  |  |  | FTW_UPDATE_ACK | $\begin{aligned} & \text { FTW_UP- } \\ & \text { DATE_REQ } \end{aligned}$ | 0x00 | R/W |
| 0x114 | FTW0 | FTW0 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x115 | FTW1 | FTW1 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x116 | FTW2 | FTW2 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x117 | FTW3 | FTW3 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x118 | FTW4 | FTW4 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x119 | FTW5 | FTW5 |  |  |  |  |  |  |  | 0x10 | R/W |
| $0 \times 11 \mathrm{~A}$ | $\begin{aligned} & \text { NCO_PHASE_ } \\ & \text { OFFSETO } \end{aligned}$ | NCO_PHASE_OFFSET0 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x11B | NCO_PHASE OFFSET1 | NCO_PHASE_OFFSET1 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x11C | $\begin{aligned} & \text { NCO_PHASE_ } \\ & \text { ADJ0 } \end{aligned}$ | PHASEADJ[7:0] |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x11D | $\begin{aligned} & \text { NCO_PHASE_ } \\ & \text { ADJ1 } \end{aligned}$ | PHASEADJ[12:8] |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x11F | TXEN_SM_0 | PA_FALL PA_RISE |  |  |  | RESERVED | GP_PA_ON_ INVERT | GP_PA <br> CTRL | $\begin{array}{\|l\|} \hline \text { TXEN_SM_ } \\ \text { EN } \\ \hline \end{array}$ | 0x83 | R/W |
| 0x121 | TXEN_SM_2 | RISE_COUNT_0 |  |  |  |  |  |  |  | 0x0F | R/W |
| 0x122 | TXEN_SM_3 | RISE_COUNT_1 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x123 | TXEN_SM_4 | FALL_COUNT_0 |  |  |  |  |  |  |  | 0xFF | R/W |
| 0x124 | TXEN_SM_5 | FALL_COUNT_1 |  |  |  |  |  |  |  | 0xFF | R/W |
| 0x12D | $\begin{aligned} & \text { DEVICE_CONFIG_ } \\ & \text { REGO } \end{aligned}$ | DEVICE_CONFIG_0 |  |  |  |  |  |  |  | 0x46 | R/W |
| 0x12F | $\begin{aligned} & \text { DIE_TEMP_ } \\ & \text { CTRLO } \end{aligned}$ | RESERVED |  |  |  |  |  |  | AUXADC ENABLE | 0x20 | R/W |
| 0x132 | DIE_TEMP0 | DIE_TEMP_LSB |  |  |  |  |  |  |  | 0x00 | R |
| 0x133 | DIE_TEMP1 | DIE_TEMP_MSB |  |  |  |  |  |  |  | 0x00 | R |

## AD9154

| Reg. | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | R/W |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x134 | $\begin{aligned} & \text { DIE_TEMP_ } \\ & \text { UPDATE } \end{aligned}$ | RESERVED |  |  |  |  |  |  | DIE_TEMP UPDATE | 0x00 | R/W |
| 0x135 | $\begin{aligned} & \text { DC_OFFSET_ } \\ & \text { CTRL } \end{aligned}$ | RESERVED |  |  |  |  |  |  | $\begin{aligned} & \text { DC_OFF- } \\ & \text { SET_ON } \end{aligned}$ | 0x00 | R/W |
| 0x136 | $\begin{aligned} & \text { IPATH_DC- } \\ & \text { OFFSET_1PART0 } \end{aligned}$ | IPATH_DC_OFFSET_1PART0 |  |  |  |  |  |  |  | 0x00 | R/W |
| $0 \times 137$ | $\begin{aligned} & \text { IPATH_DC_-_1 } \\ & \text { OFFSET_1PART1 } \end{aligned}$ | IPATH_DC_OFFSET_1PART1 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x138 | $\begin{aligned} & \text { QPATH_DC_- } \\ & \text { OFFSET_1PART0 } \end{aligned}$ | QPATH_DC_OFFSET_1PART0 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x139 | $\begin{aligned} & \text { QPATH_DC_} \\ & \text { OFFSET_1PART1 } \end{aligned}$ | QPATH_DC_OFFSET_1PART1 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x13A | $\begin{aligned} & \text { IPATH_DC_- } \\ & \text { OFFSET_2PART } \end{aligned}$ | RESERVED |  |  | IPATH_DC_OFFSET_2PART |  |  |  |  | 0x00 | R/W |
| 0x13B | $\begin{aligned} & \text { QPATH_DC_- } \\ & \text { OFFSET_2PART } \end{aligned}$ | RESERVED |  |  | QPATH_DC_OFFSET_2PART |  |  |  |  | 0x00 | R/W |
| 0x13C | $\begin{aligned} & \text { IDAC_DIG_ } \\ & \text { GAIN0 } \end{aligned}$ | IDAC_DIG_GAIN0 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x13D | $\begin{aligned} & \text { IDAC_DIG_ } \\ & \text { GAIN1 } \end{aligned}$ | RESERVED |  |  |  | IDAC_DIG_GAIN1 |  |  |  | 0x08 | R/W |
| 0x13E | $\begin{aligned} & \text { QDAC_DIG_ } \\ & \text { GAIN0 } \end{aligned}$ | GAINCODEQ[7:0] |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x13F | $\begin{aligned} & \text { QDAC_DIG_ } \\ & \text { GAIN1 } \end{aligned}$ | RESERVED |  |  |  | GAINCODEQ[11:8] |  |  |  | 0x08 | R/W |
| 0x140 | GAIN_RAMP_ UP_STEPO | GAIN_RAMP_UP_STEPO |  |  |  |  |  |  |  | 0x04 | R/W |
| 0x141 | GAIN_RAMP_ UP_STEP1 | RESERVED |  |  |  | GAIN_RAMP_UP_STEP1 |  |  |  | 0x00 | R/W |
| 0x142 | GAIN_RAMP DOWN_STEPO | GAIN_RAMP_DOWN_STEP0 |  |  |  |  |  |  |  | 0x09 | R/W |
| 0x143 | GAIN_RAMP DOWN_STEP1 | RESERVED |  |  |  | GAIN_RAMP_DOWN_STEP1 |  |  |  | 0x00 | R/W |
| 0x146 | $\begin{aligned} & \text { DEVICE_CONFIG } \\ & \text { REG1 } \end{aligned}$ | DEVICE_CONFIG1 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x147 | BLSM_STAT | BE_ROTATE_REQ |  | RESERVED |  |  |  |  |  | 0x00 | R/W |
| 0x14B | PRBS | $\begin{aligned} & \text { PRBS_-_ } \\ & \text { GOOD_Q } \end{aligned}$ | $\begin{aligned} & \text { PRBS_-_ } \\ & \text { GOOD_I } \end{aligned}$ | RESERVED |  |  | $\begin{aligned} & \text { PRBS } \\ & \text { MODE } \end{aligned}$ | $\begin{aligned} & \hline \text { PRBS } \\ & \text { RESET } \end{aligned}$ | RBS_EN | 0x10 | R/W |
| 0x14C | PRBS_ERROR_I | PRBS_COUNT_I |  |  |  |  |  |  |  | 0x00 | R |
| 0x14D | PRBS_ERROR_Q | PRBS_COUNT_Q |  |  |  |  |  |  |  | 0x00 | R |
| 0x1B0 | DACPLLTO | VCO_PD_IN | $\begin{aligned} & \text { VCO_PD_ } \\ & \text { PTAT } \\ & \hline \end{aligned}$ | VCO_PD_ALC | SYNTH_PD | LDO_PD | RESERVED | $\begin{array}{\|l\|} \hline \text { LOGEN_ } \\ \hline \text { PD } \\ \hline \end{array}$ | RESERVED | 0xFA | R/W |
| 0x1B1 | DACPLLT1 | RESERVED |  |  |  | PFD_DELAY |  | $\begin{aligned} & \text { PFD_ } \\ & \text { EDGE } \end{aligned}$ | RESERVED | 0x04 | R/W |
| 0x1B2 | DACPLLT2 | EXT_ALC_ WORD_EN | EXT_ALC_WORD |  |  |  |  |  |  | 0x00 | R/W |
| 0x1B3 | DACPLLT3 | EXT_BAND1 |  |  |  |  |  |  |  | 0x00 | W |
| 0x1B4 | DACPLLT4 | $\begin{aligned} & \text { BYP_LOAD_ } \\ & \text { DELAY } \\ & \hline \end{aligned}$ | VCO_CAL_OFFSET |  |  |  | RESERVED | $\begin{array}{\|l\|} \hline \text { EXT_____ }^{\text {BAND_EN }} \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \text { EXT_- } \\ \text { BAND2 } \\ \hline \end{array}$ | 0x78 | R/W |
| 0x1B5 | DACPLLT5 | INIT_ALC_VALUE |  |  |  | VCO_VAR |  |  |  | 0x83 | R/W |
| 0x1B6 | DACPLLT6 | RESERVED | $\begin{gathered} \text { PORESETB_ } \\ \text { VCO } \end{gathered}$ | EXT_VCO_BITSEL |  | VCO_LVL_OUT |  |  |  | 0x4A | R/W |
| 0x1B7 | DACPLLT7 | LD_SYNTH | RESERVED | CP_IBLEED |  |  |  |  |  | 0x00 | R/W |
| 0x1B8 | DACPLLT8 | RESERVED | COMP_OUT | CP_CAL DONE | $\begin{aligned} & \text { VCO_CAL_IN_ } \\ & \text { PROG } \end{aligned}$ | CP_CALBITS |  |  |  | 0x00 | R |
| 0x1B9 | DACPLLT9 | HALF_VCO_ CAL_CLK | DITHER MODE | MACHINE ENABLE | $\begin{aligned} & \text { CP_OFFSET_ } \\ & \text { OFF } \\ & \hline \end{aligned}$ | FORCE_CP_ CALBITS | $\begin{array}{\|l} \hline \mathrm{CAP}_{-} \mathrm{CAL} \\ \mathrm{EN} \\ \hline \end{array}$ | CP_TEST |  | 0x34 | R/W |
| 0X1BA | DACPLLTA | MACHINE_STATE |  |  |  | FCP_CALBITS |  |  |  | 0x00 | R/W |
| 0x1BB | DACPLLTB | RESERVED |  |  | VCO_BIAS_TCF |  | VCO_BIAS_REF |  |  | 0x0C | R/W |
| 0x1BC | DACPLLTC | $\begin{aligned} & \text { VCO_BYP_ } \\ & \text { BIASR } \\ & \hline \end{aligned}$ | RESERVED |  | $\begin{aligned} & \text { VCO_COMP_ } \\ & \text { BIASR } \end{aligned}$ | PRSC_HIGHR | $\begin{aligned} & \text { LAST_- } \\ & \text { ALC_EN } \end{aligned}$ | PRSC_B | AS_CTRL | 0x00 | R/W |
| 0x1BD | DACPLLTD | RESERVED |  |  |  | $\begin{aligned} & \text { VCO_CAL_ } \\ & \text { REF_MON } \end{aligned}$ | VCO_CAL_REF_TCF |  |  | 0x00 | R/W |
| 0x1BE | DACPLLTE | RESERVED |  |  |  | $\begin{aligned} & \text { VCO_PDO_ } \\ & \text { VR } \end{aligned}$ | $\begin{aligned} & \text { VCO_PDO_ } \\ & \text { VRTCF } \end{aligned}$ | $\begin{aligned} & \text { VCO_PDO } \\ & \hline \text { CALTCF } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { VCO_PDO } \\ & \text { VCOBUF } \end{aligned}$ | 0x00 | R/W |
| 0x1BF | DACPLLTF | I_CAL_EN | I_ALC_WAIT_D |  |  | I_CAL_COUNT |  | FDBCK_DELAY |  | 0x8D | R/W |

Data Sheet
AD9154

| Reg. | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | R/W |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x1C0 | DACPLLT10 | RESERVED |  | USE_NEW_CAL | $\begin{aligned} & \text { DOUBLE_FO_ } \\ & \text { CAL_CNT } \end{aligned}$ | LOCKDETECT_COUNT |  | LOCK_MODE |  | 0x2E | R/W |
| 0x1C1 | DACPLLT11 | RESERVED | $\begin{aligned} & \text { CP_LVL_ } \\ & \text { DET_PD } \end{aligned}$ | CP_VL_LOW |  |  | CP_VL_HIGH |  |  | 0x15 | R/W |
| 0x1C2 | DACPLLT15 | SDM_BP | SDM_PD | RESERVED |  | SDM_PROG |  |  |  | 0x80 | R/W |
| 0x1C3 | DACPLLT16 | RESERVED | SDM_PROG3 | SDM_PROG2 | SDM_PROG1 |  |  |  |  | 0x00 | R/W |
| 0x1C4 | DACPLLT17 | RESERVED | VCO_VAR_REF_TCF |  |  | VCO_VAR_OFF |  |  |  | 0x33 | R/W |
| 0x1C5 | DACPLLT18 | RESERVED |  |  |  | VCO_VAR_REF |  |  |  | 0x08 | R/W |
| 0x200 | MASTER_PD | RESERVED |  |  |  |  |  |  | SPI_PD_ MASTER | 0x01 | R/W |
| 0x201 | PHY_PD | UNUSEDLANES |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x203 | GENERIC_PD | RESERVED |  |  |  |  |  | $\begin{aligned} & \text { SPI_- } \\ & \text { SYNC1_PD } \end{aligned}$ | SPI_ <br> SYNC2_PD | 0x00 | R/W |
| 0x206 | CDR_RESET | RESERVED |  |  |  |  |  |  | $\begin{aligned} & \text { SPI_CDR_ } \\ & \text { RESETN } \end{aligned}$ | 0x01 | R/W |
| 0x230 | $\begin{aligned} & \text { CDR_} \\ & \text { OPERATING_ } \\ & \text { MODE_REG_0 } \end{aligned}$ | RESERVED |  | HALFRATE | RESERVED |  |  | $\begin{aligned} & \text { CDR_OVER } \\ & \text {-SAMP } \end{aligned}$ | RESERVED | 0x28 | R/W |
| 0x268 | EQ_BIAS_REG | EQ_POWER_MODE |  | RESERVED |  |  |  |  |  | 0x62 | R/W |
| 0x280 | SYNTH_ENABLE CNTRL | RESERVED |  |  |  |  | SPI_RECAL_ SYNTH | RESERVED | SPI_ENABLE_SYNTH | 0x00 | R/W |
| 0x281 | PLL_STATUS | RESERVED |  | SPI_CP_OVER RANGE_HIGH_ RB | SPI_CP_OVER RANGE_LOW_R B | SPI_CP_CAL VALID_RB | $\begin{aligned} & \text { SPI_VCO_} \\ & \text { CAL_IN_PRO } \\ & \text { GRESS_RB } \end{aligned}$ | SPI_CURRENTS READY_RB | $\begin{aligned} & \text { SPI_PLL_} \\ & \text { LOCK_RB } \end{aligned}$ | 0x00 | R |
| 0x284 | LOOP_FILTER_1 | LOOP_FILTER_1 |  |  |  |  |  |  |  | 0x77 | R/W |
| 0x285 | LOOP_FILTER_2 | LOOP_FILTER_2 |  |  |  |  |  |  |  | 0x87 | R/W |
| $0 \times 286$ | LOOP_FILTER_3 | LOOP_FILTER_3 |  |  |  |  |  |  |  | 0x08 | R/W |
| 0x287 | CP_CURRENT | RESERVED | $\begin{aligned} & \text { SPI_SERDES_- } \\ & \text { LOGEN_POW- } \\ & \text { ER_MODE } \end{aligned}$ | SPI_CP_CURRENT |  |  |  |  |  | 0x3F | R/W |
| 0x289 | REF_CLK DIVIDER_LDO | RESERVED |  |  |  | $\begin{aligned} & \text { SPI_LDO_REF } \\ & \text { SEL } \end{aligned}$ | $\begin{aligned} & \text { SPI_LDO_} \\ & \text { BYPASS_FILT } \end{aligned}$ | SPI_CDR_OVERSAMP |  | 0x04 | R/W |
| 0x28A | VCO_LDO | SPI_SERDES_LDO_CONFIG |  |  |  |  |  |  |  | 0x2B | R/W |
| 0x28B | PLL_PD_REG | RESERVED | SPI_VCO_PD | $\begin{array}{\|l} \hline \begin{array}{l} \text { SPI_VCO_PD_ } \\ \text { PTAT } \end{array} \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{SPI} \mathrm{VCO} \text { PDD_ } \\ & \mathrm{ALC} \end{aligned}$ | SPI_SYN_PD | $\begin{gathered} \text { SPI_SERDES } \\ \text { LDO_PD } \\ \hline \end{gathered}$ | SPI_SERDES_LOGEN_ PD_CORE |  | Ox7F | R/W |
| 0x290 | ALC VARACTOR | SPI_INIT_ALC_VALUE |  |  |  | SPI_VCO_VARACTOR |  |  |  | 0x83 | R/W |
| $0 \times 291$ | VCO_OUTPUT | RESERVED |  |  |  | SPI_VCO_OUTPUT_LEVEL |  |  |  | 0x49 | R/W |
| 0x294 | CP_CONFIG | SPI_HALF_ VCO_CAL_ CLK | SPI_DITHER MODE | SPI_ENABLE_ MACHINE | SPI_CP OFFSET_OFF | SPI_CP FORCE CALBITS | $\begin{aligned} & \text { SPI_CP_ } \\ & \text { CAL_EN } \end{aligned}$ | SPI_CP | TEST | 0xB0 | R/W |
| $0 \times 296$ | VCO_BIAS_1 | RESERVED |  |  | SPI_VCO_BIAS_TCF |  | SPI_VCO_BIAS_REF |  |  | 0x0C | R/W |
| 0x297 | VCO_BIAS_2 | RESERVED |  | SPI_VCO_BYPASS_BIAS_ DAC_R | SPI_VCO_ COMP_BYPASS_BIASR | SPI_PRESCALE BYPASS_R | $\begin{aligned} & \text { SPI_LAST_ } \\ & \text { ALC_EN } \end{aligned}$ | SPI_PRESC | ALE_BIAS | 0x00 | R/W |
| 0×299 | VCO_PD_ OVERRIDES | RESERVED |  |  |  | SPI_VCO_PD _OVERRIDE_ VAR_REF | $\begin{aligned} & \text { SPI_VCO_P } \\ & \text { D_OVER- } \\ & \text { RIDE_VAR_R } \\ & \text { EF_TCF } \end{aligned}$ | SPI_VCO_ PD_OVERRIDE_CAL TCF | $\begin{aligned} & \text { SPI_VCO_- } \\ & \text { PD_OVER- } \\ & \text { RIDE_VCO } \\ & \text { BUF } \end{aligned}$ | 0x00 | R/W |
| 0x29A | VCO_CAL | $\begin{aligned} & \text { SPI_VCO_ } \\ & \text { CAL_EN } \end{aligned}$ | SPI_VCO_CAL_ALC_WAIT |  |  | SPI_VCO_CAL_COUNT |  | SPI_FB_CLOCK_ADV |  | 0xFE | R/W |
| 0x29C | $\begin{aligned} & \text { CP_LEVEL_ } \\ & \text { DETECT } \end{aligned}$ | RESERVED | $\begin{aligned} & \text { SPI_CP_LEVEL } \\ & \text { DET_PD } \end{aligned}$ | SPI_CP_LEVEL_THRESHOLD_LOW |  |  | SPI_CP_LEVEL_THRESHOLD_HIGH |  |  | 0x17 | R/W |
| 0x29F | VCO_VARACTOR CONTROL_0 | RESERVED | SPI_VCO_VARACTOR_REF_TCF |  |  | SPI_VCO_VARACTOR_OFFSET |  |  |  | 0x33 | R/W |
| 0x2A0 | VCO_VARACTOR CONTROL_1 | RESERVED |  |  |  | SPI_VCO_VARACTOR_REF |  |  |  | 0x08 | R/W |
| 0x2A7 | $\begin{aligned} & \text { TERM_BLK1_CTR } \\ & \text { LREG0 } \end{aligned}$ | RESERVED |  |  |  |  |  |  | $\begin{aligned} & \text { SPI_I_TUNE } \\ & \text { R_CAL } \\ & \hline \text { TERMBLK1 } \\ & \hline \end{aligned}$ | 0x00 | R/W |
| 0x2AE | TERM_BLK2_ CTRLREGO | RESERVED |  |  |  |  |  |  | $\begin{aligned} & \text { SPI_I_TUNE } \\ & \text { R_CAL } \\ & \hline \text { TERMBLK2 } \end{aligned}$ | 0x00 | R/W |
| 0x300 | $\begin{aligned} & \text { GENERAL_JRX_C } \\ & \text { TRL_0 } \\ & \hline \end{aligned}$ | RESERVED | $\begin{aligned} & \text { CHECKSUM_ } \\ & \text { MODE } \\ & \hline \end{aligned}$ | RESE | RVED | DUALLINK | CURRENTLINK | ENL | NKS | 0x00 | R/W |
| 0x301 | $\begin{aligned} & \text { GENERAL_JRX_C } \\ & \text { TRL_1 } \end{aligned}$ | RESERVED |  |  |  |  | SUBCLASSV_LOCAL |  |  | 0x01 | R/W |

## AD9154



| Reg. | Name | Bit 7 | Bit 6 Bit 5 | Bit $4 \times$ Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | R/W |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x409 | S_REG |  | JESDV_RD |  | S_RD |  |  | 0x00 | R |
| $0 \times 40 \mathrm{~A}$ | HD_CF_REG | HD_RD | RESERVED |  | CF_RD |  |  | 0x00 | R |
| 0×40B | RES1_REG |  |  | RES1_RD |  |  |  | 0x00 | R |
| 0x40C | RES2_REG |  |  | RES2_RD |  |  |  | 0x00 | R |
| 0x40D | CHECKSUM_REG |  |  | LANEOCHECKSUM_RD |  |  |  | 0x00 | R |
| 0x40E | COMPSUMO_REG |  |  | FCMPO_RD |  |  |  | 0x00 | R |
| $0 \times 412$ | LID1_REG |  | RESERVED |  | LID1_RD |  |  | 0x00 | R |
| 0×415 | $\begin{aligned} & \text { CHECKSUM1_ } \\ & \text { REG } \end{aligned}$ |  |  | FCHK1_RD |  |  |  | 0x00 | R |
| $0 \times 416$ | COMPSUM1_REG |  |  | FCMP1_RD |  |  |  | 0x00 | R |
| $0 \times 41 \mathrm{~A}$ | LID2_REG |  | RESERVED |  | LID2_RD |  |  | 0x00 | R |
| 0x41D | $\begin{aligned} & \text { CHECKSUM2 } \\ & \text { REG } \end{aligned}$ |  |  | FCHK2_RD |  |  |  | 0x00 | R |
| 0x41E | $\begin{aligned} & \text { COMPSUM2 } \\ & \text { REG } \end{aligned}$ |  |  | FCMP2_RD |  |  |  | 0x00 | R |
| $0 \times 422$ | LID3_REG |  | RESERVED |  | LID3_RD |  |  | 0x00 | R |
| 0x425 | $\begin{aligned} & \text { CHECKSUM3_ } \\ & \text { REG } \\ & \hline \end{aligned}$ |  |  | FCHK3_RD |  |  |  | 0x00 | R |
| 0x426 | $\begin{aligned} & \text { COMPSUM3_ } \\ & \text { REG } \\ & \hline \end{aligned}$ |  |  | FCMP3_RD |  |  |  | 0x00 | R |
| 0x42A | LID4_REG |  | RESERVED |  | LID4_RD |  |  | 0x00 | R |
| 0x42D | $\begin{aligned} & \text { CHECKSUM4_ } \\ & \text { REG } \\ & \hline \end{aligned}$ |  |  | FCHK4_RD |  |  |  | 0x00 | R |
| 0x42E | $\begin{aligned} & \text { COMPSUM4- } \\ & \text { REG } \end{aligned}$ |  |  | FCMP4_RD |  |  |  | 0x00 | R |
| 0x432 | LID5_REG |  | RESERVED |  | LID5_RD |  |  | 0x00 | R |
| $0 \times 435$ | $\begin{aligned} & \text { CHECKSUM5_ } \\ & \text { REG } \end{aligned}$ |  |  | FCHK5_RD |  |  |  | 0x00 | R |
| 0×436 | $\begin{aligned} & \text { COMPSUM5_ } \\ & \text { REG } \end{aligned}$ |  |  | FCMP5_RD |  |  |  | 0x00 | R |
| $0 \times 43 \mathrm{~A}$ | LID6_REG |  | RESERVED |  | LID6_RD |  |  | 0x00 | R |
| 0x43D | $\begin{aligned} & \text { CHECKSUM6_ } \\ & \text { REG } \end{aligned}$ |  |  | FCHK6_RD |  |  |  | 0x00 | R |
| 0x43E | $\begin{aligned} & \text { COMPSUM6_ } \\ & \text { REG } \end{aligned}$ |  |  | FCMP6_RD |  |  |  | 0x00 | R |
| $0 \times 442$ | LID7_REG |  | RESERVED |  | LID7_RD |  |  | 0x00 | R |
| 0x445 | $\begin{aligned} & \text { CHECKSUM7_ } \\ & \text { REG } \end{aligned}$ |  |  | FCHK7_RD |  |  |  | 0x00 | R |
| $0 \times 446$ | $\begin{aligned} & \text { COMPSUM7_ } \\ & \text { REG } \end{aligned}$ |  |  | FCMP7_RD |  |  |  | 0x00 | R |
| $0 \times 450$ | ILS_DID |  |  | DID |  |  |  | 0x00 | R/W |
| $0 \times 451$ | ILS_BID |  | ADJCNT |  |  |  |  | 0x00 | R/W |
| $0 \times 452$ | ILS_LID0 | RESERVED | ADJDIR PHADJ |  | LIDO |  |  | 0x00 | R/W |
| 0x453 | ILS_SCR_L | SCR | RESERVED |  | L |  |  | 0x83 | R/W |
| $0 \times 454$ | ILS_F |  |  | F |  |  |  | 0x00 | R/W |
| 0x455 | ILS_K |  | RESERVED |  | K |  |  | 0x1F | R/W |
| 0x456 | ILS_M |  |  | M |  |  |  | 0x01 | R |
| $0 \times 457$ | ILS_CS_N |  | CS |  | N |  |  | 0x1F | R/W |
| 0x458 | ILS_NP |  | SUBCLASSV |  | NP |  |  | 0x2F | R/W |
| 0x459 | ILS_S |  | JESDVER |  | S |  |  | 0x20 | R/W |
| $0 \times 45 \mathrm{~A}$ | ILS_HD_CF | HD | RESERVED |  | CF |  |  | 0×80 | R/W |
| 0x45D | ILS_CHECKSUM |  |  | LANEOCHECKSUM |  |  |  | 0x45 | R/W |
| $0 \times 46 \mathrm{~B}$ | ERRCNTRMON |  |  | ERRCNTRMON |  |  |  | 0x00 | R/W |
| 0x46C | LANEDESKEW |  |  | LANEDESKEW |  |  |  | 0x0F | R/W |
| 0x46D | BADDISPARITY |  |  | BADDISPARITY |  |  |  | 0x00 | R/W |
| $0 \times 46 \mathrm{E}$ | NITDISPARITY |  |  | NITDISPARITY |  |  |  | 0x00 | R/W |
| 0x46F | $\begin{aligned} & \text { UNEXPECTEDK- } \\ & \text { CHAR } \end{aligned}$ |  |  | UEKC |  |  |  | 0x00 | R/W |
| $0 \times 470$ | $\begin{aligned} & \text { CODEGRPSYNC- } \\ & \text { FLG } \end{aligned}$ |  |  | CODEGRPSYNC |  |  |  | 0x00 | R/W |
| $0 \times 471$ | FRAMESYNCFLG |  |  | FRAMESYNC |  |  |  | 0x00 | R/W |


| Reg. | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | R/W |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x472 | $\begin{aligned} & \text { GOODCHKSUM- } \\ & \text { FLG } \end{aligned}$ | GOODCHECKSUM |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x473 | INITLANESYNCFLG | INITIALLANESYNC |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x476 | CTRLREG1 | F_AGAIN |  |  |  |  |  |  |  | 0x01 | R/W |
| 0x477 | CTRLREG2 | ILAS_MODE | RESERVED |  |  | $\begin{aligned} & \hline \text { THRESHOLD_ } \\ & \text { MASK_EN } \end{aligned}$ | RESERVED |  |  | 0x00 | R/W |
| 0x478 | KVAL | KSYNC |  |  |  |  |  |  |  | 0x01 | R/W |
| 0x47A | IRQVECTOR | BADDIS MASK | NITD_MASK | UEKC_MASK | RESERVED | INITIALLANESYNC_MASK | BADCHECKSUM_MASK | RESERVED | CODEGRP SYNC MASK | 0x00 | R/W |
| 0x47B | SYNCASSERTIONMASK | BADDIS_S | NIT_S | UCC_S | CMM | CMM_ENABLE |  | RESERVED |  | 0x08 | R/W |
| 0x47C | ERRORTHRES | ETH |  |  |  |  |  |  |  | 0xFF | R/W |
| 0x47D | LANEENABLE | LANE_ENA |  |  |  |  |  |  |  | 0x0F | R/W |
| 0x47E | RAMP_ENA | RESERVED |  |  |  |  |  |  | ENA RAMP CHECK | 0x00 | R/W |
| 0x520 | DIG_TESTO | RESERVED |  |  |  |  |  | $\begin{aligned} & \text { DC_TEST_ } \\ & \text { MOD } \\ & \hline \end{aligned}$ | RESERVED | 0x1C | R/W |
| 0x521 | TEST_DC VALUEIO | TEST_DC_VALUEIO |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x522 | TEST_DC VALUEI1 | TEST_DC_VALUEI1 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x523 | $\begin{aligned} & \hline \text { TEST_DC- } \\ & \text { VALUEQ0 } \\ & \hline \end{aligned}$ | TEST_DC_VALUEQ0 |  |  |  |  |  |  |  | 0x00 | R/W |
| 0x524 | TEST_DC VALUEQ1 | TEST_DC_VALUEQ1 |  |  |  |  |  |  |  | 0x00 | R/W |

## REGISTER DETAILS

Table 93. AD9154 Register Details

| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x000 | SPI_INTFCONFA | 7 | SOFTRESET_M |  | Soft Reset (Mirror). | 0x0 | R |
|  |  | 6 | LSBFIRST_M |  | LSB First (Mirror). | 0x0 | R |
|  |  | 5 | ADDRINC_M |  | Address Increment (Mirror). | 0x0 | R |
|  |  | 4 | SDOACTIVE_M |  | SDO Active (Mirror). | 0x0 | R |
|  |  | 3 | SDOACTIVE |  | SDO Active. | 0x0 | R/W |
|  |  | 2 | ADDRINC | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Address Increment. When set, causes incrementing streaming addresses; otherwise, descending addresses are generated. <br> Streaming addresses are incremented. <br> Streaming addresses are decremented. | 0x0 | R/W |
|  |  | 1 | LSBFIRST | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | LSB First. When set, causes input and output data to be oriented LSB first. If this bit is clear, data is oriented MSB first. <br> Shift LSB in first. <br> Shift MSB in first. | 0x0 | R/W |
|  |  | 0 | SOFTRESET | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Soft Reset. Setting this bit initiates a reset. This bit is autoclearing after the soft reset is complete. <br> Pulse the soft reset line. <br> Release soft reset. | 0x0 | R/W |
| 0x003 | SPI_CHIPTYPE | [7:0] | CHIPTYPE |  | High Speed DAC. | 0x4 | R |
| 0x004 | SPI_PRODIDL | [7:0] | PRODIDL |  | Product ID Low. | 0x54 | R |
| 0x005 | SPI_PRODIDH | [7:0] | PRODIDH |  | Product ID High. | 0x91 | R |
| 0x006 | SPI_CHIPGRADE | [7:4] | PROD_GRADE |  | Product Grade. | 0x9 | R |
|  |  | [3:0] | DEV_REVISION |  | Device Revision. | 0x9 | R |
| 0x008 | DUAL_PAGE | [7:2] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [1:0] | PAGEINDX | 1 2 3 | Page or Index Pointer. <br> Select Link A. <br> Select Link B. <br> Select Link A and Link B. | 0x3 | R/W |
| 0x011 | PWRCNTRLO | 7 | PD_BG | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Reference Power-Down. <br> Reference on. <br> Reference powered down. Overrides TXENx masked bit. | 0x1 | R/W |
|  |  | 6 | PDDAC0 | 0 | PD I Channel DAC 0. <br> Enable DACO I channel Dual0. <br> Power down DACO I channel Dual0. Overrides TXENx masked bit. | 0x1 | R/W |
|  |  | 5 | PDDAC1 | 0 | PD Q Channel DAC 1. <br> Enable Q channel DAC of Dual A. <br> Power Down Q channel DAC of Dual A. Overrides TXENx masked bit. | 0x1 | R/W |
|  |  | 4 | PDDAC2 | 0 | PD I Channel DAC 2. <br> Enable I channel DAC of Dual B. <br> Power Down I channel DAC of Dual B. Overrides TXENx masked bit. | 0x1 | R/W |
|  |  | 3 | PDDAC3 | 0 | PD Q Channel DAC 3. <br> Enable Q channel DAC of Dual B. <br> Powers down Q channel DAC of Dual B. Overrides TXENx masked bit. | 0x1 | R/W |
|  |  | [2:0] | RESERVED |  | Reserved. | 0x0 | R |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x012 | TXENMASK1 | 7 | DACB_MASK | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Dual 23 DAC Power-Down Mask for TXEN1. <br> Default power-down to control by power-down bit only. If TXEN1 is low, DAC 2 and DAC 3 are powered down; otherwise state of individual power-downs. | 0x0 | R/W |
|  |  | 6 | DACA_MASK | 0 1 | Dual 01 DAC power-down mask for TXENO. Default power-down to control by power-down bit only. <br> If TXENO is low, DAC 0 and DAC 1 are powered down; otherwise state of individual power-downs. | 0x0 | R/W |
|  |  | [5:0] | RESERVED |  | Reserved | 0x0 | R/W |
| 0x013 | PWRCNTRL3 | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 6 | ENA_PA_CTRL FROM_PAPROT_ ERR |  | Control PA enable from PAProt block. | 0x0 | R/W |
|  |  | 5 | ENA_PA_CTRL_ FROM_TXENSM |  | Control PA enable from TXEN state machine. | 0x1 | R/W |
|  |  | 4 | $\begin{aligned} & \text { ENA_PA_CTRL_- } \\ & \text { FROM_BLSM } \end{aligned}$ |  | Control PA enable from blanking state machine. | 0x0 | R/W |
|  |  | 3 | $\begin{aligned} & \text { ENA_PA_CTRL_ } \\ & \text { FROM_SPI } \end{aligned}$ |  | Control PA enable via SPI. | 0x0 | R/W |
|  |  | 2 | SPI_PA_CTRL |  | PA on/off via SPI. | 0x0 | R/W |
|  |  | 1 | ENA_SPI_TXEN |  | TXENx from SPI control. | 0x0 | R/W |
|  |  | 0 | SPI_TXEN | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | SPITXENx. TXENx SPI is high. TXENx SPI is low. | 0x0 | R/W |
| 0x014 | COARSE GROUP_DLY | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [3:0] | COARSE GROUP_DLY | $\begin{array}{r} 0 \\ 15 \end{array}$ | Coarse Group Delay. The range of the delay is -4 to +3 DAC clock periods and the resolution is $1 / 2$ DAC clock period. <br> minimum delay. maximum delay. | 0x8 | R/W |
| 0x01F | IRQ_ENABLEO | [7:6] | RESERVED |  | Reserved. | 0x0 | R/W |
|  |  | 5 | EN_DACPLLLOST | 1 | Enable DAC PLL Lost Detection. The DACPLLLOCK, when enabled, shows that the DAC (clock generation) PLL has dropped its lock state. Enable DAC PLL lost. | 0x0 | R/W |
|  |  | 4 | EN_DACPLLLOCK | 1 | Enable DAC PLL Lock Detection. The DACPLLLOCK, when enabled, shows that the DAC (clock generation) PLL has reached a lock state. Enable DAC PLL lock. | 0x0 | R/W |
|  |  | 3 | EN_SERPLLLOST | 1 | Enable SERDES PLL Lost Detection. The SERPLLLOCK, when enabled, shows that the SERDES (JESD204B interface) PLL has dropped its lock state. Enable SERDES PLL lost. | 0x0 | R/W |
|  |  | 2 | EN_SERPLLLOCK | 1 | Enable SERDES PLL Lock Detection. The SERPLLLOCK, when enabled, shows that the SERDES (JESD204B interface) PLL has reached a lock state. Enable SERDES PLL lock. | 0x0 | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 1 | EN_LANEFIFOERR | 1 | Enable Lane FIFO Error Detection. A lane FIFO error occurs when there is a full or empty condition on any of the FIFOs between the deserializer block and the core digital. An error on this FIFO requires a link disable and re-enable to remove. The STATUS of the Lane FIFOs can be found in Register 0x30C (FIFO full) and Register 0x30D (FIFO empty). <br> Enable lane FIFO error. | 0x0 | R/W |
|  |  | 0 | RESERVED |  | Reserved | 0x0 | R/W |
| 0x020 | IRQ_ENABLE1 | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 3 | EN_PRBSQ1 | 1 | Enable PRBS Imaginary DAC Dual B interrupt. Enable PRBS Q1. | 0x0 | R/W |
|  |  | 2 | EN_PRBSI1 | 1 | Enable PRBS real DAC Dual B interrupt. Enable PRBS I1. | 0x0 | R/W |
|  |  | 1 | EN_PRBSQ0 | 1 | Enable PRBS Imaginary DAC Dual A interrupt. Enable PRBS Q0. | 0x0 | R/W |
|  |  | 0 | EN_PRBSIO | 1 | Enable PRBS real DAC Dual A interrupt. Enable PRBS IO. | 0x0 | R/W |
| 0x021 | IRQ_ENABLE2 | 7 | EN_PAERRO | 1 | Link A PA Error. Enable PA Error. | 0x0 | R/W |
|  |  | 6 | RESERVED |  | Reserved. | 0x0 | R/W |
|  |  | 5 | EN_BLNKDONE0 | 1 | Link A Blanking Done. Enable Link A blanking done. | 0x0 | R/W |
|  |  | 4 | EN_REFNCOCLRO | 1 | Link A NCO Clear Tripped. NCO clear tripped. | 0x0 | R/W |
|  |  | 3 | EN_REFLOCKO | 1 | Link A Alignment Locked. Enable ref locked interrupt. | 0x0 | R/W |
|  |  | 2 | EN_REFROTAO | 1 | Link A Alignment Rotate. Enable ref rotate interrupt. | 0x0 | R/W |
|  |  | 1 | EN_REFWLIM0 | 1 | Link A Over/Under Threshold. Enable over/under limit interrupt. | 0x0 | R/W |
|  |  | 0 | EN_REFTRIP0 | 1 | Link A Alignment Trip. Enable ref tripped interrupt. | 0x0 | R/W |
| 0x022 | IRQ_ENABLE3 | 7 | EN_PAERR1 | 1 | Link B PA Error. Enable PA error. | 0x0 | R/W |
|  |  | 6 | RESERVED |  | Reserved. | 0x0 | R/W |
|  |  | 5 | EN_BLNKDONE1 | 1 | Link B Blanking Done. Enable Link B blanking done. | 0x0 | R/W |
|  |  | 4 | EN_REFNCOCLR1 | 1 | Link B NCO Clear Tripped. NCO clear tripped. | 0x0 | R/W |
|  |  | 3 | EN_REFLOCK1 | 1 | Link B Alignment Locked. Enable ref locked interrupt. | 0x0 | R/W |
|  |  | 2 | EN_REFROTA1 | 1 | Link B Alignment Rotate. Enable ref rotate interrupt. | 0x0 | R/W |
|  |  | 1 | EN_REFWLIM1 | 1 | Link B Over/Under Threshold. Enable over/under limit interrupt. | 0x0 | R/W |
|  |  | 0 | EN_REFTRIP1 | 1 | Link B Alignment Trip. Enable ref tripped interrupt. | 0x0 | R/W |
| 0x023 | IRQ_STATUSO | [7:6] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 5 | IRQ_DACPLLLOST | 1 | DAC PLL Lost. DAC PLL lost. | 0x0 | R |
|  |  | 4 | IRQ_DACPLLLOCK | 1 | DAC PLL Lock. DAC PLL lock. | 0x0 | R |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 3 | IRQ_SERPLLLOST | 1 | SERDES PLL Lost. SERDES PLL lost. | 0x0 | R |
|  |  | 2 | IRQ_SERPLLLOCK | 1 | SERDES PLL Lock. SERDES PLL lock. | 0x0 | R |
|  |  | 1 | IRQ_LANEFIFOERR | 1 | Lane FIFO Error. Lane FIFO error. | 0x0 | R |
|  |  | 0 | RESERVED |  | Reserved | 0x0 | R |
| 0x024 | IRQ_STATUS1 | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 3 | IRQ_PRBSQ1 | 1 | PRBS Data Check Error DAC B Imaginary. Service PRBS Q1. | 0x0 | R |
|  |  | 2 | IRQ_PRBSI1 | 1 | PRBS Data Check Error DAC B Real. Service PRBS I1. | 0x0 | R |
|  |  | 1 | IRQ_PRBSQ0 | 1 | PRBS Data Check Error DAC A Imaginary. Service PRBS Q0. | 0x0 | R |
|  |  | 0 | IRQ_PRBSIO | 1 | PRBS Data Check Error DAC A Real. Service PRBS IO. | 0x0 | R |
| 0x025 | IRQ_STATUS2 | 7 | IRQ_PAERRO | 1 | Link A PA Error. Service Link A PA error. | 0x0 | R |
|  |  | 6 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 5 | IRQ_BLNKDONE0 | 1 | Link A Blanking Done. Link A blank done. | 0x0 | R |
|  |  | 4 | IRQ_REFNCOCLR0 | 1 | Link A Alignment Underrange. NCO clear tripped. | 0x0 | R |
|  |  | 3 | IRQ_REFLOCKO | 1 | Link A BIST Done. Link A alignment locked. | 0x0 | R |
|  |  | 2 | IRQ_REFROTAO | 1 | Link A Alignment Trip. Rotate interrupt occurred. | 0x0 | R |
|  |  | 1 | IRQ_REFWLIM0 | 1 | Link A Alignment Lock. Service over/under limit interrupt. | 0x0 | R |
|  |  | 0 | IRQ_REFTRIPO | 1 | Link A Alignment Rotate. Trip interrupt occurred. | 0x0 | R |
| 0x026 | IRQ_STATUS3 | 7 | IRQ_PAERR1 | 1 | Link B PA Error. Service Link B PA error. | 0x0 | R |
|  |  | 6 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 5 | IRQ_BLNKDONE1 |  | Reserved | 0x0 | R |
|  |  | 4 | IRQ_REFNCOCLR1 | 1 | Link B Alignment Underrange. NCO clear tripped. | 0x0 | R |
|  |  | 3 | IRQ_REFLOCK1 | 1 | Link B BIST Done. Link B alignment locked. | 0x0 | R |
|  |  | 2 | IRQ_REFROTA1 | 1 | Link B Alignment Trip. Rotate interrupt occurred. | 0x0 | R |
|  |  | 1 | IRQ_REFWLIM1 | 1 | Link B Alignment Lock. Service over/under limit interrupt. | 0x0 | R |
|  |  | 0 | IRQ_REFTRIP1 | 1 | Link B Alignment Rotate. Ref trip. | 0x0 | R |
| 0x030 | JESD_CHECKS | [7:6] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 5 | ERR_DLYOVER | 1 | $\begin{aligned} & \text { LMFC_Delay > JESD_K Parameter. } \\ & \text { LMFC_Delay > JESD_K. } \end{aligned}$ | 0x0 | R |
|  |  | 4 | ERR_WINLIMIT | 1 | Unsupported Window Limit. Unsupported window limit. | 0x0 | R |
|  |  | 3 | ERR_JESDBAD | 1 | Unsupported M/L/S/F Selection. This JESD combination is not supported. | 0x0 | R |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 2 | ERR_KUNSUPP | 1 | Unsupported K Values. K value unsupported. | 0x0 | R |
|  |  | 1 | ERR_SUBCLASS | 1 | Unsupported SUBCLASSV Value. Unsupported subclass value. | 0x0 | R |
|  |  | 0 | ERR_INTSUPP | 1 | Unsupported Interpolation Factor. Error with interpolation value. | 0x0 | R |
| 0x034 | SYNC ERRWINDOW | [7:3] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [2:0] | ERRWINDOW | 0 1 2 3 4 5 6 7 | Sync Error Window. Synchronization rotates the clock based on a difference in the sample of the current phase of the internal clocks and the programmed target based on the SYSREF $\pm$ sample time. If SYSREF $\pm$ cannot be guaranteed to always exist in the same period of the device clock associated with the target phase from SYSREF $\pm$ to SYSREF $\pm$ (ERRWINDOW $=0$ ), then the user may choose to apply an error window to synchronization. The error window allows the SYSREF $\pm$ sample phase to vary within the confines of the window without triggering a clock adjustment. <br> Error window tolerance $\pm 1 / 2$. <br> Error window tolerance $\pm 1$. <br> Error window tolerance $\pm 2$. <br> Error window tolerance $\pm 3$. <br> Error window tolerance $\pm 4$. <br> Error window tolerance $\pm 5$. <br> Error window tolerance $\pm 6$. <br> Error window tolerance $\pm 7$. | 0x0 | R/W |
| 0x038 | SYNC LASTERR_L | [7:0] | LASTERROR_L |  | Sync Last Error[7:0]. The value of SYNC_LASTERR_L and SYNC_LASTERR_H[0] for the readback SYNC_LASTERR. SYNC_LASTERR is a measure of the error between the SYSREF sample phase and the target value that caused the last clock adjustment. This value is sticky and does not update until a clock adjustment occurs. Clear this value using the SYNCCLRLAST bit. The value is in DAC clocks. | 0x0 | R |
| 0x039 | SYNC LASTERR_H | 7 | LASTUNDER | 1 | Sync Last Error Under Flag. This bit shows that the phase error between the SYSREF sample point and the target is below the error window limit. Current phase error over window tolerance. | 0x0 | R |
|  |  | 6 | LASTOVER | 1 | Sync Last Error Over Flag. This bit shows that the phase error between the SYSREF sample point and the target is above the error window limit. Last phase error under window tolerance. | 0x0 | R |
|  |  | [5:1] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 0 | LASTERROR_H |  | Sync Last Error, Bit 8, and Flags. | 0x0 | R |
| 0x03A | SYNC CONTROL | 7 | SYNCENABLE | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Sync Logic Enable. <br> Enable sync logic. <br> Disable sync logic. | 0x0 | R/W |
|  |  | 6 | SYNCARM | 1 | Sync Arming Strobe. <br> Sync one-shot arming. | 0x0 | R/W |
|  |  | 5 | SYNCCLRSTKY | 1 | Sync Sticky Bit Clear. <br> Clear sticky status bits REFROTA and REFTRIP. | 0x0 | R/W |
|  |  | 4 | SYNCCLRLAST | 1 | Sync Clear LAST. <br> Clear the LAST errors. | 0x0 | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | [3:0] | SYNCMODE | $\begin{gathered} 0 \\ 1 \\ 2 \\ 5 \\ 6 \\ 8 \\ \text { A } \\ 9 \\ D \\ \hline \end{gathered}$ | Sync Mode. <br> Reserved. <br> Sync one-shot mode. <br> Sync continuous mode. <br> Reserved. <br> Reserved. <br> Sync monitor only mode. <br> Sync one-shot then monitor. <br> Sync one-shot then monitor. <br> Reserved.. <br> Reserved | 0x0 | R/W |
| 0x03B | SYNC_STATUS | 7 | REFBUSY | 1 | Sync Machine Busy. Sync logic SM is busy. | 0x0 | R |
|  |  | [6:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 3 | REFLOCK | 1 | Sync Alignment Locked. Sync logic aligned within window. | 0x0 | R |
|  |  | 2 | REFROTA | 1 | Sync Rotated. Sync logic rotated with SYSREF $\pm$ (sticky). | 0x0 | R |
|  |  | 1 | REFWLIM | 1 | Sync Alignment Limit Range. <br> Phase error outside of specified window error threshold. | 0x0 | R |
|  |  | 0 | REFTRIP | 1 | Sync Tripped After Arming. Sync received SYSREF pulse (sticky). | 0x0 | R |
| 0x03C | SYNC CURRERR_L | [7:0] | CURRERROR_L |  | Sync Alignment Error. This register gives the user real time access of the SYSREF $\pm$ to the internal clock counters. The value of SYNC_CURRERR = (SYNC_CURRERR_H[0],SYNC_CURRERR_L) is the difference between the SYSREF $\pm$ position relative to the clock divider and the target position relative to the internal counter. This register monitors the phase of the internal clocks in monitor modes of operation. If an adjustment of the clocks is made on any given SYSREF $\pm$, the value of the phase error is placed into SYNC_LASTERR and SYNC_CURRERR is forced to 0. | 0x0 | R |
| 0x03D | SYNC CURRERR_H | 7 | CURRUNDER | 1 | Sync Current Error Under Flag. <br> Current phase error under window tolerance. | 0x0 | R |
|  |  | 6 | CURROVER | 1 | Sync Current Error Over Flag. <br> Current phase error over window tolerance. | 0x0 | R |
|  |  | [5:1] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 0 | CURRERROR_H |  | Sync Current Error[8]. | 0x0 | R |
| 0x040 | DAC_GAINO_I | [7:2] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [1:0] | DAC_GAIN_I1 |  | I DAC Current Scaling MSBs | 0x3 | R/W |
| 0x041 | DAC_GAIN1_I | [7:0] | DAC_GAIN_I0 |  | I DAC Current Scaling LSBs. | 0xFF | R/W |
| 0x042 | DAC_GAINO_Q | [7:2] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [1:0] | DAC_GAIN_Q1 |  | Q DAC Current Scaling MSBs. | 0x3 | R/W |
| 0x043 | DAC_GAIN1_Q | [7:0] | DAC_GAIN_Q0 |  | Q DAC current scaling LSBs. | 0xFF | R/W |
| 0x044 | $\begin{aligned} & \text { GROUPDELAY } \\ & \text { COMP_I } \end{aligned}$ | [7:0] | GROUP DELAY COMP I [7:0] |  | Group Delay Compensation Bits for I Channel. These bits set the group delay compensation for the I channel DAC. | 0x0 | R/W |
| 0x045 | $\begin{aligned} & \text { GROUPDELAY } \\ & \text { COMP_Q } \end{aligned}$ | [7:0] | $\begin{aligned} & \text { GROUP DELAY } \\ & \text { COMP Q [7:0] } \end{aligned}$ |  | Group Delay Compensation Bits for Q Channel. These bits set the group delay compensation for the Q channel DAC. | 0x0 | R/W |
| 0x046 | GROUPDELAY COMP_BYP | [7:2] | RESERVED |  | Reserved. | 0x0 | R |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 1 | $\begin{aligned} & \text { GROUPCOMP_ } \\ & \text { BYPI } \end{aligned}$ |  | Bypass the Q Channel Group Delay Compensation Circuitry. | 0x1 | R/W |
|  |  | 0 | $\begin{aligned} & \text { GROUPCOMP_ } \\ & \text { BYPQ } \end{aligned}$ |  | Bypass the I Channel Group Delay Compensation Circuitry. | 0x1 | R/W |
| 0x04A | MIX_MODE | [7:1] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 0 | MIX_MODE | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Mix Mode Enable. Mix mode off. Mix mode on. | 0x0 | R/W |
| 0x050 | NCO CLRMODE | 7 | NCOCLRARM | 1 | Arm NCO Clear. Arms NCO clearing operation. <br> Arm NCO clear logic. | 0x0 | R/W |
|  |  | 6 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 5 | NCOCLRMTCH | 1 | NCO Clear Data Match. Key NCO clear data match. | 0x0 | R |
|  |  | 4 | NCOCLRPASS | 1 | NCO Clear Passed. NCO clear took effect. | 0x0 | R |
|  |  | 3 | NCOCLRFAIL | 1 | NCO Clear Failed. NCO reset during rotate. | 0x0 | R |
|  |  | 2 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [1:0] | NCOCLRMODE | $\begin{aligned} & 0 \\ & 2 \\ & 1 \end{aligned}$ | NCO Clear Mode. NCO clearing disabled. NCO clear on data key. NCO clear on SYSREF. | 0x0 | R/W |
| 0x051 | NCOKEY_ILSB | [7:0] | NCOKEYILSB |  | NCO DataKey for I Channel LSB. | 0x0 | R/W |
| 0x052 | NCOKEY_IMSB | [7:0] | NCOKEYIMSB |  | NCO DataKey for I Channel MSB. | 0x0 | R/W |
| 0x053 | NCOKEY_QLSB | [7:0] | NCOKEYQLSB |  | NCO DataKey for Q Channel LSB. | 0x0 | R/W |
| 0x054 | $\begin{aligned} & \text { NCOKEY_- } \\ & \text { QMSB } \end{aligned}$ | [7:0] | NCOKEYQMSB |  | NCO DataKey for Q Channel MSB. | 0x0 | R/W |
| 0x060 | PA_THRESO | [7:0] | $\begin{aligned} & \text { PDP_THRESHOLD } \\ & {[7: 0]} \end{aligned}$ |  | Average Power Threshold for Comparison. | 0x0 | R/W |
| 0x061 | PA_THRES1 | $\begin{aligned} & {[7: 5]} \\ & {[4: 0]} \end{aligned}$ | RESERVED PA_THRESHOLD_ MSB |  | Reserved. <br> Average Power Threshold for Comparison. | $\begin{aligned} & 0 \times 0 \\ & 0 \times 0 \end{aligned}$ | $\begin{aligned} & \hline R \\ & R / W \end{aligned}$ |
| 0x062 | PDP_AVG_TIME | 7 | PDP_ENABLE | 1 | Enable Average Power Calculation and Error Detection | 0x0 | R/W |
|  |  | 6 | PA_BUS_SWAP |  | Swap Channel A or Channel B Data Bus for Power Calculation. | 0x0 | R/W |
|  |  | [5:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [3:0] | PDP_AVG_TIME |  | Set Power Average Time. | 0x0 | R/W |
| 0x063 | PA_POWERO | [7:0] | PDP_POWER[7:0] |  | Average Power Bus $=I^{2}+Q^{2}$ (I/Q Use 6 MSBs of Data Bus). | 0x0 | R |
| 0x064 | PA_POWER1 | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | PDP_POWER[12:8] |  | Average Power Bus $=1^{2}+\mathrm{Q}^{2}(I / \mathrm{Q}$ Use 6 MSBs of Data Bus). | 0x0 | R |
| 0x080 | CLKCFG0 | 7 | PD_CLK01 | 0 | Power-Down Clock for Dual A. Enable clock divider in Dual A. Disable clock divider in Dual A. | 0x1 | R/W |
|  |  | 6 | PD_CLK23 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Power-Down Clock for Dual B. Enable clock divider in Dual B. Power-down clock divider in Dual B. | 0x1 | R/W |
|  |  | 5 | PDCLOCKDIG | 0 | Power-Down Clocks to All DACs. <br> Enable clock for all DACs. <br> Power-down clock for all DACs. | 0x1 | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 4 | PD_PCLK | $\begin{aligned} & 0 \\ & 1 \\ & \hline \end{aligned}$ | Power-Down Calibration Reference/SERDES PLL Clock. <br> Enable clock to SERDES PLL/calibration logic. <br> Disable clock to SERDES PLL/calibration logic. | 0x1 | R/W |
|  |  | 3 | PDCLOCKREC | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Power-Down Clock Receiver. <br> Enable clock receiver analog buffer. <br> Power-down clock receiver analog buffer. | 0x1 | R/W |
|  |  | 2 | DUTY_EN |  | Enable Duty Cycle Control of Clock Receiver, Always = 1. | 0x1 | R/W |
|  |  | 1 | RF_SYNC_EN |  | Enable SYSREF $\pm$ timing for RF clock chain. | 0x1 | R/W |
|  |  | 0 | RF_CLKDIV_EN | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Enable RF Clock Divider. The RF clock divider divides the input clock by 2 and provides the result to the DAC for sampling. <br> RF clock divider disabled. <br> RF clock divider enabled. | 0x0 | R/W |
| 0x081 | SYSREF_ ACTRLO | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 4 | PDSYSREF |  | Power Down SYSREF $\pm$ Buffer. This bit powers down the SYSREF $\pm$ receiver. For Subclass 1 operation to work, this buffer must be enabled. | 0x1 | R/W |
|  |  | 3 | HYS_ON | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Hysteresis On. This bit enables the programmable hysteresis control for the SYSREF $\pm$ receiver. <br> Disable hysteresis in SYSREF $\pm$ receiver. <br> Enable hysteresis in SYSREF $\pm$ receiver. | 0x0 | R/W |
|  |  | 2 | SYSREF_RISE | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Use SYSREF $\pm$ Rising Edge. <br> Use SYSREF $\pm$ falling edge for alignment. <br> Use SYSREF $\pm$ rising edge for alignment. | 0x0 | R/W |
|  |  | [1:0] | HYS_CNTRL1 |  | MSBs of Hysteresis Control. Hysteresis control bits are control bits for the amount of hysteresis in the SYSREF $\pm$ receiver. Each of the ten bits adds 10 mV of differential hysteresis to the receiver input. Two of the 10 bits are contained here. The other 8 bits are in HYS_CNTRLO. | 0x0 | R/W |
| 0x082 | $\begin{aligned} & \hline \text { SYSREF_- }^{\text {ACTRL1 }} \end{aligned}$ | [7:0] | HYS_CNTRLO |  | Low Bits of Hysteresis Control. Hysteresis control bits are control bits for the amount of hysteresis in the SYSREF $\pm$ receiver. Each of the ten bits adds 10 mV of differential hysteresis to the receiver input. Eight of the 10 bits are contained here. The other 2 bits are in HYS_CNTRL1. | 0x0 | R/W |
| 0x083 | DACPLLCNTRL | 7 | SYNTH_RECAL |  | Recalibrate VCO Band. Set this bit to reinitialize the calibration of the VCO band in the DAC PLL. This bit does not power cycle the DAC PLL, nor does it recalibrate the charge pump. Set this bit after changing any setting associated with the PLL. Do not set this bit until after an initial PLL lock is achieved. | 0x0 | R/W |
|  |  | [6:5] | RESERVED |  | Reserved. | 0x0 | R |


| Addr. | Name | Bits | Bit Name | Settings | Description |  | Reset |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## AD9154

| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x087 | DACLOOPFILT1 | [7:4] | LF_C2_WORD |  | C2 Control Word. | 0x8 | R/W |
|  |  | [3:0] | LF_C1_WORD |  | C1 Control Word. | 0x8 | R/W |
| 0x088 | DACLOOPFILT2 | [7:4] | LF_R1_WORD |  | R1 Control Word. | 0x8 | R/W |
|  |  | [3:0] | LF_C3_WORD |  | C3 control Word. | 0x8 | R/W |
| 0x089 | DACLOOPFILT3 | 7 | LF_BYPASS_R3 |  | Enable R3 resistor programming start at 0. Disable R3 resistor is LF_R3_WORD $=0$. | 0x0 | R/W |
|  |  | 6 | LF_BYPASS_R1 |  | Bypass R1 Resistor. <br> Enable R1 resistor programming at 0. Disable R1 if LF_R1_WORD $=0$. | 0x0 | R/W |
|  |  | 5 | LF_BYPASS_C2 |  | Bypass C2 Capacitor. <br> Enable C2 capacitor programming at 0. <br> Disable C2 capacitor is LF_C2_WORD $=0$. | 0x0 | R/W |
|  |  | 4 | LF_BYPASS_C1 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Bypass C1 Capacitor. <br> Enable C1 capacitor programming at 0 . <br> Disable C1 capacitor if LF_C1_WORD $=0$. | 0x0 | R/W |
|  |  | [3:0] | LF_R3_WORD |  | R3 Control Word. | 0x8 | R/W |
| 0x08A | DACCPCNTRL | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 6 | VT_FORCE | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Control voltage not brought out for test. Control voltage brought out for test. | 0x0 | R/W |
|  |  | [5:0] | CP_CURRENT |  | Charge Pump Current Control. | 0x20 | R/W |
| 0x08B | DACLOGEN CNTRL | [7:6] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [5:4] | LO_POWER_ MODE | 0 1 3 | Local Oscillator Generator (Logen) Power Mode. <br> Full power-VCO, 8 GHz to 12 GHz . <br> Half power-VCO, 6 GHz to 8 GHz . <br> Off. | 0x0 | R/W |
|  |  | [3:2] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [1:0] | LODIVMODE | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \end{aligned}$ | Logen Division. <br> Reserved. <br> Divide by 4-VCO to DAC clock. Divide by 8-VCO to DAC clock. Divide by 16-VCO to DAC clock. | 0x0 | R/W |
| 0x08C | DACLDOCNTRL1 | 7 | LDO_REF_SEL |  | Reference Selection Bit. <br> Generate reference from BG. Generate reference from supply. | 0x0 | R/W |
|  |  | 6 | $\begin{aligned} & \text { LDO_BYPASS_ } \\ & \text { FILT } \end{aligned}$ | 0 | Enable voltage filter to LDO input. Disable voltage filter to LDO input. | 0x0 | R/W |
|  |  | [5:3] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [2:0] | REFDIVMODE | 0 1 2 3 4 5 6 7 | Reference Clock Division Ratio. $1 \times$. $2 \times$. $4 \times$. $8 \times$. $16 \times$. $32 \times$. $16 \times$. $32 x$. | 0x0 | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x08D | DAC- <br> LDOCNTRL2 | 7 | LDO_BYPASS | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Bypass LDO Function. <br> LDO operates normally. LDO output shorted to VDD. | 0x0 | R/W |
|  |  | [6:5] | LDO_INRUSH |  | LDO Startup Speed Control. | 0x1 | R/W |
|  |  | [4:2] | LDO_SEL | 0 1 2 3 4 5 6 7 | LDO Voltage and Power Setup. 1.08 V low power. 1.08 V mid power. 1.08 V high power. Not used. 1.02 V low power. 1.02 V mid power. 1.02 V high power. Not used. | 0x2 | R/W |
|  |  | [1:0] | LDO_VDROP | 0 1 2 3 | LDO Passgate Control. One passgate used. Two passgates used. Three passgates used. Four passgates used. | 0x3 | R/W |
| 0x110 | DATA_FORMAT | 7 | BINARY_FMT | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Binary or Twos Complementary Format on DATA Bus. Input data is twos compliment. Input data is offset binary. | 0x0 | R/W |
|  |  | [6:0] | RESERVED |  | Reserved. | 0x0 | R |
| 0x111 | DATAPATH_ <br> CTRL | 7 | INVSINC_ENABLE | 1 | Enable Inverse Sinc Filter. | 0x1 | R/W |
|  |  | 6 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 5 | DIG_GAIN_ ENABLE | 1 | Enable Digital Gain. | 0x1 | R/W |
|  |  | 4 | PHASE_ADJ_ ENABLE | 1 | Enable Phase Compensation. | 0x0 | R/W |
|  |  | [3:2] | $\begin{aligned} & \text { MODULATION_ } \\ & \text { TYPE } \end{aligned}$ | 0 1 2 3 | Selects Type of Modulation Operation. <br> No modulation. <br> Fine modulation (uses FTW). <br> $\mathrm{f}_{\mathrm{s}} / 4$ modulation. <br> $\mathrm{f}_{\mathrm{s}} / 8$ modulation. | 0x0 | R/W |
|  |  | 1 | SEL_SIDEBAND | 1 | Select Upper or Lower Sideband from Modulation Result. | 0x0 | R/W |
|  |  | 0 | I_TO_Q | 1 | Send I Datapath into Q DAC. | 0x0 | R/W |
| 0x112 | INTERPMODE | [7:3] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [2:0] | INTERPMODE | 0 1 3 4 | Interpolation Mode. 1x (bypass). <br> 2x mode. <br> $4 x$ mode. <br> 8x mode. | 0x1 | R/W |
| 0x113 | NCO_FTW UPDATE | [7:2] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 1 | $\begin{aligned} & \text { FTW_UPDATE_ } \\ & \text { ACK } \end{aligned}$ |  | Frequency Tuning Word Update Acknowledge. | 0x0 | R |
|  |  | 0 | $\begin{aligned} & \text { FTW_UPDATE_- } \\ & \text { REQ } \end{aligned}$ |  | Frequency Tuning Word Update Request from SPI. | 0x0 | R/W |
| 0x114 | FTW0 | [7:0] | FTW0 |  | NCO Frequency Tuning Word, FTW[7:0]. | 0x0 | R/W |
| 0x115 | FTW1 | [7:0] | FTW1 |  | NCO Frequency Tuning Word, FTW[15:8]. | 0x0 | R/W |
| 0x116 | FTW2 | [7:0] | FTW2 |  | NCO Frequency Tuning Word, FTW[23:16]. | 0x0 | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x117 | FTW3 | [7:0] | FTW3 |  | NCO Frequency Tuning Word, FTW[31:24]. | 0x0 | R/W |
| 0x118 | FTW4 | [7:0] | FTW4 |  | NCO Frequency Tuning Word, FTW[39:32]. | 0x0 | R/W |
| 0x119 | FTW5 | [7:0] | FTW5 |  | NCO Frequency Tuning Word, FTW[47:40]. | 0x10 | R/W |
| $0 \times 11 \mathrm{~A}$ | $\begin{aligned} & \text { NCO_PHASE_ } \\ & \text { OFFSETO } \end{aligned}$ | [7:0] | $\begin{aligned} & \text { NCO_PHASE_ } \\ & \text { OFFSETO } \end{aligned}$ |  | NCO Phase Offset, NCO_PHASE_OFFSET[7:0]. | 0x0 | R/W |
| 0x11B | NCO_PHASE_ OFFSET1 | [7:0] | $\begin{aligned} & \text { NCO_PHASE_ } \\ & \text { OFFSET1 } \end{aligned}$ |  | NCO Phase Offset, NCO_PHASE_OFFSET[15:8]. | 0x0 | R/W |
| 0x11C | $\begin{aligned} & \text { NCO_- } \\ & \text { PHASEADJ[7:0] } \end{aligned}$ | [7:0] | PHASEADJ[7:0] |  | Phase Compensation Word, PHASE_ADJ[7:0]. | 0x0 | R/W |
| 0x11D | $\begin{aligned} & \text { NCO_} \\ & \text { PHASEADJ } \\ & {[12: 8]} \\ & \hline \end{aligned}$ | [7:0] | PHASEADJ[12:8] |  | Phase Compensation Word, PHASE_ADJ[12:8]. | 0x0 | R/W |
| 0x11F | TXEN_SM_0 | [7:6] | PA_FALL |  | PA Fall Control. | 0x2 | R/W |
|  |  | [5:4] | PA_RISE |  | PA Rises Control. | 0x0 | R/W |
|  |  | 3 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 2 | GP_PA_ON_ INVERT |  | External Modulator Polarity Invert. | 0x0 | R/W |
|  |  | 1 | GP_PA_CTRL |  | External PA Control. Enabled by default to allow external mod control instead of sync signal through this pin. | 0x1 | R/W |
|  |  | 0 | TXEN_SM_EN |  | Enable TXEN State Machine. | 0x1 | R/W |
| 0x121 | TXEN_SM_2 | [7:0] | RISE_COUNT_0 |  |  | 0xF | R/W |
| 0x122 | TXEN_SM_3 | [7:0] | RISE_COUNT_1 |  |  | 0x0 | R/W |
| 0x123 | TXEN_SM_4 | [7:0] | FALL_COUNT_0 |  |  | 0xFF | R/W |
| 0x124 | TXEN_SM_5 | [7:0] | FALL_COUNT_1 |  |  | 0xFF | R/W |
| 0x12D | DEVICE CONFIG_REGO | [7:0] | $\begin{aligned} & \text { DEVICE_- } \\ & \text { CONFIG_0 } \end{aligned}$ |  | Must Be Set to 0x8B for Proper Digital Datapath Configuration. | 0x46 | R/W |
| 0x12F | DIE_TEMP_ CTRLO | [7:1] | RESERVED |  | Reserved. | 0x10 | R/W |
|  |  | 0 | $\begin{aligned} & \text { AUXADC- } \\ & \text { ENABLE } \end{aligned}$ |  | 1 = Enable AUXADC Block. | 0x0 | R/W |
| 0x132 | DIE_TEMP0 | [7:0] | DIE_TEMP_LSB |  | AUXADC Readback Value Bits[7:0], LSB. | 0x0 | R |
| 0x133 | DIE_TEMP1 | [7:0] | DIE_TEMP_MSB |  | AUXADC Readback Value Bits[15:8], MSB. | 0x0 | R |
| 0x134 | DIE_TEMP_ UPDATE | [7:1] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 0 | DIE_TEMP_ <br> UPDATE |  | Die Temperature Update. When updated, new temperature code is received. | 0x0 | R/W |
| 0x135 | DC_OFFSET_ CTRL | [7:1] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 0 | DC_OFFSET_ON |  | 1 = Enable DC Offset Module. | 0x0 | R/W |
| 0x136 | IPATH_DC_OFFSET_1PART0 | [7:0] | $\begin{aligned} & \text { IPATH_DC_- } \\ & \text { OFFSET_1PARTO } \end{aligned}$ |  | LSB of First Part of DC Offset Value for I Path. | 0x0 | R/W |
| 0x137 | IPATH_DC_OFFSET_1PART1 | [7:0] | $\begin{array}{\|l\|} \hline \text { IPATH_DC_- } \\ \text { OFFSET_1PART1 } \end{array}$ |  | MSB of First Part of DC Offset Value for I Path. | 0x0 | R/W |
| 0x138 | QPATH_DC OFFSET_ 1PART0 | [7:0] | $\begin{aligned} & \text { QPATH_DC_- } \\ & \text { OFFSET_1PARTO } \end{aligned}$ |  | LSB of First Part of DC Offset Value for Q Path. | 0x0 | R/W |
| 0x139 | QPATH_DC_ OFFSET_ 1PART1 | [7:0] | $\begin{aligned} & \text { QPATH_DC_- } \\ & \text { OFFSET_1PART1 } \end{aligned}$ |  | MSB of First Part of DC Offset Value for Q Path. | 0x0 | R/W |
| 0x13A | $\begin{aligned} & \text { IPATH_DC_- } \\ & \text { OFFSET_2PART } \end{aligned}$ | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | $\begin{aligned} & \hline \text { IPATH_DC_- } \\ & \text { OFFSET_2PART } \end{aligned}$ |  | Second Part Of DC Offset Value For I Path. | 0x0 | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0×13B | $\begin{aligned} & \text { QPATH_DC_- } \\ & \text { OFFSET_2PART } \end{aligned}$ | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | QPATH_DC OFFSET_2PART |  | Second Part of DC Offset Value for Q Path. | 0x0 | R/W |
| 0x13C | $\begin{aligned} & \text { IDAC_DIG_ } \\ & \text { GAINO } \end{aligned}$ | [7:0] | $\begin{aligned} & \text { IDAC_DIG_ } \\ & \text { GAINO } \end{aligned}$ |  | LSB of I DAC Digital Gain. | 0x0 | R/W |
| 0x13D | $\begin{array}{\|l} \begin{array}{l} \text { IDAC_DIG_ } \\ \text { GAIN1 } \end{array} \end{array}$ | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [3:0] | $\begin{aligned} & \text { IDAC_DIG_ } \\ & \text { GAIN1 } \end{aligned}$ |  | MSB of I DAC Digital Gain. | 0x8 | R/W |
| 0x13E | $\begin{aligned} & \text { QDAC_DIG_ } \\ & \text { GAIN0 } \end{aligned}$ | [7:0] | $\begin{aligned} & \text { QDAC_DIG_ } \\ & \text { GAINO } \end{aligned}$ |  | LSB of Q DAC Digital Gain. | 0x0 | R/W |
| 0x13F | $\begin{aligned} & \text { QDAC_DIG_ } \\ & \text { GAIN1 } \end{aligned}$ | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [3:0] | $\begin{aligned} & \text { QDAC_DIG_ } \\ & \text { GAIN1 } \end{aligned}$ |  | MSB of Q DAC Digital Gain. | 0x8 | R/W |
| 0x140 | GAIN_RAMP UP_STEPO | [7:0] | GAIN_RAMP_ UP_STEPO |  | LSB of Digital Gain Rises. | 0x4 | R/W |
| 0x141 | $\begin{aligned} & \hline \text { GAIN_RAMP_U } \\ & \text { P_STEP1 } \end{aligned}$ | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [3:0] | GAIN_RAMP_ UP_STEP1 |  | MSB of Digital Gain Rises. | 0x0 | R/W |
| 0x142 | $\begin{aligned} & \hline \text { GAIN_RAMP_D } \\ & \text { OWN_STEPO } \\ & \hline \end{aligned}$ | [7:0] | GAIN_RAMP DOWN_STEPO |  | LSB of Digital Gain Drops. | 0x9 | R/W |
| 0x143 | $\begin{aligned} & \text { GAIN_RAMP_D } \\ & \text { OWN_STEP1 } \end{aligned}$ | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [3:0] | GAIN RAMP DOWN_STEP1 |  | MSB of Digital Gain Drops. | 0x0 | R/W |
| 0x146 | DEVICE_CONFI G_REG1 | [7:0] | DEVICE <br> CONFIG_1 |  | Must be Set to 0x01 During Startup. | 0x0 | R/W |
| 0x147 | BLSM_STAT | [7:6] | BE_ROTATE_REQ |  | BE_ROTATE_REQ Forced Value. | 0x0 | R/W |
|  |  | [5:0] | RESERVED |  | Reserved. | 0x0 | R/W |
| 0x14B | PRBS | 7 | PRBS_GOOD_Q | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Good Data Indicator Imaginary Channel. Incorrect sequence detected. Correct PRBS sequence detected. | 0x0 | R |
|  |  | 6 | PRBS_GOOD_I | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Good Data Indicator Real Channel. Incorrect sequence detected. Correct PRBS sequence detected. | 0x0 | R |
|  |  | 5 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:3] | RESERVED |  | Reserved. | 0x1 | R/W |
|  |  | 2 | PRBS_MODE | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Polynomial Select. <br> 7-bit: $x^{7}+x^{6}+1$ <br> 15-bit: $x^{15}+x^{14}+1$ | 0x0 | R/W |
|  |  | 1 | PRBS_RESET | 0 | Reset Error Counters. Normal operation. Reset counters. | 0x0 | R/W |
|  |  | 0 | PRBS_EN | 0 | Enable PRBS Checker. Disable. Enable. | 0x0 | R/W |
| 0x14C | PRBS_ERROR_I | [7:0] | PRBS_COUNT_I |  | Error Count Value Real Channel. | 0x0 | R |
| 0x14D | PRBS_ERROR_Q | [7:0] | PRBS_COUNT_Q |  | Error Count Value Imaginary Channel. | 0x0 | R |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x1B0 | DACPLLTO | 7 | VCO_PD_IN |  | VCO PD. <br> If power machine disabled this powers up the VCO. <br> If power machine disabled this powers down the VCO. | 0x1 | R/W |
|  |  | 6 | VCO_PD_PTAT | 1 | PD ptat current gen VCO. <br> If power machine disabled this powers down the VCO ptat gen. <br> If power machine disabled this powers up the VCO ptat gen. | 0x1 | R/W |
|  |  | 5 | VCO_PD_ALC | 1 | PD ALC Circuit in VCO. <br> If power machine disabled this powers down the VCO ALC. <br> If power machine disabled this powers up the VCO ALC. | 0x1 | R/W |
|  |  | 4 | SYNTH_PD | 0 1 | PD Total Synthesizer/Reset Machine. <br> If power machine disabled this powers up the synthesizer. <br> If power machine disabled this powers down the synthesizer. | 0x1 | R/W |
|  |  | 3 | LDO_PD | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | PD LDO. <br> If power machine disabled this powers up the LDO. If power machine disabled this powers down the LDO. | 0x1 | R/W |
|  |  | 2 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 1 | LOGEN_PD | 0 1 | PD LO Generator. <br> If power machine disabled this powers up the Prescaler/DAC clock gen. <br> If power machine disabled this powers down the Prescaler/DAC clock gen. | 0x1 | R/W |
|  |  | 0 | RESERVED |  | Reserved. | 0x0 | R |
| 0x1B1 | DACPLLT1 | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [3:2] | PFD_DELAY | 0 1 2 3 | PFD Delay. Shortest delay. Longer delay. Longer delay still. Longest delay. | 0x1 | R/W |
|  |  | 1 | PFD_EDGE | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | PFD Clock Edge. <br> Reference rising edge. <br> Reference falling edge. | 0x0 | R/W |
|  |  | 0 | RESERVED |  | Reserved. | 0x0 | R |
| 0x1B2 | DACPLLT2 | 7 | $\begin{aligned} & \hline \text { EXT_ALC_WORD_ } \\ & \text { EN } \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Force ALC Word Externally. <br> Norm operation auto ALC. Manually set ALC. | 0x0 | R/W |
|  |  | [6:0] | EXT_ALC_WORD |  | External ALC Word. | 0x0 | W |
| 0x1B3 | DACPLLT3 | [7:0] | EXT_BAND1 |  | Bottom bit of VCO tuning band to be forced. | 0x0 | W |
| 0x1B4 | DACPLLT4 | 7 | BYP_LOAD_DELAY |  | Bypass Load Delay. | 0x0 | R/W |
|  |  | [6:3] | VCO_CAL_OFFSET |  | Starting Offset for VCO Calibration. | 0xF | R/W |
|  |  | 2 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 1 | EXT_BAND_EN |  | FORCE VCO Tuning Band Externally. Normal autocal mode. Manual for VCO band. | 0x0 | R/W |
|  |  | 0 | EXT_BAND2 |  | External band MSB. | 0x0 | W |
| 0x1B5 | DACPLLT5 | $\begin{array}{\|l\|} \hline[7: 4] \\ {[3: 0]} \\ \hline \end{array}$ | INIT_ALC_VALUE VCO_VAR |  | Initial ALC Sweep Value. Varactor KVO Setting. | $\begin{aligned} & \hline 0 \times 8 \\ & 0 \times 3 \\ & \hline \end{aligned}$ | $\begin{array}{\|l} \hline \text { R/W } \\ \text { R/W } \\ \hline \end{array}$ |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x1B6 | DACPLLT6 | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 6 | PORESETB_VCO |  | Reset for VCO Logic. | 0x1 | R/W |
|  |  | [5:4] | EXT_VCO_BITSEL |  | External VCO Bitsel. | 0x0 | R/W |
|  |  | [3:0] | VCO_LVL_OUT |  | VCO Amplitude Control. | 0xA | R/W |
| 0x1B7 | DACPLLT7 | 7 | LD_SYNTH | 1 | Manual Recalibration of Synthesizer. <br> Enable circuitry to reduce the voltage of the cal offset target point. <br> Disable circuitry to reduce the voltage of the cal offset target point. | 0x0 | R/W |
|  |  | 6 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [5:0] | CP_IBLEED |  | Charge Pump Offset. | 0x0 | R/W |
| 0x1B8 | DACPLLT8 | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 6 | COMP_OUT |  | CP Calibration comparator output. | 0x0 | R |
|  |  | 5 | CP_CAL_DONE |  | CP Calibration has completed. | 0x0 | R |
|  |  | 4 | $\begin{aligned} & \text { VCO_CAL_IN_ } \\ & \text { PROG } \end{aligned}$ |  | VCO Calibration occurring. | 0x0 | R |
|  |  | [3:0] | CP_CALBITS |  | Calibrated CP outcome. | 0x0 | R |
| 0x1B9 | DACPLLT9 | 7 | $\begin{aligned} & \text { HALF_VCO_CAL_ } \\ & \text { CLK } \end{aligned}$ |  | Slow down VCO Calibration clock. | 0x0 | R/W |
|  |  | 6 | DITHER_MODE |  | Dither Mode-Not used. | 0x0 | R/W |
|  |  | 5 | $\begin{aligned} & \hline \text { MACHINE_ }^{\text {ENABLE }} \end{aligned}$ |  | PLL power mode machine enable. | 0x1 | R/W |
|  |  | 4 | CP_OFFSET_OFF |  | Turn off CP offset. | 0x1 | R/W |
|  |  | 3 | FORCE_CP_ CALBITS | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Force external CP cal code. <br> CP Calibration auto-if device off. CP Calibration manual-if device off. | 0x0 | R/W |
|  |  | 2 | CAP_CAL_EN | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Enable CP Calibration. <br> Disable charge pump calibration. <br> Enable charge pump calibration. | 0x1 | R/W |
|  |  | [1:0] | CP_TEST |  | CP Test Modes. | 0x0 | R/W |
| 0x1BA | DACPLLTA | [7:4] | MACHINE_STATE |  | Power-Up Machine State. | 0x0 | R |
|  |  | [3:0] | FCP_CALBITS |  | External CP Calibration Bits to Drive. These are the externally forced calibration bits for the charge pump in the PLL when the power-up machine is not in use. The power-up machine automatically calibrates the charge pump and stores the value in the device. | 0x0 | R/W |
| 0x1BB | DACPLLTB | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:3] | VCO_BIAS_TCF |  | Temperature Coefficient for VCO bias. | 0x1 | R/W |
|  |  | [2:0] | VCO_BIAS_REF |  | VCO Bias control. | 0x4 | R/W |
| 0x1BC | DACPLLTC | 7 | VCO_BYP_BIASR |  | Bypass VCO bias Resistor. | 0x0 | R/W |
|  |  | [6:5] | RESERVED |  | Reserved. | 0x0 | R/W |
|  |  | 4 | $\begin{aligned} & \text { VCO_COMP_BYP_ } \\ & \text { BIASR } \end{aligned}$ |  | Bypass Resistor in VCO Comparator. | 0x0 | R/W |
|  |  | 3 | PRSC_HIGHR |  | PRSC configuration. | 0x0 | R/W |
|  |  | 2 | LAST_ALC_EN |  | Enable Last ALC. | 0x0 | R/W |
|  |  | [1:0] | PRSC_BIAS_CTRL |  | PRSC bias Control. | 0x0 | R/W |
| 0x1BD | DACPLLTD | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 3 | $\begin{aligned} & \text { VCO_CAL_REF_ } \\ & \text { MON } \end{aligned}$ |  | Sent control voltage to outside world. | 0x0 | R/W |
|  |  | [2:0] | $\begin{aligned} & \text { VCO_CAL_REF_ } \\ & \text { TCF } \end{aligned}$ |  | Temperature Coefficient for Calibration reference. | 0x0 | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x1BE | DACPLLTE | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 3 | VCO_PDO_VR |  | Varactor Reference Power-down Override. | 0x0 | R/W |
|  |  | 2 | VCO_PDO_VRTCF |  | Varactor Temperature Coefficient Power-Down | 0x0 | R/W |
|  |  | 1 | $\begin{aligned} & \text { VCO_PDO_ } \\ & \text { CALTCF } \end{aligned}$ |  | Calibration Temperature Coefficient Power-Down. | 0x0 | R/W |
|  |  | 0 | $\begin{aligned} & \hline \text { VCO_PDO_ } \\ & \text { VCOBUF } \end{aligned}$ |  | VCO Buffer PD Override. | 0x0 | R/W |
| 0x1BF | DACPLLTF | 7 | I_CAL_EN |  | VCO Band Calibration Enable. | 0x1 | R/W |
|  |  | [6:4] | I_ALC_WAIT_D |  | VCO calibration wait for ALC cal from band change. | 0x0 | R/W |
|  |  | [3:2] | I_CAL_COUNT |  | Calibration Count Length. | 0x3 | R/W |
|  |  | [1:0] | FDBCK_DELAY |  | Feedback Clock Advance. | 0x1 | R/W |
| 0x1C0 | DACPLLT10 | [7:6] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 5 | USE_NEW_CAL | $\begin{aligned} & 0 \\ & 1 \\ & \hline \end{aligned}$ | Use new calibrator. use old calibrator. use new calibrator. | 0x1 | R/W |
|  |  | 4 | $\begin{aligned} & \text { DOUBLE_FO_CAL_ } \\ & \text { CNT } \end{aligned}$ |  | Increase calibrator count by $2 \times$-Old calibrator machine. | 0x0 | R/W |
|  |  | [3:2] | $\begin{aligned} & \text { LOCKDETECT_CO } \\ & \text { UNT } \end{aligned}$ |  | Counter length for Lock detector. | 0x3 | R/W |
|  |  | [1:0] | LOCK_MODE |  | Lock Detector Mode. | 0x2 | R/W |
| 0x1C1 | DACPLLT11 | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 6 | CP_LVL_DET_PD |  | Level detector power-down. | 0x0 | R/W |
|  |  | [5:3] | CP_VL_LOW |  | Low Level detect voltage. | 0x2 | R/W |
|  |  | [2:0] | CP_VL_HIGH |  | High Level detection point. | 0x5 | R/W |
| 0x1C2 | DACPLLT15 | 7 | SDM_BP |  | Bypass Sigma Delta. | 0x1 | R/W |
|  |  | 6 | SDM_PD |  | Power-Down SDM. | 0x0 | R/W |
|  |  | [5:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [3:0] | SDM_PROG |  | Program SDM. | 0x0 | R/W |
| 0x1C3 | DACPLLT16 | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 6 | SDM_PROG3 |  | SIF Clock. | 0x0 | R/W |
|  |  | 5 | SDM_PROG2 |  | SIF Preset Bar. | 0x0 | R/W |
|  |  | [4:0] | SDM_PROG1 |  | SIF Address. | 0x0 | R/W |
| 0x1C4 | DACPLLT17 | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [6:4] | $\begin{aligned} & \text { VCO_VAR_REF_ } \\ & \text { TCF } \end{aligned}$ |  | Varactor Reference Temperature Coefficient. | 0x3 | R/W |
|  |  | [3:0] | VCO_VAR_OFF |  | Varactor Offset. | 0x3 | R/W |
| 0x1C5 | DACPLLT18 | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [3:0] | VCO_VAR_REF |  | VCO Varactor Reference. | 0x8 | R/W |
| 0x200 | MASTER_PD | [7:1] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 0 | SPI_PD_MASTER |  | Power down the entire JESD204B Rx analog (all eight channels + bias). | 0x1 | R/W |
| 0x201 | PHY_PD | [7:0] | UNUSEDLANES |  | SPI override to power down the individual PHYs. Set Bit $x$ to power down the corresponding SERDINx $\pm$ PHY. | 0x0 | R/W |
| 0×203 | GENERIC_PD | [7:2] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 1 | SPI_SYNC1_PD |  | Power down LVDS buffer for SYMCOUT0 $\pm$. | 0x0 | R/W |
|  |  | 0 | SPI_SYNC2_PD |  | Power down LVDS buffer for SYNCOUT1 $\pm$. | 0x0 | R/W |
| 0x206 | CDR_RESET | [7:1] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 0 | SPI_CDR_RESETN | 0 1 | Resets the digital control logic for all PHYs. CDR logic is reset. <br> CDR logic is operational. | 0x1 | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x230 | CDR OPERATING MODE_REG_0 | [7:6] | RESERVED |  | Reserved. | 0x0 | R/W |
|  |  | 5 | HALFRATE | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Enables half rate CDR operation. Disables CDR half rate operation, data rate $\leq 6 \mathrm{Gbps}$. Enables CDR half rate operation, data rate $>6 \mathrm{Gbps}$. | 0x1 | R/W |
|  |  | [4:2] | RESERVED |  | Reserved. | 0x0 | R/W |
|  |  | 1 <br> 0 | $\begin{aligned} & \text { CDR_OVERSAMP } \\ & \text { RESERVED } \end{aligned}$ |  | Enables Oversampling of the Input Data. Set to 1 when $1.44 \mathrm{Gbps} \leq$ lane rate $\leq 2.88 \mathrm{Gbps}$. Reserved. | $\begin{aligned} & 0 \times 0 \\ & 0 \times 0 \end{aligned}$ | $\begin{aligned} & \text { R/W } \\ & \text { R/W } \end{aligned}$ |
| 0x268 | EQ_BIAS_REG | [7:6] | $\begin{aligned} & \text { EQ_POWER_ } \\ & \text { MODE } \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Controls the equalizer power/insertion loss capability. <br> Normal Mode. <br> Low Power. | 0x1 | R/W |
|  |  | [5:0] | RESERVED |  | Reserved. | 0x32 | R/W |
| 0x280 | SYNTH ENABLE CNTRL | [7:3] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 2 | SPI_RECAL_ SYNTH |  | Set this bit high to re-run all of the SERDES PLL calibration routines. <br> Set this bit low again to allow for additional recalibrations. Rising edge causes the calibration. | 0x0 | R/W |
|  |  | 1 | RESERVED |  | Reserved. | 0x0 | R/W |
|  |  | 0 | SPI_ENABLE_ SYNTH |  | Enable the SERDES PLL. <br> Setting this bit turns on all currents and proceeds to calibrate the PLL. <br> Make sure reference clock and division ratios are correct before enabling this bit. | 0x0 | R/W |
| 0x281 | PLL_STATUS | [7:6] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 5 | SPI_CP_OVER_ RANGE_HIGH_RB | 0 1 | Applies if SPI_VCO_OUTPUT_LEVEL $=0$. If set, the CP output is above CP Level Threshold High. <br> Charge pump output is below CP_LEVEL_THRESHOLD_HIGH. <br> Charge pump output is above CP_LEVEL_THRESHOLD_HIGH. | 0x0 | R |
|  |  | 4 | SPI_CP_OVER_ RANGE_LOW_RB | 0 1 | Applies if SPI_VCO_OUTPUT_LEVEL $=0$. If set, the CP output is below CP Level Threshold Low. <br> Charge pump output is above CP_LEVEL_THRESHOLD_LOW. <br> Charge pump output is below CP_LEVEL_THRESHOLD_LOW. | 0x0 | R |
|  |  | 3 | SPI_CP_CAL_ VALID_RB | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | This bit tells the user if the charge pump cal has completed. <br> Charge pump calibration is not valid. Charge pump calibration is valid. | 0x0 | R |
|  |  | 2 | SPI_VCO_CAL_IN _PROGRESS_RB | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | This bit set indicates that a VCO calibration is running. <br> VCO calibration is not running. VCO calibration is running. | 0x0 | R |
|  |  | 1 | SPI_CURRENTS_ READY_RB | 0 | PLL bias currents are not ready. PLL bias currents are ready. | 0x0 | R |
|  |  | 0 | $\begin{aligned} & \text { SPI_PLL_LOCK_ } \\ & \text { RB } \end{aligned}$ | 0 | If set, the synth locked in the number of clock cycles set by Lock Detect Count. <br> PLL is not locked. <br> PLL is locked. | 0x0 | R |

## AD9154

| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x284 | $\begin{aligned} & \hline \text { LOOP____ } \\ & \text { FILTER_1 } \end{aligned}$ | $\begin{array}{\|l\|} \hline[7: 4] \\ {[3: 0]} \\ \hline \end{array}$ | LOOP_FILTER_1 |  | Loop filter configuration setting. | $\begin{aligned} & 0 \times 7 \\ & 0 \times 7 \end{aligned}$ | $\begin{aligned} & \text { R/W } \\ & \text { R/W } \end{aligned}$ |
| 0×285 | $\begin{aligned} & \hline \text { LOOP_____ }^{\text {FILTER_2 }} \end{aligned}$ | $\begin{array}{\|l\|} \hline[7: 4] \\ {[3: 0]} \\ \hline \end{array}$ | LOOP_FILTER_2 |  | Loop filter configuration setting. | $\begin{aligned} & 0 \times 8 \\ & 0 \times 7 \end{aligned}$ | $\begin{aligned} & \hline \text { R/W } \\ & R / W \end{aligned}$ |
| 0x286 | $\begin{aligned} & \hline \text { LOOP__ } \\ & \text { FILTER_3 } \end{aligned}$ | $\begin{aligned} & {[7: 4]} \\ & {[3: 0]} \end{aligned}$ | LOOP_FILTER_3 |  | Loop filter configuration setting. | $\begin{aligned} & 0 \times 0 \\ & 0 \times 8 \end{aligned}$ | $\begin{aligned} & \hline \text { R/W } \\ & R / W \end{aligned}$ |
| 0x287 | CP_CURRENT | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 6 | SPI_SERDES LOGEN_POWER_ MODE | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Power Mode 0. Power Mode 1. | 0x0 | R/W |
|  |  | [5:0] | SPI_CP_CURRENT |  | CP Current Setting. | 0x3F | R/W |
| 0x289 | REF_CLK DIVIDER_LDO | [7:4] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 3 | $\begin{aligned} & \hline \text { SPI_LDO_REF_ } \\ & \text { SEL } \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Selects LDO reference to be from the band gap or a voltage divider (VDD/2). <br> Select band gap for reference. <br> Select voltage divider (VDD/2) for reference. | 0x0 | R/W |
|  |  | 2 | $\begin{aligned} & \hline \text { SPI_LDO_- } \\ & \text { BYPASS_FILT } \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Bypasses filter on LDO reference input. <br> Filter enabled. <br> Filter bypassed. | 0x1 | R/W |
|  |  | [1:0] | SPI_CDR OVERSAMP | 0 1 2 | Enable oversampling of input data. <br> The valid options are: <br> $1 \times, 2 \times$, and $4 \times$. <br> $1 \times$ works for Half Rate-6.25 Gbps to 12.5 Gbps . <br> $1 \times$ works for Full Rate—3.125 Gbps to 6.25 Gbps . <br> $2 \times$ works for Full Rate—1.625 Gbps to 3.125 Gbps <br> ( $2 \times$ oversampling). <br> $4 \times$ works for Full Rate—812.5 Mbps to 1.625 Gbps ( $4 \times$ oversampling). <br> Oversampling set in Register 0x230. <br> No oversampling. Data rate $>6$ Gbps. <br> Oversample by $2 \times .3 \mathrm{Gbps}<$ data rate $\leq 6 \mathrm{Gbps}$. <br> Oversample by $4 \times 1.5 \mathrm{Gbps}<$ data rate $\leq 3 \mathrm{Gbps}$. | 0x0 | R/W |
| 0x28A | VCO_LDO | [7:0] | SPI_SERDES_LDO CONFIG |  | VCO LDO Setting. | 0x2B | R/W |
| 0x28B | PLL_PD_REG | 7 | RESERVED |  | Reserved. | 0x0 | R/W |
|  |  | 6 | SPI_VCO_PD | 0 | VCO enable. VCO enabled. VCO disabled. | 0x1 | R/W |
|  |  | 5 | $\begin{aligned} & \text { SPI_VCO_PD_ } \\ & \text { PTAT } \end{aligned}$ |  |  | 0x1 | R/W |
|  |  | 4 | SPI_VCO_PD_ALC |  |  | 0x1 | R/W |
|  |  | 3 | SPI_SYN_PD |  |  | 0x1 | R/W |
|  |  | 2 | $\begin{aligned} & \text { SPI_SERDES_ } \\ & \text { LDO_PD } \end{aligned}$ | 0 1 | PD LDO. <br> LDO enabled. <br> LDO disabled. | 0x1 | R/W |
|  |  | 1 | $\begin{aligned} & \text { SPI_SERDES_ } \\ & \text { LOGEN_PD_ } \\ & \text { OUTBUF } \end{aligned}$ | 0 | PD divider buffer. Buffer enabled. <br> Buffer disabled. | 0x1 | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 0 | SPI SERDES LOGEN_PD_CORE | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | PD Logen Dividers. <br> Dividers enabled. <br> Dividers disabled. | 0x1 | R/W |
| 0x290 | ALC VARACTOR | [7:4] | $\begin{aligned} & \text { SPI_INIT_ALC_ } \\ & \text { VALUE } \end{aligned}$ |  | ALC Value Setting. | 0x8 | R/W |
|  |  | [3:0] | $\begin{aligned} & \text { SPI_VCO- } \\ & \text { VARACTOR } \end{aligned}$ |  | VCO KV Setting. | 0x3 | R/W |
| 0x291 | VCO_OUTPUT | [7:4] | RESERVED |  | Reserved. | 0x4 | R/W |
|  |  | [3:0] | $\begin{aligned} & \text { SPI_VCO_- } \\ & \text { OUTPUT_LEVEL } \end{aligned}$ |  | VCO output level setting. | 0x9 | R/W |
| 0×294 | CP_CONFIG | 7 | SPI_HALF_VCO_ CAL_CLK |  |  | 0x1 | R/W |
|  |  | 6 | SPI_DITHER_ MODE |  |  | 0x0 | R/W |
|  |  | 5 | SPI_ENABLE_ MACHINE |  |  | 0x1 | R/W |
|  |  | 4 | $\begin{aligned} & \text { SPI_CP_OFFSET_ } \\ & \text { OFF } \end{aligned}$ |  |  | 0x1 | R/W |
|  |  | 3 | $\begin{aligned} & \text { SPI_CP_FORCE_ } \\ & \text { CALBITS } \end{aligned}$ |  |  | 0x0 | R/W |
|  |  | 2 | SPI_CP_CAL_EN |  |  | 0x0 | R/W |
|  |  | [1:0] | SPI_CP_TEST |  |  | 0x0 | R/W |
| 0x296 | VCO_BIAS_1 | [7:5] | RESERVED |  | Reserved. | 0x0 | R/W |
|  |  | [4:3] | $\begin{aligned} & \text { SPI_VCO_BIAS_ } \\ & \text { TCF } \end{aligned}$ |  |  | 0x1 | R/W |
|  |  | [2:0] | $\begin{aligned} & \hline \text { SPI_VCO_BIAS_ } \\ & \text { REF } \end{aligned}$ |  | CP Calibration Control. | 0x4 | R/W |
| 0×297 | VCO_BIAS_2 | [7:6] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 5 | SPI_VCO_BYPASS _BIAS_DAC_R |  |  | 0x0 | R/W |
|  |  | 4 | SPI_VCO_COMP BYPASS_BIASR |  |  | 0x0 | R/W |
|  |  | 3 | SPI_PRESCALE_ BYPASS_R |  |  | 0x0 | R/W |
|  |  | 2 | $\begin{aligned} & \text { SPI_LAST_ALC_ } \\ & \text { EN } \end{aligned}$ |  |  | 0x0 | R/W |
|  |  | [1:0] | SPI_PRESCALE_ BIAS |  |  | 0x0 | R/W |
| 0x299 | $\begin{aligned} & \text { VCO_PD_-_ } \\ & \text { OVERRIDES } \end{aligned}$ | [7:4] | RESERVED |  |  | 0x0 | R/W |
|  |  | 3 | SPI_VCO_PD OVERRIDE_VAR_ REF |  |  | 0x0 | R/W |
|  |  | 2 | SPI_VCO_PD OVERRIDE_VAR_ REF_TCF |  |  | 0x0 | R/W |
|  |  | 1 | SPI_VCO_PD_ OVERRIDE_CAL_ TCF |  |  | 0x0 | R/W |
|  |  | 0 | SPI_VCO_PD_ OVERRIDE_ VCOBUF |  |  | 0x0 | R/W |

## AD9154

| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x29A | VCO_CAL | 7 | SPI_VCO_CAL_EN |  |  | 0x1 | R/W |
|  |  | [6:4] | SPI_VCO_CAL_ ALC_WAIT |  |  | 0x7 | R/W |
|  |  | [3:2] | $\begin{aligned} & \text { SPI_VCO_CAL_ } \\ & \text { COUNT } \end{aligned}$ |  |  | 0x3 | R/W |
|  |  | [1:0] | $\begin{aligned} & \text { SPI_FB_CLOCK_ } \\ & \text { ADV } \end{aligned}$ |  |  | 0x2 | R/W |
| 0x29C | $\begin{aligned} & \text { CP_LEVEL_ } \\ & \text { DETECT } \end{aligned}$ | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 6 | $\begin{aligned} & \hline \text { SPI_CP_LEVEL_ } \\ & \text { DET_PD } \end{aligned}$ |  |  | 0x0 | R/W |
|  |  | [5:3] | $\begin{aligned} & \text { SPI_CP_LEVEL_- } \\ & \text { THRESHOLD_LOW } \end{aligned}$ |  |  | 0x2 | R/W |
|  |  | [2:0] | $\begin{aligned} & \hline \text { SPI_CP_LEVEL_ } \\ & \text { THRESHOLD_ } \\ & \text { HIGH } \\ & \hline \end{aligned}$ |  |  | 0x7 | R/W |
| 0x29F | VCO VARACTOR CONTROL_0 | 7 | RESERVED |  |  | 0x0 | R |
|  |  | [6:4] | SPI_VCO_VARACTOR_REF_TCF |  |  | 0x3 | R/W |
|  |  | [3:0] | SPI_VCO_VARACTOR_OFFSET |  |  | 0x3 | R/W |
| 0x2A0 | VCO VARACTOR CONTROL_1 | [7:4] | RESERVED |  |  | 0x0 | R |
|  |  | [3:0] | $\begin{aligned} & \text { SPI_VCO_- } \\ & \text { VARACTOR_REF } \end{aligned}$ |  |  | 0x8 | R/W |
| 0x2A7 | TERM_BLK1_ CTRLREGO | [7:1] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 0 | $\begin{aligned} & \text { SPI_I_TUNE_R_ } \\ & \text { CAL_TERMBLK1 } \end{aligned}$ |  | Rising edge of this bit starts a termination calibration routine. | 0x0 | R/W |
| 0x2AE | $\begin{aligned} & \text { TERM_BLK2_ } \\ & \text { CTRLREG0 } \end{aligned}$ | [7:1] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 0 | $\begin{aligned} & \text { SPI_I_TUNE_R_ } \\ & \text { CAL_TERMBLK2 } \end{aligned}$ |  | Rising edge of this bit starts a termination calibration routine. | 0x0 | R/W |
| 0×300 | $\begin{aligned} & \text { GENERAL_- } \\ & \text { JRX_CTRL_0 } \end{aligned}$ | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 6 | CHECKSUMMODE | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | JESD204B link parameter checksum calculation method. <br> checksum is the sum of fields. checksum is the sum of octets. | 0x0 | R/W |
|  |  | [5:4] | RESERVED |  | Reserved | 0x0 | R/W |
|  |  | 3 2 | DUALLINK <br> CURRENTLINK | 0 1 0 1 | This register selects either single link or dual link mode. <br> Single link mode. <br> Dual link mode. <br> To select which QBD register map to work with. <br> User access to QBD_0 registers. <br> User access to QBD_1 registers. | $\begin{array}{\|c} 0 \times 0 \\ 0 \times 0 \end{array}$ | R/W <br> R/W |
|  |  | [1:0] | ENLINKS |  | Brings up JESD204B Rx digital when all link parameters are programmed and all clocks are ready Bit 0 applies to Link 0 while Bit 1 applies to Link 1. Link 1 is only available in dual link mode. Both links may be brought up separately or together. | 0x0 | R/W |
| 0x301 | GENERAL JRX_CTRL_1 | [7:3] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [2:0] | $\begin{aligned} & \text { SUBCLASSV_ } \\ & \text { LOCAL } \end{aligned}$ | 0 1 | JESD204B Subclass Subclass 0 Subclass 1 | 0x1 | R/W |



## AD9154

| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x30D | $\begin{aligned} & \text { FIFO_STATUS_ } \\ & \text { REG_1 } \end{aligned}$ | [7:0] | $\begin{aligned} & \text { LANE_FIFO_ } \\ & \text { EMPTY } \end{aligned}$ |  | FIFO Empty Flags for Each Logical Lane. An empty FIFO indicates an error in the JESD204B configuration or with a system clock. If the FIFO for Lane $x$ is empty, Bit $x$ in this register will be high. | 0x0 | R |
| 0x312 | $\begin{array}{\|l} \text { SYNCB_ } \\ \text { GEN_1 } \end{array}$ | [7:6] | RESERVED |  | Reserved. | 0x0 | R/W |
|  |  | [5:4] | SYNCB_ERR_DUR | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & \hline \end{aligned}$ | Duration of $\overline{\text { SYNCOUTX } \pm}$ Low for Error. The duration applies to both SYNCOUTO and SYNCOUT1. A sync error is asserted at the end of a multiframe whenever one or more disparity, not in table or unexpected control character errors are encountered. <br> $1 / 2$ PCLK cycle. <br> 1 PCLK cycle. <br> 2 PCLK cycles. | 0x0 | R/W |
|  |  | [3:0] | RESERVED |  | Reserved. | 0x0 | R/W |
| 0x314 | SPI_SYNC_CTRL | [7:1] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 0 | $\begin{aligned} & \text { SPI_SYNC_CLK_ } \\ & \text { SEL } \end{aligned}$ | 0 | SERDES SPI Configuration. <br> Setting in PHY Layer setup. | 0x0 | R/W |
| $0 \times 315$ | $\begin{aligned} & \text { PHY_PRBS_ } \\ & \text { TEST_EN } \end{aligned}$ | [7:0] | PHY_TEST_EN |  | Set Bit x to enable the PHY test for Lane x . | 0x0 | R/W |
| 0x316 | $\begin{aligned} & \text { PHY_PRBS_ } \\ & \text { TEST_CTRL } \end{aligned}$ | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [6:4] | $\begin{aligned} & \text { PHY_SRC_ERR_ } \\ & \text { CNT } \end{aligned}$ |  | Report Lane Error Count. | 0x0 | R/W |
|  |  | [3:2] | $\begin{aligned} & \text { PHY_PRBS_ } \\ & \text { PAT_SEL } \end{aligned}$ | 0 1 2 3 | To select PRBS pattern for PHY BER test. <br> PRBS7. <br> PRBS15. <br> PRBS31. <br> Not used. | 0x0 | R/W |
|  |  | 1 | PHY_TEST_START | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | To start and stop the PHY PRBS test. test not started. test started. | 0x0 | R/W |
|  |  | 0 | PHY_TEST_RESET | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Reset PHY PRBS test state machine, and error counters. <br> not reset. reset. | 0x0 | R/W |
| 0x317 | PHY_PRBS TEST_THRESHOLD_LOBITS | [7:0] | $\begin{aligned} & \text { PHY_PRBS_- } \\ & \text { THRESHOLD_ } \\ & \text { LOBITS } \end{aligned}$ |  | Bits[7:0] of the 24-bit threshold value to set the error flag for PHY PRBS test. | 0x0 | R/W |
| 0x318 | PHY_PRBS TEST_THRESH OLD_MIDBITS | [7:0] | $\begin{aligned} & \text { PHY_PRBS_- } \\ & \text { THRESHOLD_ } \\ & \text { MIDBITS } \end{aligned}$ |  | Bits[15:8] of the 24-bit threshold value to set the error flag for PHY PRBS test. | 0x0 | R/W |
| 0x319 | PHY_PRBS TEST_THRESHOLD_HIBITS | [7:0] | $\begin{aligned} & \hline \text { PHY_PRBS_- } \\ & \text { THRESHOLD_ } \\ & \text { HIBITS } \end{aligned}$ |  | Bits[23:16] of the 24-bit threshold value to set the error flag for PHY PRBS test. | 0x0 | R/W |
| 0x31A | PHY_PRBS TEST_ERRCNT_ LOBITS | [7:0] | PHY_PRBS_ERR_ CNT_LOBITS |  | Bits[7:0] of the 24-bit reported PHY BERT error count from selected lane. | 0x0 | R |
| 0x31B | PHY_PRBS TEST_ERRCNT_ MIDBITS | [7:0] | PHY_PRBS_ERR_ CNT_MIDBITS |  | Bits[15:8] of the 24-bit reported PHY BERT error count from selected lane. | 0x0 | R |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x31C | PHY_PRBS TEST_ERRCNT_ HIBITS | [7:0] | PHY_PRBS_ERR_ CNT_HIBITS |  | Bits[23:16] of the 24-bit reported PHY BERT error count from selected lane. | 0x0 | R |
| 0x31D | PHY_PRBS TEST_STATUS | [7:0] | PHY_PRBS_PASS |  | Each bit is for the corresponding lane. Report PHY BERT pass/fail for each lane. | 0xFF | R |
| 0x32C | $\begin{aligned} & \hline \text { SHORT_TPL_ } \\ & \text { TEST_0 } \end{aligned}$ | [7:6] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [5:4] | $\begin{aligned} & \text { SHORT_TPL_SP_ } \\ & \text { SEL } \end{aligned}$ | 0 1 2 3 | Short Transport Layer Sample Select. Select which sample to check from a specific DAC. <br> Sample 0. <br> Sample 1. <br> Sample 2. <br> Sample 3. | 0x0 | R/W |
|  |  | [3:2] | $\begin{aligned} & \text { SHORT_TPL_M_ } \\ & \text { SEL } \end{aligned}$ | 0 1 2 3 | Short Transport Layer Test DAC Select. Select which DAC to check. <br> DAC 0. <br> DAC 1. <br> DAC 2. <br> DAC 3. | 0x0 | R/W |
|  |  | 1 | $\begin{aligned} & \text { SHORT_TPL_TEST } \\ & \text { _RESET } \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Short Transport Layer Test Reset. Resets the result of short transport layer test at SHORT_TPL_DIFF. <br> Not reset. <br> Reset. | 0x0 | R/W |
|  |  | 0 | $\begin{aligned} & \text { SHORT_TPL_ } \\ & \text { TEST_EN } \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Short Transport Layer Test Enable. Enable short transport layer test. <br> Disable. <br> Enable. | 0x0 | R/W |
| 0x32D | $\begin{aligned} & \hline \text { SHORT_TPL_ } \\ & \text { TEST_1 } \end{aligned}$ | [7:0] | $\begin{aligned} & \text { SHORT_TPL_REF_ } \\ & \text { SP_LSB } \end{aligned}$ |  | Short Transport Layer Reference Sample LSB. This is the lower 8 bits of expected DAC sample. It compares with the received DAC sample at the output of JESD204B Rx. | 0x0 | R/W |
| 0x32E | $\begin{aligned} & \hline \text { SHORT_TPL_ } \\ & \text { TEST_2 } \end{aligned}$ | [7:0] | $\begin{aligned} & \hline \text { SHORT_TPL_REF_ } \\ & \text { SP_MSB } \end{aligned}$ |  | Short Transport Layer Test Reference Sample MSB. This is the upper 8 bits of expected DAC sample. It compares with the received sample at JESD Rx output. | 0x0 | R/W |
| 0x32F | $\begin{aligned} & \hline \text { SHORT_TPL_ } \\ & \text { TEST_3 } \end{aligned}$ | $\left[\begin{array}{l} {[7: 1]} \\ 0 \end{array}\right.$ | RESERVED <br> SHORT_TPL_FAIL | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Reserved. <br> Short Transport Layer Test Fail. This bit shows if the selected DAC sample matches the reference sample. If they match test pass; otherwise test fail. <br> Test pass. <br> Test fail. | $\begin{aligned} & 0 \times 0 \\ & 0 \times 0 \end{aligned}$ | R |
| 0x333 | $\begin{aligned} & \hline \text { DEVICE_CON- } \\ & \text { FIG_REG2 } \\ & \hline \end{aligned}$ | [7:0] | RESERVED |  | Must be set to 0x1 for correct JESD204B receiver operation. | 0x0 | R/W |
| 0x334 | $\begin{aligned} & \hline \text { JESD_BIT_- } \\ & \text { INVERSE_CTRL } \end{aligned}$ | [7:0] | INVLANES |  | Logic Lane Invert. Set Bit $x$ high to invert the JESD204B deserialized data on Logical Lane $x$. | 0x0 | R/W |
| 0x400 | DID_REG | [7:0] | DID_RD |  | DID is the Device ID No. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R |
| 0x401 | BID_REG | [7:4] | ADJCNT_RD |  | ADJCNT is the Adjustment Resolution to DAC LMFC. Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R |
|  |  | [3:0] | BID_RD |  | BID is the Bank ID-Extension to DID. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x402 | LIDO_REG | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 6 | ADJDIR_RD |  | ADJDIR is the Direction to Adjust DAC LMFC. Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R |
|  |  | 5 | PHADJ_RD |  | PHADJ is the Phase Adjustment Request to DAC. Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R |
|  |  | [4:0] | LIDO_RD |  | LID0 is the Lane Identification for Lane 0 . Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R |
| 0x403 | SCR_L_REG | 7 | SCR_RD | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | SCR is the Tx Scrambling Status. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. <br> Scrambling is disabled. <br> Scrambling is enabled. | 0x0 | R |
|  |  | [6:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | L_RD | 0 1 3 | L is the Number of Lanes per Converter Device. Link information received on lane 0 as specified in section 8.3 of JESD204B. <br> 1 lane per converter device. <br> 2 lanes per converter device. <br> 4 lanes per converter device. | 0x0 | R |
| 0x404 | F_REG | [7:0] | F_RD | 0 1 3 | F is the Number of Octets Per Frame. <br> Settings of 1,2 , and 4 are valid. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. <br> 1 octet per frame. <br> 2 octets per frame. <br> 4 octets per frame. | 0x0 | R |
| 0x405 | K_REG | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | K_RD |  | K is the Number of Frames per Multiframe. <br> Settings of 16 or 32 are valid. <br> Link information received on lane 0 as specified in section 8.3 of JESD204B. $\begin{aligned} & 01111=16 . \\ & 11111=32 . \end{aligned}$ | 0x0 | R |
| 0x406 | M_REG | [7:0] | M_RD | 0 1 3 | M is the Number of Converters/Device. Link information received on Lane 0 as specified in Section 8.3 of JESD204B. <br> Must be 1,2, or 4 to be compatible with AD9154 1 converter per device. <br> 2 converters per device. <br> 4 converters per device. | 0x0 | R |
| 0x407 | CS_N_REG | [7:6] | CS_RD |  | CS is the Number of Control Bits/Sample. Link information received on Lane 0 as specified in Section 8.3 of JESD204B. <br> Must be 0 to be compatible with AD9154. | 0x0 | R |
|  |  | 5 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | N_RD |  | $\mathrm{N}=$ converter resolution. | 0x0 | R |
| 0x408 | NP_REG | [7:5] | SUBCLASSV_RD |  | SUBCLASSV is the Device SubClass Version. Link information received on lane 0 as specified in section 8.3 of JESD204B. | 0x0 | R |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | [4:0] | NP_RD |  | Np is the Total Number of Bits/Sample. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. <br> = 16 bits per sample. | 0x0 | R |
| 0x409 | S_REG | [7:5] | JESDV_RD | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | JESDV is the JESD204 Version. <br> Link information received on lane 0 as specified in section 8.3 of JESD204B. JESD204A. JESD204B. | 0x0 | R |
|  |  | [4:0] | S_RD | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | S is the Number of Samples/Converter per Frame Cycle. <br> Link information received on lane 0 as specified in section 8.3 of JESD204B. <br> One sample per converter per frame. <br> Two samples per converter per frame. | 0x0 | R |
| 0x40A | HD_CF_REG | 7 | HD_RD | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | HD is the High Density Format. Refer to Section 5.1.3 of JESD204B standard. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. <br> Low density mode. <br> High density mode. | 0x0 | R |
|  |  | [6:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | CF_RD |  | CF is the Number of Control Words per Frame Clock Period per Link. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. <br> Must be 0 to be compatible to the AD9154. | 0x0 | R |
| 0x40B | RES1_REG | [7:0] | RES1_RD |  | Reserved Field 1. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R |
| 0x40C | RES2_REG | [7:0] | RES2_RD |  | Reserved Field 2. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R |
| 0x40D | $\begin{aligned} & \hline \text { CHECKSUM_ } \\ & \text { REG } \end{aligned}$ | [7:0] | LANEOCHECKSU M_RD |  | Checksum for Lane 0. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R |
| 0x40E | $\begin{aligned} & \text { COMPSUMO_ } \\ & \text { REG } \end{aligned}$ | [7:0] | FCMP0_RD |  | Computed Checksum for Lane 0 . <br> The JESD204B Rx computes the checksum of the link information received on Lane 0 as specified in Section 8.3 of JESD204B. The computation method is set by the CHECKSUMMODE bit (Register 0x300[6]) and should match the likewise calculated checksum in Register 0x40D. | 0x0 | R |
| 0x412 | LID1_REG | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | LID1_RD |  | Lane Identification for Lane 1. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R |
| 0x415 | $\begin{aligned} & \text { CHECKSUM1_ } \\ & \text { REG } \end{aligned}$ | [7:0] | FCHK1_RD |  | Checksum for Lane 1. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R |
| 0x416 | $\begin{array}{\|l} \hline \text { COMPSUM1_ } \\ \text { REG } \\ \hline \end{array}$ | [7:0] | FCMP1_RD |  | Computed Checksum for Lane 1. See description for Register 0x40E. | 0x0 | R |
| 0x41A | LID2_REG | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | LID2_RD |  | Lane Identification for Lane 2. | 0x0 | R |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x41D | CHECKSUM2_ REG | [7:0] | FCHK2_RD |  | Checksum for Lane 2. | 0x0 | R |
| 0x41E | COMPSUM2 REG | [7:0] | FCMP2_RD |  | Computed Checksum for Lane 2. See description for Register 0x40E. | 0x0 | R |
| 0x422 | LID3_REG | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | LID3_RD |  | Lane Identification for Lane 3. | 0x0 | R |
| 0x425 | $\begin{aligned} & \text { CHECKSUM3_ } \\ & \text { REG } \end{aligned}$ | [7:0] | FCHK3_RD |  | Checksum for Lane 3. | 0x0 | R |
| 0x426 | COMPSUM3 REG | [7:0] | FCMP3_RD |  | Computed Checksum for LANE 3 (see description for Register 0x40E). | 0x0 | R |
| 0x42A | LID4_REG | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | LID4_RD |  | Lane Identification for Lane 4. | 0x0 | R |
| 0x42D | $\begin{aligned} & \text { CHECKSUM4_ } \\ & \text { REG } \end{aligned}$ | [7:0] | FCHK4_RD |  | Checksum for Lane 4 | 0x0 | R |
| 0x42E | COMPSUM4 REG | [7:0] | FCMP4_RD |  | Computed Checksum for Lane 4 (see description for Register 0x40E). | 0x0 | R |
| 0x432 | LID5_REG | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | LID5_RD |  | Lane Identification for Lane 5. | 0x0 | R |
| 0x435 | $\begin{aligned} & \text { CHECKSUM5_ } \\ & \text { REG } \end{aligned}$ | [7:0] | FCHK5_RD |  | Checksum for Lane 5. | 0x0 | R |
| 0x436 | COMPSUM5_ REG | [7:0] | FCMP5_RD |  | Computed Checksum for Lane 5 (see description for Register 0x40E). | 0x0 | R |
| 0x43A | LID6_REG | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | LID6_RD |  | Lane Identification for Lane 6. | 0x0 | R |
| 0x43D | $\begin{aligned} & \text { CHECKSUM6_ } \\ & \text { REG } \end{aligned}$ | [7:0] | FCHK6_RD |  | Checksum for Lane 6. | 0x0 | R |
| 0x43E | COMPSUM6_ REG | [7:0] | FCMP6_RD |  | Computed Checksum for Lane 6 (see description for Register 0x40E). | 0x0 | R |
| 0x442 | LID7_REG | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | LID7_RD |  | Lane Identification for Lane 7. | 0x0 | R |
| 0x445 | $\begin{aligned} & \text { CHECKSUM7_ } \\ & \text { REG } \\ & \hline \end{aligned}$ | [7:0] | FCHK7_RD |  | Checksum for Lane 7. | 0x0 | R |
| 0x446 | $\begin{aligned} & \text { COMPSUM7_ } \\ & \text { REG } \\ & \hline \end{aligned}$ | [7:0] | FCMP7_RD |  | Computed Checksum for Lane 7 (see description for Register 0x40E). | 0x0 | R |
| 0x450 | ILS_DID | [7:0] | DID |  | DID is the Device ID Number. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. <br> Must be set to value read in Register 0x400. | 0x0 | R/W |
| 0x451 | ILS_BID | [7:4] | ADJCNT |  | ADJCNT is the Adjustment Resolution to DAC LMFC. Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R/W |
|  |  | [3:0] | BID |  | BID is the Bank ID-Extension to DID. <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. <br> Must be set to value read in Register 0x401[3:0]. | 0x0 | R/W |
| 0x452 | ILS_LID0 | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 6 | ADJDIR |  | ADJDIR is the Direction to Adjust DAC LMFC. Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R/W |
|  |  | 5 | PHADJ |  | PHADJ is the Phase Adjustment Request To DAC. Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R/W |
|  |  | [4:0] | LIDO |  | LID0 is the Lane identification for Lane 0 . <br> Link information received on Lane 0 as specified in Section 8.3 of JESD204B. | 0x0 | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | $\begin{array}{\|l} \text { Access } \\ \hline \text { R/W } \\ \hline \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x453 | ILS_SCR_L | 7 | SCR | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | SCR is the Rx Descrambling Enable. Is disabled. Is enabled. | 0x1 |  |
|  |  | [6:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | L | $\begin{aligned} & 00000 \\ & 00001 \\ & 00011 \\ & 00111 \end{aligned}$ | L is the Number of Lanes Per Converter Device Settings of 2,4 , and 8 are valid for single single link mode. Settings of 1,2 , and 4 are valid for dual link mode. <br> 1 lane. <br> 2 lanes. <br> 4 lanes. <br> 8 lanes. | 0x3 | R/W |
| 0x454 | ILS_F | [7:0] | F |  | This value of $F$ does not soft configure the QBD . The Register CTRLREG1 soft configures the QBD. | 0x0 | R/W |
| 0x455 | ILS_K | [7:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | K |  | K is the number of frames per multiframe. <br> Settings of 16 or 32 are valid. Must be set to 32 when $\mathrm{F}=4$ (Register 0x476). $\begin{aligned} & 01111=16 . \\ & 11111=32 . \end{aligned}$ | 0x1F | R/W |
| 0x456 | ILS_M | [7:0] | M | 0 1 3 | M is the number of converters/device. <br> Settings of 1,2 , and 4 are valid for single link mode. Settings of 1 and 2 are valid in dual link mode. Refer to Table 15 and Table 16. <br> 1 converter per device. <br> 2 converters per device. <br> 4 converters per device. | 0x1 | R |
| 0x457 | ILS_CS_N | [7:6] | CS |  | CS is the number of control bits/sample. Must be set to 0 . Control bits are not supported. | 0x0 | R/W |
|  |  | 5 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | N |  | $\mathrm{N}=$ converter resolution. Must be set to 16 ( $0 \times 0 \mathrm{~F}$ ). | 0x1F | R/W |
| 0x458 | ILS_NP | [7:5] | SUBCLASSV |  | SUBCLASSV = device Subclass version. <br> Must be set to 1 (3'b001). | 0x1 | R/W |
|  |  | [4:0] | NP |  | $\mathrm{Np}=$ total no. of bits/sample. <br> Must be set to 16 ( $0 \times 0 \mathrm{~F}$ ). Refer to Table 15 and Table 16. | 0xF | R/W |
| 0x459 | ILS_S | [7:5] | JESDVER | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | JESDV is the JESD204 version. JESD204A. | 0x1 | R/W |
|  |  | [4:0] | S |  | $\mathrm{S}=$ no. of samples/converter per frame cycle. Settings of 1 and 2 are valid. Refer to Table 15 and Table 16. $\begin{aligned} & S=00000->1 \text { Sample. } \\ & S=00001->2 \text { Samples. } \end{aligned}$ | 0x0 | R/W |
| 0x45A | ILS_HD_CF | 7 | HD | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | HD is high density mode. Refer to section 5.1.3 of JESD204B standard. density mode. density mode. | 0x1 | R/W |
|  |  | [6:5] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [4:0] | CF |  | CF is the number of control words per frame clock period per link. <br> Must be set to 0 . Control bits are not supported. | 0x0 | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x45D | ILS_CHECKSUM | [7:0] | LANEOCHECKSUM |  | Checksum for Lane 0. <br> The checksum for the values programmed into Register $0 \times 450$ to Register $0 \times 45 \mathrm{C}$ must be calculated according to section 8.3 of the JESD204B spec and written here [SUM(Register 0x450 - Register 0x45C) \% 256 ]. | 0x45 | R/W |
| 0x46B | ERRCNTRMON | 7 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [6:4] | LANESEL | 0 1 3 3 4 5 6 7 | Lane Select for JESD204B Error Counter. <br> Writing these bits selects the JESD lane to monitor the error type designated by the register write to CNTRSEL (Bits 1:0]) BADDISCNTR, NITCNTR and UEKCCNTR error counters in each lane are accessed via indirect addressing. To read a counter value, the LANESEL and CNTRSEL are first written, then the read back accesses the desired counter. <br> Selects Lane 0. <br> Selects Lane 1. <br> Selects Lane 2. <br> Selects Lane 3. <br> Selects Lane 4. <br> Selects Lane 5. <br> Selects Lane 6. <br> Selects Lane 7. | 0x0 | W |
|  |  | [3:2] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [7:0] | READERRORCNTR |  | Read JESD204B Error Counter. <br> After selecting the lane and error counter by writing to LANESEL (Bits[6:4]) and CNTRSEL (1:0), the selected error counter is read back here. | 0x0 | R |
|  |  | [1:0] | CNTRSEL | 0 1 2 | JESD204B Error Counter Select. <br> Writing these bits allows the readback of the following JESD204B errors for the lane designated by the register write to LANESEL (Bits[6:4]). To read a counter value, the LANESEL and CNTRSEL are first written, then the read back access the desired counter. <br> BADDISCNTR: bad running disparity counter. NITCNTR: not in table error counter. <br> UCCCNTR: Unexpected control character counter. | 0x0 | W |
| 0x46C | LANEDESKEW | [7:0] | LANEDESKEW |  | Lane Deskew. <br> Enabled on a per lane basis by writing 1 to the appropriate bit position: Bits[7:0] map to Lane 7 to Lane 0. Note that in dual link mode, only Bits[3:0] are used for each link. <br> 1: Deskew enabled for Lane 0. <br> 1: Deskew enabled for Lane 1. <br> 1: Deskew enabled for Lane 2. <br> 1: Deskew enabled for Lane 3. <br> 1: Deskew enabled for Lane 4. <br> 1: Deskew enabled for Lane 5. <br> 1: Deskew enabled for Lane 6. <br> 1: Deskew enabled for Lane 7. | 0xF | R/W |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0x46D | BADDISPARITY | 7 | RSTIRQ_DIS |  | Reset BADDIS IRQ counter for lane selected via Bits[2:0] by writing 1 to this bit. | 0x0 | W |
|  |  | 6 | DISABLE_ERRCNT DIS |  | Disable the BADDIS error counter for lane selected via Bits[2:0] by writing 1 to this bit. | 0x0 | W |
|  |  | 5 | RSTERRCNTR_DIS |  | Reset BADDIS error counter for lane selected via Bits[2:0] by writing 1 to this bit. | 0x0 | W |
|  |  | [4:3] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [7:0] | BADDIS | 1 | Bad Disparity Character Error (BADDIS). <br> Each bit corresponds to each lane. The error count can be accessed via Register 0x46B. Note that in dual link mode, only Bits[3:0] are used for each link. BadDisparitycharacter error count has reached the threshold count of Register 0x7C for any lane with its corresponding bit set when reading this register. Bad Disparity character error count has Not reached the threshold count. | $0 \times 0$ | R |
|  |  | [2:0] | LANEADDR_DIS |  | Lane Address for functions described in Bits[7:5] | 0x0 | W |
| 0x46E | NITDISPARITY | 7 | RSTIRQ_NIT |  | Reset IRQ for lane selected via Bits[2:0] by writing 1 to this bit. | 0x0 | W |
|  |  | 6 | $\begin{array}{\|l\|} \hline \text { DISABLE_- } \\ \text { ERRCNT_NIT } \\ \hline \end{array}$ |  | Disable the error counter for lane selected via Bits[2:0] by writing 1 to this bit. | 0x0 | W |
|  |  | 5 | RSTERRCNTR_NIT |  | Reset error counter for lane selected via Bits[2:0] by writing 1 to this bit. | 0x0 | W |
|  |  | [4:3] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [7:0] | NITD |  | Not In Table Disparity Character Error (NITD). Each bit corresponds to each lane. The error count can be accessed via Register 0x46B. Note that in dual link mode, only Bits[3:0] are used for each link. | 0x0 | R |
|  |  | [2:0] | LANEADDR_NIT |  | Lane Address for functions described in Bits[7:5]. | 0x0 | W |
| 0x46F | UNEXPECTEDK CHAR | 7 | RSTIRQ_K |  | Reset IRQ for lane selected via Bits[2:0] by writing 1 to this bit. | $0 \times 0$ | W |
|  |  | 6 | DISABLE_ERRCNT _K |  | Disable the error counter for lane selected via Bits[2:0] by writing 1 to this bit. | 0x0 | W |
|  |  | 5 | RSTERRCNTR_K |  | Reset error counter for lane selected via Bits[2:0] by writing 1 to this bit. | 0x0 | W |
|  |  | [4:3] | RESERVED |  | Reserved. | 0x0 | R |
|  |  | [2:0] | LANEADDR_K |  | Lane Address for functions described in Bits[7:5]. | 0x0 | W |
| 0x470 | CODEGRPSYNCFLG | [7:0] | CODEGRPSYNC |  | Code Group Sync Flag (from each instantiated lane) Writing 1 to Bit 7 resets the IRQ. The associated IRQ flag is located in Register 0x470[0]. <br> A loss of CODEGRPSYNC triggers Sync Request assertion. Refer to the SYSREF, SYNCOUT, and the Deterministic Latency section. <br> 1 on Bit x of this register = synchronization was achieved on lane $L$. <br> 0 on Bit x of this register $=$ synchronization was lost on Lane $x$. | 0x0 | R/W |
| 0x471 | FRAMESYNCFLG | [7:0] | FRAMESYNC |  | Frame Sync Flag (from each instantiated lane). This register indicates the live status for each lane. Writing 1 to Bit 7 resets the IRQ. <br> A loss of Frame Sync automatically initiates a synchronization sequence. | $0 \times 0$ | R/W |
| 0x472 | $\begin{aligned} & \text { GOODCHK- } \\ & \text { SUMFLG } \end{aligned}$ | [7:0] | GOOD- <br> CHECKSUM |  | Good Check Sum flag (from each instantiated lane.) Writing 1 to Bit 7 resets the IRQ. The associated IRQ flag is located in Register 0x470[2]. | 0x0 | R/W |



| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 2 | BADCHECKSUM_ MASK | 1 | Bad Checksum Mask. <br> If there is a bad checksum (Register 0x472) on any lane, $\overline{\mathrm{IRQ}}$ is pulled low. | 0x0 | W |
|  |  | 2 | $\begin{aligned} & \text { BADCHECKSUM_ } \\ & \text { FLAG } \end{aligned}$ | 1 | Bad Checksum Flag. <br> Bad checksum on at least one lane. Read Register 0x472 to determine which lanes are in error. | 0x0 | R |
|  |  | 1 | RESERVED |  | Reserved. | 0x0 | R |
|  |  | 0 | $\begin{aligned} & \text { CODEGRPSYNC_ } \\ & \text { FLAG } \end{aligned}$ | 1 | Code Group Sync Flag. Code group sync failed on at least one lane. Read Register 0x470 to determine which lanes are in error. <br> Code group sync failed on at least one lane. Read Register $0 \times 470$ to determine which lanes are in error. | 0x0 | R |
|  |  | 0 | CODEGRPSYNC_ MASK | 1 | Code Group Sync Machine Mask. If code group sync (Register 0x470) fails on any lane, $\overline{\mathrm{IRQ}}$ is pulled low. | 0x0 | W |
| 0x47B | SYNCASSERTIONMASK | 7 | BADDIS_S | 1 | Bad Disparity Error on Sync. <br> Asserts a sync request on $\overline{\text { SYNCOUTX } \pm}$ when the bad disparity character count reaches the threshold in Register 0x47C. | 0x0 | R/W |
|  |  | 6 | NIT_S | 1 | Not in table Error on Sync. $\qquad$ <br> Asserts a sync request on SYNCOUTX $\pm$ when the not in table character count reaches the threshold in Register 0x47C. | 0x0 | R/W |
|  |  | 5 | UCC_S | 1 | Unexpected Control Character Error on Sync. Asserts a sync request on SYNCOUTx $\pm$ when the unexpected control character count reaches the threshold in Register 0x47C. | 0x0 | R/W |
|  |  | 4 | CMM | 1 | Configuration Mismatch IRQ. If CMM_ENABLE is high, this bit latches on a rising edge and pull $\overline{\mathrm{RQ}}$ low. When latched, write a 1 to clear this bit. If CMM_ENABLE is low, this bit is non-functional. Link Lane 0 configuration registers (Register 0x450 to Register 0x45D) do not match the JESD204B transmit settings (Register 0x400 to Register 0x40D). <br> Configuration Mismatch IRQ. If CMM_ENABLE is high, this bit latches on a rising edge and pull $\overline{\mathrm{RQ}}$ low. When latched, write a 1 to clear this bit. If CMM_ENABLE is low, this bit is non-functional. | 0x0 | R/W |
|  |  | 3 | CMM_ENABLE | 1 | Configuration Mismatch IRQ Enable. <br> Enables IRQ generation if a configuration mismatch is detected. <br> Configuration mismatch IRQ disabled. <br> Mismatch IRQ disabled. | 0x1 | R/W |
|  |  | [2:0] | RESERVED |  | Reserved. | 0x0 | R |
| 0x47C | ERRORTHRES | [7:0] | ETH |  | Error Threshold. Bad disparity, not in table, and unexpected control character errors are counted and compared to the error threshold value. When the count reaches the threshold, either an IRQ is generated or the $\overline{\text { SYNCOUTx } \pm}$ signal is asserted per the mask register settings, or both. Function is performed in all lanes. | 0xFF | R/W |
| 0x47D | LANEENABLE | [7:0] | LANE_ENA |  | Lane Enable. Setting Bit $x$ enables Link Lane $x$. This register must be programmed before receiving the code group pattern for proper operation. | 0xF | R/W |
| 0x47E | RAMP_ENA | [7:1] | RESERVED |  | Reserved. | 0x0 | R |


| Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 0 | $\begin{aligned} & \text { ENA_RAMP_ } \\ & \text { CHECK } \end{aligned}$ | 0 1 | Enable Ramp Checking at the Beginning of ILAS. <br> Disable ramp checking at beginning of ILAS; ILAS data need not be a ramp. <br> Enable ramp checking; ILAS data needs to be a ramp starting at 00-01-02; otherwise, the ramp ILAS fails and the device does not start up. | 0x0 | R/W |
| 0x520 | DIG_TESTO | $\left[\begin{array}{l} {[7: 2]} \\ 1 \\ 0 \end{array}\right.$ | $\begin{array}{\|l\|} \hline \text { RESERVED } \\ \text { DC_TEST_MOD } \\ \text { RESERVED } \\ \hline \end{array}$ |  | Reserved. <br> DC Test Mode Enable. <br> Reserved. | $\begin{array}{\|l\|} \hline 0 \times 0 \\ 0 \times 0 \\ 0 \times 0 \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline R \\ R / W \\ R / W \\ \hline \end{array}$ |
| 0x521 | $\begin{aligned} & \text { TEST_DC- } \\ & \text { VALUEIO } \end{aligned}$ | [7:0] | $\begin{aligned} & \hline \text { TEST_DC_ } \\ & \text { VALUEIO } \end{aligned}$ |  | DC value LSB of $\mathrm{f}_{\mathrm{s}} / 8$ and decoder testing for I DAC. | 0x0 | R/W |
| 0x522 | $\begin{aligned} & \text { TEST_DC- } \\ & \text { VALUEI1 } \end{aligned}$ | [7:0] | $\begin{aligned} & \text { TEST_DC- } \\ & \text { VALUEI1 } \end{aligned}$ |  | DC value MSB of $\mathrm{f}_{\mathrm{s}} / 8$ and decoder testing for I DAC. | 0x0 | R/W |
| 0x523 | TEST_DC VALUEQ0 | [7:0] | $\begin{aligned} & \text { TEST_DC- } \\ & \text { VALUEQO } \end{aligned}$ |  | DC value LSB of $\mathrm{f}_{5} / 8$ and decoder testing for Q DAC. | 0x0 | R/W |
| 0x524 | $\begin{aligned} & \hline \text { TEST_DC } \\ & \text { VALUEO1 } \end{aligned}$ | [7:0] | $\begin{aligned} & \hline \text { TEST_DC_ } \\ & \text { VALUEQ1 } \end{aligned}$ |  | DC value MSB of $\mathrm{f}_{\mathrm{s}} / 8$ and decoder testing for Q DAC. | 0x0 | R/W |

## OUTLINE DIMENSIONS



COMPLIANT TO JEDEC STANDARDS MO-220-VRRD
Figure 89. 88-Lead Lead Frame Chip Scale Package [LFCSP_VQ]
$12 \mathrm{~mm} \times 12 \mathrm{~mm}$ Body, Very Thin Quad (CP-88-6)
Dimensions shown in millimeters


COMPLIANT TO JEDEC STANDARDS MO-220
Figure 90. 88-Lead Lead Frame Chip Scale Package [LFCSP_VQ]
$12 \mathrm{~mm} \times 12 \mathrm{~mm}$ Body, Very Thin Quad
Dimensions shown in millimeters

ORDERING GUIDE

| Model $^{1}$ | Temperature Range | Package Description | Package Option |
| :--- | :--- | :--- | :--- |
| AD9154BCPZ | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 88 -Lead LFCSP_VQ | CP-88-6 |
| AD9154BCPZRL | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 88 -Lead LFCSP_VQ | CP-88-6 |
| AD9154BCPAZ | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 88 -Lead LFCSP_VQ (Variable Lead Length) | CP-88-9 |
| AD9154BCPAZRL | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 88 -Lead LFCSP_VQ (Variable Lead Length) | CP-88-9 |
| AD9154-EBZ |  | DPG3 Evaluation Board |  |
| AD9154-FMC-EBZ |  | FMC Evaluation Board |  |
| AD9154-M6720-EBZ |  | DPG3 Evaluation Board with ADRF6720-27 Modulator |  |

[^5]
## Mouser Electronics

Authorized Distributor

Click to View Pricing, Inventory, Delivery \& Lifecycle Information:

Analog Devices Inc.:
AD9154BCPZ AD9154-FMC-EBZ AD9154-M6720-EBZ AD9154-EBZ AD9154BCPZRL AD9154BCPAZRL AD9154BCPAZ


[^0]:    ${ }^{1}$ Offset error is a measure of how far from full-scale range (FSR) the DAC output current is at $25^{\circ} \mathrm{C}$ (in ppm).
    ${ }^{2}$ Gain drift is a measure of the slope of the DAC output current across its full temperature range (in ppm/ ${ }^{\circ} \mathrm{C}$ ).

[^1]:    PClockPeriod $=40 /$ LaneRate

[^2]:    ${ }^{1} 0 x$ denotes a register value that the user must fill in. See the Variable and Description columns for information on selecting the appropriate register value.

[^3]:    ${ }^{1} \mathrm{~K}$ must be 32 in Mode 4 and Mode 9 . K can be 16 or 32 in all other modes.

[^4]:    ${ }^{1}$ F must be programmed in two places: Register 0x454, Bits[7:0] and Register 0x459, Bits[7:0].

[^5]:    ${ }^{1} Z=$ RoHs Compliant Part.

